diff options
Diffstat (limited to 'rt/lib/RT/CurrentUser.pm')
| -rwxr-xr-x | rt/lib/RT/CurrentUser.pm | 270 | 
1 files changed, 270 insertions, 0 deletions
| diff --git a/rt/lib/RT/CurrentUser.pm b/rt/lib/RT/CurrentUser.pm new file mode 100755 index 000000000..6997ddbac --- /dev/null +++ b/rt/lib/RT/CurrentUser.pm @@ -0,0 +1,270 @@ +# $Header: /home/cvs/cvsroot/freeside/rt/lib/RT/CurrentUser.pm,v 1.1 2002-08-12 06:17:07 ivan Exp $ +# (c) 1996-1999 Jesse Vincent <jesse@fsck.com> +# This software is redistributable under the terms of the GNU GPL + +=head1 NAME + +  RT::CurrentUser - an RT object representing the current user + +=head1 SYNOPSIS + +  use RT::CurrentUser + + +=head1 DESCRIPTION + + +=head1 METHODS + + +=begin testing + +ok (require RT::TestHarness); +ok (require RT::CurrentUser); + +=end testing + +=cut + + +package RT::CurrentUser; +use RT::Record; +@ISA= qw(RT::Record); + + +# {{{ sub _Init  + +#The basic idea here is that $self->CurrentUser is always supposed +# to be a CurrentUser object. but that's hard to do when we're trying to load +# the CurrentUser object + +sub _Init  { +  my $self = shift; +  my $Name = shift; + +  $self->{'table'} = "Users"; + +  if (defined($Name)) { +    $self->Load($Name); +  } +   +  $self->_MyCurrentUser($self); + +} +# }}} + +# {{{ sub Create + +sub Create { +    return (0, 'Permission Denied'); +} + +# }}} + +# {{{ sub Delete + +sub Delete { +    return (0, 'Permission Denied'); +} + +# }}} + +# {{{ sub UserObj + +=head2 UserObj + +  Returns the RT::User object associated with this CurrentUser object. + +=cut + +sub UserObj { +    my $self = shift; +     +    unless ($self->{'UserObj'}) { +	use RT::User; +	$self->{'UserObj'} = RT::User->new($self); +	unless ($self->{'UserObj'}->Load($self->Id)) { +	    $RT::Logger->err("Couldn't load ".$self->Id. "from the users database.\n"); +	} +	 +    } +    return ($self->{'UserObj'}); +} +# }}} + +# {{{ sub _Accessible  +sub _Accessible  { +  my $self = shift; +  my %Cols = ( +	      Name => 'read', +	      Gecos => 'read', +	      RealName => 'read', +	      Password => 'neither', +	      EmailAddress => 'read', +	      Privileged => 'read', +	      IsAdministrator => 'read' +	     ); +  return($self->SUPER::_Accessible(@_, %Cols)); +} +# }}} + +# {{{ sub LoadByEmail + +=head2 LoadByEmail + +Loads a User into this CurrentUser object. +Takes the email address of the user to load. + +=cut + +sub LoadByEmail  { +    my $self = shift; +    my $identifier = shift; +         +    $self->LoadByCol("EmailAddress",$identifier); +     +} +# }}} + +# {{{ sub LoadByGecos + +=head2 LoadByGecos + +Loads a User into this CurrentUser object. +Takes a unix username as its only argument. + +=cut + +sub LoadByGecos  { +    my $self = shift; +    my $identifier = shift; +         +    $self->LoadByCol("Gecos",$identifier); +     +} +# }}} + +# {{{ sub LoadByName + +=head2 LoadByName + +Loads a User into this CurrentUser object. +Takes a Name. +=cut + +sub LoadByName { +    my $self = shift; +    my $identifier = shift; +    $self->LoadByCol("Name",$identifier); +     +} +# }}} + +# {{{ sub Load  + +=head2 Load + +Loads a User into this CurrentUser object. +Takes either an integer (users id column reference) or a Name +The latter is deprecated. Instead, you should use LoadByName. +Formerly, this routine also took email addresses.  + +=cut + +sub Load  { +  my $self = shift; +  my $identifier = shift; + +  #if it's an int, load by id. otherwise, load by name. +  if ($identifier !~ /\D/) { +    $self->SUPER::LoadById($identifier); +  } +  else { +      # This is a bit dangerous, we might get false authen if somebody +      # uses ambigous userids or real names: +      $self->LoadByCol("Name",$identifier); +  } +} + +# }}} + +# {{{ sub IsPassword + +=head2 IsPassword + +Takes a password as a string.  Passes it off to IsPassword in this +user's UserObj.  If it is the user's password and the user isn't +disabled, returns 1. + +Otherwise, returns undef. + +=cut + +sub IsPassword {  +  my $self = shift; +  my $value = shift; +   +  return ($self->UserObj->IsPassword($value));  +} + +# }}} + +# {{{ sub Privileged + +=head2 Privileged + +Returns true if the current user can be granted rights and be +a member of groups. + +=cut + +sub Privileged { +    my $self = shift; +    return ($self->UserObj->Privileged()); +} + +# }}} + +# {{{ Convenient ACL methods + +=head2 HasQueueRight + +calls $self->UserObj->HasQueueRight with the arguments passed in + +=cut + +sub HasQueueRight { +	my $self = shift; +	return ($self->UserObj->HasQueueRight(@_)); +} + +=head2 HasSystemRight + +calls $self->UserObj->HasSystemRight with the arguments passed in + +=cut + + +sub HasSystemRight { +	my $self = shift; +	return ($self->UserObj->HasSystemRight(@_)); +} +# }}} + +# {{{ sub HasRight + +=head2 HasSystemRight + +calls $self->UserObj->HasRight with the arguments passed in + +=cut + +sub HasRight { +  my $self = shift; +  return ($self->UserObj->HasRight(@_)); +} + +# }}} + +1; +  | 
