%# BEGIN BPS TAGGED BLOCK {{{ %# %# COPYRIGHT: %# %# This software is Copyright (c) 1996-2009 Best Practical Solutions, LLC %# %# %# (Except where explicitly superseded by other copyright notices) %# %# %# LICENSE: %# %# 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. %# %# You should have received a copy of the GNU General Public License %# along with this program; if not, write to the Free Software %# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA %# 02110-1301 or visit their web page on the internet at %# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html. %# %# %# CONTRIBUTION SUBMISSION POLICY: %# %# (The following paragraph is not intended to limit the rights granted %# to you to modify and distribute this software under the terms of %# the GNU General Public License and is only of importance to you if %# you choose to contribute your changes and enhancements to the %# community by submitting them to Best Practical Solutions, LLC.) %# %# By intentionally submitting any modifications, corrections or %# derivatives to this work, or any other work intended for use with %# Request Tracker, to Best Practical Solutions, LLC, you confirm that %# you are the copyright holder for those contributions and you grant %# Best Practical Solutions, LLC a nonexclusive, worldwide, irrevocable, %# royalty-free, perpetual, license to use, copy, create derivative %# works based on those contributions, and sublicense and distribute %# those contributions and any derivatives thereof. %# %# END BPS TAGGED BLOCK }}} <& /Admin/Elements/Header, Title => $title &> <& /Admin/Elements/UserTabs, id => $id, UserObj => $UserObj, current_tab => $current_tab, Title => $title &> <& /Elements/ListActions, actions => \@results &>
%if ($Create) { % } else { % }
<&| /Widgets/TitleBox, title => loc('Identity') &>
<&|/l&>Username: <&|/l&>(required)
<&|/l&>Email:
<&|/l&>Real Name:
<&|/l&>Nickname:
<&|/l&>Unix login:
<&|/l&>Language: <& /Elements/SelectLang, Name => 'Lang', Default => $UserObj->Lang &>
<&|/l&>Extra info:

<&| /Widgets/TitleBox, 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/Callback, _CallbackName => 'LeftColumnBottom', UserObj => $UserObj, %ARGS &>
<&| /Widgets/TitleBox, title => loc('Location') &>
<&|/l&>Organization:
<&|/l&>Address1:
<&|/l&>Address2:
<&|/l&>City:
<&|/l&>State:
<&|/l&>Zip:
<&|/l&>Country:

<&| /Widgets/TitleBox, title => loc('Phone numbers') &>
<&|/l&>Residence:
<&|/l&>Work:
<&|/l&>Mobile:
<&|/l&>Pager:

<&| /Widgets/TitleBox, title => loc('Custom Fields') &> % my $CFs = $UserObj->CustomFields; % while (my $CF = $CFs->Next) { % }
<% $CF->Name %>: % if ($UserObj->id) { <& /Elements/EditCustomField, %ARGS, Object => $UserObj, CustomField => $CF &> % } else { <& /Elements/EditCustomField, %ARGS, NamePrefix => 'Object-RT::User-new-CustomField-', CustomField => $CF &> % }
<& /Elements/Callback, _CallbackName => 'RightColumnBottom', UserObj => $UserObj, %ARGS &>
<&| /Widgets/TitleBox, title => loc('Comments about this user') &> %if ($UserObj->Privileged) {
<&| /Widgets/TitleBox, title => loc('Signature') &> % }
<& /Elements/Submit, Label => loc('Save Changes') &>
<%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'}, Name => $ARGS{'Name'}, Comments => $ARGS{'Comments'}, Signature => $ARGS{'Signature'}, EmailAddress => $ARGS{'EmailAddress'}, FreeformContactInfo => $ARGS{'FreeformContactInfo'}, Organization => $ARGS{'Organization'}, RealName => $ARGS{'RealName'}, NickName => $ARGS{'NickName'}, Lang => $ARGS{'Lang'}, EmailEncoding => $ARGS{'EmailEncoding'}, WebEncoding => $ARGS{'WebEncoding'}, ExternalContactInfoId => $ARGS{'ExternalContactInfoId'}, ContactInfoSystem => $ARGS{'ContactInfoSystem'}, Gecos => $ARGS{'Gecos'}, ExternalAuthId => $ARGS{'ExternalAuthId'}, AuthSystem => $ARGS{'AuthSystem'}, HomePhone => $ARGS{'HomePhone'}, WorkPhone => $ARGS{'WorkPhone'}, MobilePhone => $ARGS{'MobilePhone'}, PagerPhone => $ARGS{'PagerPhone'}, Address1 => $ARGS{'Address1'}, Address2 => $ARGS{'Address2'}, City => $ARGS{'City'}, State => $ARGS{'State'}, Zip => $ARGS{'Zip'}, Country => $ARGS{'Country'}, Privileged => $ARGS{'Privileged'}, Disabled => ($ARGS{'Enabled'} ? 0 : 1) ); if ($val) { push @results, $msg; foreach my $key ( keys %ARGS) { # Convert custom fields on the "new" object to custom fields on the one we've just created if ($key =~ /^Object-RT::User-new-CustomField-(.*)$/) { $ARGS{'Object-RT::User-'.$val.'-CustomField-'.$1} = delete $ARGS{$key}; } } push @results, ProcessObjectCustomFieldUpdates( ARGSRef => \%ARGS, Object => $UserObj ); } 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 && $id ne 'new') { 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); push @results, ProcessObjectCustomFieldUpdates( ARGSRef => \%ARGS, Object => $UserObj ); # {{{ Deal with special fields: Privileged, Enabled 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. $Disabled = $Enabled ? 0 : 1; if ( ($SetEnabled) and ( $Disabled != $UserObj->Disabled) ) { my ($code, $msg) = $UserObj->SetDisabled($Disabled); push @results, loc('Enabled status [_1]', loc_fuzzy($msg)); } # }}} } if ( $UserObj->Id ) { my $password_not_set; # Deal with Password field if ( !$Pass1 and !$Pass2 ) { $password_not_set = 1; } elsif ( $Pass1 ne $Pass2 ) { $password_not_set = 1; push @results, loc("Passwords do not match."); } elsif ( $Pass1 eq $Pass2 and !$UserObj->IsPassword($Pass1) ) { my ($code, $msg) = $UserObj->SetPassword($Pass1); push @results, loc_fuzzy($msg); $password_not_set = 1 unless $code; } if ($id eq 'new' and $password_not_set) { push @results, loc("A password was not set, so user won't be able to login."); } } # {{{ Do some setup for the ui unless ($UserObj->Disabled()) { $EnabledChecked ="CHECKED"; } if ($UserObj->Privileged()) { $PrivilegedChecked = "CHECKED"; } # }}} # set the id, so the the menu will have the right info, this needs to # be done here to avoid creating and then modifying a user $id = $UserObj->Id; <%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