9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
# File 'lib/graphql_devise/resolvers/check_password_token.rb', line 9
def resolve(reset_password_token:, redirect_url: nil)
resource = resource_class.with_reset_password_token(reset_password_token)
raise_user_error(I18n.t('graphql_devise.passwords.reset_token_not_found')) if resource.blank?
if resource.reset_password_period_valid?
token_info = client_and_token(resource.create_token)
resource.skip_confirmation! if confirmable_enabled? && !resource.confirmed_at
resource.allow_password_change = true if recoverable_enabled?
resource.save!
yield resource if block_given?
= { reset_password: true }
= (
token_info,
)
if redirect_url.present?
check_redirect_url_whitelist!(redirect_url)
controller.redirect_to(resource.build_auth_url(redirect_url, ))
else
(resource)
end
resource
else
raise_user_error(I18n.t('graphql_devise.passwords.reset_token_expired'))
end
end
|