blob: bb389b7a3abcf30771afccf149bec94056163303 (
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
# frozen_string_literal: true
class ProjectMemberPresenter < MemberPresenter
presents ::ProjectMember
def access_level_roles
ProjectMember.permissible_access_level_roles(current_user, source)
end
def can_remove?
# If this user is attempting to manage an Owner member and doesn't have permission, do not allow
return can_manage_owners? if member.owner?
super
end
def can_update?
# If this user is attempting to manage an Owner member and doesn't have permission, do not allow
return can_manage_owners? if member.owner?
super
end
def last_owner?
# all owners of a project in a group are removable.
# but in personal projects, the namespace holder is not removable.
member.holder_of_the_personal_namespace?
end
private
def admin_member_permission
:admin_project_member
end
def update_member_permission
:update_project_member
end
def destroy_member_permission
:destroy_project_member
end
def can_manage_owners?
can?(current_user, :manage_owners, source)
end
end
ProjectMemberPresenter.prepend_mod_with('ProjectMemberPresenter')
|