#
# Copyright (c) 2000 Dirk Koopman G1TLH
#
-# $Id$
+#
#
my ($self, $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}) {
- if ($line eq 'ALL' || $key =~ /$line/) {
- my $ur = DXUser->get_current($key);
- if ($ur && $ur->lockout) {
- push @out, $key;
- ++$count;
+@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;
}
}
}
-}
-
-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;
+ });
+
+
+return (1, @out);