I am using an API authentication program. I rewrote the SessionController:create method as follows:
class Users::SessionsController < Devise::SessionsController def create resource = warden.authenticate!(:scope => resource_name, :recall => "#{controller_path}#new") set_flash_message(:notice, :signed_in) if is_navigational_format? val = sign_in(resource_name, resource) current_user.reset_authentication_token! respond_to do |format| format.html do respond_with resource, :location => redirect_location(resource_name, resource) end format.json do render :json => { :status => OK_OK, :auth_token => current_user.authentication_token }.to_json, :status => :ok end end end end
As you can see, I am responding with a status code when authenticating with JSON. When authentication fails, I get the following response:
{"error":"Invalid email or password."}
How do I change this message? I do not know where to replace this warden.authenticate! method warden.authenticate! .
source share