これは、deviseのセッションコントローラーをオーバーライドすることで行いました。
カスタムセッションコントローラのルートにエントリを追加します。
devise_for :users, :controllers => {:sessions => 'sessions'}
そして、セッションコントローラーをオーバーライドします。
class SessionsController < Devise::SessionsController
def create
resource = warden.authenticate!(:scope => resource_name, :recall => "sessions#failure")
return sign_in_and_redirect(resource_name, resource)
end
def sign_in_and_redirect(resource_or_scope, resource=nil)
scope = Devise::Mapping.find_scope!(resource_or_scope)
resource ||= resource_or_scope
sign_in(scope, resource) unless warden.user(scope) == resource
respond_with do |format|
format.json {render :json => {:success => true} }
format.any {super}
end
end
def failure
respond_with do |format|
format.json {render:json => {:success => false, :errors => ["Login failed."]} }
format.any {redirect_to :back, :notice => "Wrong Email / Password" }
end
#return render:json => {:success => false, :errors => ["Login failed."]}
end
end
" Rails&Devise:Override SessionsControllerは、同じテーマに関するより多くの議論です。