2020-02-02 17:22:38 +00:00
|
|
|
class DeviseOverrides::ConfirmationsController < Devise::ConfirmationsController
|
2021-06-07 11:56:08 +00:00
|
|
|
include AuthHelper
|
2019-08-19 08:19:57 +00:00
|
|
|
skip_before_action :require_no_authentication, raise: false
|
|
|
|
skip_before_action :authenticate_user!, raise: false
|
2019-08-14 09:48:44 +00:00
|
|
|
|
|
|
|
def create
|
2019-10-20 08:47:26 +00:00
|
|
|
@confirmable = User.find_by(confirmation_token: params[:confirmation_token])
|
2021-06-07 11:56:08 +00:00
|
|
|
render_confirmation_success and return if @confirmable&.confirm
|
2020-10-02 09:57:26 +00:00
|
|
|
|
2021-06-07 11:56:08 +00:00
|
|
|
render_confirmation_error
|
2019-08-14 09:48:44 +00:00
|
|
|
end
|
|
|
|
|
2021-06-07 11:56:08 +00:00
|
|
|
private
|
2020-10-02 09:57:26 +00:00
|
|
|
|
|
|
|
def render_confirmation_success
|
2021-06-07 11:56:08 +00:00
|
|
|
send_auth_headers(@confirmable)
|
2022-10-06 00:24:34 +00:00
|
|
|
render partial: 'devise/auth', formats: [:json], locals: { resource: @confirmable }
|
2020-10-02 09:57:26 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def render_confirmation_error
|
|
|
|
if @confirmable.blank?
|
2021-06-07 11:56:08 +00:00
|
|
|
render json: { message: 'Invalid token', redirect_url: '/' }, status: :unprocessable_entity
|
2020-10-02 09:57:26 +00:00
|
|
|
elsif @confirmable.confirmed_at
|
2021-06-07 11:56:08 +00:00
|
|
|
render json: { message: 'Already confirmed', redirect_url: '/' }, status: :unprocessable_entity
|
2020-10-02 09:57:26 +00:00
|
|
|
else
|
2021-06-07 11:56:08 +00:00
|
|
|
render json: { message: 'Failure', redirect_url: '/' }, status: :unprocessable_entity
|
2020-10-02 09:57:26 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-08-14 09:48:44 +00:00
|
|
|
def create_reset_token_link(user)
|
2021-12-09 05:41:46 +00:00
|
|
|
token = user.send(:set_reset_password_token)
|
|
|
|
"/app/auth/password/edit?config=default&redirect_url=&reset_password_token=#{token}"
|
2019-08-14 09:48:44 +00:00
|
|
|
end
|
|
|
|
end
|