X-Git-Url: http://dxcluster.org/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2FDXMsg.pm;h=bbda05cb5571c5c8718e28708c6456350a9a87d7;hb=b060a0a3ee72530aa3f10d453186a662b66d7efe;hp=6a6f104aa346073dc0a6eb5e979b7beee023ed72;hpb=3d29b1a4d4aab997da2deff10470068601744530;p=spider.git diff --git a/perl/DXMsg.pm b/perl/DXMsg.pm index 6a6f104a..bbda05cb 100644 --- a/perl/DXMsg.pm +++ b/perl/DXMsg.pm @@ -24,12 +24,14 @@ use FileHandle; use Carp; use strict; -use vars qw(%work @msg $msgdir %valid %busy); +use vars qw(%work @msg $msgdir %valid %busy $maxage $last_clean); %work = (); # outstanding jobs @msg = (); # messages we have %busy = (); # station interlocks $msgdir = "$main::root/msg"; # directory contain the msgs +$maxage = 30 * 86400; # the maximum age that a message shall live for if not marked +$last_clean = 0; # last time we did a clean %valid = ( fromnode => '9,From Node', @@ -51,6 +53,7 @@ $msgdir = "$main::root/msg"; # directory contain the msgs read => '9,Times read', size => '0,Size', msgno => '0,Msgno', + keep => '0,Keep this?,yesno', ); # allocate a new object @@ -170,6 +173,7 @@ sub process add_dir($ref); my $dxchan = DXChannel->get($ref->{to}); $dxchan->send("New mail has arrived for you") if $dxchan; + Log('msg', "Message $ref->{msgno} from $ref->{from} received from $f[2] for $ref->{to}"); } $ref->stop_msg($self); queue_msg(); @@ -184,10 +188,12 @@ sub process my $ref = $work{"$f[2]$f[3]"}; if ($ref) { if ($ref->{private}) { # remove it if it private and gone off site# - $ref->del_msg; + Log('msg', "Message $ref->{msgno} from $ref->{from} sent to $f[2] and deleted"); + $ref->del_msg; } else { - push @{$ref->{gotit}}, $f[2]; # mark this up as being received - $ref->store($ref->{lines}); # re- store the file + Log('msg', "Message $ref->{msgno} from $ref->{from} sent to $f[2]"); + push @{$ref->{gotit}}, $f[2]; # mark this up as being received + $ref->store($ref->{lines}); # re- store the file } $ref->stop_msg($self); } else { @@ -242,6 +248,8 @@ sub process last SWITCH; } } + + clean_old() if $main::systime - $last_clean > 3600 ; # clean the message queue } @@ -320,6 +328,27 @@ sub del_msg dbg('msg', "deleting $self->{msgno}\n"); } +# clean out old messages from the message queue +sub clean_old +{ + my $ref; + + # mark old messages for deletion + foreach $ref (@msg) { + if (!$ref->{keep} && $ref->{t} < $main::systime - $maxage) { + $ref->{deleteme} = 1; + delete $ref->{gotit}; + delete $ref->{list}; + unlink filename($ref->{msgno}); + dbg('msg', "deleting old $ref->{msgno}\n"); + } + } + + # remove them all from the active message list + @msg = map { $_->{deleteme} ? () : $_ } @msg; + $last_clean = $main::systime; +} + # read in a message header sub read_msg_header {