add cmd line to forkcall stats
[spider.git] / cmd / show / lockout.pl
index 6b7b7d49d667aa4b921c9d385f2a7d9b3c29831d..e97b4bcf34c53436429478592a624ac2bd8fe5f4 100644 (file)
@@ -5,13 +5,58 @@
 #
 # Copyright (c) 2000 Dirk Koopman G1TLH
 #
-# $Id$
+#
 #
 
 my ($self, $line) = @_;
 return (1, $self->msg('e5')) unless $self->priv >= 9;
 
-# search thru the user for nodes
-my @out = sort map { my $ref; (($ref = DXUser->get_current($_)) && $ref->lockout) ? $_ : () } DXUser::get_all_calls;
+my @out;
+
+use DB_File;
+
+if ($line) {
+       $line =~ s/[^\w\-\/]+//g;
+       $line = "\U\Q$line";
+}
+
+return (1, $self->msg('lockoutuse')) unless $line;
+
+@out = $self->spawn_cmd("show lockout $line", sub {
+                                                       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{lockout}) {
+               if (\$line eq 'ALL' || \$key =~ /^$line/) {
+                       my \$ur = DXUser::get_current(\$key);
+                       if (\$ur && \$ur->lockout) {
+                               push \@val, \$key;
+                               ++\$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;
+                                               });
+
+
 return (1, @out);
 
+