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