Sha256: e2e21fed9757b8800a9da504efdcbbec028af4eb3252d3e22b014b633cfaa092

Contents?: true

Size: 1.34 KB

Versions: 4

Compression:

Stored size: 1.34 KB

Contents

module Alchemy
  class UserSessionsController < ::Devise::SessionsController
    include Alchemy::Admin::Locale

    protect_from_forgery prepend: true

    before_action except: 'destroy' do
      enforce_ssl if ssl_required? && !request.ssl?
    end

    before_action :check_user_count, :only => :new

    helper 'Alchemy::Admin::Base'

    layout 'alchemy/admin'

    def new
      super
    end

    def create
      authenticate_user!

      if user_signed_in?
        if session[:redirect_path].blank?
          redirect_path = admin_dashboard_path
        else
          # We have to strip double slashes from beginning of path, because of strange rails/rack bug.
          redirect_path = session[:redirect_path].gsub(/\A\/{2,}/, '/')
        end
        redirect_to redirect_path,
          notice: t(:signed_in, scope: 'devise.sessions')
      else
        super
      end
    end

    def destroy
      current_alchemy_user.try(:unlock_pages!)
      cookies.clear
      session.clear
      super
    end

    private

    def check_user_count
      if User.count == 0
        redirect_to admin_signup_path
      end
    end

    # Overwriting the default of Devise
    def after_sign_out_path_for(resource_or_scope)
      if request.referer.blank? || request.referer.to_s =~ /admin/
        root_path
      else
        request.referer
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
alchemy-devise-4.4.0 app/controllers/alchemy/user_sessions_controller.rb
alchemy-devise-4.3.1 app/controllers/alchemy/user_sessions_controller.rb
alchemy-devise-4.3.0 app/controllers/alchemy/user_sessions_controller.rb
alchemy-devise-4.2.1 app/controllers/alchemy/user_sessions_controller.rb