]> git.sesse.net Git - nms/blob - web/nettkart.pl
Use the right image.
[nms] / web / nettkart.pl
1 #! /usr/bin/perl
2 use CGI;
3 use GD;
4 use DBI;
5 use lib '../include';
6 use nms;
7 my $cgi = CGI->new;
8
9 my $dbh = nms::db_connect();
10
11 GD::Image->trueColor(1);
12 $img = GD::Image->new('bg07.png');
13
14 my $blk = $img->colorResolve(0, 0, 0);
15
16 for my $y (42..236) {
17         my $i = 2.0 * ($y - 236.0) / (42.0 - 237.0);
18         my $clr = get_color($i);
19         
20         $img->filledRectangle(32,$y,53,$y+1,$clr);
21 }
22
23 my $q = $dbh->prepare('select * from switches natural join placements natural left join
24 ( select switch,sum(bytes_in)/count(*) as
25 bytes_in,sum(bytes_out)/count(*) as bytes_out from get_datarate() group
26 by switch ) t1 where ip<>\'127.0.0.1\'');
27 $q->execute();
28 while (my $ref = $q->fetchrow_hashref()) {
29
30         # for now:
31         # 100kbit/port = all green
32         # 1gbit/port = all red
33         
34         my $clr;
35
36         if (defined($ref->{'bytes_in'})) {
37                 my $intensity = 0.0;
38                 my $traffic = 4.0 * $ref->{'bytes_in'} + $ref->{'bytes_out'};  # average and convert to bits (should be about the same in practice)
39
40                 my $max = 20_000_000.0;   # 10mbit
41                 my $min =    100_000.0;   # 100kbit
42                 if ($traffic >= $min) {
43                         $intensity = 2.0 * (log($traffic / $min) / log(10)) / (log($max / $min) / log(10));
44                         $intensity = 2.0 if ($intensity > 2.0);
45                 }       
46                 $clr = get_color($intensity);
47         } else {
48                 $clr = $img->colorResolve(0, 0, 255);
49         }
50         
51         $ref->{'placement'} =~ /\((\d+),(\d+)\),\((\d+),(\d+)\)/;
52         $img->filledRectangle($3,$4,$1,$2,$clr);
53         $img->rectangle($3,$4,$1,$2,$blk);
54         $img->stringUp(gdSmallFont,$3,$2-3,$ref->{'sysname'},$blk);
55 }
56 $dbh->disconnect;
57
58 print $cgi->header(-type=>'image/png');
59 print $img->png;
60
61 sub get_color {
62         my $intensity = shift;
63         my $gamma = 1.0/1.90;
64         if ($intensity > 1.0) {
65                 return $img->colorResolve(255.0, 255.0 * ((2.0 - $intensity) ** $gamma), 0);
66         } else {
67                 return $img->colorResolve(255.0 * ($intensity ** $gamma), 255, 0);
68         }
69 }