2024-02-05 06:05:13 +11:00
|
|
|
module Authentication
|
|
|
|
extend ActiveSupport::Concern
|
|
|
|
|
|
|
|
included do
|
2024-10-03 14:42:22 -04:00
|
|
|
before_action :set_request_details
|
2024-04-03 10:35:55 -04:00
|
|
|
before_action :authenticate_user!
|
2025-02-25 08:48:26 -06:00
|
|
|
before_action :set_sentry_user
|
2024-04-03 10:35:55 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
class_methods do
|
|
|
|
def skip_authentication(**options)
|
|
|
|
skip_before_action :authenticate_user!, **options
|
2025-02-25 08:48:26 -06:00
|
|
|
skip_before_action :set_sentry_user, **options
|
2024-04-03 10:35:55 -04:00
|
|
|
end
|
2024-02-05 06:05:13 +11:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
2024-08-23 10:06:24 -04:00
|
|
|
def authenticate_user!
|
2024-10-18 11:26:58 -05:00
|
|
|
if session_record = find_session_by_cookie
|
2024-10-03 14:42:22 -04:00
|
|
|
Current.session = session_record
|
2024-08-23 10:06:24 -04:00
|
|
|
else
|
2024-09-13 17:24:19 -04:00
|
|
|
if self_hosted_first_login?
|
|
|
|
redirect_to new_registration_url
|
|
|
|
else
|
|
|
|
redirect_to new_session_url
|
|
|
|
end
|
2024-08-23 10:06:24 -04:00
|
|
|
end
|
2024-02-05 10:36:46 +11:00
|
|
|
end
|
2024-02-05 06:05:13 +11:00
|
|
|
|
2024-10-18 11:26:58 -05:00
|
|
|
def find_session_by_cookie
|
2025-03-05 13:10:53 -06:00
|
|
|
cookie_value = cookies.signed[:session_token]
|
2025-03-05 13:20:36 -06:00
|
|
|
|
|
|
|
if cookie_value.present?
|
2025-03-05 13:44:56 -06:00
|
|
|
Session.find_by(id: cookie_value)
|
2025-03-05 13:20:36 -06:00
|
|
|
else
|
|
|
|
nil
|
|
|
|
end
|
2024-10-18 11:26:58 -05:00
|
|
|
end
|
|
|
|
|
2024-10-03 14:42:22 -04:00
|
|
|
def create_session_for(user)
|
|
|
|
session = user.sessions.create!
|
2025-03-05 13:20:36 -06:00
|
|
|
cookies.signed.permanent[:session_token] = { value: session.id, httponly: true }
|
2024-10-03 14:42:22 -04:00
|
|
|
session
|
2024-08-23 10:06:24 -04:00
|
|
|
end
|
2024-09-13 17:24:19 -04:00
|
|
|
|
|
|
|
def self_hosted_first_login?
|
|
|
|
Rails.application.config.app_mode.self_hosted? && User.count.zero?
|
|
|
|
end
|
2024-10-03 14:42:22 -04:00
|
|
|
|
|
|
|
def set_request_details
|
|
|
|
Current.user_agent = request.user_agent
|
|
|
|
Current.ip_address = request.ip
|
|
|
|
end
|
2025-02-25 08:48:26 -06:00
|
|
|
|
|
|
|
def set_sentry_user
|
|
|
|
return unless defined?(Sentry) && ENV["SENTRY_DSN"].present?
|
|
|
|
|
|
|
|
if Current.user
|
|
|
|
Sentry.set_user(
|
|
|
|
id: Current.user.id,
|
|
|
|
email: Current.user.email,
|
|
|
|
username: Current.user.display_name,
|
|
|
|
ip_address: Current.ip_address
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
2024-02-05 06:05:13 +11:00
|
|
|
end
|