You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
61 lines
1.5 KiB
61 lines
1.5 KiB
class UserPolicy |
|
attr_reader :current_user, :user |
|
|
|
def initialize(current_user, user) |
|
@current_user = current_user |
|
@user = user |
|
end |
|
|
|
def edit_password? |
|
@current_user == @user |
|
end |
|
|
|
def edit_roles? |
|
(@current_user.data_coordinator? || @current_user.support?) && @user.active? |
|
end |
|
|
|
%w[ |
|
edit_roles? |
|
edit_dpo? |
|
edit_key_contact? |
|
].each do |method_name| |
|
define_method method_name do |
|
(@current_user.data_coordinator? || @current_user.support?) && @user.active? |
|
end |
|
end |
|
|
|
%w[ |
|
edit_emails? |
|
edit_telephone_numbers? |
|
edit_names? |
|
].each do |method_name| |
|
define_method method_name do |
|
(@current_user == @user || @current_user.data_coordinator? || @current_user.support?) && @user.active? |
|
end |
|
end |
|
|
|
def delete_confirmation? |
|
delete? |
|
end |
|
|
|
def delete? |
|
return false unless current_user.support? |
|
return false unless user.status == :deactivated |
|
|
|
!has_any_logs_in_editable_collection_period && !has_signed_data_protection_agreement? |
|
end |
|
|
|
private |
|
|
|
def has_any_logs_in_editable_collection_period |
|
editable_from_date = FormHandler.instance.earliest_open_for_editing_collection_start_date |
|
|
|
LettingsLog.where(assigned_to_id: user.id).after_date(editable_from_date).or(LettingsLog.where(startdate: nil, assigned_to_id: user.id)).any? |
|
end |
|
|
|
def has_signed_data_protection_agreement? |
|
return false unless user.is_dpo? && user.organisation.data_protection_confirmed? |
|
|
|
user.organisation.data_protection_confirmation.data_protection_officer == user |
|
end |
|
end
|
|
|