diff options
| author | Azul <azul@leap.se> | 2012-11-22 13:05:32 +0100 | 
|---|---|---|
| committer | Azul <azul@leap.se> | 2012-11-22 13:05:32 +0100 | 
| commit | 6d5f8d0f993093b51d1f11bb528c535dcf88a969 (patch) | |
| tree | 6664d69537dae7c1a9a60972a1ce2e3dc9e43031 | |
| parent | cec9ad7c514f2f3c767bd12bfc3df28db4d1a98b (diff) | |
beautify login workflow
* translating error messages
* not caching login and password in js anymore
* catching non responses
| m--------- | users/app/assets/javascripts/srp | 0 | ||||
| -rw-r--r-- | users/app/assets/javascripts/users.js.coffee | 6 | ||||
| -rw-r--r-- | users/app/controllers/controller_extension/authentication.rb | 8 | ||||
| -rw-r--r-- | users/app/controllers/sessions_controller.rb | 3 | ||||
| -rw-r--r-- | users/config/locales/en.yml | 2 | ||||
| -rw-r--r-- | users/lib/warden/strategies/secure_remote_password.rb | 4 | 
6 files changed, 15 insertions, 8 deletions
| diff --git a/users/app/assets/javascripts/srp b/users/app/assets/javascripts/srp -Subproject 635ea47f1c19d7985a8f5107c070ae19edf9dd5 +Subproject 076d6e251e4caf826787d87b11434e535960455 diff --git a/users/app/assets/javascripts/users.js.coffee b/users/app/assets/javascripts/users.js.coffee index 6d1dda2..d0ec32f 100644 --- a/users/app/assets/javascripts/users.js.coffee +++ b/users/app/assets/javascripts/users.js.coffee @@ -37,10 +37,10 @@ srp.loggedIn = ->  srp.error = (message) ->    if $.isPlainObject(message) && message.errors -    for key, value of message.errors -      element = $('form input[name="session['+key+']"]') +    for field, error of message.errors +      element = $('form input[name="session['+field+']"]')        next unless element -      element.trigger('element:validate:fail.ClientSideValidations', value).data('valid', false) +      element.trigger('element:validate:fail.ClientSideValidations', error).data('valid', false)    else      alert(message) diff --git a/users/app/controllers/controller_extension/authentication.rb b/users/app/controllers/controller_extension/authentication.rb index 87f7921..6ac7a5b 100644 --- a/users/app/controllers/controller_extension/authentication.rb +++ b/users/app/controllers/controller_extension/authentication.rb @@ -7,8 +7,12 @@ module ControllerExtension::Authentication      helper_method :current_user, :logged_in?, :admin?    end -  def authentication_error -    warden.winning_strategy.try(:message) +  def authentication_errors +    return unless errors = warden.winning_strategy.try(:message) +    errors.inject({}) do |translated,err| +      translated[err.first] = I18n.t(err.last) +      translated +    end    end    def logged_in? diff --git a/users/app/controllers/sessions_controller.rb b/users/app/controllers/sessions_controller.rb index 32d1ddc..bc910b5 100644 --- a/users/app/controllers/sessions_controller.rb +++ b/users/app/controllers/sessions_controller.rb @@ -4,7 +4,8 @@ class SessionsController < ApplicationController    def new      @session = Session.new -    if @errors = authentication_error +    if authentication_errors +      @errors = authentication_errors        render :status => 422      end    end diff --git a/users/config/locales/en.yml b/users/config/locales/en.yml index 172b85f..be3f28e 100644 --- a/users/config/locales/en.yml +++ b/users/config/locales/en.yml @@ -4,3 +4,5 @@ en:    cancel: "Cancel"    login: "Login"    login_message: "Please login with your account." +  wrong_password: "wrong password" +  user_not_found: "could not be found" diff --git a/users/lib/warden/strategies/secure_remote_password.rb b/users/lib/warden/strategies/secure_remote_password.rb index 8266e2d..95570e0 100644 --- a/users/lib/warden/strategies/secure_remote_password.rb +++ b/users/lib/warden/strategies/secure_remote_password.rb @@ -26,7 +26,7 @@ module Warden        def validate!          user = session[:handshake].authenticate(params['client_auth'].hex) -        user ? success!(user) : fail!(:password => "Could not log in") +        user ? success!(user) : fail!(:password => "wrong_password")        end        def initialize! @@ -34,7 +34,7 @@ module Warden          session[:handshake] = user.initialize_auth(params['A'].hex)          custom! json_response(session[:handshake])        rescue RECORD_NOT_FOUND -        fail! :login => "User not found!" +        fail! :login => "user_not_found"        end        def json_response(object) | 
