Codeminer42/cm42-central

View on GitHub
app/controllers/registrations_controller.rb

Summary

Maintainability
A
0 mins
Test Coverage
class RegistrationsController < Devise::RegistrationsController
  prepend_before_action :check_captcha, only: :create, if: -> { show_recaptcha? }
  before_action :set_resource_locale, only: :create
  before_action :check_registration_enabled, only: %i[new create]
  before_action :devise_params
  after_action :reset_locale, only: :update

  def disable_two_factor
    verify_token = Authy::API.verify(id: current_user.authy_id, token: params[:token], force: true)

    if verify_token.ok?
      disable_authy = Authy::API.delete_user(id: current_user.authy_id)

      if disable_authy.ok?
        current_user.update(authy_id: nil, authy_enabled: false)

        set_flash_message :notice, :disabled, scope: 'devise.devise_authy'
        redirect_to edit_user_registration_path
      else
        set_flash_message :error, :not_disabled, now: true, scope: 'devise.devise_authy'
        render :verify_two_factor
      end
    else
      set_flash_message :error, :invalid_token, now: true, scope: 'devise.devise_authy'
      render :verify_two_factor
    end
  end

  def tour
    @user = User.find(params[:id])
    if @user.update(user_params)
      render json: @user, status: :ok
    else
      render json: @user.errors, status: :unprocessable_entity
    end
  end

  def reset_tour
    @user = User.find(params[:id])
    if @user.update(user_params)
      redirect_to :back, flash: { notice: t('reset_tour_success') }
    else
      redirect_to :back, flash: { error: t('reset_tour_fail') }
    end
  end

  private

  def user_params
    params.require(:user).permit(:finished_tour)
  end

  protected

  def after_inactive_sign_up_path_for(resource)
    new_session_path(resource)
  end

  def check_registration_enabled
    return unless Fulcrum::Application.config.fulcrum.disable_registration

    render_404
  end

  def devise_params
    devise_parameter_sanitizer.permit(:sign_up) do |u|
      u.permit(:email, :name, :initials, :username, :team_slug)
    end
    devise_parameter_sanitizer.permit(:account_update) do |u|
      u.permit(:email, :password, :password_confirmation, :remember_me,
               :name, :initials, :username, :email_delivery, :email_acceptance,
               :email_rejection, :locale, :time_zone, :current_password)
    end
  end

  def check_captcha
    return if verify_recaptcha

    self.resource = resource_class.new sign_up_params
    respond_with_navigational(resource) { render :new }
  end

  def set_resource_locale
    return unless resource
    resource.locale = if session[:locale]
                        session[:locale]
                      else
                        I18n.locale
                      end
  end

  def reset_locale
    session[:locale] = nil
  end
end