X-Git-Url: http://dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=cmd%2Fshow%2Fregistered.pl;h=b3f345d96317186b9d58e4ae56d08fc61a375a37;hb=9c8f43f26a7db08c4ff6ef2213c95c9f509abe36;hp=ebc468d1cf2a44a2f9fc6e05187de03d7f4daae5;hpb=579810d363939640538f88a9caa86e01fe9c7709;p=spider.git diff --git a/cmd/show/registered.pl b/cmd/show/registered.pl index ebc468d1..b3f345d9 100644 --- a/cmd/show/registered.pl +++ b/cmd/show/registered.pl @@ -5,34 +5,68 @@ # # Copyright (c) 2001 Dirk Koopman G1TLH # -# $Id$ # +# + +sub handle +{ + my ($self, $line) = @_; + return (1, $self->msg('e5')) unless $self->priv >= 9; + + my @out; -my ($self, $line) = @_; -return (1, $self->msg('e5')) unless $self->priv >= 9; + use DB_File; -my @out; + if ($line) { + $line =~ s/[^\w\-\/]+//g; + $line = "^\U\Q$line"; + } -use DB_File; + if ($self->{_nospawn}) { + @out = generate($self, $line); + } else { + @out = $self->spawn_cmd("show/registered $line", sub { return (generate($self, $line)); }); + } -if ($line) { - $line =~ s/[^\w\-\/]+//g; - $line = "^\U\Q$line"; + return (1, @out); } -my ($action, $count, $key, $data) = (0,0,0,0); -for ($action = DXUser::R_FIRST, $count = 0; !$DXUser::dbm->seq($key, $data, $action); $action = DXUser::R_NEXT) { - if ($data =~ m{registered =>}) { - if (!$line || ($line && $key =~ /$line/)) { - my $u = DXUser->get_current($key); - if ($u && $u->registered) { - push @out, $key; - ++$count; +sub generate +{ + my $self = shift; + my $line = shift; + my @out; + my @val; + + + my ($action, $count, $key, $data) = (0,0,0,0); + eval qq{for (\$action = DXUser::R_FIRST, \$count = 0; !\$DXUser::dbm->seq(\$key, \$data, \$action); \$action = DXUser::R_NEXT) { + if (\$data =~ m{registered}) { + if (!\$line || (\$line && \$key =~ /^$line/)) { + my \$u = DXUser::get_current(\$key); + if (\$u && \$u->registered) { + push \@val, \$key; + ++\$count; } } } -} - -return (1, @out, $self->msg('rec', $count)); +} }; + my @l; + foreach my $call (@val) { + if (@l >= 5) { + push @out, sprintf "%-12s %-12s %-12s %-12s %-12s", @l; + @l = (); + } + push @l, $call; + } + if (@l) { + push @l, "" while @l < 5; + push @out, sprintf "%-12s %-12s %-12s %-12s %-12s", @l; + } + push @out, $@ if $@; + push @out, , $self->msg('rec', $count); + return @out; + +}