1. Incorporated sh/st, (un)set/lockout, forward/opername from Iain G0RDI
[spider.git] / perl / DXChannel.pm
index 3eb387efaea99492f3038a555589d451e6ee74a7..640bc4e5345bbf1800a4ee4590cac543666bc462 100644 (file)
@@ -60,7 +60,13 @@ use vars qw(%channels %valid);
   lang => '0,Language',
   func => '9,Function',
   loc => '9,Local Vars',     # used by func to store local variables in
+  beep => '0,Want Beeps,yesno',
   lastread => '9,Last Msg Read',
+  outbound => '9,outbound?,yesno',
+  remotecmd => '9,doing rcmd,yesno',
+  pagelth => '0,Page Length',
+  pagedata => '9,Page Data Store',
+  group => '0,Access Group,parray',               # used to create a group of users/nodes for some purpose or other
 );
 
 # create a new channel object [$obj = DXChannel->new($call, $msg_conn_obj, $user_obj)]
@@ -78,6 +84,8 @@ sub alloc
   $self->{oldstate} = 0;
   $self->{lang} = $user->{lang} if defined $user;
   $self->{lang} = $main::lang if !$self->{lang};
+  $user->new_group() if !$user->group;
+  $self->{group} = $user->group;
   bless $self, $pkg; 
   return $channels{$call} = $self;
 }
@@ -112,6 +120,7 @@ sub get_by_cnum
 sub del
 {
   my $self = shift;
+  $self->{group} = undef;      # belt and braces
   delete $channels{$self->{call}};
 }
 
@@ -148,8 +157,8 @@ sub send_now
        
   foreach $line (@_) {
     chomp $line;
-       dbg('chan', "-> $sort $call $line\n") if $conn;
        $conn->send_now("$sort$call|$line") if $conn;
+       dbg('chan', "-> $sort $call $line") if $conn;
   }
   $self->{t} = time;
 }
@@ -166,8 +175,8 @@ sub send              # this is always later and always data
 
   foreach $line (@_) {
     chomp $line;
-       dbg('chan', "-> D $call $line\n") if $conn;
        $conn->send_later("D$call|$line") if $conn;
+       dbg('chan', "-> D $call $line") if $conn;
   }
   $self->{t} = time;
 }