Change DXUser->get* to DXUser::get*
[spider.git] / cmd / show / lockout.pl
index 04d1ef12fca5529f62e447b032e0e2b82d7407cd..91ae4f4ae7ab87fc84943a03673db98386a342b2 100644 (file)
@@ -5,7 +5,7 @@
 #
 # Copyright (c) 2000 Dirk Koopman G1TLH
 #
-# $Id$
+#
 #
 
 my ($self, $line) = @_;
@@ -15,16 +15,27 @@ my @out;
 
 use DB_File;
 
+if ($line) {
+       $line =~ s/[^\w\-\/]+//g;
+       $line = "\U\Q$line";
+}
+
+return (1, $self->msg('lockoutuse')) unless $line;
+
 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{lockout =>}) {
-               my $u = DXUser->get_current($key);
-               if ($u && $u->lockout) {
-                       push @out, $key;
-                       ++$count;
+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 \@out, \$key;
+                               ++\$count;
+                       }
                }
        }
-} 
+} };
+
+push @out, $@ if $@;
 
 return (1, @out, $self->msg('rec', $count));