source: trunk/third/moira/gen/nagios-cluster.gen @ 25198

Revision 25198, 3.0 KB checked in by jdreed, 13 years ago (diff)
In moira: * Snapshot moira@r4042 (6/28/11) * Update version number to include moira revision number
  • Property svn:executable set to *
Line 
1#!/moira/bin/perl -Tw
2
3# $Id: nagios-cluster.gen 4031 2011-03-04 21:09:08Z jweiss $
4# The following exit codes are defined and MUST BE CONSISTENT with the
5# error codes the library uses:
6$MR_DBMS_ERR = 47836421;
7$MR_OCONFIG = 47836460;
8
9$outfile = '/moira/dcm/nagios-cluster.out';
10
11use DBI;
12
13umask 022;
14open(OUT, ">$outfile") || exit $MR_OCONFIG;
15print OUT "# This File is automatically generated by Moira.  Do not edit.\n\n";
16
17
18$dbh = DBI->connect("dbi:Oracle:moira", "moira", "moira")
19  || exit $MR_DBMS_ERR;
20
21
22$sth1 = $dbh->prepare("SELECT m.name FROM machine m, clusters c, mcmap p " .
23                     "WHERE m.status=1 AND c.name='cluster' AND " .
24                     "(m.mach_id=p.mach_id AND p.clu_id=c.clu_id)")
25    || exit $MR_DBMS_ERR;
26$sth1->execute || exit $MR_DBMS_ERR;
27
28my %clusters;
29while (($name) = $sth1->fetchrow_array) {
30    next if $name eq "[NONE]";
31    $name = lc($name);
32    my $cluster = $name;
33    $cluster =~ s/\..*$//;
34    $cluster =~ s/\-[^\-]*$//;
35#    print "$name\t$cluster\n";
36    push @$cluster, $name;
37    $clusters{$cluster}++;
38
39
40    print OUT <<"END";
41define host{
42        host_name               $name
43        alias                   $name
44        address                 $name
45        contact_groups          noone
46        use                     generic-host
47        }
48
49define service{
50        host_name               $name
51        contact_groups          noone
52        use                     ping-service
53        }
54
55define service{
56        host_name               $name
57        contact_groups          noone
58        use                     no-ssh-service
59        }
60
61define service{
62        host_name               $name
63        contact_groups          noone
64        use                     no-telnet-service
65        }
66
67define service{
68        host_name               $name
69        contact_groups          noone
70        use                     no-ftp-service
71        }
72
73define service{
74        host_name               $name
75        contact_groups          noone
76        use                     public-service
77        }
78
79define service{
80        host_name               $name
81        contact_groups          noone
82        use                     update-service
83        }
84
85define service{
86        host_name               $name
87        contact_groups          noone
88        use                     modules-service
89        }
90
91END
92}
93
94foreach $key (sort (keys %clusters)) {
95    print OUT <<END;
96define hostgroup {
97        hostgroup_name          $key
98        alias                   $key
99END
100    print OUT "\tmembers\t\t";
101    $maybecomma = "";
102    foreach $machine (@$key) {
103        print OUT "$maybecomma$machine";
104        $maybecomma = ",";
105    }
106    print OUT "\n\t}\n\n";
107}
108
109
110print OUT "\n### Printers\n\n";
111
112$sth0 = $dbh->prepare("SELECT UNIQUE m.name FROM machine m, printers p " .
113                     "WHERE (p.type = 'DORM' OR p.type ='CLUSTER') " .
114                     "AND p.mach_id = m.mach_id AND m.status=1")
115    || exit $MR_DBMS_ERR;
116
117$sth0->execute || exit $MR_DBMS_ERR;
118
119while (($name) = $sth0->fetchrow_array) {
120    next if $name eq "[NONE]";
121    $name = lc($name);
122    push(@allprinters, $name);
123    print OUT <<"END";
124define host{
125        host_name               $name
126        alias                   $name
127        address                 $name
128        contact_groups          noone
129        use                     generic-host
130        }
131
132define service{
133        host_name               $name
134        contact_groups          noone
135        use                     ping-service
136        }
137
138define service{
139        host_name               $name
140        contact_groups          noone
141        use                     hpjd-service
142        }
143
144END
145
146}
147
148print OUT <<END;
149define hostgroup{
150        hostgroup_name          printers
151        alias                   printers
152END
153
154print OUT "\tmembers\t\t";
155
156$maybecomma = "";
157foreach $printer (@allprinters) {
158    print OUT "$maybecomma$printer";
159    $maybecomma = ",";
160}
161
162print OUT "\n\t}\n\n";
163
164close(OUT);
165$dbh->disconnect;
166
167exit 0;
Note: See TracBrowser for help on using the repository browser.