X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=cmd%2Fannounce.pl;h=df7b91d0f54b7913ff423ae64a5981c6e9cf661d;hb=a8d4234c702d3cf6049a9e53bd07cfc924eaee25;hp=cb2e325dff6c8c6e62811e276ae8fe913a59345b;hpb=0824a94355e5fb2b4c379bb013d66466725629f5;p=spider.git diff --git a/cmd/announce.pl b/cmd/announce.pl index cb2e325d..df7b91d0 100644 --- a/cmd/announce.pl +++ b/cmd/announce.pl @@ -12,15 +12,21 @@ # # $Id$ # +# Modified 13Dec98 Iain Phillips G0RDI +# my ($self, $line) = @_; my @f = split /\s+/, $line; +return (1, $self->msg('e5')) if $self->remotecmd; +return (1, $self->msg('e9')) if !@f; + my $sort = uc $f[0]; my @locals = DXCommandmode->get_all(); my $to; my $from = $self->call; my $t = ztime(time); my $tonode; +my $toflag = '*'; my $sysopflag; if ($sort eq "FULL") { @@ -31,14 +37,26 @@ if ($sort eq "FULL") { @locals = map { $_->priv >= 5 ? $_ : () } @locals; $to = "SYSOP"; $sysopflag = '*'; +} elsif ($sort eq "LOCAL") { + $line =~ s/^$f[0]\s+//; # remove it + $to = "LOCAL"; } else { $to = "LOCAL"; } -DXProt::broadcast_list("To $to de $from <$t>: $line", @locals); +# change ^ into : for transmission +$line =~ s/\^/:/og; + +my @bad; +if (@bad = BadWords::check($line)) { + return (1, $self->msg('e17', @bad)); +} + +return (1, $self->msg('dup')) if AnnTalk::dup($from, $toflag, $line); +Log('ann', $to, $from, $line); +DXProt::broadcast_list("To $to de $from <$t>: $line", 'ann', undef, @locals); if ($to ne "LOCAL") { - $line =~ s/\^//og; # remove ^ characters! - my $pc = DXProt::pc12($self, $line, $tonode, $sysopflag, 0); + my $pc = DXProt::pc12($from, $line, $tonode, $sysopflag, 0); DXProt::broadcast_ak1a($pc); }