Class: RailsSimpleAuth::SessionsController
- Inherits:
-
BaseController
- Object
- ApplicationController
- BaseController
- RailsSimpleAuth::SessionsController
- Defined in:
- app/controllers/rails_simple_auth/sessions_controller.rb
Instance Method Summary collapse
- #create ⇒ Object
- #destroy ⇒ Object
- #magic_link_form ⇒ Object
- #magic_link_login ⇒ Object
- #new ⇒ Object
- #request_magic_link ⇒ Object
Instance Method Details
#create ⇒ Object
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'app/controllers/rails_simple_auth/sessions_controller.rb', line 30 def create user = user_class.find_by(email: params[:email]) || user_class.new(password: SecureRandom.hex(32)) if user.authenticate(params[:password]) && user.persisted? if confirmation_required_for?(user) @error_message = 'Please confirm your email before signing in.' @previous_email = params[:email] render :new, status: :unprocessable_content else sign_in_and_redirect(user) end else Rails.logger.warn("Failed login attempt for email: #{params[:email]} from IP: #{client_ip}") @error_message = 'Invalid email or password' @previous_email = params[:email] render :new, status: :unprocessable_content end end |
#destroy ⇒ Object
49 50 51 52 53 54 |
# File 'app/controllers/rails_simple_auth/sessions_controller.rb', line 49 def destroy user = current_user destroy_current_session run_after_sign_out_callback(user) if user redirect_to resolve_path(:after_sign_out_path), notice: 'Signed out successfully.' end |
#magic_link_form ⇒ Object
56 57 58 59 60 |
# File 'app/controllers/rails_simple_auth/sessions_controller.rb', line 56 def magic_link_form return redirect_to resolve_path(:after_sign_in_path) if permanent_user_signed_in? store_referrer_for_redirect end |
#magic_link_login ⇒ Object
73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 |
# File 'app/controllers/rails_simple_auth/sessions_controller.rb', line 73 def magic_link_login user = user_class.find_signed(params[:token], purpose: :magic_link) if user # Auto-confirm unconfirmed users via magic link (email ownership verified) if user.respond_to?(:confirm!) && user.respond_to?(:unconfirmed?) && user.unconfirmed? && !user.confirm! # Confirmation failed (e.g., email already taken during reconfirmation) = user.errors..first || 'Could not confirm email.' redirect_to new_session_path, alert: return end sign_in_and_redirect(user) else redirect_to new_session_path, alert: 'Invalid or expired magic link.' end end |
#new ⇒ Object
24 25 26 27 28 |
# File 'app/controllers/rails_simple_auth/sessions_controller.rb', line 24 def new return redirect_to resolve_path(:after_sign_in_path) if permanent_user_signed_in? store_referrer_for_redirect end |
#request_magic_link ⇒ Object
62 63 64 65 66 67 68 69 70 71 |
# File 'app/controllers/rails_simple_auth/sessions_controller.rb', line 62 def request_magic_link user = user_class.find_by(email: params[:email]) if user.respond_to?(:generate_magic_link_token) token = user.generate_magic_link_token RailsSimpleAuth.configuration.mailer.magic_link(user, token).deliver_later end redirect_to new_session_path, notice: 'If an account exists with that email, a magic link has been sent.' end |