11 |
my $debug = 0; |
my $debug = 0; |
12 |
|
|
13 |
my $width = 600; # width of bar |
my $width = 600; # width of bar |
14 |
my $height = 19; # height of bar |
my $height = 15; # height of bar |
15 |
my $use_js = 1; # use JavaScript pop-up |
my $use_js = 1; # use JavaScript pop-up |
16 |
|
|
17 |
# status colors |
# status colors |
18 |
my %cols = ( |
my %cols = ( |
19 |
'In Progress' => '0,255,0', |
'In Progress' => '0,255,0', |
20 |
'In Progress/Failure' => '255,64,255', |
'In Progress/Failures' => '192,64,192', |
21 |
'In Progress/Errors' => '255,64,0', |
'In Progress/Errors' => '255,128,128', |
22 |
'Queuing' => '255,255,0', |
'Queuing' => '255,255,0', |
23 |
|
'Queuing/Errors' => '255,192,64', |
24 |
'Aborted' => '255,0,0', |
'Aborted' => '255,0,0', |
25 |
'Failed' => '255,0,0', |
'Failed' => '255,0,0', |
26 |
'Completed' => '64,255,64', |
'Completed' => '64,255,64', |
60 |
# keep count of each status |
# keep count of each status |
61 |
my %count; |
my %count; |
62 |
|
|
63 |
if (param('pic')) { |
if (path_info()) { |
64 |
print "Content-type: image/png\nCache-Control: max-age=3600, must-revalidate\n\n"; |
print "Content-type: image/png\nCache-Control: max-age=86400, must-revalidate\nExpires: ",scalar localtime(time()+24*60*60),"\nLast-Modified: ",scalar localtime(0),"\n"; |
65 |
# create picture using GD |
# create picture using GD |
66 |
use GD; |
use GD; |
67 |
my $im = new GD::Image(1,$height); |
my $im = new GD::Image(1,$height); |
68 |
my $back = $im->colorAllocate(255,255,255); |
my $back = $im->colorAllocate(255,255,255); |
69 |
$im->transparent($back); |
$im->transparent($back); |
70 |
my ($r,$g,$b) = split(/,/,param('pic')); |
my $col = path_info(); $col =~ s,/,,g; |
71 |
|
my ($r,$g,$b) = split(/,/,$col); |
72 |
my $col = $im->colorAllocate($r,$g,$b); |
my $col = $im->colorAllocate($r,$g,$b); |
73 |
$im->fill(0,0,$col); |
$im->fill(0,0,$col); |
74 |
|
print "Content-Length: ",length($im->png),"\n\n"; |
75 |
binmode STDOUT; |
binmode STDOUT; |
76 |
print $im->png; |
print $im->png; |
77 |
exit; |
exit; |
78 |
} |
} |
79 |
|
|
80 |
print "Content-type: text/html |
print "Content-type: text/html |
81 |
|
Cache-Control: max-age=60, must-revalidate |
82 |
|
|
83 |
<html> |
<html> |
84 |
<head> |
<head> |
85 |
<title>OmniBack Gantt: $from - $to</title>"; |
<title>OmniBack Gantt: $from - $to</title> |
86 |
|
<meta HTTP-EQUIV=\"Refresh\" CONTENT=600>"; |
87 |
if ($use_js) { |
if ($use_js) { |
88 |
print ' |
print ' |
89 |
<script type="text/javascript" language="javascript" src="1k.js"></script> |
<script type="text/javascript" language="javascript" src="1k.js"></script> |
130 |
print "<tr><td align=right><small>hour grid</small></td><td colspan=2>"; |
print "<tr><td align=right><small>hour grid</small></td><td colspan=2>"; |
131 |
my @c = ("255,255,128","255,192,128"); |
my @c = ("255,255,128","255,192,128"); |
132 |
my $hr=strftime("%H",localtime ($from_t)); |
my $hr=strftime("%H",localtime ($from_t)); |
133 |
my $min_l=1; |
sub hour_bar { |
134 |
print color_bar(3600 - $from_t % 3600,$c[0],sprintf("%02d",$hr++ % 24)); |
my ($t,$c,$hr) = @_; |
135 |
|
my $clock_hr = $hr % 24; |
136 |
|
my $alt = sprintf("%02d:00",$clock_hr); |
137 |
|
if ($clock_hr == 0) { |
138 |
|
my $pix_hr = int(1 / $width); |
139 |
|
print color_bar($pix_hr,"0,0,0",strftime("%Y-%m-%d", localtime($from_t + $hr*3600))); |
140 |
|
print color_bar($t-$pix_hr,$c,$alt); |
141 |
|
} else { |
142 |
|
print color_bar($t,$c,$alt); |
143 |
|
} |
144 |
|
} |
145 |
|
hour_bar(3600 - $from_t % 3600,$c[0],$hr++); |
146 |
for (my $i=1; $i<int(($to_t-$from_t)/3600); $i++) { |
for (my $i=1; $i<int(($to_t-$from_t)/3600); $i++) { |
147 |
print color_bar(3600,$c[1],sprintf("%02d",$hr++ % 24)); |
hour_bar(3600,$c[1],$hr++); |
148 |
push @c, shift @c; |
push @c, shift @c; |
149 |
} |
} |
150 |
print color_bar($from_t % 3600,$c[1],sprintf("%02d",$hr % 24)); |
hour_bar($from_t % 3600,$c[1],$hr); |
151 |
print "</td></tr>\n"; |
print "</td></tr>\n"; |
152 |
} |
} |
153 |
|
|
182 |
my $col = shift @_ || '240,240,240'; # default color (filler) |
my $col = shift @_ || '240,240,240'; # default color (filler) |
183 |
my $alt = shift @_ || undef; |
my $alt = shift @_ || undef; |
184 |
my $min_l = shift @_ || 1; |
my $min_l = shift @_ || 1; |
185 |
|
my $h = shift @_ || $height; |
186 |
|
|
187 |
my $size = $l / ($len_t / $width); |
my $size = $l / ($len_t / $width); |
188 |
$fix_s += $size - int($size); |
$fix_s += $size - int($size); |
207 |
|
|
208 |
print STDERR "bar[$col] len:$l s scale:",($len_t/$width)," size:$size px<br> alt:$alt\n" if ($debug); |
print STDERR "bar[$col] len:$l s scale:",($len_t/$width)," size:$size px<br> alt:$alt\n" if ($debug); |
209 |
|
|
210 |
my $html = "<img src=\"".$q->url(-relative=>1)."?pic=$col\" width=\"$size\" height=\"$height\""; |
my $html = "<img src=\"".$q->url(-relative=>1)."/$col\" width=\"$size\" height=\"$h\""; |
211 |
|
|
212 |
if ($use_js && $alt) { |
if ($use_js && $alt) { |
213 |
$html .= " onmouseover=\"T('$alt')\" onmouseout=\"T()\""; |
$html .= " onmouseover=\"T('$alt')\" onmouseout=\"T()\""; |
224 |
from gantt |
from gantt |
225 |
where (start < '$from' and finish > '$from') or |
where (start < '$from' and finish > '$from') or |
226 |
(start > '$from' and start < '$to') |
(start > '$from' and start < '$to') |
227 |
order by device,specification |
order by device,specification,start |
228 |
"; |
"; |
229 |
|
|
230 |
my $sth = $dbh->prepare($sql) || die "sql: $sql ".$dbh->errstr; |
my $sth = $dbh->prepare($sql) || die "sql: $sql ".$dbh->errstr; |
236 |
|
|
237 |
$sth->execute() || die "sql: $sql ".$dbh->errstr; |
$sth->execute() || die "sql: $sql ".$dbh->errstr; |
238 |
|
|
239 |
|
my $dev; # current device |
240 |
|
my @dev_t; # all minutes in one hour [1440] |
241 |
|
my @dev_sum_t; |
242 |
|
|
243 |
|
sub sum_bar { |
244 |
|
my $label = shift @_; |
245 |
|
my @dev_t = @_; |
246 |
|
# display device summary |
247 |
|
my $max_use = 0; |
248 |
|
for (my $i=0; $i < $len_t; $i++) { |
249 |
|
$max_use = $dev_t[$i] if (defined $dev_t[$i] && $dev_t[$i] > $max_use); |
250 |
|
} |
251 |
|
print "<tr><td align=right><small>$label [$max_use]</small></td><td colspan=2>"; |
252 |
|
my $last_var = 0; |
253 |
|
my $len = 0; |
254 |
|
for (my $i=1; $i<= ($to_t-$from_t); $i++) { |
255 |
|
my $v = $dev_t[$i] || 0; |
256 |
|
if ($v == $last_var) { |
257 |
|
$len++; |
258 |
|
} else { |
259 |
|
my $h = $last_var / $max_use * $height; |
260 |
|
my $c = 255 - int (255 * $last_var / $max_use); |
261 |
|
print color_bar($len,"$c,$c,$c","$last_var concurrent jobs",1,$h+1); |
262 |
|
$len = 0; |
263 |
|
$last_var = $v; |
264 |
|
} |
265 |
|
} |
266 |
|
my $h = $last_var / $max_use * $height; |
267 |
|
my $c = 255 - int (255 * $last_var / $max_use); |
268 |
|
print color_bar($len,"$c,$c,$c","$last_var concurrent jobs",1,$h+1) if ($len); |
269 |
|
print "</td></tr>"; |
270 |
|
} |
271 |
|
|
272 |
while(my $row = $sth->fetchrow_hashref) { |
while(my $row = $sth->fetchrow_hashref) { |
273 |
if (!defined $curr_spec || $row->{specification} ne $curr_spec) { |
if (!defined $curr_spec || $row->{specification} ne $curr_spec) { |
274 |
|
|
279 |
} |
} |
280 |
|
|
281 |
print "</td></tr>\n" if ($curr_t != $from_t); |
print "</td></tr>\n" if ($curr_t != $from_t); |
282 |
|
|
283 |
|
if ($dev && @dev_t && $dev ne $row->{device}) { |
284 |
|
sum_bar("summary for $dev",@dev_t); |
285 |
|
$dev = $row->{device}; |
286 |
|
@dev_t = (); |
287 |
|
} elsif (! $dev) { |
288 |
|
$dev = $row->{device}; |
289 |
|
} |
290 |
|
|
291 |
|
# init vars for next line |
292 |
($fix_s,$fix_d) = (0,0); # init fix vars for bar |
($fix_s,$fix_d) = (0,0); # init fix vars for bar |
293 |
print "<tr><td>", $row->{specification},"</td><td colspan=2>"; |
print "<tr><td>", $row->{specification},"</td><td colspan=2>"; |
294 |
|
|
306 |
print STDERR "[middle filler $curr_t:$t]" if ($debug); |
print STDERR "[middle filler $curr_t:$t]" if ($debug); |
307 |
print bar($t); |
print bar($t); |
308 |
$curr_t = $start_t; |
$curr_t = $start_t; |
309 |
|
} else { |
310 |
|
# prepend too few seconds to next event |
311 |
|
$start_t = $curr_t; |
312 |
} |
} |
313 |
|
|
314 |
my $len = $fin_t - $start_t; |
my $len = $fin_t - $start_t; |
333 |
my $alt = $row->{start}." - ".$row->{finish}."<br>"; |
my $alt = $row->{start}." - ".$row->{finish}."<br>"; |
334 |
$alt =~ s/:\d\d\.\d+//g; |
$alt =~ s/:\d\d\.\d+//g; |
335 |
$alt =~ s/\s+/ /g; |
$alt =~ s/\s+/ /g; |
336 |
$alt .= $row->{type}." <b>".$row->{status}."</b><br>". |
$alt .= $row->{specification}."<br>". |
337 |
$row->{user_group_host}." <i>".$row->{sessionid}."</i><br>". |
$row->{type}." <b>".$row->{status}."</b><br>". |
338 |
$row->{device}." on ".$row->{host}; |
$row->{user_group_host}." <i>".$row->{sessionid}."</i><br>". |
339 |
|
$row->{device}." on ".$row->{host}; |
340 |
print bar($len,$row->{status},$alt); |
print bar($len,$row->{status},$alt); |
341 |
|
|
342 |
|
# store use of devices for each minute |
343 |
|
for (my $s=0; $s<$len; $s++) { |
344 |
|
$dev_t[$curr_t-$from_t+$s]++; |
345 |
|
$dev_sum_t[$curr_t-$from_t+$s]++; |
346 |
|
} |
347 |
|
|
348 |
$curr_t += $len; |
$curr_t += $len; |
349 |
|
|
350 |
# print Dumper($row); |
# print Dumper($row); |
365 |
$dbh->disconnect; |
$dbh->disconnect; |
366 |
|
|
367 |
print "</td></tr>\n"; |
print "</td></tr>\n"; |
368 |
|
sum_bar("summary for $dev",@dev_t); |
369 |
hour_grid(); |
hour_grid(); |
370 |
|
sum_bar("summary for all devices",@dev_sum_t); |
371 |
print "</table>"; |
print "</table>"; |
372 |
|
|
373 |
|
|
384 |
# it will first evaluate bar sub (thus increasing number by one) and |
# it will first evaluate bar sub (thus increasing number by one) and |
385 |
# then display number (wrongly). |
# then display number (wrongly). |
386 |
} |
} |
387 |
print "</table>\n<p>Reload <a href=\"",$q->url(-relative=>1),"\">current</a>.</p></body></html>"; |
print "</table>\n<p>Reload <a href=\"",$q->url(-relative=>1),"\">current</a> or see <a href=\"db2gantt_help.html\">help</a>.</p></body></html>"; |
388 |
|
|