2 # DX cluster user routines
4 # Copyright (c) 1998 - Dirk Koopman G1TLH
14 use MLDBM qw(DB_File);
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,Home Node',
43 lockout => '9,Locked out?,yesno', # won't let them in at all
44 dxok => '9,DX Spots?,yesno', # accept his dx spots?
45 annok => '9,Announces?,yesno', # accept his announces?
46 reg => '0,Registered?,yesno', # is this user registered?
48 hmsgno => '0,Highest Msgno',
57 return if $name =~ /::DESTROY$/;
60 confess "Non-existant field '$AUTOLOAD'" if !$valid{$name};
62 $self->{$name} = shift;
65 return $self->{$name};
69 # initialise the system
75 confess "need a filename in User" if !$fn;
76 $dbm = tie (%u, MLDBM, $fn, O_CREAT|O_RDWR, 0666) or confess "can't open user file: $fn ($!)";
93 # new - create a new user
102 confess "can't create existing call $call in User\n!" if $u{$call};
105 $self->{call} = $call;
114 # get - get an existing user - this seems to return a different reference everytime it is
122 $call =~ s/-\d+$//o; # strip ssid
127 # get all callsigns in the database
132 return (sort keys %u);
136 # get an existing either from the channel (if there is one) or from the database
138 # It is important to note that if you have done a get (for the channel say) and you
139 # want access or modify that you must use this call (and you must NOT use get's all
140 # over the place willy nilly!)
147 $call =~ s/-\d+$//o; # strip ssid
149 my $dxchan = DXChannel->get($call);
150 return $dxchan->user if $dxchan;
161 my $call = $self->{call};
166 # del - delete a user
172 my $call = $self->{call};
177 # close - close down a user
183 $self->{lastin} = time;
188 # return a list of valid elements
197 # return a prompt for a field
202 my ($self, $ele) = @_;
207 # enter an element from input, returns 1 for success
212 my ($self, $ele, $value) = @_;
213 return 0 if (!defined $valid{$ele});
215 return 0 if $value eq "";
216 if ($ele eq 'long') {
217 my ($longd, $longm, $longl) = $value =~ /(\d+) (\d+) ([EWew])/;
218 return 0 if (!$longl || $longd < 0 || $longd > 180 || $longm < 0 || $longm > 59);
219 $longd += ($longm/60);
220 $longd = 0-$longd if (uc $longl) eq 'W';
221 $self->{'long'} = $longd;
223 } elsif ($ele eq 'lat') {
224 my ($latd, $latm, $latl) = $value =~ /(\d+) (\d+) ([NSns])/;
225 return 0 if (!$latl || $latd < 0 || $latd > 90 || $latm < 0 || $latm > 59);
227 $latd = 0-$latd if (uc $latl) eq 'S';
228 $self->{'lat'} = $latd;
230 } elsif ($ele eq 'qra') {
231 $self->{'qra'} = UC $value;
234 $self->{$ele} = $value; # default action
240 # some variable accessors
244 @_ ? $self->{sort} = shift : $self->{sort} ;