graphql 1.13.5 → 1.13.9

Sign up to get free protection for your applications and to get access to all the features.
Files changed (53) hide show
  1. checksums.yaml +4 -4
  2. data/lib/generators/graphql/core.rb +0 -7
  3. data/lib/generators/graphql/enum_generator.rb +4 -10
  4. data/lib/generators/graphql/field_extractor.rb +31 -0
  5. data/lib/generators/graphql/input_generator.rb +50 -0
  6. data/lib/generators/graphql/install/mutation_root_generator.rb +34 -0
  7. data/lib/generators/graphql/{templates → install/templates}/base_mutation.erb +0 -0
  8. data/lib/generators/graphql/{templates → install/templates}/mutation_type.erb +0 -0
  9. data/lib/generators/graphql/install_generator.rb +1 -1
  10. data/lib/generators/graphql/interface_generator.rb +7 -7
  11. data/lib/generators/graphql/mutation_create_generator.rb +22 -0
  12. data/lib/generators/graphql/mutation_delete_generator.rb +22 -0
  13. data/lib/generators/graphql/mutation_generator.rb +5 -30
  14. data/lib/generators/graphql/mutation_update_generator.rb +22 -0
  15. data/lib/generators/graphql/object_generator.rb +8 -37
  16. data/lib/generators/graphql/orm_mutations_base.rb +40 -0
  17. data/lib/generators/graphql/scalar_generator.rb +4 -2
  18. data/lib/generators/graphql/templates/enum.erb +5 -1
  19. data/lib/generators/graphql/templates/input.erb +9 -0
  20. data/lib/generators/graphql/templates/interface.erb +4 -2
  21. data/lib/generators/graphql/templates/mutation.erb +1 -1
  22. data/lib/generators/graphql/templates/mutation_create.erb +20 -0
  23. data/lib/generators/graphql/templates/mutation_delete.erb +20 -0
  24. data/lib/generators/graphql/templates/mutation_update.erb +21 -0
  25. data/lib/generators/graphql/templates/object.erb +4 -2
  26. data/lib/generators/graphql/templates/scalar.erb +3 -1
  27. data/lib/generators/graphql/templates/union.erb +4 -2
  28. data/lib/generators/graphql/type_generator.rb +46 -9
  29. data/lib/generators/graphql/union_generator.rb +5 -5
  30. data/lib/graphql/analysis/ast/visitor.rb +2 -1
  31. data/lib/graphql/dataloader/source.rb +2 -2
  32. data/lib/graphql/date_encoding_error.rb +16 -0
  33. data/lib/graphql/execution/interpreter/runtime.rb +29 -14
  34. data/lib/graphql/introspection/directive_location_enum.rb +2 -2
  35. data/lib/graphql/introspection/directive_type.rb +2 -0
  36. data/lib/graphql/introspection/schema_type.rb +5 -0
  37. data/lib/graphql/introspection/type_type.rb +9 -3
  38. data/lib/graphql/introspection.rb +4 -1
  39. data/lib/graphql/pagination/relation_connection.rb +4 -4
  40. data/lib/graphql/rubocop/graphql/default_required_true.rb +4 -4
  41. data/lib/graphql/schema/argument.rb +18 -1
  42. data/lib/graphql/schema/directive.rb +11 -0
  43. data/lib/graphql/schema/field.rb +21 -12
  44. data/lib/graphql/schema/input_object.rb +1 -1
  45. data/lib/graphql/schema/loader.rb +3 -0
  46. data/lib/graphql/schema/scalar.rb +12 -0
  47. data/lib/graphql/schema.rb +12 -5
  48. data/lib/graphql/types/iso_8601_date.rb +13 -5
  49. data/lib/graphql/types/iso_8601_date_time.rb +8 -1
  50. data/lib/graphql/types/relay/connection_behaviors.rb +2 -1
  51. data/lib/graphql/version.rb +1 -1
  52. data/lib/graphql.rb +12 -0
  53. metadata +20 -8
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 532fad107d6e2086bf07c1501a5a14aff55bb7dbafb5d6813a2fb902ac9eb1ff
4
- data.tar.gz: 87e0d968351c5e6bf74d0036cfcb87ec0114d575d632794f1b71f2c40e44e4af
3
+ metadata.gz: 6d96eacd39201c81802bc7a525b5ff5392e918582ef7814a14c5f650d82fa1ca
4
+ data.tar.gz: 45f26d9425c711c1d91026837f900fa172a511258a95ae1ba9356c76fcf905bb
5
5
  SHA512:
6
- metadata.gz: 4721a304fde79ad452e4d6c265841c04c300f34c23c727d374bb584d289277c6352dad5b572d1acc7b79311040b84c49f67a5ab2c34749a27dd366f2fdae3bb3
7
- data.tar.gz: c773bcd7603ab6c665e0058fe9852fa241f91db068fa7b1cdb382ddf36e90ffeb4134891ccb37786c60b95e5efb6dc259338aeecb70138fb74122c49277711bd
6
+ metadata.gz: bc31be3568df7a167eda2ae0c81ae05999cc34de47a5a0aeae082795b7ae4750d4b1b17c744e5f6100cf4b9039e51371f0fb82c37cd1ceb72febf1bb2ef898fd
7
+ data.tar.gz: 723da375b4060fc8d348a7b84261fe2c3ed6f06c32ad346feaeef7ec1dee11a91666f91a2d38c0f750c0a2373114f9a4f7a9d4f0775e28bac72b3e5c954a2dc4
@@ -25,13 +25,6 @@ module Graphql
25
25
  end
26
26
  end
27
27
 
28
- def create_mutation_root_type
29
- create_dir("#{options[:directory]}/mutations")
30
- template("base_mutation.erb", "#{options[:directory]}/mutations/base_mutation.rb", { skip: true })
31
- template("mutation_type.erb", "#{options[:directory]}/types/mutation_type.rb", { skip: true })
32
- insert_root_type('mutation', 'MutationType')
33
- end
34
-
35
28
  def schema_file_path
36
29
  "#{options[:directory]}/#{schema_name.underscore}.rb"
37
30
  end
@@ -13,20 +13,14 @@ module Graphql
13
13
  desc "Create a GraphQL::EnumType with the given name and values"
14
14
  source_root File.expand_path('../templates', __FILE__)
15
15
 
16
- argument :values,
17
- type: :array,
18
- default: [],
19
- banner: "value{:ruby_value} value{:ruby_value} ...",
20
- desc: "Values for this enum (if present, ruby_value will be inserted verbatim)"
16
+ private
21
17
 
22
- def create_type_file
23
- template "enum.erb", "#{options[:directory]}/types/#{type_file_name}.rb"
18
+ def graphql_type
19
+ "enum"
24
20
  end
25
21
 
26
- private
27
-
28
22
  def prepared_values
29
- values.map { |v| v.split(":", 2) }
23
+ custom_fields.map { |v| v.split(":", 2) }
30
24
  end
31
25
  end
32
26
  end
@@ -0,0 +1,31 @@
1
+ # frozen_string_literal: true
2
+ require 'rails/generators/base'
3
+
4
+ module Graphql
5
+ module Generators
6
+ module FieldExtractor
7
+ def fields
8
+ columns = []
9
+ columns += (klass&.columns&.map { |c| generate_column_string(c) } || [])
10
+ columns + custom_fields
11
+ end
12
+
13
+ def generate_column_string(column)
14
+ name = column.name
15
+ required = column.null ? "" : "!"
16
+ type = column_type_string(column)
17
+ "#{name}:#{required}#{type}"
18
+ end
19
+
20
+ def column_type_string(column)
21
+ column.name == "id" ? "ID" : column.type.to_s.camelize
22
+ end
23
+
24
+ def klass
25
+ @klass ||= Module.const_get(name.camelize)
26
+ rescue NameError
27
+ @klass = nil
28
+ end
29
+ end
30
+ end
31
+ end
@@ -0,0 +1,50 @@
1
+ # frozen_string_literal: true
2
+ require 'generators/graphql/type_generator'
3
+ require 'generators/graphql/field_extractor'
4
+
5
+ module Graphql
6
+ module Generators
7
+ # Generate an input type by name,
8
+ # with the specified fields.
9
+ #
10
+ # ```
11
+ # rails g graphql:object PostType name:string!
12
+ # ```
13
+ class InputGenerator < TypeGeneratorBase
14
+ desc "Create a GraphQL::InputObjectType with the given name and fields"
15
+ source_root File.expand_path('../templates', __FILE__)
16
+ include FieldExtractor
17
+
18
+ def self.normalize_type_expression(type_expression, mode:, null: true)
19
+ case type_expression.camelize
20
+ when "Text", "Citext"
21
+ ["String", null]
22
+ when "Decimal"
23
+ ["Float", null]
24
+ when "DateTime", "Datetime"
25
+ ["GraphQL::Types::ISO8601DateTime", null]
26
+ when "Date"
27
+ ["GraphQL::Types::ISO8601Date", null]
28
+ when "Json", "Jsonb", "Hstore"
29
+ ["GraphQL::Types::JSON", null]
30
+ else
31
+ super
32
+ end
33
+ end
34
+
35
+ private
36
+
37
+ def graphql_type
38
+ "input"
39
+ end
40
+
41
+ def type_ruby_name
42
+ super.gsub(/Type\z/, "InputType")
43
+ end
44
+
45
+ def type_file_name
46
+ super.gsub(/_type\z/, "_input_type")
47
+ end
48
+ end
49
+ end
50
+ end
@@ -0,0 +1,34 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "rails/generators/base"
4
+ require_relative "../core"
5
+
6
+ module Graphql
7
+ module Generators
8
+ module Install
9
+ class MutationRootGenerator < Rails::Generators::Base
10
+ include Core
11
+
12
+ desc "Create mutation base type, mutation root tipe, and adds the latter to the schema"
13
+ source_root File.expand_path('../templates', __FILE__)
14
+
15
+ class_option :schema,
16
+ type: :string,
17
+ default: nil,
18
+ desc: "Name for the schema constant (default: {app_name}Schema)"
19
+
20
+ class_option :skip_keeps,
21
+ type: :boolean,
22
+ default: false,
23
+ desc: "Skip .keep files for source control"
24
+
25
+ def generate
26
+ create_dir("#{options[:directory]}/mutations")
27
+ template("base_mutation.erb", "#{options[:directory]}/mutations/base_mutation.rb", { skip: true })
28
+ template("mutation_type.erb", "#{options[:directory]}/types/mutation_type.rb", { skip: true })
29
+ insert_root_type('mutation', 'MutationType')
30
+ end
31
+ end
32
+ end
33
+ end
34
+ end
@@ -109,7 +109,7 @@ module Graphql
109
109
  template("query_type.erb", "#{options[:directory]}/types/query_type.rb")
110
110
  insert_root_type('query', 'QueryType')
111
111
 
112
- create_mutation_root_type unless options.skip_mutation_root_type?
112
+ invoke "graphql:install:mutation_root" unless options.skip_mutation_root_type?
113
113
 
114
114
  template("graphql_controller.erb", "app/controllers/graphql_controller.rb")
115
115
  route('post "/graphql", to: "graphql#execute"')
@@ -13,14 +13,14 @@ module Graphql
13
13
  desc "Create a GraphQL::InterfaceType with the given name and fields"
14
14
  source_root File.expand_path('../templates', __FILE__)
15
15
 
16
- argument :fields,
17
- type: :array,
18
- default: [],
19
- banner: "name:type name:type ...",
20
- desc: "Fields for this interface (type may be expressed as Ruby or GraphQL)"
16
+ private
21
17
 
22
- def create_type_file
23
- template "interface.erb", "#{options[:directory]}/types/#{type_file_name}.rb"
18
+ def graphql_type
19
+ "interface"
20
+ end
21
+
22
+ def fields
23
+ custom_fields
24
24
  end
25
25
  end
26
26
  end
@@ -0,0 +1,22 @@
1
+ # frozen_string_literal: true
2
+ require_relative 'orm_mutations_base'
3
+
4
+ module Graphql
5
+ module Generators
6
+ # TODO: What other options should be supported?
7
+ #
8
+ # @example Generate a `GraphQL::Schema::RelayClassicMutation` by name
9
+ # rails g graphql:mutation CreatePostMutation
10
+ class MutationCreateGenerator < OrmMutationsBase
11
+
12
+ desc "Scaffold a Relay Classic ORM create mutation for the given model class"
13
+ source_root File.expand_path('../templates', __FILE__)
14
+
15
+ private
16
+
17
+ def operation_type
18
+ "create"
19
+ end
20
+ end
21
+ end
22
+ end
@@ -0,0 +1,22 @@
1
+ # frozen_string_literal: true
2
+ require_relative 'orm_mutations_base'
3
+
4
+ module Graphql
5
+ module Generators
6
+ # TODO: What other options should be supported?
7
+ #
8
+ # @example Generate a `GraphQL::Schema::RelayClassicMutation` by name
9
+ # rails g graphql:mutation CreatePostMutation
10
+ class MutationDeleteGenerator < OrmMutationsBase
11
+
12
+ desc "Scaffold a Relay Classic ORM delete mutation for the given model class"
13
+ source_root File.expand_path('../templates', __FILE__)
14
+
15
+ private
16
+
17
+ def operation_type
18
+ "delete"
19
+ end
20
+ end
21
+ end
22
+ end
@@ -9,47 +9,22 @@ module Graphql
9
9
  #
10
10
  # @example Generate a `GraphQL::Schema::RelayClassicMutation` by name
11
11
  # rails g graphql:mutation CreatePostMutation
12
- class MutationGenerator < Rails::Generators::Base
12
+ class MutationGenerator < Rails::Generators::NamedBase
13
13
  include Core
14
14
 
15
15
  desc "Create a Relay Classic mutation by name"
16
16
  source_root File.expand_path('../templates', __FILE__)
17
17
 
18
- argument :name, type: :string
19
-
20
- def initialize(args, *options) # :nodoc:
21
- # Unfreeze name in case it's given as a frozen string
22
- args[0] = args[0].dup if args[0].is_a?(String) && args[0].frozen?
23
- super
24
-
25
- assign_names!(name)
26
- end
27
-
28
- attr_reader :file_name, :mutation_name, :field_name
29
-
30
18
  def create_mutation_file
31
- unless @behavior == :revoke
32
- create_mutation_root_type
33
- else
34
- log :gsub, "#{options[:directory]}/types/mutation_type.rb"
35
- end
36
-
37
- template "mutation.erb", "#{options[:directory]}/mutations/#{file_name}.rb"
19
+ template "mutation.erb", File.join(options[:directory], "/mutations/", class_path, "#{file_name}.rb")
38
20
 
39
21
  sentinel = /class .*MutationType\s*<\s*[^\s]+?\n/m
40
22
  in_root do
41
- gsub_file "#{options[:directory]}/types/mutation_type.rb", / \# TODO\: Add Mutations as fields\s*\n/m, ""
42
- inject_into_file "#{options[:directory]}/types/mutation_type.rb", " field :#{field_name}, mutation: Mutations::#{mutation_name}\n", after: sentinel, verbose: false, force: false
23
+ path = "#{options[:directory]}/types/mutation_type.rb"
24
+ invoke "graphql:install:mutation_root" unless File.exist?(path)
25
+ inject_into_file "#{options[:directory]}/types/mutation_type.rb", " field :#{file_name}, mutation: Mutations::#{class_name}\n", after: sentinel, verbose: false, force: false
43
26
  end
44
27
  end
45
-
46
- private
47
-
48
- def assign_names!(name)
49
- @field_name = name.camelize.underscore
50
- @mutation_name = name.camelize(:upper)
51
- @file_name = name.camelize.underscore
52
- end
53
28
  end
54
29
  end
55
30
  end
@@ -0,0 +1,22 @@
1
+ # frozen_string_literal: true
2
+ require_relative 'orm_mutations_base'
3
+
4
+ module Graphql
5
+ module Generators
6
+ # TODO: What other options should be supported?
7
+ #
8
+ # @example Generate a `GraphQL::Schema::RelayClassicMutation` by name
9
+ # rails g graphql:mutation CreatePostMutation
10
+ class MutationUpdateGenerator < OrmMutationsBase
11
+
12
+ desc "Scaffold a Relay Classic ORM update mutation for the given model class"
13
+ source_root File.expand_path('../templates', __FILE__)
14
+
15
+ private
16
+
17
+ def operation_type
18
+ "update"
19
+ end
20
+ end
21
+ end
22
+ end
@@ -1,5 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
  require 'generators/graphql/type_generator'
3
+ require 'generators/graphql/field_extractor'
3
4
 
4
5
  module Graphql
5
6
  module Generators
@@ -15,31 +16,16 @@ module Graphql
15
16
  desc "Create a GraphQL::ObjectType with the given name and fields." \
16
17
  "If the given type name matches an existing ActiveRecord model, the generated type will automatically include fields for the models database columns."
17
18
  source_root File.expand_path('../templates', __FILE__)
18
-
19
- argument :custom_fields,
20
- type: :array,
21
- default: [],
22
- banner: "name:type name:type ...",
23
- desc: "Fields for this object (type may be expressed as Ruby or GraphQL)"
19
+ include FieldExtractor
24
20
 
25
21
  class_option :node,
26
22
  type: :boolean,
27
23
  default: false,
28
24
  desc: "Include the Relay Node interface"
29
25
 
30
- def create_type_file
31
- template "object.erb", "#{options[:directory]}/types/#{type_file_name}.rb"
32
- end
33
-
34
- def fields
35
- columns = []
36
- columns += klass.columns.map { |c| generate_column_string(c) } if class_exists?
37
- columns + custom_fields
38
- end
39
-
40
26
  def self.normalize_type_expression(type_expression, mode:, null: true)
41
- case type_expression
42
- when "Text"
27
+ case type_expression.camelize
28
+ when "Text", "Citext"
43
29
  ["String", null]
44
30
  when "Decimal"
45
31
  ["Float", null]
@@ -47,6 +33,8 @@ module Graphql
47
33
  ["GraphQL::Types::ISO8601DateTime", null]
48
34
  when "Date"
49
35
  ["GraphQL::Types::ISO8601Date", null]
36
+ when "Json", "Jsonb", "Hstore"
37
+ ["GraphQL::Types::JSON", null]
50
38
  else
51
39
  super
52
40
  end
@@ -54,25 +42,8 @@ module Graphql
54
42
 
55
43
  private
56
44
 
57
- def generate_column_string(column)
58
- name = column.name
59
- required = column.null ? "" : "!"
60
- type = column_type_string(column)
61
- "#{name}:#{required}#{type}"
62
- end
63
-
64
- def column_type_string(column)
65
- column.name == "id" ? "ID" : column.type.to_s.camelize
66
- end
67
-
68
- def class_exists?
69
- klass.is_a?(Class) && klass.ancestors.include?(ActiveRecord::Base)
70
- rescue NameError
71
- return false
72
- end
73
-
74
- def klass
75
- @klass ||= Module.const_get(type_name.camelize)
45
+ def graphql_type
46
+ "object"
76
47
  end
77
48
  end
78
49
  end
@@ -0,0 +1,40 @@
1
+ # frozen_string_literal: true
2
+ require 'rails/generators'
3
+ require 'rails/generators/named_base'
4
+ require_relative 'core'
5
+
6
+ module Graphql
7
+ module Generators
8
+ # TODO: What other options should be supported?
9
+ #
10
+ # @example Generate a `GraphQL::Schema::RelayClassicMutation` by name
11
+ # rails g graphql:mutation CreatePostMutation
12
+ class OrmMutationsBase < Rails::Generators::NamedBase
13
+ include Core
14
+ include Rails::Generators::ResourceHelpers
15
+
16
+ desc "Create a Relay Classic mutation by name"
17
+
18
+ class_option :orm, banner: "NAME", type: :string, required: true,
19
+ desc: "ORM to generate the controller for"
20
+
21
+ class_option 'namespaced_types',
22
+ type: :boolean,
23
+ required: false,
24
+ default: false,
25
+ banner: "Namespaced",
26
+ desc: "If the generated types will be namespaced"
27
+
28
+ def create_mutation_file
29
+ template "mutation_#{operation_type}.erb", File.join(options[:directory], "/mutations/", class_path, "#{file_name}_#{operation_type}.rb")
30
+
31
+ sentinel = /class .*MutationType\s*<\s*[^\s]+?\n/m
32
+ in_root do
33
+ path = "#{options[:directory]}/types/mutation_type.rb"
34
+ invoke "graphql:install:mutation_root" unless File.exist?(path)
35
+ inject_into_file "#{options[:directory]}/types/mutation_type.rb", " field :#{file_name}_#{operation_type}, mutation: Mutations::#{class_name}#{operation_type.classify}\n", after: sentinel, verbose: false, force: false
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
@@ -12,8 +12,10 @@ module Graphql
12
12
  desc "Create a GraphQL::ScalarType with the given name"
13
13
  source_root File.expand_path('../templates', __FILE__)
14
14
 
15
- def create_type_file
16
- template "scalar.erb", "#{options[:directory]}/types/#{type_file_name}.rb"
15
+ private
16
+
17
+ def graphql_type
18
+ "scalar"
17
19
  end
18
20
  end
19
21
  end
@@ -1,6 +1,10 @@
1
+ # frozen_string_literal: true
2
+
1
3
  <% module_namespacing_when_supported do -%>
2
4
  module Types
3
- class <%= type_ruby_name.split('::')[-1] %> < Types::BaseEnum
5
+ class <%= ruby_class_name %> < Types::BaseEnum
6
+ description "<%= human_name %> enum"
7
+
4
8
  <% prepared_values.each do |v| %> value "<%= v[0] %>"<%= v.length > 1 ? ", value: #{v[1]}" : "" %>
5
9
  <% end %> end
6
10
  end
@@ -0,0 +1,9 @@
1
+ # frozen_string_literal: true
2
+
3
+ <% module_namespacing_when_supported do -%>
4
+ module Types
5
+ class <%= ruby_class_name %> < Types::BaseInputObject
6
+ <% normalized_fields.each do |f| %> <%= f.to_input_argument %>
7
+ <% end %> end
8
+ end
9
+ <% end -%>
@@ -1,8 +1,10 @@
1
+ # frozen_string_literal: true
2
+
1
3
  <% module_namespacing_when_supported do -%>
2
4
  module Types
3
- module <%= type_ruby_name.split('::')[-1] %>
5
+ module <%= ruby_class_name %>
4
6
  include Types::BaseInterface
5
- <% normalized_fields.each do |f| %> <%= f.to_ruby %>
7
+ <% normalized_fields.each do |f| %> <%= f.to_object_field %>
6
8
  <% end %> end
7
9
  end
8
10
  <% end -%>
@@ -1,6 +1,6 @@
1
1
  <% module_namespacing_when_supported do -%>
2
2
  module Mutations
3
- class <%= mutation_name %> < BaseMutation
3
+ class <%= class_name %> < BaseMutation
4
4
  # TODO: define return fields
5
5
  # field :post, Types::PostType, null: false
6
6
 
@@ -0,0 +1,20 @@
1
+ # frozen_string_literal: true
2
+
3
+ <% module_namespacing_when_supported do -%>
4
+ module Mutations
5
+ class <%= class_name %>Create < BaseMutation
6
+ description "Creates a new <%= file_name %>"
7
+
8
+ field :<%= file_name %>, Types::<%= options[:namespaced_types] ? 'Objects::' : '' %><%= class_name %>Type, null: false
9
+
10
+ argument :<%= file_name %>_input, Types::<%= options[:namespaced_types] ? 'Inputs::' : '' %><%= class_name %>InputType, required: true
11
+
12
+ def resolve(<%= file_name %>_input:)
13
+ <%= singular_table_name %> = ::<%= orm_class.build(class_name, "**#{file_name}_input") %>
14
+ raise GraphQL::ExecutionError.new "Error creating <%= file_name %>", extensions: <%= singular_table_name %>.errors.to_hash unless <%= orm_instance.save %>
15
+
16
+ { <%= file_name %>: <%= singular_table_name %> }
17
+ end
18
+ end
19
+ end
20
+ <% end -%>
@@ -0,0 +1,20 @@
1
+ # frozen_string_literal: true
2
+
3
+ <% module_namespacing_when_supported do -%>
4
+ module Mutations
5
+ class <%= class_name %>Delete < BaseMutation
6
+ description "Deletes a <%= file_name %> by ID"
7
+
8
+ field :<%= file_name %>, Types::<%= options[:namespaced_types] ? 'Objects::' : '' %><%= class_name %>Type, null: false
9
+
10
+ argument :id, ID, required: true
11
+
12
+ def resolve(id:)
13
+ <%= singular_table_name %> = ::<%= orm_class.find(class_name, "id") %>
14
+ raise GraphQL::ExecutionError.new "Error deleting <%= file_name %>", extensions: <%= singular_table_name %>.errors.to_hash unless <%= orm_instance.destroy %>
15
+
16
+ { <%= file_name %>: <%= singular_table_name %> }
17
+ end
18
+ end
19
+ end
20
+ <% end -%>
@@ -0,0 +1,21 @@
1
+ # frozen_string_literal: true
2
+
3
+ <% module_namespacing_when_supported do -%>
4
+ module Mutations
5
+ class <%= class_name %>Update < BaseMutation
6
+ description "Updates a <%= file_name %> by id"
7
+
8
+ field :<%= file_name %>, Types::<%= options[:namespaced_types] ? 'Objects::' : '' %><%= class_name %>Type, null: false
9
+
10
+ argument :id, ID, required: true
11
+ argument :<%= file_name %>_input, Types::<%= options[:namespaced_types] ? 'Inputs::' : '' %><%= class_name %>InputType, required: true
12
+
13
+ def resolve(id:, <%= file_name %>_input:)
14
+ <%= singular_table_name %> = ::<%= orm_class.find(class_name, "id") %>
15
+ raise GraphQL::ExecutionError.new "Error updating <%= file_name %>", extensions: <%= singular_table_name %>.errors.to_hash unless <%= orm_instance.update("**#{file_name}_input") %>
16
+
17
+ { <%= file_name %>: <%= singular_table_name %> }
18
+ end
19
+ end
20
+ end
21
+ <% end -%>
@@ -1,8 +1,10 @@
1
+ # frozen_string_literal: true
2
+
1
3
  <% module_namespacing_when_supported do -%>
2
4
  module Types
3
- class <%= type_ruby_name.split('::')[-1] %> < Types::BaseObject
5
+ class <%= ruby_class_name %> < Types::BaseObject
4
6
  <% if options.node %> implements GraphQL::Types::Relay::Node
5
- <% end %><% normalized_fields.each do |f| %> <%= f.to_ruby %>
7
+ <% end %><% normalized_fields.each do |f| %> <%= f.to_object_field %>
6
8
  <% end %> end
7
9
  end
8
10
  <% end -%>
@@ -1,6 +1,8 @@
1
+ # frozen_string_literal: true
2
+
1
3
  <% module_namespacing_when_supported do -%>
2
4
  module Types
3
- class <%= type_ruby_name.split('::')[-1] %> < Types::BaseScalar
5
+ class <%= ruby_class_name %> < Types::BaseScalar
4
6
  def self.coerce_input(input_value, context)
5
7
  # Override this to prepare a client-provided GraphQL value for your Ruby code
6
8
  input_value
@@ -1,7 +1,9 @@
1
+ # frozen_string_literal: true
2
+
1
3
  <% module_namespacing_when_supported do -%>
2
4
  module Types
3
- class <%= type_ruby_name.split('::')[-1] %> < Types::BaseUnion
4
- <% if possible_types.any? %> possible_types <%= normalized_possible_types.join(", ") %>
5
+ class <%= ruby_class_name %> < Types::BaseUnion
6
+ <% if custom_fields.any? %> possible_types <%= normalized_possible_types.join(", ") %>
5
7
  <% end %> end
6
8
  end
7
9
  <% end -%>