Commit ef1785c1 authored by Alex Kalderimis's avatar Alex Kalderimis

Replace complex map union with MergeHash

parent 37a0205d
...@@ -4,6 +4,7 @@ module GraphqlHelpers ...@@ -4,6 +4,7 @@ module GraphqlHelpers
MutationDefinition = Struct.new(:query, :variables) MutationDefinition = Struct.new(:query, :variables)
NoData = Class.new(StandardError) NoData = Class.new(StandardError)
UnauthorizedObject = Class.new(StandardError)
# makes an underscored string look like a fieldname # makes an underscored string look like a fieldname
# "merge_request" => "mergeRequest" # "merge_request" => "mergeRequest"
...@@ -127,15 +128,12 @@ module GraphqlHelpers ...@@ -127,15 +128,12 @@ module GraphqlHelpers
end end
def serialize_variables(variables) def serialize_variables(variables)
return unless variables
return variables if variables.is_a?(String) return variables if variables.is_a?(String)
variables = variables.is_a?(Array) ? variables.map(&:to_h).reduce { |a, b| a.merge(b) } : variables.try(:to_h) ::Gitlab::Utils::MergeHash.merge(Array.wrap(variables).map(&:to_h)).to_json
variables.to_json
end end
UnauthorizedObject = Class.new(StandardError)
def resolve_field(name, object, args = {}, current_user: nil) def resolve_field(name, object, args = {}, current_user: nil)
q = GraphQL::Query.new(GitlabSchema) q = GraphQL::Query.new(GitlabSchema)
context = GraphQL::Query::Context.new(query: q, object: object, values: { current_user: current_user }) context = GraphQL::Query::Context.new(query: q, object: object, values: { current_user: current_user })
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment