1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
%# BEGIN LICENSE BLOCK
%#
%# Copyright (c) 1996-2003 Jesse Vincent <jesse@bestpractical.com>
%#
%# (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
<& /SelfService/Elements/Header, Title => loc('Preferences') &>
<& /Elements/ListActions, actions => \@results &>
<form method=post>
% unless ($RT::WebExternalAuth and !$RT::WebFallbackToInternalAuth) {
<& /Elements/TitleBoxStart, title => loc('Change password') &>
<&|/l&>New password</&>: <input type=password name="NewPass1" size=16>
<&|/l&>Confirm</&>: <input type=password name="NewPass2" size=16>
<& /Elements/TitleBoxEnd &>
<BR>
% }
<& /Elements/Submit, Label => loc('Save Changes') &>
</form>
<%INIT>
my @results;
if ($NewPass1) {
if ($NewPass1 ne $NewPass2) {
push (@results, "Passwords did not match.");
}
else {
my ($val, $msg)=$session{'CurrentUser'}->UserObj->SetPassword($NewPass1);
push (@results, "Password: ".$msg);
}
}
if ($Signature) {
$Signature =~ s/(\r\n|\r)/\n/g;
if ($Signature ne $session{'CurrentUser'}->UserObj->Signature) {
my ($val, $msg)=$session{'CurrentUser'}->UserObj->SetSignature($Signature);
push (@results, "Signature: ".$msg);
}
}
#A hack to make sure that session gets rewritten.
$session{'i'}++;
</%INIT>
<%ARGS>
$Signature => undef
$NewPass1 => undef
$NewPass2 => undef
</%ARGS>
|