Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'app/services/bulk_imports/create_service.rb')
-rw-r--r--app/services/bulk_imports/create_service.rb33
1 files changed, 32 insertions, 1 deletions
diff --git a/app/services/bulk_imports/create_service.rb b/app/services/bulk_imports/create_service.rb
index d3c6dcca588..124b5964232 100644
--- a/app/services/bulk_imports/create_service.rb
+++ b/app/services/bulk_imports/create_service.rb
@@ -57,11 +57,14 @@ module BulkImports
bulk_import = BulkImport.create!(
user: current_user,
source_type: 'gitlab',
- source_version: client.instance_version
+ source_version: client.instance_version,
+ source_enterprise: client.instance_enterprise
)
bulk_import.create_configuration!(credentials.slice(:url, :access_token))
Array.wrap(params).each do |entity|
+ track_access_level(entity)
+
BulkImports::Entity.create!(
bulk_import: bulk_import,
source_type: entity[:source_type],
@@ -75,6 +78,34 @@ module BulkImports
end
end
+ def track_access_level(entity)
+ Gitlab::Tracking.event(
+ self.class.name,
+ 'create',
+ label: 'import_access_level',
+ user: current_user,
+ extra: { user_role: user_role(entity[:destination_namespace]), import_type: 'bulk_import_group' }
+ )
+ end
+
+ def user_role(destination_namespace)
+ namespace = Namespace.find_by_full_path(destination_namespace)
+ # if there is no parent namespace we assume user will be group creator/owner
+ return owner_role unless destination_namespace
+ return owner_role unless namespace
+ return owner_role unless namespace.group_namespace? # user namespace
+
+ membership = current_user.group_members.find_by(source_id: namespace.id) # rubocop:disable CodeReuse/ActiveRecord
+
+ return 'Not a member' unless membership
+
+ Gitlab::Access.human_access(membership.access_level)
+ end
+
+ def owner_role
+ Gitlab::Access.human_access(Gitlab::Access::OWNER)
+ end
+
def client
@client ||= BulkImports::Clients::HTTP.new(
url: @credentials[:url],