Keep a blank line before and after private Keep a blank line before and after protected Remove extra empty line at class body end Remove extra blank line Add final newline Use 2 (not 3) spaces for indentation Use 2 (not 4) spaces for indentation Remove space before comma Add space after comma Remove trailing whitespaces Remove unnecessary spacing Use snake_case for variable names Do not use then for multi-line if Remove unused block argument - i Use the new Ruby 1.9 hash syntax Remove unused assignment to variable Indent when as deep as case Align attributes Align end with def
59 lines
1.5 KiB
Ruby
59 lines
1.5 KiB
Ruby
class Verification::LetterController < ApplicationController
|
|
before_action :authenticate_user!, except: [:edit, :update]
|
|
before_action :login_via_form, only: :update
|
|
|
|
before_action :verify_resident!, if: :signed_in?
|
|
before_action :verify_phone!, if: :signed_in?
|
|
before_action :verify_verified!, if: :signed_in?
|
|
before_action :verify_lock, if: :signed_in?
|
|
|
|
skip_authorization_check
|
|
|
|
def new
|
|
@letter = Verification::Letter.new(user: current_user)
|
|
end
|
|
|
|
def create
|
|
@letter = Verification::Letter.new(user: current_user)
|
|
@letter.save
|
|
redirect_to letter_path
|
|
end
|
|
|
|
def show
|
|
end
|
|
|
|
def edit
|
|
@letter = Verification::Letter.new
|
|
end
|
|
|
|
def update
|
|
@letter = Verification::Letter.new(letter_params.merge(user: current_user, verify: true))
|
|
if @letter.valid?
|
|
current_user.update(verified_at: Time.now)
|
|
redirect_to account_path, notice: t('verification.letter.update.flash.success')
|
|
else
|
|
Lock.increase_tries(@letter.user) if @letter.user
|
|
render :edit
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def letter_params
|
|
params.require(:verification_letter).permit(:verification_code, :email, :password)
|
|
end
|
|
|
|
def verify_phone!
|
|
unless current_user.confirmed_phone?
|
|
redirect_to verified_user_path, alert: t('verification.letter.alert.unconfirmed_code')
|
|
end
|
|
end
|
|
|
|
def login_via_form
|
|
user = User.find_by email: letter_params[:email]
|
|
if user && user.valid_password?(letter_params[:password])
|
|
sign_in(user)
|
|
end
|
|
end
|
|
|
|
end |