blob: 53c547cde9e10a7afbf42a85a370608e1811db5a (
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
50
51
52
53
54
|
# frozen_string_literal: true
module Projects
module ImportExport
class ProjectExportPresenter < Gitlab::View::Presenter::Delegated
# NOTE: This is needed because this presenter is serialized to JSON,
# and we need to make sure that `#as_json` is called in this class so
# it will use the overriden attributes below. Otherwise the call is
# delegated to the model and will use the original methods.
include ActiveModel::Serializers::JSON
presents ::Project, as: :project
delegator_override_with ActiveModel::Serializers::JSON
delegator_override_with ActiveModel::Naming
delegator_override :include_root_in_json, :include_root_in_json?
delegator_override :project_members
def project_members
super + converted_group_members
end
delegator_override :description
def description
self.respond_to?(:override_description) ? override_description : super
end
delegator_override :protected_branches
def protected_branches
project.exported_protected_branches
end
private
def converted_group_members
group_members.each do |group_member|
group_member.source_type = 'Project' # Make group members project members of the future import
end
end
# rubocop: disable CodeReuse/ActiveRecord
def group_members
return [] unless current_user.can?(:admin_group, project.group)
# We need `.connected_to_user` here otherwise when a group has an
# invitee, it would make the following query return 0 rows since a NULL
# user_id would be present in the subquery
non_null_user_ids = project.project_members.connected_to_user.select(:user_id)
GroupMembersFinder.new(project.group).execute.where.not(user_id: non_null_user_ids)
end
# rubocop: enable CodeReuse/ActiveRecord
end
end
end
|