Fix all the DXUser API changes to use JSON
[spider.git] / cmd / show / isolate.pl
index c874e8a8f930f46ef16e818da4de018238dea7af..c16515a3908f46b940771dd11a73308adbc6e192 100644 (file)
@@ -5,27 +5,64 @@
 #
 # Copyright (c) 2000 Dirk Koopman G1TLH
 #
-# $Id$
+#
 #
 
-my ($self, $line) = @_;
-return (1, $self->msg('e5')) unless $self->priv >= 1;
+sub handle
+{
+       my ($self, $line) = @_;
+       return (1, $self->msg('e5')) unless $self->priv >= 1;
 
-my @out;
+       my @out;
 
-use DB_File;
+       if ($self->{_nospawn}) {
+               return (1, generate($self));
+       } else {
+               return (1, $self->spawn_cmd("show/isolate $line", sub { return (generate($self)); }));
+       }
+       
+}
 
-my ($action, $count, $key, $data);
-for ($action = R_FIRST, $count = 0; !$DXUser::dbm->seq($key, $data, $action); $action = R_NEXT) {
-       if ($data =~ m{isolate =>}) {
-               my $u = DXUser->get_current($key);
-               if ($u && $u->isolate) {
-                       push @out, $key;
-                       ++$count;
+sub generate
+{
+       my $self = shift;
+       my @out;
+       my @val;
+                                                       
+#      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{isolate}) {
+#                      my $u = DXUser::get_current($key);
+#                      if ($u && $u->isolate) {
+#                              push @val, $key;
+#                              ++$count;
+#                      }
+#              }
+#      } 
+       @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{"isolate":1} ? $k : ();
+                                               });
+
+       my $count = @val;
+       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;
        }
-} 
 
-return (1, @out, $self->msg('rec', $count));
+       push @out, , $self->msg('rec', $count);
+       return @out;    
+}