]> git.sesse.net Git - nms/blob - web/dhcpkart.pl
initial import
[nms] / web / dhcpkart.pl
1 #! /usr/bin/perl
2 use CGI;
3 use GD;
4 use DBI;
5 my $cgi = CGI->new;
6
7 my $greentimeout = 900;
8 my $maxtimeout = $greentimeout*9;
9
10 my $dbh = DBI->connect("dbi:Pg:dbname=snmpfetch;host=violet.tg05.gathering.org", "snmpfetch", "removed")
11         or die "Couldn't connect to database";
12
13 GD::Image->trueColor(1);
14 $img = GD::Image->new('snmp-bg.png');
15
16 my $blk = $img->colorResolve(0, 0, 0);
17
18 $img->string(gdMediumBoldFont,0,0,"TG05 - DHCP-lease status",$blk);
19 $img->string(gdSmallFont,0,20,"Last recieved DHCP-request",$blk);
20
21 # first  1/5: green (<30 min)
22 # middle 3/5: yellow -> red (30 min - 6 hours)
23 # last   1/5: blue (>6 hours)
24 my $grn = $img->colorResolve(0, 255, 0);
25 my $blu = $img->colorResolve(0, 0, 255);
26
27 my $l1 = 42 + (236 - 42)/5;
28 my $l2 = 236 - (236 - 42)/5;
29
30 $img->filledRectangle(32, 42, 53, $l1, $grn);
31 $img->string(gdSmallFont,56,$l1-8,($greentimeout/60)." min",$blk);
32
33 $img->filledRectangle(32, $l2, 53, 237, $blu);
34 $img->string(gdSmallFont,56,$l2-5,($maxtimeout/60)." min",$blk);
35
36 for my $y ($l1..$l2) {
37         my $i = 1.0 - ($y - $l1) / ($l2 - $l1);
38         my $clr = get_color($i);
39
40         $img->filledRectangle(32,$y,53,$y+1,$clr);
41 }
42
43 my $q = $dbh->prepare('select switch,sysname,placement,EXTRACT(EPOCH FROM now() - last_ack) as age from switches natural join placements natural join dhcp');
44 $q->execute();
45 while (my $ref = $q->fetchrow_hashref()) {
46         my $age = $ref->{'age'};
47         if (!defined($age) || $age > $maxtimeout) {
48                 $clr = $img->colorResolve(0, 0, 255);
49         } elsif ($age < $greentimeout) {
50                 $clr = $img->colorResolve(0, 255, 0);
51         } else {
52                 # 30 minutes = 0.0
53                 # 6 hours = 1.0
54         
55                 my $intensity = log($age / $greentimeout) / log($maxtimeout/$greentimeout);
56                 $clr = get_color(1.0 - $intensity);
57         }
58         
59         $_ = $ref->{'sysname'};
60         if (!m/d0/i) { # don't draw distro-switches
61                 $ref->{'placement'} =~ /\((\d+),(\d+)\),\((\d+),(\d+)\)/;
62                 $img->filledRectangle($3,$4,$1,$2,$clr);
63                 $img->rectangle($3,$4,$1,$2,$blk);
64
65                 $img->stringUp(gdSmallFont,$3,$2-3,$ref->{'sysname'},$blk);
66         }
67 }
68 $dbh->disconnect;
69
70 if (!defined($ARGV[0])) {
71         print $cgi->header(-type=>'image/png',
72                            -refresh=>'10; http://nms.tg05.gathering.org/dhcpkart.pl');
73 }
74 print $img->png;
75
76 sub get_color {
77         my $intensity = shift;
78         my $gamma = 1.0/1.90;
79         return $img->colorResolve(255.0, 255.0 * ($intensity ** $gamma), 0);
80 }