简体   繁体   中英

Rails devise if session sign_in error, then redirect to some page (back)

How can i change standart devise session_controller, so that if, for example i entered incorrect password i'm redirected :back (is not required), and see my error's...

For what i need this? Becouse i have my login only in template which is rendered in layout left block on all pages, and i didn't have new action-view...

So how to do error's redirect to other page with validation message errors... ?

Here is standart session_controller (now i didn't create it one, it is "nested"):

class Devise::SessionsController < DeviseController
  prepend_before_filter :require_no_authentication, :only => [ :new, :create ]
  prepend_before_filter :allow_params_authentication!, :only => :create
  prepend_before_filter { request.env["devise.skip_timeout"] = true }

  # GET /resource/sign_in
  def new
    self.resource = build_resource(nil, :unsafe => true)
    clean_up_passwords(resource)
    respond_with(resource, serialize_options(resource))
  end

  # POST /resource/sign_in
  def create
    self.resource = warden.authenticate!(auth_options)
    set_flash_message(:notice, :signed_in) if is_navigational_format?
    sign_in(resource_name, resource)
    respond_with resource, :location => after_sign_in_path_for(resource)
  end

  # DELETE /resource/sign_out
  def destroy
    redirect_path = after_sign_out_path_for(resource_name)
    signed_out = (Devise.sign_out_all_scopes ? sign_out : sign_out(resource_name))
    set_flash_message :notice, :signed_out if signed_out && is_navigational_format?

    # We actually need to hardcode this as Rails default responder doesn't
    # support returning empty response on GET request
    respond_to do |format|
      format.all { head :no_content }
      format.any(*navigational_formats) { redirect_to redirect_path }
    end
  end

  protected

  def serialize_options(resource)
    methods = resource_class.authentication_keys.dup
    methods = methods.keys if methods.is_a?(Hash)
    methods << :password if resource.respond_to?(:password)
    { :methods => methods, :only => [:password] }
  end

  def auth_options
    { :scope => resource_name, :recall => "#{controller_path}#new" }
  end
end

also method in appcontroller

def after_sign_in_path_for(resource)      
    case resource
      when User then 
        user = User.find(current_user.id)
        total_markup_for_user = user.groups.map(&:markup).sum
        if current_cart.present?
          cart_id = current_cart.id
        else
          cart_id = nil
        end
        ***
        end
        if request.referrer.to_s.include? "users"
          root_path
        else
          request.referrer 
        end
      when Admin::Admin then :admin_mainpage
    end
  end

Devise has documentation that shows you how to override their default redirects here:

https://github.com/plataformatec/devise/wiki/How-To:-Redirect-to-a-specific-page-on-successful-sign-in

Basically you would go into your application_controller.rb and for example write something like this

def after_sign_in_path_for(resource)
  request.env['omniauth.origin'] || stored_location_for(resource) || new_survey_path
end

def after_sign_out_path_for(resource_or_scope)
 root_path
end

end

hope it helps

Try something like this, add a new respond_with in case sign_in returns false.

def create
  self.resource = warden.authenticate!(auth_options)
  set_flash_message(:notice, :signed_in) if is_navigational_format?
  if sign_in(resource_name, resource)
    respond_with resource, location: after_sign_in_path_for(resource)
  else
    respond_with resource, location: root_path
  end
end

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM