Moved sending of mail to warnmsg.

Allow non-word characters in usernames (machine accounts end with $)
This commit is contained in:
hjp 2005-12-12 08:48:44 +00:00
parent 3808d97c6d
commit b7eb8717bd
1 changed files with 23 additions and 24 deletions

View File

@ -15,6 +15,7 @@ sub warnmsg {
'/fc4700' => 'K:', '/fc4700' => 'K:',
'/usr/local/www' => 'W:', '/usr/local/www' => 'W:',
); );
my $sunit = $unit eq "Files" ? "i" : "b";
my $wo; my $wo;
if ($dosdrv{$mount}) { if ($dosdrv{$mount}) {
@ -43,7 +44,7 @@ sub warnmsg {
"andere Netzplatte verschieben.\n" . "andere Netzplatte verschieben.\n" .
"\n" . "\n" .
"Sie können sich Ihre Verbrauchsgraphen unter\n" . "Sie können sich Ihre Verbrauchsgraphen unter\n" .
"http://intra.wsr.ac.at/informationssysteme/quotas/$user$mount_t.png ansehen. \n" . "http://intra.wsr.ac.at/informationssysteme/quotas/$user${mount_t}_$sunit.png ansehen. \n" .
"Der Graph zeigten den verbrauchten Platz ('used') sowie die beiden\n" . "Der Graph zeigten den verbrauchten Platz ('used') sowie die beiden\n" .
"Quotas ('soft' und 'hard')\n" . "Quotas ('soft' und 'hard')\n" .
"Die Softquota können Sie kurzfristig (noch $grace) überschreiten,\n" . "Die Softquota können Sie kurzfristig (noch $grace) überschreiten,\n" .
@ -54,7 +55,23 @@ sub warnmsg {
"Peter Holzer, hjp\@wsr.ac.at, Kl. 786\n" . "Peter Holzer, hjp\@wsr.ac.at, Kl. 786\n" .
"Gina Lanik, gina\@wsr.ac.at, Kl. 738\n" . "Gina Lanik, gina\@wsr.ac.at, Kl. 738\n" .
"Michael Demelbauer, michael\@wsr.ac.at, Kl. 787\n"; "Michael Demelbauer, michael\@wsr.ac.at, Kl. 787\n";
return $msg;
my $timestamp = "/usr/local/dfstat/quotacheck-timestamps/$user:$mount_t:$sunit";
if (!-e $timestamp) {
sendmail($user, $msg, $mount);
open (PMSG, ">$timestamp")
or die "cannot open $timestamp: $!";
print PMSG (@time);
close (PMSG);
} else {
my $comp = -A $timestamp;
#print STDERR "comp = $comp\n";
if ($comp > 5) {
sendmail($user, $msg, $mount);
}
}
} }
my %opts; my %opts;
@ -96,13 +113,13 @@ sub parseline($$) {
return undef unless (/\b\d+\b/); # ignore header lines return undef unless (/\b\d+\b/); # ignore header lines
my $msg = ""; my $msg = "";
my $user; my $user;
if (/(\w+) \s+ -- \s* if (/(\S+) \s+ -- \s*
(\d+)\s+(\d+)\s+(\d+)\s+ (\d+)\s+(\d+)\s+(\d+)\s+
(\d+)\s+(\d+)\s+(\d+) (\d+)\s+(\d+)\s+(\d+)
/x) { /x) {
$user = $1; $user = $1;
#print "ok: $1\n"; #print "ok: $1\n";
} elsif (/(\w+) \s+ \+- \s* } elsif (/(\S+) \s+ \+- \s*
(\d+)\s+(\d+)\s+(\d+)\s+($hpuxtime|$linuxtime)\s+ (\d+)\s+(\d+)\s+(\d+)\s+($hpuxtime|$linuxtime)\s+
(\d+)\s+(\d+)\s+(\d+) (\d+)\s+(\d+)\s+(\d+)
/x) { /x) {
@ -110,14 +127,14 @@ sub parseline($$) {
$user = $1; $user = $1;
$msg = warnmsg($mount, $2/1024, $3/1024, $4/1024, $5, "MB", $user); $msg = warnmsg($mount, $2/1024, $3/1024, $4/1024, $5, "MB", $user);
} elsif (/(\w+) \s+ -\+ \s* } elsif (/(\S+) \s+ -\+ \s*
(\d+)\s+(\d+)\s+(\d+)\s+ (\d+)\s+(\d+)\s+(\d+)\s+
(\d+)\s+(\d+)\s+(\d+)\s+($hpuxtime|$linuxtime) (\d+)\s+(\d+)\s+(\d+)\s+($hpuxtime|$linuxtime)
/x) { /x) {
print "file limit: $1: $5 > ($6 $7) $8\n"; print "file limit: $1: $5 > ($6 $7) $8\n";
$user = $1; $user = $1;
$msg = warnmsg($mount, $5, $6, $7, $8, "Files", $user); $msg = warnmsg($mount, $5, $6, $7, $8, "Files", $user);
} elsif (/(\w+) \s+ \+\+ \s* } elsif (/(\S+) \s+ \+\+ \s*
(\d+)\s+(\d+)\s+(\d+)\s+($hpuxtime|$linuxtime)\s+ (\d+)\s+(\d+)\s+(\d+)\s+($hpuxtime|$linuxtime)\s+
(\d+)\s+(\d+)\s+(\d+)\s+($hpuxtime|$linuxtime) (\d+)\s+(\d+)\s+(\d+)\s+($hpuxtime|$linuxtime)
/x) { /x) {
@ -160,24 +177,6 @@ for my $ln (@df) {
while (<REPQUOTA>) { while (<REPQUOTA>) {
next unless (/\b\d+\b/); # ignore header lines next unless (/\b\d+\b/); # ignore header lines
my ($user, $msg) = parseline($mount, $_); my ($user, $msg) = parseline($mount, $_);
if ($msg) {
my $timestamp = "/usr/local/dfstat/quotacheck-timestamps/$user:$mount_t";
if (!-e $timestamp) {
sendmail($user, $msg, $mount);
open (PMSG, ">$timestamp")
or die "cannot open $timestamp: $!";
print PMSG (@time);
close (PMSG);
} else {
my $comp = -A $timestamp;
#print STDERR "comp = $comp\n";
if ($comp > 5) {
sendmail($user, $msg, $mount);
}
}
}
} }
close (REPQUOTA); close (REPQUOTA);
} }