-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;
+# }
+# }
+# }
+ #} };
+ my $count;
+ 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{"registered":1} ? $k : ();
+ });
+ } else {
+ for my $call (split /\s+/, $line) {
+ my $l = DXUser::get($call, 1);
+ next unless $l;
+ next unless $l =~ m{"registered":1};
+ push @val, $call;