diff options
author | aurynn_cmd <aurynn_cmd@4979c152-3d1c-0410-bac9-87ea11338e46> | 2008-07-11 20:20:58 +0000 |
---|---|---|
committer | aurynn_cmd <aurynn_cmd@4979c152-3d1c-0410-bac9-87ea11338e46> | 2008-07-11 20:20:58 +0000 |
commit | 747c00b6abfb4ba8a687a338ac37448d5595cf87 (patch) | |
tree | 67dadbb20ec3616ed1429d299f62c55bc4d3ae18 /LedgerSMB/DBObject | |
parent | ca5f7b9b2eb6e42d92ca08272aae315b578046ad (diff) |
Re-adding my admin-specific stuff.
git-svn-id: https://ledger-smb.svn.sourceforge.net/svnroot/ledger-smb/trunk@2213 4979c152-3d1c-0410-bac9-87ea11338e46
Diffstat (limited to 'LedgerSMB/DBObject')
-rw-r--r-- | LedgerSMB/DBObject/User.pm | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/LedgerSMB/DBObject/User.pm b/LedgerSMB/DBObject/User.pm new file mode 100644 index 00000000..c84c6336 --- /dev/null +++ b/LedgerSMB/DBObject/User.pm @@ -0,0 +1,80 @@ +package LedgerSMB::DBObject::User; + +use base qw/LedgerSMB::DBObject/; + +sub save { + + my $self = shift @_; + + my $user = $self->get(); + + if ( $user->{id} && $self->{is_a_user} ) { + + # doesn't check for the password - that's done in the sproc. + $self->{id} = shift @{ $self->exec_method(procname=>'admin__save_user', + args=>[$user->{id}, $self->{username}, $self->{password}] ) }; + if (!$self->{id}) { + + return 0; + } + } + elsif ($user && !$self->{is_a_user}) { + + # there WAS a user, and we've decided we want that user to go away now. + + $self->{id} = $user->{id}; + return $self->remove(); + + } + elsif ($self->{is_a_user}) { + + # No user ID, meaning, creating a new one. + $self->{id} = shift @{ $self->exec_method(procname=>'admin__save_user', + args=>[undef, $self->{username}, $self->{password}] ) }; + } + return 1; +} + +sub get { + + my $self = shift @_; + + my ($user_id, $username) = @{ $self->exec_method(procname=>'admin__get_user', + args=>[$self->{id}])}; + + return {id=>$user_id, username=>$username}; +} + +sub remove { + + my $self = shift; + + my $code = $self->exec_method(procname=>"admin__delete_user", args=>[$self->{id}, $self->{username}]); + $self->{id} = undef; # never existed.. + + return $code->[0]; +} + +sub save_prefs { + + my $self = shift @_; + + my $pref_id = $self->exec_method(procname=>"admin__save_preferences", + args=>[ + 'language', + 'stylesheet', + 'printer', + 'dateformat', + 'numberformat' + ] + ); +} + +sub get_all_users { + + my $self = shift @_; + + $self->{users} = $self->exec_method( procname=>"user__get_all_users" ); +} + +1; |