X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=cmd%2Fping.pl;h=89f43a0bb86144eb90284d0e1ed087f7dd0b221a;hb=f2882b6c4323ac02e60e54bcf2d9c9fdd396de9b;hp=05ccd829d8ab61f989a85eb09cd702786e01aaf5;hpb=6624dcdf07d628e8d6a16fc6549edf40be25b7b2;p=spider.git diff --git a/cmd/ping.pl b/cmd/ping.pl index 05ccd829..89f43a0b 100644 --- a/cmd/ping.pl +++ b/cmd/ping.pl @@ -3,30 +3,46 @@ # # Copyright (c) 1998 Dirk Koopman G1TLH # -# $Id$ # +# + +my $counter; + +sub init +{ + $counter = 0; +} + +sub handle +{ + my $self = shift; + my $line = uc shift; # only one callsign allowed + my ($call) = $line =~ /^\s*(\S+)/; -my $self = shift; -my $line = uc shift; # only one callsign allowed -my ($call) = $line =~ /^\s*(\S+)/; +# $DB::single = 1; -# are we permitted? -return (1, $self->msg('e5')) if $self->priv < 1; + if ($self->{priv} < 1) { + if ($call) { + return (1, "PONG $call"); + } + ++$counter, return (1, "PONG $counter") + } -# is there a call? -return (1, $self->msg('e6')) if !$call; + # is there a call? + return (1, $self->msg('e6')) if !$call; -# is it me? -return (1, $self->msg('pinge1')) if $call eq $main::mycall; + # is it me? + return (1, $self->msg('pinge1')) if $call eq $main::mycall; -# can we see it? Is it a node? -my $noderef = Route::Node::get($call); + # can we see it? Is it a node? + my $noderef = Route::Node::get($call); -return (1, $self->msg('e7', $call)) unless $noderef; + return (1, $self->msg('e7', $call)) unless $noderef; -# ping it -DXProt::addping($self->call, $call); + # ping it + DXXml::Ping::add($self, $call); -return (1, $self->msg('pingo', $call)); + return (1, $self->msg('pingo', $call)); +}