Sha256: ceb4fce36e96bbefc07f8319b92b084420a7c3bf04deacfa56340e0ce71cc792

Contents?: true

Size: 1.43 KB

Versions: 2

Compression:

Stored size: 1.43 KB

Contents

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

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

    before_action :check_user_count, :only => :new

    helper 'Alchemy::Admin::Base', 'Alchemy::Pages'

    layout 'alchemy/login'

    def new
      super
    end

    def create
      authenticate_user!

      if user_signed_in?
        store_screen_size
        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

    def store_screen_size
      session[:screen_size] = params[:user_screensize]
    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

2 entries across 2 versions & 1 rubygems

Version Path
alchemy-devise-2.1.0 app/controllers/alchemy/user_sessions_controller.rb
alchemy-devise-2.1.0.beta3 app/controllers/alchemy/user_sessions_controller.rb