31 lines
1.2 KiB
Ruby
31 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
# Concern for handling deprecation arguments.
|
|
# https://docs.gitlab.com/ee/development/api_graphql_styleguide.html#deprecating-fields-and-enum-values
|
|
module GitlabStyleDeprecations
|
|
extend ActiveSupport::Concern
|
|
|
|
private
|
|
|
|
def 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-fields-arguments-and-enum-values'
|
|
end
|
|
|
|
deprecation = kwargs.delete(:deprecated)
|
|
return kwargs unless deprecation
|
|
|
|
milestone, reason = deprecation.values_at(:milestone, :reason).map(&:presence)
|
|
|
|
raise ArgumentError, 'Please provide a `milestone` within `deprecated`' unless milestone
|
|
raise ArgumentError, 'Please provide a `reason` within `deprecated`' unless reason
|
|
raise ArgumentError, '`milestone` must be a `String`' unless milestone.is_a?(String)
|
|
|
|
deprecated_in = "Deprecated in #{milestone}"
|
|
kwargs[:deprecation_reason] = "#{reason}. #{deprecated_in}."
|
|
kwargs[:description] += " #{deprecated_in}: #{reason}." if kwargs[:description]
|
|
|
|
kwargs
|
|
end
|
|
end
|