2016-11-15 17:56:29 +02:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-03-05 23:43:05 +02:00
|
|
|
class Auth::PasswordsController < Devise::PasswordsController
|
2023-10-23 18:46:21 +03:00
|
|
|
skip_before_action :check_self_destruct!
|
2017-08-03 18:45:45 +03:00
|
|
|
before_action :check_validity_of_reset_password_token, only: :edit
|
2017-11-21 08:13:37 +02:00
|
|
|
before_action :set_pack
|
2018-07-31 02:14:33 +03:00
|
|
|
before_action :set_body_classes
|
2017-08-03 18:45:45 +03:00
|
|
|
|
2016-03-05 23:43:05 +02:00
|
|
|
layout 'auth'
|
2017-08-03 18:45:45 +03:00
|
|
|
|
2020-01-24 01:20:38 +02:00
|
|
|
def update
|
|
|
|
super do |resource|
|
2020-07-07 16:26:31 +03:00
|
|
|
if resource.errors.empty?
|
|
|
|
resource.session_activations.destroy_all
|
2022-12-15 16:47:06 +02:00
|
|
|
|
|
|
|
resource.revoke_access!
|
2020-07-07 16:26:31 +03:00
|
|
|
end
|
2020-01-24 01:20:38 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-08-03 18:45:45 +03:00
|
|
|
private
|
|
|
|
|
|
|
|
def check_validity_of_reset_password_token
|
|
|
|
unless reset_password_token_is_valid?
|
|
|
|
flash[:error] = I18n.t('auth.invalid_reset_password_token')
|
|
|
|
redirect_to new_password_path(resource_name)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-07-31 02:14:33 +03:00
|
|
|
def set_body_classes
|
|
|
|
@body_classes = 'lighter'
|
|
|
|
end
|
|
|
|
|
2017-08-03 18:45:45 +03:00
|
|
|
def reset_password_token_is_valid?
|
|
|
|
resource_class.with_reset_password_token(params[:reset_password_token]).present?
|
|
|
|
end
|
2017-11-21 08:13:37 +02:00
|
|
|
|
|
|
|
def set_pack
|
|
|
|
use_pack 'auth'
|
|
|
|
end
|
2016-03-05 23:43:05 +02:00
|
|
|
end
|