%# BEGIN LICENSE BLOCK %# %# Copyright (c) 1996-2003 Jesse Vincent %# %# (Except where explictly superceded by other copyright notices) %# %# This work is made available to you under the terms of Version 2 of %# the GNU General Public License. A copy of that license should have %# been provided with this software, but in any event can be snarfed %# from www.gnu.org. %# %# This work is distributed in the hope that it will be useful, but %# WITHOUT ANY WARRANTY; without even the implied warranty of %# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU %# General Public License for more details. %# %# Unless otherwise specified, all modifications, corrections or %# extensions to this work which alter its source code become the %# property of Best Practical Solutions, LLC when submitted for %# inclusion in the work. %# %# %# END LICENSE BLOCK <& /Admin/Elements/Header, Title => $title &> <& /Admin/Elements/UserTabs, id => $id, UserObj => $UserObj, current_subtab => $current_tab, Title => $title &> <& /Elements/ListActions, actions => \@results &>
%if ($Create) { % } else { % }
<& /Elements/TitleBoxStart, title => loc('Identity') &>
<&|/l&>Username: <&|/l&>(required)
<&|/l&>Email:
<&|/l&>Real Name:
<&|/l&>Nickname:
<&|/l&>Unix login:
<&|/l&>Extra info:
<& /Elements/TitleBoxEnd &>
<& /Elements/TitleBoxStart, title => loc('Access control') &> > <&|/l&>Let this user access RT
> <&|/l&>Let this user be granted rights
% unless ($RT::WebExternalAuth and !$RT::WebFallbackToInternalAuth) {
<&|/l&>New Password:
<&|/l&>Retype Password:
% } <& /Elements/TitleBoxEnd &>
<& /Elements/TitleBoxStart, title => loc('Location') &>
<&|/l&>Organization:
<&|/l&>Address1:
<&|/l&>Address2:
<&|/l&>City:
<&|/l&>State:
<&|/l&>Zip:
<&|/l&>Country:
<& /Elements/TitleBoxEnd &>
<& /Elements/TitleBoxStart, title => loc('Phone numbers') &>
<&|/l&>Residence:
<&|/l&>Work:
<&|/l&>Mobile:
<&|/l&>Pager:
<& /Elements/TitleBoxEnd &>
<& /Elements/TitleBoxStart, title => loc('Comments about this user') &> <& /Elements/TitleBoxEnd &> %if ($UserObj->Privileged) {
<& /Elements/TitleBoxStart, title => loc('Signature') &> <& /Elements/TitleBoxEnd &> % }
<& /Elements/Submit &>
<%INIT> my $current_tab; my $UserObj = new RT::User($session{'CurrentUser'}); my ($title, $PrivilegedChecked, $EnabledChecked, $Disabled, $result, @results); my ($val, $msg); if ($Create) { $current_tab = 'Admin/Users/Modify.html?Create=1'; $title = loc("Create a new user"); } else { $current_tab = 'Admin/Users/Modify.html?id='.$id; if ($id eq 'new') { ($val, $msg) = $UserObj->Create( Name => $Name, EmailAddress => $ARGS{'EmailAddress'} ); if ($val) { push @results, $msg; } else { push @results, loc('User could not be created: [_1]', $msg); } } else { $UserObj->Load($id) || $UserObj->Load($Name) || Abort("Couldn't load user '$Name'"); $val = $UserObj->Id(); } if ($val) { $title = loc("Modify the user [_1]", $UserObj->Name); } # If the create failed else { $title = loc("Create a new user"); $Create = 1; } } # If we have a user to modify, lets try. if ($UserObj->Id) { my @fields = qw(Name Comments Signature EmailAddress FreeformContactInfo Organization RealName NickName Lang EmailEncoding WebEncoding ExternalContactInfoId ContactInfoSystem Gecos ExternalAuthId AuthSystem HomePhone WorkPhone MobilePhone PagerPhone Address1 Address2 City State Zip Country ); my @fieldresults = UpdateRecordObject ( AttributesRef => \@fields, Object => $UserObj, ARGSRef => \%ARGS ); push (@results,@fieldresults); # {{{ Deal with special fields: Privileged, Enabled and Password if ( ($SetPrivileged) and ( $Privileged != $UserObj->Privileged) ) { my ($code, $msg) = $UserObj->SetPrivileged($Privileged); push @results, loc('Privileged status: [_1]', loc_fuzzy($msg)); } #we're asking about enabled on the web page but really care about disabled. if ($Enabled == 1) { $Disabled = 0; } else { $Disabled = 1; } if ( ($SetEnabled) and ( $Disabled != $UserObj->Disabled) ) { my ($code, $msg) = $UserObj->SetDisabled($Disabled); push @results, loc('Enabled status [_1]', loc_fuzzy($msg)); } #TODO: make this report errors properly if ((defined $Pass1) and ($Pass1 ne '') and ($Pass1 eq $Pass2) and (!$UserObj->IsPassword($Pass1))) { my ($code, $msg); ($code, $msg) = $UserObj->SetPassword($Pass1); push @results, loc('Password: [_1]', loc_fuzzy($msg)); } elsif ( $Pass1 && ($Pass1 ne $Pass2)) { push @results, loc("Passwords do not match."); } # }}} } # {{{ Do some setup for the ui unless ($UserObj->Disabled()) { $EnabledChecked ="CHECKED"; } if ($UserObj->Privileged()) { $PrivilegedChecked = "CHECKED"; } # }}} <%ARGS> $id => undef $Name => undef $Comments => undef $Signature => undef $EmailAddress => undef $FreeformContactInfo => undef $Organization => undef $RealName => undef $NickName => undef $Privileged => undef $SetPrivileged => undef $Enabled => undef $SetEnabled => undef $Lang => undef $EmailEncoding => undef $WebEncoding => undef $ExternalContactInfoId => undef $ContactInfoSystem => undef $Gecos => undef $ExternalAuthId => undef $AuthSystem => undef $HomePhone => undef $WorkPhone => undef $MobilePhone => undef $PagerPhone => undef $Address1 => undef $Address2 => undef $City => undef $State => undef $Zip => undef $Country => undef $Pass1 => undef $Pass2=> undef $Create=> undef