class SessionsController < ApplicationController include UsersHelper def new if current_user flash[:alert] = "You are already logged in!" redirect_to current_user else if params[:return_path] && params[:return_path][0] == "/" cookies[:return_path] = params[:return_path] end end end def create unless current_user user = User.find_by_email(params[:email]) if user && user.authenticate(params[:password]) if user.disabled? flash[:alert] = "Your account has been disabled!" elsif user.banned? flash[:alert] = "You are banned!" elsif user.totp_enabled && !TOTP.valid?(user.totp_secret, params[:totp_code].to_i) flash[:alert] = "You're doing it wrong!" render action: 'new' return else session[:user_id] = user.id flash[:notice] = "Logged in!" new_ign = fetch_name(user.uuid) if new_ign.present? && new_ign != user.ign user.name = new_ign if user.ign == user.name user.ign = new_ign if (user.save rescue false) flash[:notice] += " Your name has been changed to #{new_ign}!" else flash[:alert] = "Failed to save your new username #{new_ign}! Please contact admins." end end flash[:alert] = "Remember to validate your email! Your account may be deleted soon!" if !user.confirmed? end else flash[:alert] = "You're doing it wrong!" render action: 'new' return end else flash[:alert] = "You are already logged in!" end if cookies[:return_path] begin # might be invalid path URI.parse(cookies[:return_path]) redirect_to cookies[:return_path] rescue URI::Error flash[:alert] = "Invalid return path!" redirect_to blogposts_path end cookies.delete(:return_path) else redirect_to blogposts_path end end def destroy if original_user = User.find_by_id(session[:original_user_id]) logout_user = current_user session[:user_id] = original_user.try(:id) session.delete(:original_user_id) puts "User #{original_user} reverted from #{logout_user}!" flash[:notice] = "You are no longer '#{logout_user.name}'!" redirect_to original_user else session.delete(:user_id) redirect_to login_path, :notice => "Logged out!" end end def become original_user = current_user new_user = User.find_by_id(params[:user]) if original_user && new_user && admin? && current_user.role >= new_user.role if original_user == new_user flash[:alert] = "You are already '#{new_user.name}'!" else if session[:original_user_id] flash[:alert] = "Please revert to your account first" else session[:original_user_id] = original_user.id session[:user_id] = new_user.id puts "User #{original_user} became #{new_user}!" flash[:notice] = "You are now '#{new_user.name}'!" end end else flash[:alert] = "You are not allowed to become this user" end redirect_to new_user end def revert if old_user = current_user original_user = User.find_by_id(session[:original_user_id]) if original_user && original_user.try(:admin?) session.delete(:original_user_id) session[:user_id] = original_user.try(:id) flash[:notice] = "You are no longer '#{old_user.name}'!" end redirect_to old_user else redirect_to login_path end end end