summaryrefslogtreecommitdiffstats
path: root/install/ui
diff options
context:
space:
mode:
authorEndi S. Dewata <edewata@redhat.com>2011-11-04 13:48:22 -0500
committerMartin Kosek <mkosek@redhat.com>2011-11-07 14:18:25 +0100
commit2eb6414372581655ba04dff7539294c75f84a281 (patch)
tree78763ef2892732ed384cc422680e1c7f35d63540 /install/ui
parent08137836a3ddce17aa5d383a02d177d35b3df266 (diff)
downloadfreeipa-2eb6414372581655ba04dff7539294c75f84a281.tar.gz
freeipa-2eb6414372581655ba04dff7539294c75f84a281.tar.xz
freeipa-2eb6414372581655ba04dff7539294c75f84a281.zip
Added current password field.
The reset password dialog for user has been modified to provide a field to specify the current password when changing the user's own password. Ticket #2065
Diffstat (limited to 'install/ui')
-rw-r--r--install/ui/test/data/ipa_init.json2
-rw-r--r--install/ui/user.js34
2 files changed, 30 insertions, 6 deletions
diff --git a/install/ui/test/data/ipa_init.json b/install/ui/test/data/ipa_init.json
index 5ba1ad1f5..75f3793d2 100644
--- a/install/ui/test/data/ipa_init.json
+++ b/install/ui/test/data/ipa_init.json
@@ -330,6 +330,8 @@
}
},
"password": {
+ "current_password": "Current Password",
+ "current_password_required": "Current password is required",
"new_password": "New Password",
"password_change_complete": "Password change complete",
"password_must_match": "Passwords must match",
diff --git a/install/ui/user.js b/install/ui/user.js
index 8207bf091..a0949d794 100644
--- a/install/ui/user.js
+++ b/install/ui/user.js
@@ -382,18 +382,29 @@ IPA.user_password_widget = function(spec) {
that.show_dialog = function() {
+ that.pkey = IPA.nav.get_state('user-pkey');
+ that.self_service = that.pkey === IPA.whoami.uid[0];
+
var dialog = IPA.dialog({
title: IPA.messages.password.reset_password,
width: 400
});
- var password1 = dialog.add_field(IPA.text_widget({
+ if (that.self_service) {
+ dialog.add_field(IPA.text_widget({
+ name: 'current_password',
+ label: IPA.messages.password.current_password,
+ type: 'password'
+ }));
+ }
+
+ dialog.add_field(IPA.text_widget({
name: 'password1',
label: IPA.messages.password.new_password,
type: 'password'
}));
- var password2 = dialog.add_field(IPA.text_widget({
+ dialog.add_field(IPA.text_widget({
name: 'password2',
label: IPA.messages.password.verify_password,
type: 'password'
@@ -407,6 +418,16 @@ IPA.user_password_widget = function(spec) {
var record = {};
dialog.save(record);
+ var current_password;
+
+ if (that.self_service) {
+ current_password = record.current_password[0];
+ if (!current_password) {
+ alert(IPA.messages.password.current_password_required);
+ return;
+ }
+ }
+
var new_password = record.password1[0];
var repeat_password = record.password2[0];
@@ -416,6 +437,7 @@ IPA.user_password_widget = function(spec) {
}
that.set_password(
+ current_password,
new_password,
function(data, text_status, xhr) {
alert(IPA.messages.password.password_change_complete);
@@ -439,20 +461,20 @@ IPA.user_password_widget = function(spec) {
dialog.open(that.container);
};
- that.set_password = function(password, on_success, on_error) {
- var user_pkey = IPA.nav.get_state('user-pkey');
+ that.set_password = function(current_password, password, on_success, on_error) {
var args;
- if (user_pkey === IPA.whoami.uid[0]) {
+ if (that.self_service) {
args = [];
} else {
- args = [user_pkey];
+ args = [that.pkey];
}
var command = IPA.command({
method: 'passwd',
args: args,
options: {
+ current_password: current_password,
password: password
},
on_success: on_success,