X-Git-Url: http://www.dxcluster.org/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2FDXUser.pm;h=f5f7e0491f561351c0a146c5c98cdbcf3b1993b6;hb=6b6a8002929017b6d4217f68fa492a2d728ee1fe;hp=60abaeda3098f77598b67e2603f33790c3661c75;hpb=60c0ea1747bc8ad95e531d29025f7bcee4fd10c1;p=spider.git diff --git a/perl/DXUser.pm b/perl/DXUser.pm index 60abaeda..f5f7e049 100644 --- a/perl/DXUser.pm +++ b/perl/DXUser.pm @@ -29,12 +29,24 @@ $filename = undef; qra => 'Locator', email => 'E-mail Address', priv => 'Privilege Level', - sort => 'Type of User', lastin => 'Last Time in', passwd => 'Password', - addr => 'Full Address' + addr => 'Full Address', + 'sort' => 'Type of User', # A - ak1a, U - User, S - spider cluster, B - BBS ); +sub AUTOLOAD +{ + my $self = shift; + my $name = $AUTOLOAD; + + return if $name =~ /::DESTROY$/; + $name =~ s/.*:://o; + + die "Non-existant field '$AUTOLOAD'" if !$valid{$name}; + @_ ? $self->{$name} = shift : $self->{$name} ; +} + # # initialise the system # @@ -42,8 +54,8 @@ sub init { my ($pkg, $fn) = @_; - die "need a filename in User\n" if !$fn; - $dbm = tie %u, MLDBM, $fn, O_CREAT|O_RDWR, 0666 or die "can't open user file: $fn ($!)\n"; + die "need a filename in User" if !$fn; + $dbm = tie %u, MLDBM, $fn, O_CREAT|O_RDWR, 0666 or die "can't open user file: $fn ($!)"; $filename = $fn; } @@ -78,7 +90,7 @@ sub new sub get { - my $call = shift; + my ($pkg, $call) = @_; return $u{$call}; } @@ -119,19 +131,19 @@ sub close # return a list of valid elements # -sub elements +sub fields { return keys(%valid); } # -# return a prompt together with the existing value +# return a prompt for a field # -sub prompt +sub field_prompt { my ($self, $ele) = @_; - return "$valid{$ele} [$self->{$ele}]"; + return $valid{$ele}; } # @@ -167,5 +179,12 @@ sub enter } return 0; } + +# some variable accessors +sub sort +{ + my $self = shift; + @_ ? $self->{sort} = shift : $self->{sort} ; +} 1; __END__