about summary refs log blame commit diff
path: root/app/controllers/settings/two_factor_auths_controller.rb
blob: cfee92391a7b02aec3b48fa4eedc33479271da4c (plain) (tree)
1
2
3
4
5
6
7
8
9
10

                                                                
                




                                                     
                                                                                                                      















                                                      
# frozen_string_literal: true

class Settings::TwoFactorAuthsController < ApplicationController
  layout 'admin'

  before_action :authenticate_user!

  def show
    return unless current_user.otp_required_for_login

    @provision_url = current_user.otp_provisioning_uri(current_user.email, issuer: Rails.configuration.x.local_domain)
    @qrcode        = RQRCode::QRCode.new(@provision_url)
  end

  def enable
    current_user.otp_required_for_login = true
    current_user.otp_secret = User.generate_otp_secret
    current_user.save!

    redirect_to settings_two_factor_auth_path
  end

  def disable
    current_user.otp_required_for_login = false
    current_user.save!

    redirect_to settings_two_factor_auth_path
  end
end