2012-06-30 17 views
5

Sono riuscito a configurare l'autenticazione JSON. Ho implementato il seguente codice:Devise autenticazione fallita via json rimanda html invece di jeff

class Users:: SessionsController < Devise::SessionsController 
    def create 
    respond_to do |format| 
     format.html { super } 
     format.json { 
     warden.authenticate!(:scope => resource_name, :recall => "#{controller_path}#failure") 
     render :json => {:success => true} 
     } 
    end 
    end 

    def destroy 
    respond_to do |format| 
     format.html {super} 
     format.json { 
     Devise.sign_out_all_scopes ? sign_out : sign_out(resource_name) 
     render :json => {} 
     } 
    end 
    end 

    def failure 
    render :json => {:success => false, :errors => ["Login Failed"]} 
    end 
end 

Questo funziona correttamente, ma quando l'autenticazione non riesce, l'errore non restituisce l'errore json. Ho un errore personalizzato per ideare. Se rimuovo redirect_url o rimuovo completamente l'errore del cliente, l'autenticazione restituisce un json con il messaggio di errore. Il mio fallimento personalizzato è la seguente:

class CustomFailure < Devise::FailureApp 
    def redirect_url 
    #return super unless [:worker, :employer, :user].include?(scope) #make it specific to a scope 
    '/' 
    end 

    # You need to override respond to eliminate recall 
    def respond 
    if http_auth? 
     http_auth 
    else 
    redirect 
    end 
end 

fine

ogni modo per mantenere il reindirizzamento se una richiesta di html, e restituire un JSON con un msg fallimento se una richiesta JSON?

Grazie!

risposta

5

Devi dire al direttore di utilizzare quell'errore personalizzato.

def failure 
    respond_to do |format| 
    format.html {super} 
    format.json do 
     warden.custom_failure! 
     render :json => {:success => false, :errors => ["Login Failed"]} 
    end 
    end 
end 
Problemi correlati