|
|
|
class UsersController < ApplicationController
|
|
|
|
include Pagy::Backend
|
|
|
|
include Devise::Controllers::SignInOut
|
|
|
|
include Helpers::Email
|
|
|
|
before_action :authenticate_user!
|
|
|
|
before_action :find_resource, except: %i[new create]
|
|
|
|
before_action :authenticate_scope!, except: %i[new]
|
|
|
|
|
|
|
|
def index
|
|
|
|
redirect_to users_organisation_path(current_user.organisation) unless current_user.support?
|
|
|
|
|
|
|
|
@pagy, @users = pagy(User.all.where(active: true).includes(:organisation))
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html
|
|
|
|
format.csv do
|
|
|
|
if current_user.support?
|
|
|
|
send_data User.all.where(active: true).includes(:organisation).to_csv, filename: "users-#{Time.zone.now}.csv"
|
|
|
|
else
|
|
|
|
head :unauthorized
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def show; end
|
|
|
|
|
|
|
|
def update
|
|
|
|
if @user.update(user_params)
|
|
|
|
if @user == current_user
|
|
|
|
bypass_sign_in @user
|
|
|
|
flash[:notice] = I18n.t("devise.passwords.updated") if user_params.key?("password")
|
|
|
|
redirect_to account_path
|
|
|
|
else
|
|
|
|
redirect_to user_path(@user)
|
|
|
|
end
|
|
|
|
elsif user_params.key?("password")
|
|
|
|
format_error_messages
|
|
|
|
@minimum_password_length = User.password_length.min
|
|
|
|
render "devise/passwords/edit", locals: { resource: @user, resource_name: "user" }, status: :unprocessable_entity
|
|
|
|
else
|
|
|
|
format_error_messages
|
|
|
|
render :edit, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def new
|
|
|
|
@resource = User.new
|
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
@resource = User.new
|
|
|
|
if user_params["email"].empty?
|
|
|
|
@resource.errors.add :email, I18n.t("validations.email.blank")
|
|
|
|
elsif !email_valid?(user_params["email"])
|
|
|
|
@resource.errors.add :email, I18n.t("validations.email.invalid")
|
|
|
|
elsif user_params[:role] && !current_user.assignable_roles.key?(user_params[:role].to_sym)
|
|
|
|
@resource.errors.add :role, I18n.t("validations.role.invalid")
|
|
|
|
end
|
|
|
|
if @resource.errors.present?
|
|
|
|
render :new, status: :unprocessable_entity
|
|
|
|
else
|
|
|
|
user = User.create(user_params.merge(org_params).merge(password_params))
|
|
|
|
if user.persisted?
|
|
|
|
redirect_to created_user_redirect_path
|
|
|
|
else
|
|
|
|
@resource.errors.add :email, I18n.t("validations.email.taken")
|
|
|
|
render :new, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def edit_password
|
|
|
|
@minimum_password_length = User.password_length.min
|
|
|
|
render "devise/passwords/edit", locals: { resource: @user, resource_name: "user" }
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def format_error_messages
|
|
|
|
errors = @user.errors.to_hash
|
|
|
|
@user.errors.clear
|
|
|
|
errors.each do |attribute, message|
|
|
|
|
@user.errors.add attribute.to_sym, format_error_message(attribute, message)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def format_error_message(attribute, message)
|
|
|
|
[attribute.to_s.humanize.capitalize, message].join(" ")
|
|
|
|
end
|
|
|
|
|
|
|
|
def password_params
|
|
|
|
{ password: SecureRandom.hex(8) }
|
|
|
|
end
|
|
|
|
|
|
|
|
def org_params
|
|
|
|
return {} if current_user.support?
|
|
|
|
|
|
|
|
{ organisation: current_user.organisation }
|
|
|
|
end
|
|
|
|
|
|
|
|
def user_params
|
|
|
|
if @user == current_user
|
|
|
|
if current_user.data_coordinator? || current_user.support?
|
|
|
|
params.require(:user).permit(:email, :name, :password, :password_confirmation, :role, :is_dpo, :is_key_contact)
|
|
|
|
else
|
|
|
|
params.require(:user).permit(:email, :name, :password, :password_confirmation)
|
|
|
|
end
|
|
|
|
elsif current_user.data_coordinator?
|
|
|
|
params.require(:user).permit(:email, :name, :role, :is_dpo, :is_key_contact)
|
|
|
|
elsif current_user.support?
|
|
|
|
params.require(:user).permit(:email, :name, :role, :is_dpo, :is_key_contact, :organisation_id)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def created_user_redirect_path
|
|
|
|
if current_user.support?
|
|
|
|
users_path
|
|
|
|
else
|
|
|
|
users_organisation_path(current_user.organisation)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def find_resource
|
|
|
|
@user = params[:id] ? User.find_by(id: params[:id]) : current_user
|
|
|
|
end
|
|
|
|
|
|
|
|
def authenticate_scope!
|
|
|
|
if action_name == "create"
|
|
|
|
head :unauthorized and return unless current_user.data_coordinator? || current_user.support?
|
|
|
|
else
|
|
|
|
render_not_found and return unless (current_user.organisation == @user.organisation) || current_user.support?
|
|
|
|
render_not_found and return if action_name == "edit_password" && current_user != @user
|
|
|
|
render_not_found and return unless action_name == "show" ||
|
|
|
|
current_user.data_coordinator? || current_user.support? || current_user == @user
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|