summaryrefslogtreecommitdiff
path: root/app/graphql/types/concerns/gitlab_style_deprecations.rb
diff options
context:
space:
mode:
Diffstat (limited to 'app/graphql/types/concerns/gitlab_style_deprecations.rb')
-rw-r--r--app/graphql/types/concerns/gitlab_style_deprecations.rb36
1 files changed, 0 insertions, 36 deletions
diff --git a/app/graphql/types/concerns/gitlab_style_deprecations.rb b/app/graphql/types/concerns/gitlab_style_deprecations.rb
deleted file mode 100644
index 859a27cac4c..00000000000
--- a/app/graphql/types/concerns/gitlab_style_deprecations.rb
+++ /dev/null
@@ -1,36 +0,0 @@
-# frozen_string_literal: true
-
-# Concern for handling GraphQL deprecations.
-# https://docs.gitlab.com/ee/development/api_graphql_styleguide.html#deprecating-schema-items
-module GitlabStyleDeprecations
- extend ActiveSupport::Concern
-
- included do
- attr_accessor :deprecation
- end
-
- def visible?(ctx)
- super && ctx[:remove_deprecated] == true ? deprecation.nil? : true
- end
-
- private
-
- # Set deprecation, mutate the arguments
- def init_gitlab_deprecation(kwargs)
- if kwargs[:deprecation_reason].present?
- raise ArgumentError, 'Use `deprecated` property instead of `deprecation_reason`. ' \
- 'See https://docs.gitlab.com/ee/development/api_graphql_styleguide.html#deprecating-schema-items'
- end
-
- # GitLab allows items to be marked as "alpha", which leverages GraphQL deprecations.
- deprecation_args = kwargs.extract!(:alpha, :deprecated)
-
- self.deprecation = ::Gitlab::Graphql::Deprecation.parse(**deprecation_args)
- return unless deprecation
-
- raise ArgumentError, "Bad deprecation. #{deprecation.errors.full_messages.to_sentence}" unless deprecation.valid?
-
- kwargs[:deprecation_reason] = deprecation.deprecation_reason
- kwargs[:description] = deprecation.edit_description(kwargs[:description])
- end
-end