X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=cmd%2Fkill.pl;h=8c8e275cbdb6c19bd801c0b1b02e4de0720bea6f;hb=refs%2Fheads%2Fnewdisc;hp=fb58bc247c09655408dbb91193f7fe596c518e75;hpb=c73f18c7f4534761e29b51f3f0426f6f1f7a073b;p=spider.git diff --git a/cmd/kill.pl b/cmd/kill.pl index fb58bc24..8c8e275c 100644 --- a/cmd/kill.pl +++ b/cmd/kill.pl @@ -1,9 +1,9 @@ # # kill or delete a message # -# Copyright (c) Dirk Koopman G1TLH +# Copyright (c) 1998 Dirk Koopman G1TLH +# # -# $Id$ # use strict; @@ -17,6 +17,7 @@ my $ref; my @refs; my $call = $self->call; my $full; +my $expunge; # $DB::single = 1; @@ -25,6 +26,9 @@ while (@f) { if ($f =~ /^fu/io) { return (1, $self->msg('e5')) if $self->priv < 5; $full = 1; + } elsif ($f =~ /^ex/io) { + return (1, $self->msg('e5')) if $self->priv < 6; + $expunge = 1; } elsif ($f =~ /^\d+$/o) { $ref = DXMsg::get($f); if (!$ref) { @@ -40,7 +44,7 @@ while (@f) { my $from = $1; my $to = $2; @refs = grep { !($self->priv < 5 && $_->to ne $call && $_->from ne $call) } DXMsg::get_all() unless @refs; - @refs = grep { $_->msgno >= $from && $_->msgno < $to } @refs; + @refs = grep { $_->msgno >= $from && $_->msgno <= $to } @refs; } elsif ($f =~ /^fr/io) { $f = shift @f; if ($f) { @@ -62,12 +66,18 @@ while (@f) { } foreach $ref ( @refs) { + if ($ref->keep) { + push @out, $self->msg('m18', $ref->msgno); + next; + } + my $tonode = $ref->tonode; + $ref->stop_msg($tonode) if $tonode; + $ref->mark_delete($expunge ? 0 : undef); + push @out, $self->msg('m12', $ref->msgno); Log('msg', "Message $ref->{msgno} from $ref->{from} to $ref->{to} deleted by $call"); if ($full) { - DXProt::broadcast_all_ak1a(DXProt::pc49($self->call, $ref->{subject}), $DXProt::me); + DXChannel::broadcast_nodes(DXProt::pc49($ref->{from}, $ref->{subject}), $main::me); } - $ref->del_msg; - push @out, "Message $ref->{msgno} deleted"; } return (1, @out);