summaryrefslogtreecommitdiff
path: root/app/policies/project_member_policy.rb
blob: 40ba30fce5efe8e6f99ea6ddc49fb44c452a4c51 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
# frozen_string_literal: true

class ProjectMemberPolicy < BasePolicy
  delegate { @subject.project }

  condition(:target_is_holder_of_the_personal_namespace, scope: :subject) do
    @subject.project.personal_namespace_holder?(@subject.user)
  end

  condition(:target_is_self) { @user && @subject.user == @user }
  condition(:project_bot) { @subject.user&.project_bot? }

  rule { anonymous }.prevent_all

  rule { target_is_holder_of_the_personal_namespace }.policy do
    prevent :update_project_member
    prevent :destroy_project_member
  end

  rule { ~project_bot & can?(:admin_project_member) }.policy do
    enable :update_project_member
    enable :destroy_project_member
  end

  rule { project_bot & can?(:admin_project_member) }.enable :destroy_project_bot_member

  rule { target_is_self }.enable :destroy_project_member
end