41 lines
		
	
	
		
			961 B
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			961 B
		
	
	
	
		
			Ruby
		
	
	
	
# frozen_string_literal: true
 | 
						|
 | 
						|
class Auth::SetupController < ApplicationController
 | 
						|
  layout 'auth'
 | 
						|
 | 
						|
  before_action :authenticate_user!
 | 
						|
  before_action :require_unconfirmed_or_pending!
 | 
						|
  before_action :set_user
 | 
						|
 | 
						|
  skip_before_action :require_functional!
 | 
						|
 | 
						|
  def show; end
 | 
						|
 | 
						|
  def update
 | 
						|
    # This allows updating the e-mail without entering a password as is required
 | 
						|
    # on the account settings page; however, we only allow this for accounts
 | 
						|
    # that were not confirmed yet
 | 
						|
 | 
						|
    if @user.update(user_params)
 | 
						|
      @user.resend_confirmation_instructions unless @user.confirmed?
 | 
						|
      redirect_to auth_setup_path, notice: t('auth.setup.new_confirmation_instructions_sent')
 | 
						|
    else
 | 
						|
      render :show
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  private
 | 
						|
 | 
						|
  def require_unconfirmed_or_pending!
 | 
						|
    redirect_to root_path if current_user.confirmed? && current_user.approved?
 | 
						|
  end
 | 
						|
 | 
						|
  def set_user
 | 
						|
    @user = current_user
 | 
						|
  end
 | 
						|
 | 
						|
  def user_params
 | 
						|
    params.expect(user: [:email])
 | 
						|
  end
 | 
						|
end
 |