X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=cmd%2Fshow%2Fnode.pl;h=fa4a3505fa0226374d8ac23d7b7fd0fa57c86dab;hb=d0d643e52b8c7ab9f481c78edb8ab953a5da3b29;hp=2cdf84a380a84749def463fef204bff08544ca2b;hpb=699e2b8f9d924df78f55f69dfeded213f158b121;p=spider.git diff --git a/cmd/show/node.pl b/cmd/show/node.pl index 2cdf84a3..fa4a3505 100644 --- a/cmd/show/node.pl +++ b/cmd/show/node.pl @@ -16,30 +16,31 @@ my ($self, $line) = @_; return (1, $self->msg('e5')) unless $self->priv >= 1; - -use DB_File; +return (1, $self->msg('storable')) unless $DXUser::v3; my @call = map {uc $_} split /\s+/, $line; my @out; my $count; # search thru the user for nodes -unless (@call) { - - my ($action, $key, $data); - for ($action = R_FIRST, $count = 0; !$DXUser::dbm->seq($key, $data, $action); $action = R_NEXT) { - if ($data =~ m{sort => '[ACRSX]'}) { +if ($call[0] eq 'ALL') { + shift @call; + 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{\01[ACRSX]\0\0\0\04sort}) { push @call, $key; ++$count; } } +} elsif (@call == 0) { + @call = map {$_->call} DXChannel::get_all_nodes(); } my $call; foreach $call (@call) { - my $clref = DXCluster->get_exact($call); + my $clref = Route::Node::get($call); my $uref = DXUser->get_current($call); - my ($sort, $ver); + my ($sort, $ver, $build); my $pcall = sprintf "%-11s", $call; push @out, $self->msg('snode1') unless @out > 0; @@ -56,16 +57,22 @@ foreach $call (@call) { push @out, $self->msg('snode3', $call); next; } + $ver = ""; + $build = ""; if ($call eq $main::mycall) { $sort = "Spider"; $ver = $main::version; } else { - $ver = $clref->pcversion if $clref && $clref->pcversion; + $ver = $clref->version if $clref && $clref->version; + $ver = $uref->version if $ver && $uref->version; } my ($major, $minor, $subs) = unpack("AAA*", $ver) if $ver; if ($uref->is_spider) { - push @out, $self->msg('snode2', $pcall, $sort, "$ver "); + $ver /= 100 if $ver > 5400; + $ver -= 53 if $ver > 54; + $build = "build: " . $uref->build if $uref->build; + push @out, $self->msg('snode2', $pcall, $sort, "$ver $build"); } else { push @out, $self->msg('snode2', $pcall, $sort, $ver ? "$major\-$minor.$subs" : " "); }