diff options
author | Petr Vobornik <pvoborni@redhat.com> | 2012-04-16 12:22:34 +0200 |
---|---|---|
committer | Rob Crittenden <rcritten@redhat.com> | 2012-04-16 21:53:56 -0400 |
commit | c64bcafa137474cf31cd99e7cd6c28a00add85ff (patch) | |
tree | b02bf5514d24d35f51d713ad453f1e8e60321dd2 /install/ui/login.js | |
parent | 7b515bddbcec2499fb765be311b3d093edcf6db2 (diff) | |
download | freeipa-c64bcafa137474cf31cd99e7cd6c28a00add85ff.tar.gz freeipa-c64bcafa137474cf31cd99e7cd6c28a00add85ff.tar.xz freeipa-c64bcafa137474cf31cd99e7cd6c28a00add85ff.zip |
User is notified that password needs to be reset in forms-based login
Forms-based login procedure detects if 401 unauthorized response contains
'X-IPA-Rejection-Reason' http header with 'password-expired' value. If so
it displays an error message that user needs to reset his password.
https://fedorahosted.org/freeipa/ticket/2608
Diffstat (limited to 'install/ui/login.js')
-rw-r--r-- | install/ui/login.js | 39 |
1 files changed, 30 insertions, 9 deletions
diff --git a/install/ui/login.js b/install/ui/login.js index 68b16bce1..cd4e72d95 100644 --- a/install/ui/login.js +++ b/install/ui/login.js @@ -22,10 +22,23 @@ var LP = {}; //Login Page LP.login = function(username, password) { - var success = false; + var result = 'invalid'; function success_handler(data, text_status, xhr) { - success = true; + result = 'success'; + } + + function error_handler(xhr, text_status, error_thrown) { + + if (xhr.status === 401) { + var reason = xhr.getResponseHeader("X-IPA-Rejection-Reason"); + + //change result from invalid only if we have a header which we + //understand + if (reason === 'password-expired') { + result = 'expired'; + } + } } var data = { @@ -36,14 +49,18 @@ LP.login = function(username, password) { var request = { url: '/ipa/session/login_password', data: data, + contentType: 'application/x-www-form-urlencoded', + processData: true, + dataType: 'html', async: false, - type: "POST", - success: success_handler + type: 'POST', + success: success_handler, + error: error_handler }; $.ajax(request); - return success; + return result; }; LP.on_submit = function() { @@ -51,10 +68,14 @@ LP.on_submit = function() { var username = $('input[name=username]', LP.form).val(); var password = $('input[name=password]', LP.form).val(); - var success = LP.login(username, password); + var result = LP.login(username, password); - if (!success) { - $('#error-box').css('display', 'block'); + if (result === 'invalid') { + $('#expired').css('display', 'none'); + $('#invalid').css('display', 'block'); + } else if (result === 'expired') { + $('#invalid').css('display', 'none'); + $('#expired').css('display', 'block'); } else { window.location = '/ipa/ui'; } @@ -73,4 +94,4 @@ LP.init = function() { /* main (document onready event handler) */ $(function() { LP.init(); -});
\ No newline at end of file +}); |