-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 && $key =~ /$line/) {
- my $u = DXUser->get_current($key);
- if ($u && $u->lockout) {
- 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{lockout}) {
+ # if (\$line eq 'ALL' || \$key =~ /^$line/) {
+ # my \$ur = DXUser::get_current(\$key);
+ # if (\$ur && \$ur->lockout) {
+ # push \@val, \$key;
+ # ++\$count;
+ # }
+ # }
+ # }
+
+# $DB::single = 1;
+
+ my @val;
+ if ($line eq 'ALL') {
+ @val = DXUser::scan(sub {
+ my $k = shift;
+ my $l = shift;
+ # cheat, don't decode because we can easily pull it out from the json test
+ return $l =~ m{"lockout":1} ? $k : ();
+ });
+
+ } else {
+ for my $call (split /\s+/, $line) {
+ my $l = DXUser::get($call, 1);
+ next unless $l;
+ next unless $l =~ m{"lockout":1};
+ push @val, $call;