#!/usr/bin/perl
#
# Avast updater. Original code by Julian Field. Timeout code by
# Alessandro Bianchi. Timeout code is not perfect but should be okay.
#
use Sys::Syslog;
# If you have a web proxy or cache server, put its value in the next line
# in the syntax "full.host.name:port".
$HTTPproxy = "";
$PackageDir = shift || "/usr";
$LogFile = "/tmp/Avast.update.log";
$AvastUpdateCommand = "$PackageDir/bin/avastvpsupdate.sh";
$LockFile = "/tmp/AvastBusy.lock";
$LOCK_SH = 1;
$LOCK_EX = 2;
$LOCK_NB = 4;
$LOCK_UN = 8;
eval { Sys::Syslog::setlogsock('unix'); }; # This may fail!
Sys::Syslog::openlog("Avast-autoupdate", 'pid, nowait', 'mail');
if (-x $AvastUpdateCommand) {
# Timeout prevention
$SIG{ALRM} = sub { die "timeout"};
&LockAvast();
eval {
alarm 300;
$retval = system($AvastUpdateCommand)>>8;
&UnlockAvast();
alarm 0;
};
if ($@) {
if ($@ =~ /timeout/) {
# We timed out!
&UnlockAvast();
Sys::Syslog::syslog('err', "WARNING Avast update timed out");
alarm 0;
}
} else {
alarm 0;
Sys::Syslog::syslog('info', "Avast updated");
}
} else {
Sys::Syslog::syslog('err', "Avast updater $AvastUpdateCommand cannot be run");
}
Sys::Syslog::closelog();
exit 0;
sub LockAvast {
open(LOCK, ">$LockFile") or return;
flock(LOCK, $LOCK_EX);
print LOCK "Locked for updating Avast definitions by $$\n";
}
sub UnlockAvast {
print LOCK "Unlocked after updating Avast definitions by $$\n";
unlink $LockFile;
flock(LOCK, $LOCK_UN);
close LOCK;
}
sub UpdateAvast {
my($cmd) = @_;
open(CMD, "$cmd 2>&1 |") or return $?;
while(<CMD>) {
chomp;
Sys::Syslog::syslog('err', "Avast update warning: $_")
if /warning|error|fatal/i;
}
close CMD;
return $?>>8;
}
syntax highlighted by Code2HTML, v. 0.9.1