X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=aptcheck%2Faptcheck.pl;h=b6353002b7b7128cc8c18268fe2442db7ea7aabd;hb=12ca199577b3174589205147fe1b2365d231ab85;hp=d49e41b4840730720be414f96051a82df03c686b;hpb=68b66ad9c0d64c8d0958b871db445b0b4c03d711;p=git-tools-moved-to-github.git
diff --git a/aptcheck/aptcheck.pl b/aptcheck/aptcheck.pl
index d49e41b..b635300 100755
--- a/aptcheck/aptcheck.pl
+++ b/aptcheck/aptcheck.pl
@@ -27,9 +27,6 @@
# and architectures at the same time. Gets only the highest version from
# all, and reports anything less than this. Good enough for now.
#
-# TODO: Get the dates from ls --full-time /var/cache/apt/archives/
-# and display next to the packages, so we can see how long they have
-# been lingering. Boldface them if older than some limit
#### Init
use strict;
@@ -129,6 +126,8 @@ my %newdates; # To be written in the new version of the file
my $datefilename = "aptcheck.data";
my $dateoldfilename = "aptcheck.old";
my $thisdate = "*"; # indicates really old stuff
+my $warndate; # Older than this will be boldfaced
+
if ( -f $datefilename ) {
print "Reading dates from $datefilename\n" if $debug;
open F, $datefilename or die "Could not open date file $datefilename: $!";
@@ -142,6 +141,9 @@ if ( -f $datefilename ) {
close F;
$thisdate = `date +%F`;
chomp($thisdate);
+ $warndate = `date +%F -d "30 days ago"` ; ;
+ chomp($warndate);
+ print "Dates: now: '$thisdate' warn: '$warndate'\n" if $debug;
} else {
print "No datefile $datefilename found, starting from scratch\n";
}
@@ -218,7 +220,12 @@ for my $hline ( sort( split("\n",$hostlist) ) ) {
} else {
$newdates{$datekey} = $thisdate;
}
- $det .= "
" . $newdates{$datekey} . " | ";
+ my $dispdate = $newdates{$datekey};
+ # if ( $dispdate lt $warndate ) {
+ if ( 0 ) { # manual packages don't need to be highlighted
+ $dispdate = "$dispdate !";
+ }
+ $det .= "" . $dispdate . " | ";
$det .= "\n";
my $key = "$restrname";
if ( !$summary{$key} ) {
@@ -271,7 +278,11 @@ for my $hline ( sort( split("\n",$hostlist) ) ) {
} else {
$newdates{$datekey} = $thisdate;
}
- $det .= "" . $newdates{$datekey} . " | ";
+ my $dispdate = $newdates{$datekey};
+ if ( ( $dispdate lt $warndate ) && ( $src =~ /Security/) ) {
+ $dispdate = "$dispdate !";
+ }
+ $det .= "" . $dispdate . " | ";
$det .= "\n";
}
@@ -304,14 +315,18 @@ for my $hline ( sort( split("\n",$hostlist) ) ) {
$table .= "\n";
# Save the date file
-`mv -f $datefilename $dateoldfilename`;
-open F, ">$datefilename" or die "Could not open date file $datefilename for writing";
-for my $k (sort(keys(%newdates)) ) {
- print F "$k " . $newdates{$k}. "\n";
- print "date for '$k' '" . $newdates{$k}. "'\n" if $debug;
+if ( ! $debug ) {
+ `mv -f $datefilename $dateoldfilename`;
+ open F, ">$datefilename" or die "Could not open date file $datefilename for writing";
+ for my $k (sort(keys(%newdates)) ) {
+ print F "$k " . $newdates{$k}. "\n";
+ print "date for '$k' '" . $newdates{$k}. "'\n" if $debug;
+ }
+ close F
+ or die "Could not close date file $datefilename: $!";
+} else {
+ print "Not updating the date file, this is a debug run\n";
}
-close F
- or die "Could not close date file $datefilename: $!";
# Page header
my $outfile = "/tmp/aptcheck.html";
@@ -429,6 +444,9 @@ if ( 1 ) {
}
print F "\n";
+print F "" . ( $sectot + $owntot + $mantot + $normtot ) .
+ " packages pending ($sectot critical) \n";
+
# Graph
#my $secs = 60*60*24 * 7 * 2; # 2 weeks in secods
#my $secs = "1m"; # one month, let nagios do the math