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