2 # DX cluster user routines
4 # Copyright (c) 1998 - Dirk Koopman G1TLH
19 use vars qw(%u $dbm $filename %valid);
25 # hash of valid elements and a simple prompt
28 alias => '0,Real Callsign',
31 lat => '0,Latitude,slat',
32 long => '0,Longitude,slong',
34 email => '0,E-mail Address',
35 priv => '9,Privilege Level',
36 lastin => '0,Last Time in,cldatetime',
37 passwd => '9,Password',
38 addr => '0,Full Address',
39 'sort' => '0,Type of User', # A - ak1a, U - User, S - spider cluster, B - BBS
40 xpert => '0,Expert Status,yesno',
42 node => '0,Last Node',
43 homenode => '0,Home Node',
44 lockout => '9,Locked out?,yesno', # won't let them in at all
45 dxok => '9,DX Spots?,yesno', # accept his dx spots?
46 annok => '9,Announces?,yesno', # accept his announces?
47 reg => '0,Registered?,yesno', # is this user registered?
49 hmsgno => '0,Highest Msgno',
50 group => '0,Access Group,parray', # used to create a group of users/nodes for some purpose or other
51 isolate => '9,Isolate network,yesno',
60 return if $name =~ /::DESTROY$/;
63 confess "Non-existant field '$AUTOLOAD'" if !$valid{$name};
65 $self->{$name} = shift;
68 return $self->{$name};
72 # initialise the system
76 my ($pkg, $fn, $mode) = @_;
78 confess "need a filename in User" if !$fn;
81 $dbm = tie (%u, 'DB_File', $fn, O_CREAT|O_RDWR, 0666, $DB_BTREE) or confess "can't open user file: $fn ($!)";
83 $dbm = tie (%u, 'DB_File', $fn, O_RDONLY, 0666, $DB_BTREE) or confess "can't open user file: $fn ($!)";
102 # new - create a new user
109 # $call =~ s/-\d+$//o;
111 confess "can't create existing call $call in User\n!" if $u{$call};
113 my $self = bless {}, $pkg;
114 $self->{call} = $call;
115 $self->{'sort'} = 'U';
118 $self->{lang} = $main::lang;
119 $u{call} = $self->encode();
124 # get - get an existing user - this seems to return a different reference everytime it is
132 # $call =~ s/-\d+$//o; # strip ssid
134 return $s ? decode($s) : undef;
138 # get all callsigns in the database
143 return (sort keys %u);
147 # get an existing either from the channel (if there is one) or from the database
149 # It is important to note that if you have done a get (for the channel say) and you
150 # want access or modify that you must use this call (and you must NOT use get's all
151 # over the place willy nilly!)
158 # $call =~ s/-\d+$//o; # strip ssid
160 my $dxchan = DXChannel->get($call);
161 return $dxchan->user if $dxchan;
163 return $s ? decode($s) : undef;
173 my $call = $self->{call};
174 $u{$call} = $self->encode();
178 # create a string from a user reference
187 for $f (sort keys %$self) {
188 my $val = $$self{$f};
189 if (ref $val) { # it's an array (we think)
199 $out .= "'$f'=>q{$val},";
202 $out .= " }, 'DXUser')";
207 # create a hash from a string
220 # del - delete a user
226 my $call = $self->{call};
231 # close - close down a user
237 $self->{lastin} = time;
242 # return a list of valid elements
254 # add one or more groups
258 my $ref = $self->{group} || [ 'local' ];
259 $self->{group} = $ref if !$self->{group};
260 push @$ref, @_ if @_;
263 # remove one or more groups
267 my $ref = $self->{group} || [ 'local' ];
270 $self->{group} = $ref if !$self->{group};
272 @$ref = map { my $a = $_; return (grep { $_ eq $a } @in) ? () : $a } @$ref;
275 # does this thing contain all the groups listed?
279 my $ref = $self->{group};
282 return 0 if !$ref || @_ == 0;
283 return 1 if @$ref == 0 && @_ == 0;
284 for ($n = 0; $n < @_; ) {
287 $n++ if grep $_ eq $a, @_;
293 # simplified group test just for one group
298 my $ref = $self->{group};
301 return grep $_ eq $s, $ref;
304 # set up a default group (only happens for them's that connect direct)
308 $self->{group} = [ 'local' ];
312 # return a prompt for a field
317 my ($self, $ele) = @_;
321 # some variable accessors
325 @_ ? $self->{'sort'} = shift : $self->{'sort'} ;