24 lines
671 B
Ruby
24 lines
671 B
Ruby
# frozen_string_literal: true
|
|
|
|
module TwoFactor
|
|
class DestroyService < ::TwoFactor::BaseService
|
|
def execute
|
|
return error(_('You are not authorized to perform this action')) unless can?(current_user, :disable_two_factor, user)
|
|
return error(_('Two-factor authentication is not enabled for this user')) unless user.two_factor_enabled?
|
|
|
|
result = disable_two_factor
|
|
|
|
notification_service.disabled_two_factor(user) if result[:status] == :success
|
|
|
|
result
|
|
end
|
|
|
|
private
|
|
|
|
def disable_two_factor
|
|
::Users::UpdateService.new(current_user, user: user).execute do |user|
|
|
user.disable_two_factor!
|
|
end
|
|
end
|
|
end
|
|
end
|