fix sh/registered
authorDirk Koopman <djk@tobit.co.uk>
Mon, 6 Dec 2021 21:18:27 +0000 (21:18 +0000)
committerDirk Koopman <djk@tobit.co.uk>
Mon, 6 Dec 2021 21:18:27 +0000 (21:18 +0000)
Changes
cmd/set/register.pl
cmd/show/registered.pl
connect/gb7tlh

diff --git a/Changes b/Changes
index af509b483c8cddd9ba42e5182339f7f8fdce6b6f..ef0d371c69e1c8a33761731577f0d05e5a26dc2e 100644 (file)
--- a/Changes
+++ b/Changes
@@ -1,3 +1,6 @@
+06Dec21=======================================================================
+1. Fix show/register to allow query of individual calls as well as get a 
+   complete list.
 15Jul21=======================================================================
 1. Fix long standing bug in crontabs that commands with " rather than ' around
    strings could cause those commands not to work. 
index ac96c2a4f6c40c8329c1542b81eb264ce627a88d..edcf1acd28c917143c0e773ad76f7bcd4d65d88c 100644 (file)
@@ -17,7 +17,7 @@ if ($self->priv < 9) {
        Log('DXCommand', $self->call . " attempted to register @args");
        return (1, $self->msg('e5'));
 }
-return (1, $self->msg('reginac')) unless $main::reqreg;
+#return (1, $self->msg('reginac')) unless $main::reqreg;
 
 foreach $call (@args) {
        $call = uc $call;
index 5eb6d78d7264ce670582e9a728e9660ab493b9a2..929d014da692765bd5b4075a85029812afab03be 100644 (file)
@@ -12,29 +12,50 @@ my ($self, $line) = @_;
 return (1, $self->msg('e5')) unless $self->priv >= 9;
 
 my @out;
+my @val;
 
 use DB_File;
 
 if ($line) {
        $line =~ s/[^\w\-\/]+//g;
-       $line = "^\U\Q$line";
+       $line = "\U\Q$line";
 }
 
+my %call = ();
+$call{$_} = 1 for split /\s+/, $line;
+delete $call{'ALL'};
+
 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 \@out, \$key;
-                               ++\$count;
-                       }
+unless (keys %call) {
+       for ($action = DXUser::R_FIRST, $count = 0; !$DXUser::dbm->seq($key, $data, $action); $action = DXUser::R_NEXT) {
+               if ($data =~ m{registered}) {
+                       $call{$key} = 1;       # possible candidate
                }
        }
-} };
+}
+
+foreach $key (sort keys %call) {
+       my $u = DXUser::get_current($key);
+       if ($u && $u->registered) {
+               push @val, $key;
+               ++$count;
+       }
+}
 
-push @out, $@ if $@;
+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 (1, @out);
 
 
index 15b419a33126491b414c333cc437cc09a9670d53..48c45f50273e08b32c4fb4ad6b5bd34f2823a9b8 100644 (file)
@@ -1,8 +1,3 @@
 timeout 15
-abort (Busy|Sorry|Fail)
-# don't forget to chmod 4775 netrom_call!
-connect ax25 /usr/sbin/netrom_call bbs gb7djk g1tlh-0
-'Connect' ''
-'Connect' 'ak1a'
-'Connect'  ''
-client gb7tlh ax25
+connect telnet dirk7.int.tobit.co.uk 7300
+'ogin:' 'gb7tlh-1'