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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
# frozen_string_literal: true
module InviteMembersHelper
include Gitlab::Utils::StrongMemoize
def can_invite_members_for_project?(project)
# do not use the can_admin_project_member? helper here due to structure of the view and how membership_locked?
# is leveraged for inviting groups
can?(current_user, :admin_project_member, project)
end
def invite_accepted_notice(member)
case member.source
when Project
_("You have been granted %{member_human_access} access to project %{name}.") %
{ member_human_access: member.human_access, name: member.source.name }
when Group
_("You have been granted %{member_human_access} access to group %{name}.") %
{ member_human_access: member.human_access, name: member.source.name }
end
end
# Overridden in EE
def common_invite_group_modal_data(source, member_class, is_project)
{
id: source.id,
root_id: source.root_ancestor.id,
name: source.name,
default_access_level: Gitlab::Access::GUEST,
invalid_groups: source.related_group_ids,
help_link: help_page_url('user/permissions'),
is_project: is_project,
access_levels: member_class.permissible_access_level_roles(current_user, source).to_json,
full_path: source.full_path
}.merge(group_select_data(source))
end
# Overridden in EE
def common_invite_modal_dataset(source)
{
id: source.id,
root_id: source.root_ancestor&.id,
name: source.name,
default_access_level: Gitlab::Access::GUEST,
full_path: source.full_path
}
end
private
def group_select_data(source)
if source.root_ancestor.prevent_sharing_groups_outside_hierarchy
{ groups_filter: 'descendant_groups', parent_id: source.root_ancestor.id }
else
{}
end
end
# Overridden in EE
def users_filter_data(group)
{}
end
end
InviteMembersHelper.prepend_mod_with('InviteMembersHelper')
|