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 'lib/bulk_imports/groups/transformers/member_attributes_transformer.rb')
-rw-r--r--lib/bulk_imports/groups/transformers/member_attributes_transformer.rb56
1 files changed, 56 insertions, 0 deletions
diff --git a/lib/bulk_imports/groups/transformers/member_attributes_transformer.rb b/lib/bulk_imports/groups/transformers/member_attributes_transformer.rb
new file mode 100644
index 00000000000..622f5b60ffe
--- /dev/null
+++ b/lib/bulk_imports/groups/transformers/member_attributes_transformer.rb
@@ -0,0 +1,56 @@
+# frozen_string_literal: true
+
+module BulkImports
+ module Groups
+ module Transformers
+ class MemberAttributesTransformer
+ def initialize(*); end
+
+ def transform(context, data)
+ data
+ .then { |data| add_user(data) }
+ .then { |data| add_access_level(data) }
+ .then { |data| add_author(data, context) }
+ end
+
+ private
+
+ def add_user(data)
+ user = find_user(data&.dig('user', 'public_email'))
+
+ return unless user
+
+ data
+ .except('user')
+ .merge('user_id' => user.id)
+ end
+
+ def find_user(email)
+ return unless email
+
+ User.find_by_any_email(email, confirmed: true)
+ end
+
+ def add_access_level(data)
+ access_level = data&.dig('access_level', 'integer_value')
+
+ return unless valid_access_level?(access_level)
+
+ data.merge('access_level' => access_level)
+ end
+
+ def valid_access_level?(access_level)
+ Gitlab::Access
+ .options_with_owner
+ .value?(access_level)
+ end
+
+ def add_author(data, context)
+ return unless data
+
+ data.merge('created_by_id' => context.current_user.id)
+ end
+ end
+ end
+ end
+end