X-Git-Url: http://dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=cmd%2Fshow%2Fnode.pl;h=d45cad36155a8e85ef49131ecb2e336cbd48bdf9;hb=dc016a0633cdb15d29b9a71fdec2c230fbad201b;hp=e51b97c36f6f640169c17204926c4c715c99e387;hpb=b32338a1d9e22f4297bf6a971d2903d5952180cd;p=spider.git diff --git a/cmd/show/node.pl b/cmd/show/node.pl index e51b97c3..d45cad36 100644 --- a/cmd/show/node.pl +++ b/cmd/show/node.pl @@ -17,12 +17,22 @@ my ($self, $line) = @_; return (1, $self->msg('e5')) unless $self->priv >= 1; +use DB_File; + my @call = map {uc $_} split /\s+/, $line; my @out; +my $count; # search thru the user for nodes unless (@call) { - @call = sort map { my $ref; (($ref = DXUser->get_current($_)) && $ref->sort ne 'U') ? $_ : () } DXUser::get_all_calls; + + my ($action, $key, $data) = (0,0,0); + for ($action = DXUser::R_FIRST, $count = 0; !$DXUser::dbm->seq($key, $data, $action); $action = DXUser::R_NEXT) { + if ($data =~ m{sort => '[ACRSX]'}) { + push @call, $key; + ++$count; + } + } } my $call; @@ -34,11 +44,14 @@ foreach $call (@call) { my $pcall = sprintf "%-11s", $call; push @out, $self->msg('snode1') unless @out > 0; if ($uref) { - $sort = "Spider" if $uref->sort eq 'S'; - $sort = "AK1A " if $uref->sort eq 'A'; - $sort = "clx " if $uref->sort eq 'C'; - $sort = "Fred " if $uref->sort eq 'U'; - $sort = "BBS " if $uref->sort eq 'B'; + $sort = "Unknwn"; + $sort = "Spider" if $uref->is_spider; + $sort = "AK1A " if $uref->is_ak1a; + $sort = "Clx " if $uref->is_clx; + $sort = "User " if $uref->is_user; + $sort = "BBS " if $uref->is_bbs; + $sort = "DXNet " if $uref->is_dxnet; + $sort = "ARClus" if $uref->is_arcluster; } else { push @out, $self->msg('snode3', $call); next; @@ -51,11 +64,16 @@ foreach $call (@call) { } my ($major, $minor, $subs) = unpack("AAA*", $ver) if $ver; - if ($sort eq 'Spider') { + if ($uref->is_spider) { push @out, $self->msg('snode2', $pcall, $sort, "$ver "); } else { push @out, $self->msg('snode2', $pcall, $sort, $ver ? "$major\-$minor.$subs" : " "); } + ++$count; } -return (1, @out); +return (1, @out, $self->msg('rec', $count)); + + + +