2024-02-15 17:23:54 -06:00
|
|
|
class UsersController < ApplicationController
|
|
|
|
before_action :authenticate_user!
|
|
|
|
before_action :set_user, only: [:edit, :update, :destroy]
|
|
|
|
before_action :require_admin
|
2024-04-03 18:32:15 -05:00
|
|
|
load_and_authorize_resource
|
2024-02-15 17:23:54 -06:00
|
|
|
|
|
|
|
def index
|
|
|
|
@users = User.all
|
|
|
|
end
|
|
|
|
|
2024-04-11 23:48:16 -05:00
|
|
|
def new
|
|
|
|
@user = User.new
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2024-02-15 17:23:54 -06:00
|
|
|
def edit
|
|
|
|
end
|
|
|
|
|
2024-04-03 18:32:15 -05:00
|
|
|
def create
|
2024-04-09 18:14:10 -05:00
|
|
|
@user = User.new(user_params.except(:roles))
|
2024-04-03 18:32:15 -05:00
|
|
|
if @user.save
|
2024-04-09 18:14:10 -05:00
|
|
|
update_user_roles(@user, params[:user][:roles] || ['user'])
|
2024-04-03 18:32:15 -05:00
|
|
|
redirect_to users_path, notice: 'User was successfully created.'
|
|
|
|
else
|
|
|
|
render :new
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2024-02-15 17:23:54 -06:00
|
|
|
def update
|
2024-04-03 18:32:15 -05:00
|
|
|
# Assumes @user is already set from a before_action callback
|
|
|
|
if @user.update(user_params.except(:roles))
|
|
|
|
update_user_roles(@user, user_params[:roles])
|
2024-02-15 17:23:54 -06:00
|
|
|
redirect_to users_path, notice: 'User was successfully updated.'
|
|
|
|
else
|
|
|
|
render :edit
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2024-04-11 23:48:16 -05:00
|
|
|
def show
|
|
|
|
@user = User.includes(:access_periods).find(params[:id])
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2024-02-15 17:23:54 -06:00
|
|
|
def destroy
|
|
|
|
@user.destroy
|
|
|
|
redirect_to users_path, notice: 'User was successfully deleted.'
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def set_user
|
|
|
|
@user = User.find(params[:id])
|
|
|
|
end
|
|
|
|
|
|
|
|
def user_params
|
2024-04-09 18:14:10 -05:00
|
|
|
params.require(:user).permit(
|
|
|
|
:email, :password, :password_confirmation, :remember_me,
|
|
|
|
:first_name, :last_name, :phone, :company,
|
2024-04-11 23:48:16 -05:00
|
|
|
:access_revoked, :access_start_date, :access_end_date,
|
|
|
|
access_periods_attributes: [:id, :start_date, :end_date, :destroy],
|
2024-04-09 18:14:10 -05:00
|
|
|
roles: []
|
|
|
|
)
|
2024-02-15 17:23:54 -06:00
|
|
|
end
|
2024-04-09 17:48:54 -05:00
|
|
|
|
2024-02-15 17:23:54 -06:00
|
|
|
|
|
|
|
def require_admin
|
|
|
|
unless current_user.admin?
|
|
|
|
redirect_to root_path, alert: 'Only admins are allowed to access this section.'
|
|
|
|
end
|
|
|
|
end
|
2024-04-03 18:32:15 -05:00
|
|
|
|
|
|
|
def assign_roles(user)
|
2024-04-09 17:48:54 -05:00
|
|
|
user.roles = []
|
|
|
|
params[:user][:roles].each do |role_name|
|
|
|
|
user.add_role(role_name) unless role_name.blank?
|
|
|
|
end if params[:user][:roles].present?
|
2024-04-03 18:32:15 -05:00
|
|
|
end
|
2024-04-09 17:48:54 -05:00
|
|
|
|
2024-04-03 18:32:15 -05:00
|
|
|
|
|
|
|
def update_user_roles(user, roles_names)
|
2024-04-11 23:48:16 -05:00
|
|
|
return if roles_names.blank? # Do nothing if no roles provided
|
|
|
|
|
|
|
|
user.roles.delete_all # Consider keeping this if role reset is truly intended
|
2024-04-03 18:32:15 -05:00
|
|
|
roles_names.each do |role_name|
|
2024-04-11 23:48:16 -05:00
|
|
|
user.add_role(role_name) unless role_name.blank?
|
2024-04-03 18:32:15 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2024-04-11 23:48:16 -05:00
|
|
|
|
2024-04-03 18:32:15 -05:00
|
|
|
|
2024-02-15 17:23:54 -06:00
|
|
|
end
|