Class: RailsSimpleAuth::SessionsController

Inherits:
BaseController
  • Object
show all
Defined in:
app/controllers/rails_simple_auth/sessions_controller.rb

Instance Method Summary collapse

Instance Method Details

#createObject



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
      (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

#destroyObject



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


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


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 
  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)
      error_message = user.errors.full_messages.first || 'Could not confirm email.'
      redirect_to new_session_path, alert: error_message
      return
    end
    (user)
  else
    redirect_to new_session_path, alert: 'Invalid or expired magic link.'
  end
end

#newObject



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


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