%# BEGIN BPS TAGGED BLOCK {{{ %# %# COPYRIGHT: %# %# This software is Copyright (c) 1996-2018 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 &> <& /Elements/Tabs &> <& /Elements/ListActions, actions => \@results &>
%if ($Create) { % } else { % }
<&| /Widgets/TitleBox, title => loc('Identity'), class => 'user-info-identity' &> <& /Elements/EditCustomFields, Object => $UserObj, Grouping => 'Identity', InTable => 1 &>
<&|/l&>Username: <&|/l&>(required)
<&|/l&>Email:
<&|/l&>Real Name:
<&|/l&>Nickname:
<&|/l&>Unix login:
<&|/l&>Language: <& /Elements/SelectLang, Name => 'Lang', Default => $UserObj->Lang//$ARGS{Lang} &>
<&|/l&>Timezone: <& /Elements/SelectTimezone, Name => 'Timezone', Default => $UserObj->Timezone &>
<&|/l&>Extra info:

<&| /Widgets/TitleBox, title => loc('Customers') &> <& /Elements/EditCustomers, Object => $UserObj, CustomerString=> $CustomerString, ServiceString => $ServiceString &>
<&| /Widgets/TitleBox, title => loc('Access control'), class => 'user-info-access-control' &> Id && $UserObj->Disabled) ? '' : 'checked="checked"' |n%> />
% my $PrivilegedChecked = ((!$Create && $UserObj->Privileged()) or (!$UserObj->Id and $ARGS{Privileged})) ? 'checked="checked"' : ''; />
<& /Elements/EditPassword, User => $UserObj, Name => [qw(CurrentPass Pass1 Pass2)], &> <& /Elements/EditCustomFields, Object => $UserObj, Grouping => 'Access control' &> % $m->callback( %ARGS, CallbackName => 'LeftColumnBottom', UserObj => $UserObj );
<&| /Widgets/TitleBox, title => loc('Location'), class => 'user-info-location' &> <& /Elements/EditCustomFields, Object => $UserObj, Grouping => 'Location', InTable => 1 &>
<&|/l&>Organization:
<&|/l&>Address1:
<&|/l&>Address2:
<&|/l&>City:
<&|/l&>State:
<&|/l&>Zip:
<&|/l&>Country:

<&| /Widgets/TitleBox, title => loc('Phone numbers'), class => 'user-info-phones' &> <& /Elements/EditCustomFields, Object => $UserObj, Grouping => 'Phones', InTable => 1 &>
<&|/l&>Residence:
<&|/l&>Work:
<&|/l&>Mobile:
<&|/l&>Pager:

<& /Elements/EditCustomFieldCustomGroupings, Object => $UserObj &> % $m->callback( %ARGS, CallbackName => 'RightColumnBottom', UserObj => $UserObj );
<&| /Widgets/TitleBox, title => loc('Comments about this user'), class => 'user-info-comments' &> %if (!$Create && $UserObj->Privileged) {
<&| /Widgets/TitleBox, title => loc('Signature'), class => 'user-info-signature' &> % }
% if ( $Create ) { <& /Elements/Submit, Label => loc('Create') &> % } else { <& /Elements/Submit, Label => loc('Save Changes') &> % }
<%INIT> my $UserObj = RT::User->new($session{'CurrentUser'}); +my ($title, @results); my ($val, $msg); $ARGS{Privileged} = $ARGS{Privileged} ? 1 : 0; delete $ARGS{Privileged} unless $ARGS{SetPrivileged}; $ARGS{Disabled} = $ARGS{Enabled} ? 0 : 1; delete $ARGS{Disabled} unless $ARGS{SetEnabled}; 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 Timezone ); if ($Create) { $title = loc("Create a new user"); } elsif ( defined $id && $id eq 'new') { ( $val, $msg ) = $UserObj->Create( (map {($_ => $ARGS{$_})} @fields), Privileged => $ARGS{'Privileged'}, Disabled => $ARGS{'Disabled'}, ); if ($val) { push @results, $msg; push @results, ProcessObjectCustomFieldUpdates( ARGSRef => \%ARGS, Object => $UserObj ); $title = loc("Modify the user [_1]", $UserObj->Name); } else { push @results, loc('User could not be created: [_1]', $msg); $title = loc("Create a new user"); $Create = 1; } } else { $UserObj->Load($id) || $UserObj->Load($ARGS{Name}) || Abort("Couldn't load user '" . ( $ARGS{Name} || '') . "'"); $title = loc("Modify the user [_1]", $UserObj->Name); $m->callback( %ARGS, CallbackName => 'BeforeUpdate', User => $UserObj, ARGSRef => \%ARGS, Results => \@results ); my @fieldresults = UpdateRecordObject ( AttributesRef => \@fields, Object => $UserObj, ARGSRef => \%ARGS ); push (@results,@fieldresults); push @results, ProcessObjectCustomFieldUpdates( ARGSRef => \%ARGS, Object => $UserObj ); #deal with freeside customer links push @results, ProcessObjectCustomers( ARGSRef => \%ARGS, Object => $UserObj ); if ( defined $ARGS{Privileged} and $ARGS{Privileged} != ($UserObj->Privileged || 0) ) { my ($code, $msg) = $UserObj->SetPrivileged($ARGS{Privileged}); push @results, loc('Privileged status: [_1]', loc_fuzzy($msg)); } if ( defined $ARGS{Disabled} and $ARGS{Disabled} != $UserObj->Disabled ) { my ($code, $msg) = $UserObj->SetDisabled($ARGS{Disabled}); push @results, $msg; } } if ( $UserObj->Id ) { # Deal with Password field my ($status, $msg) = $UserObj->SafeSetPassword( Current => $CurrentPass, New => $Pass1, Confirmation => $Pass2, ); push @results, $msg; if ( $id eq 'new' && !$status ) { push @results, loc("A password was not set, so user won't be able to login."); } } # This code does automatic redirection if any updates happen. MaybeRedirectForResults( Actions => \@results, Arguments => { id => $UserObj->Id }, ) if $UserObj->Id; <%ARGS> $id => undef $CurrentPass => undef $Pass1 => undef $Pass2 => undef $Create=> undef $OnlySearchForCustomers => undef $OnlySearchForServices => undef $CustomerString => undef $ServiceString => undef