Sha256: 8d2f8525c6f6e8f0ae659763ef899602c2749e77714d317787930af3a244beca

Contents?: true

Size: 1.4 KB

Versions: 3

Compression:

Stored size: 1.4 KB

Contents

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

    before_action(except: 'destroy') { enforce_ssl if ssl_required? && !request.ssl? }
    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 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

3 entries across 3 versions & 1 rubygems

Version Path
alchemy-devise-2.1.0.beta2 app/controllers/alchemy/user_sessions_controller.rb
alchemy-devise-2.1.0.beta1 app/controllers/alchemy/user_sessions_controller.rb
alchemy-devise-2.0.0 app/controllers/alchemy/user_sessions_controller.rb