active_model_serializers 0.10.6 → 0.10.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (215) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG.md +114 -1
  3. data/README.md +21 -24
  4. data/lib/action_controller/serialization.rb +11 -1
  5. data/lib/active_model/serializable_resource.rb +2 -0
  6. data/lib/active_model/serializer/adapter/attributes.rb +2 -0
  7. data/lib/active_model/serializer/adapter/base.rb +2 -0
  8. data/lib/active_model/serializer/adapter/json.rb +2 -0
  9. data/lib/active_model/serializer/adapter/json_api.rb +2 -0
  10. data/lib/active_model/serializer/adapter/null.rb +2 -0
  11. data/lib/active_model/serializer/adapter.rb +2 -0
  12. data/lib/active_model/serializer/array_serializer.rb +2 -0
  13. data/lib/active_model/serializer/association.rb +2 -0
  14. data/lib/active_model/serializer/attribute.rb +2 -0
  15. data/lib/active_model/serializer/belongs_to_reflection.rb +2 -0
  16. data/lib/active_model/serializer/collection_serializer.rb +17 -5
  17. data/lib/active_model/serializer/concerns/caching.rb +7 -2
  18. data/lib/active_model/serializer/error_serializer.rb +2 -0
  19. data/lib/active_model/serializer/errors_serializer.rb +2 -0
  20. data/lib/active_model/serializer/field.rb +2 -0
  21. data/lib/active_model/serializer/fieldset.rb +3 -1
  22. data/lib/active_model/serializer/has_many_reflection.rb +2 -0
  23. data/lib/active_model/serializer/has_one_reflection.rb +2 -0
  24. data/lib/active_model/serializer/lazy_association.rb +6 -2
  25. data/lib/active_model/serializer/link.rb +23 -0
  26. data/lib/active_model/serializer/lint.rb +2 -0
  27. data/lib/active_model/serializer/null.rb +2 -0
  28. data/lib/active_model/serializer/reflection.rb +10 -5
  29. data/lib/active_model/serializer/version.rb +3 -1
  30. data/lib/active_model/serializer.rb +37 -19
  31. data/lib/active_model_serializers/adapter/attributes.rb +23 -0
  32. data/lib/active_model_serializers/adapter/base.rb +2 -0
  33. data/lib/active_model_serializers/adapter/json.rb +2 -0
  34. data/lib/active_model_serializers/adapter/json_api/deserialization.rb +3 -1
  35. data/lib/active_model_serializers/adapter/json_api/error.rb +2 -0
  36. data/lib/active_model_serializers/adapter/json_api/jsonapi.rb +2 -0
  37. data/lib/active_model_serializers/adapter/json_api/link.rb +2 -0
  38. data/lib/active_model_serializers/adapter/json_api/meta.rb +2 -0
  39. data/lib/active_model_serializers/adapter/json_api/pagination_links.rb +45 -20
  40. data/lib/active_model_serializers/adapter/json_api/relationship.rb +18 -4
  41. data/lib/active_model_serializers/adapter/json_api/resource_identifier.rb +33 -25
  42. data/lib/active_model_serializers/adapter/json_api.rb +14 -9
  43. data/lib/active_model_serializers/adapter/null.rb +2 -0
  44. data/lib/active_model_serializers/adapter.rb +3 -1
  45. data/lib/active_model_serializers/callbacks.rb +2 -0
  46. data/lib/active_model_serializers/deprecate.rb +2 -0
  47. data/lib/active_model_serializers/deserialization.rb +2 -0
  48. data/lib/active_model_serializers/json_pointer.rb +2 -0
  49. data/lib/active_model_serializers/logging.rb +2 -0
  50. data/lib/active_model_serializers/lookup_chain.rb +2 -0
  51. data/lib/active_model_serializers/model/caching.rb +26 -0
  52. data/lib/active_model_serializers/model.rb +2 -0
  53. data/lib/active_model_serializers/railtie.rb +4 -0
  54. data/lib/active_model_serializers/register_jsonapi_renderer.rb +2 -0
  55. data/lib/active_model_serializers/serializable_resource.rb +4 -2
  56. data/lib/active_model_serializers/serialization_context.rb +2 -0
  57. data/lib/active_model_serializers/test/schema.rb +2 -0
  58. data/lib/active_model_serializers/test/serializer.rb +2 -0
  59. data/lib/active_model_serializers/test.rb +2 -0
  60. data/lib/active_model_serializers.rb +21 -11
  61. data/lib/generators/rails/resource_override.rb +2 -0
  62. data/lib/generators/rails/serializer_generator.rb +2 -0
  63. data/lib/grape/active_model_serializers.rb +2 -0
  64. data/lib/grape/formatters/active_model_serializers.rb +2 -0
  65. data/lib/grape/helpers/active_model_serializers.rb +2 -0
  66. data/lib/tasks/rubocop.rake +2 -0
  67. metadata +43 -298
  68. data/.github/ISSUE_TEMPLATE.md +0 -29
  69. data/.github/PULL_REQUEST_TEMPLATE.md +0 -15
  70. data/.gitignore +0 -35
  71. data/.rubocop.yml +0 -105
  72. data/.simplecov +0 -110
  73. data/.travis.yml +0 -55
  74. data/CODE_OF_CONDUCT.md +0 -74
  75. data/CONTRIBUTING.md +0 -105
  76. data/Gemfile +0 -56
  77. data/Rakefile +0 -74
  78. data/active_model_serializers.gemspec +0 -63
  79. data/appveyor.yml +0 -30
  80. data/bin/bench +0 -171
  81. data/bin/bench_regression +0 -316
  82. data/bin/rubocop +0 -38
  83. data/bin/serve_benchmark +0 -39
  84. data/docs/README.md +0 -41
  85. data/docs/STYLE.md +0 -58
  86. data/docs/general/adapters.md +0 -263
  87. data/docs/general/caching.md +0 -58
  88. data/docs/general/configuration_options.md +0 -169
  89. data/docs/general/deserialization.md +0 -100
  90. data/docs/general/fields.md +0 -31
  91. data/docs/general/getting_started.md +0 -133
  92. data/docs/general/instrumentation.md +0 -40
  93. data/docs/general/key_transforms.md +0 -40
  94. data/docs/general/logging.md +0 -21
  95. data/docs/general/rendering.md +0 -293
  96. data/docs/general/serializers.md +0 -480
  97. data/docs/how-open-source-maintained.jpg +0 -0
  98. data/docs/howto/add_pagination_links.md +0 -138
  99. data/docs/howto/add_relationship_links.md +0 -140
  100. data/docs/howto/add_root_key.md +0 -55
  101. data/docs/howto/grape_integration.md +0 -42
  102. data/docs/howto/outside_controller_use.md +0 -66
  103. data/docs/howto/passing_arbitrary_options.md +0 -27
  104. data/docs/howto/serialize_poro.md +0 -73
  105. data/docs/howto/test.md +0 -154
  106. data/docs/howto/upgrade_from_0_8_to_0_10.md +0 -265
  107. data/docs/integrations/ember-and-json-api.md +0 -147
  108. data/docs/integrations/grape.md +0 -19
  109. data/docs/jsonapi/errors.md +0 -56
  110. data/docs/jsonapi/schema/schema.json +0 -366
  111. data/docs/jsonapi/schema.md +0 -151
  112. data/docs/rfcs/0000-namespace.md +0 -106
  113. data/docs/rfcs/template.md +0 -15
  114. data/test/action_controller/adapter_selector_test.rb +0 -62
  115. data/test/action_controller/explicit_serializer_test.rb +0 -135
  116. data/test/action_controller/json/include_test.rb +0 -246
  117. data/test/action_controller/json_api/deserialization_test.rb +0 -112
  118. data/test/action_controller/json_api/errors_test.rb +0 -40
  119. data/test/action_controller/json_api/fields_test.rb +0 -66
  120. data/test/action_controller/json_api/linked_test.rb +0 -202
  121. data/test/action_controller/json_api/pagination_test.rb +0 -116
  122. data/test/action_controller/json_api/transform_test.rb +0 -189
  123. data/test/action_controller/lookup_proc_test.rb +0 -49
  124. data/test/action_controller/namespace_lookup_test.rb +0 -232
  125. data/test/action_controller/serialization_scope_name_test.rb +0 -235
  126. data/test/action_controller/serialization_test.rb +0 -472
  127. data/test/active_model_serializers/adapter_for_test.rb +0 -208
  128. data/test/active_model_serializers/json_pointer_test.rb +0 -22
  129. data/test/active_model_serializers/logging_test.rb +0 -77
  130. data/test/active_model_serializers/model_test.rb +0 -142
  131. data/test/active_model_serializers/railtie_test_isolated.rb +0 -68
  132. data/test/active_model_serializers/register_jsonapi_renderer_test_isolated.rb +0 -161
  133. data/test/active_model_serializers/serialization_context_test_isolated.rb +0 -71
  134. data/test/active_model_serializers/test/schema_test.rb +0 -131
  135. data/test/active_model_serializers/test/serializer_test.rb +0 -62
  136. data/test/active_record_test.rb +0 -9
  137. data/test/adapter/attributes_test.rb +0 -40
  138. data/test/adapter/deprecation_test.rb +0 -100
  139. data/test/adapter/json/belongs_to_test.rb +0 -45
  140. data/test/adapter/json/collection_test.rb +0 -104
  141. data/test/adapter/json/has_many_test.rb +0 -53
  142. data/test/adapter/json/transform_test.rb +0 -93
  143. data/test/adapter/json_api/belongs_to_test.rb +0 -155
  144. data/test/adapter/json_api/collection_test.rb +0 -96
  145. data/test/adapter/json_api/errors_test.rb +0 -76
  146. data/test/adapter/json_api/fields_test.rb +0 -96
  147. data/test/adapter/json_api/has_many_embed_ids_test.rb +0 -43
  148. data/test/adapter/json_api/has_many_explicit_serializer_test.rb +0 -96
  149. data/test/adapter/json_api/has_many_test.rb +0 -173
  150. data/test/adapter/json_api/has_one_test.rb +0 -80
  151. data/test/adapter/json_api/include_data_if_sideloaded_test.rb +0 -183
  152. data/test/adapter/json_api/json_api_test.rb +0 -33
  153. data/test/adapter/json_api/linked_test.rb +0 -413
  154. data/test/adapter/json_api/links_test.rb +0 -95
  155. data/test/adapter/json_api/pagination_links_test.rb +0 -193
  156. data/test/adapter/json_api/parse_test.rb +0 -137
  157. data/test/adapter/json_api/relationship_test.rb +0 -397
  158. data/test/adapter/json_api/resource_identifier_test.rb +0 -110
  159. data/test/adapter/json_api/resource_meta_test.rb +0 -100
  160. data/test/adapter/json_api/toplevel_jsonapi_test.rb +0 -82
  161. data/test/adapter/json_api/transform_test.rb +0 -512
  162. data/test/adapter/json_api/type_test.rb +0 -61
  163. data/test/adapter/json_test.rb +0 -46
  164. data/test/adapter/null_test.rb +0 -22
  165. data/test/adapter/polymorphic_test.rb +0 -171
  166. data/test/adapter_test.rb +0 -67
  167. data/test/array_serializer_test.rb +0 -22
  168. data/test/benchmark/app.rb +0 -65
  169. data/test/benchmark/benchmarking_support.rb +0 -67
  170. data/test/benchmark/bm_active_record.rb +0 -81
  171. data/test/benchmark/bm_adapter.rb +0 -38
  172. data/test/benchmark/bm_caching.rb +0 -119
  173. data/test/benchmark/bm_lookup_chain.rb +0 -83
  174. data/test/benchmark/bm_transform.rb +0 -45
  175. data/test/benchmark/config.ru +0 -3
  176. data/test/benchmark/controllers.rb +0 -83
  177. data/test/benchmark/fixtures.rb +0 -219
  178. data/test/cache_test.rb +0 -651
  179. data/test/collection_serializer_test.rb +0 -123
  180. data/test/fixtures/active_record.rb +0 -113
  181. data/test/fixtures/poro.rb +0 -225
  182. data/test/generators/scaffold_controller_generator_test.rb +0 -24
  183. data/test/generators/serializer_generator_test.rb +0 -75
  184. data/test/grape_test.rb +0 -196
  185. data/test/lint_test.rb +0 -49
  186. data/test/logger_test.rb +0 -20
  187. data/test/poro_test.rb +0 -9
  188. data/test/serializable_resource_test.rb +0 -79
  189. data/test/serializers/association_macros_test.rb +0 -37
  190. data/test/serializers/associations_test.rb +0 -424
  191. data/test/serializers/attribute_test.rb +0 -153
  192. data/test/serializers/attributes_test.rb +0 -52
  193. data/test/serializers/caching_configuration_test_isolated.rb +0 -170
  194. data/test/serializers/configuration_test.rb +0 -32
  195. data/test/serializers/fieldset_test.rb +0 -14
  196. data/test/serializers/meta_test.rb +0 -202
  197. data/test/serializers/options_test.rb +0 -32
  198. data/test/serializers/read_attribute_for_serialization_test.rb +0 -79
  199. data/test/serializers/reflection_test.rb +0 -427
  200. data/test/serializers/root_test.rb +0 -21
  201. data/test/serializers/serialization_test.rb +0 -55
  202. data/test/serializers/serializer_for_test.rb +0 -136
  203. data/test/serializers/serializer_for_with_namespace_test.rb +0 -88
  204. data/test/support/custom_schemas/active_model_serializers/test/schema_test/my/index.json +0 -6
  205. data/test/support/isolated_unit.rb +0 -82
  206. data/test/support/rails5_shims.rb +0 -53
  207. data/test/support/rails_app.rb +0 -38
  208. data/test/support/schemas/active_model_serializers/test/schema_test/my/index.json +0 -6
  209. data/test/support/schemas/active_model_serializers/test/schema_test/my/show.json +0 -6
  210. data/test/support/schemas/custom/show.json +0 -7
  211. data/test/support/schemas/hyper_schema.json +0 -93
  212. data/test/support/schemas/render_using_json_api.json +0 -43
  213. data/test/support/schemas/simple_json_pointers.json +0 -10
  214. data/test/support/serialization_testing.rb +0 -71
  215. data/test/test_helper.rb +0 -70
@@ -1,265 +0,0 @@
1
- [Back to Guides](../README.md)
2
-
3
- # How to migrate from `0.8` to `0.10` safely
4
-
5
- ## Disclaimer
6
- ### Proceed at your own risk
7
- This document attempts to outline steps to upgrade your app based on the collective experience of
8
- developers who have done this already. It may not cover all edge cases and situations that may cause issues,
9
- so please proceed with a certain level of caution.
10
-
11
- ## Overview
12
- This document outlines the steps needed to migrate from `0.8` to `0.10`. The method described
13
- below has been created via the collective knowledge of contributions of those who have done
14
- the migration successfully. The method has been tested specifically for migrating from `0.8.3`
15
- to `0.10.2`.
16
-
17
- The high level approach is to upgrade to `0.10` and change all serializers to use
18
- a backwards-compatible `ActiveModel::V08::Serializer`or `ActiveModel::V08::CollectionSerializer`
19
- and a `ActiveModelSerializers::Adapter::V08Adapter`. After a few more manual changes, you should have the same
20
- functionality as you had with `AMS 0.8`. Then, you can continue to develop in your app by creating
21
- new serializers that don't use these backwards compatible versions and slowly migrate
22
- existing serializers to the `0.10` versions as needed.
23
-
24
- ### `0.10` breaking changes
25
- - Passing a serializer to `render json:` is no longer supported
26
-
27
- ```ruby
28
- render json: CustomerSerializer.new(customer) # rendered in 0.8, errors in 0.10
29
- ```
30
-
31
- - Passing a nil resource to serializer now fails
32
-
33
- ```ruby
34
- CustomerSerializer.new(nil) # returned nil in 0.8, throws error in 0.10
35
- ```
36
-
37
- - Attribute methods are no longer defined on the serializer, and must be explicitly
38
- accessed through `object`
39
-
40
- ```ruby
41
- class MySerializer
42
- attributes :foo, :bar
43
-
44
- def foo
45
- bar + 1 # bar does not work, needs to be object.bar in 0.10
46
- end
47
- end
48
- ```
49
-
50
- - `root` option to collection serializer behaves differently
51
-
52
- ```ruby
53
- # in 0.8
54
- ActiveModel::ArraySerializer.new(resources, root: "resources")
55
- # resulted in { "resources": <serialized_resources> }, does not work in 0.10
56
- ```
57
-
58
- - No default serializer when serializer doesn't exist
59
- - `@options` changed to `instance_options`
60
- - Nested relationships are no longer walked by default. Use the `:include` option at **controller `render`** level to specify what relationships to walk. E.g. `render json: @post, include: {comments: :author}` if you want the `author` relationship walked, otherwise the json would only include the post with comments. See: https://github.com/rails-api/active_model_serializers/pull/1127
61
- - To emulate `0.8`'s walking of arbitrarily deep relationships use: `include: '**'`. E.g. `render json: @post, include: '**'`
62
-
63
- ## Steps to migrate
64
-
65
- ### 1. Upgrade the `active_model_serializer` gem in you `Gemfile`
66
- Change to `gem 'active_model_serializers', '~> 0.10'` and run `bundle install`
67
-
68
- ### 2. Add `ActiveModel::V08::Serializer`
69
-
70
- ```ruby
71
- module ActiveModel
72
- module V08
73
- class Serializer < ActiveModel::Serializer
74
- include Rails.application.routes.url_helpers
75
-
76
- # AMS 0.8 would delegate method calls from within the serializer to the
77
- # object.
78
- def method_missing(*args)
79
- method = args.first
80
- read_attribute_for_serialization(method)
81
- end
82
-
83
- alias_method :options, :instance_options
84
-
85
- # Since attributes could be read from the `object` via `method_missing`,
86
- # the `try` method did not behave as before. This patches `try` with the
87
- # original implementation plus the addition of
88
- # ` || object.respond_to?(a.first, true)` to check if the object responded to
89
- # the given method.
90
- def try(*a, &b)
91
- if a.empty? || respond_to?(a.first, true) || object.respond_to?(a.first, true)
92
- try!(*a, &b)
93
- end
94
- end
95
-
96
- # AMS 0.8 would return nil if the serializer was initialized with a nil
97
- # resource.
98
- def serializable_hash(adapter_options = nil,
99
- options = {},
100
- adapter_instance =
101
- self.class.serialization_adapter_instance)
102
- object.nil? ? nil : super
103
- end
104
- end
105
- end
106
- end
107
-
108
- ```
109
- Add this class to your app however you see fit. This is the class that your existing serializers
110
- that inherit from `ActiveModel::Serializer` should inherit from.
111
-
112
- ### 3. Add `ActiveModel::V08::CollectionSerializer`
113
- ```ruby
114
- module ActiveModel
115
- module V08
116
- class CollectionSerializer < ActiveModel::Serializer::CollectionSerializer
117
- # In AMS 0.8, passing an ArraySerializer instance with a `root` option
118
- # properly nested the serialized resources within the given root.
119
- # Ex.
120
- #
121
- # class MyController < ActionController::Base
122
- # def index
123
- # render json: ActiveModel::Serializer::ArraySerializer
124
- # .new(resources, root: "resources")
125
- # end
126
- # end
127
- #
128
- # Produced
129
- #
130
- # {
131
- # "resources": [
132
- # <serialized_resource>,
133
- # ...
134
- # ]
135
- # }
136
- def as_json(options = {})
137
- if root
138
- {
139
- root => super
140
- }
141
- else
142
- super
143
- end
144
- end
145
-
146
- # AMS 0.8 used `DefaultSerializer` if it couldn't find a serializer for
147
- # the given resource. When not using an adapter, this is not true in
148
- # `0.10`
149
- def serializer_from_resource(resource, serializer_context_class, options)
150
- serializer_class =
151
- options.fetch(:serializer) { serializer_context_class.serializer_for(resource) }
152
-
153
- if serializer_class.nil? # rubocop:disable Style/GuardClause
154
- DefaultSerializer.new(resource, options)
155
- else
156
- serializer_class.new(resource, options.except(:serializer))
157
- end
158
- end
159
-
160
- class DefaultSerializer
161
- attr_reader :object, :options
162
-
163
- def initialize(object, options={})
164
- @object, @options = object, options
165
- end
166
-
167
- def serializable_hash
168
- @object.as_json(@options)
169
- end
170
- end
171
- end
172
- end
173
- end
174
- ```
175
- Add this class to your app however you see fit. This is the class that existing uses of
176
- `ActiveModel::ArraySerializer` should be changed to use.
177
-
178
- ### 4. Add `ActiveModelSerializers::Adapter::V08Adapter`
179
- ```ruby
180
- module ActiveModelSerializers
181
- module Adapter
182
- class V08Adapter < ActiveModelSerializers::Adapter::Base
183
- def serializable_hash(options = nil)
184
- options ||= {}
185
-
186
- if serializer.respond_to?(:each)
187
- if serializer.root
188
- delegate_to_json_adapter(options)
189
- else
190
- serializable_hash_for_collection(options)
191
- end
192
- else
193
- serializable_hash_for_single_resource(options)
194
- end
195
- end
196
-
197
- def serializable_hash_for_collection(options)
198
- serializer.map do |s|
199
- V08Adapter.new(s, instance_options)
200
- .serializable_hash(options)
201
- end
202
- end
203
-
204
- def serializable_hash_for_single_resource(options)
205
- if serializer.object.is_a?(ActiveModel::Serializer)
206
- # It is recommended that you add some logging here to indicate
207
- # places that should get converted to eventually allow for this
208
- # adapter to get removed.
209
- @serializer = serializer.object
210
- end
211
-
212
- if serializer.root
213
- delegate_to_json_adapter(options)
214
- else
215
- options = serialization_options(options)
216
- serializer.serializable_hash(instance_options, options, self)
217
- end
218
- end
219
-
220
- def delegate_to_json_adapter(options)
221
- ActiveModelSerializers::Adapter::Json
222
- .new(serializer, instance_options)
223
- .serializable_hash(options)
224
- end
225
- end
226
- end
227
- end
228
- ```
229
- Add this class to your app however you see fit.
230
-
231
- Add
232
- ```ruby
233
- ActiveModelSerializers.config.adapter =
234
- ActiveModelSerializers::Adapter::V08Adapter
235
- ```
236
- to `config/active_model_serializer.rb` to configure AMS to use this
237
- class as the default adapter.
238
-
239
- ### 5. Change inheritors of `ActiveModel::Serializer` to inherit from `ActiveModel::V08::Serializer`
240
- Simple find/replace
241
-
242
- ### 6. Remove `private` keyword from serializers
243
- Simple find/replace. This is required to allow the `ActiveModel::V08::Serializer`
244
- to have proper access to the methods defined in the serializer.
245
-
246
- You may be able to change the `private` to `protected`, but this is hasn't been tested yet.
247
-
248
- ### 7. Remove references to `ActiveRecord::Base#active_model_serializer`
249
- This method is no longer supported in `0.10`.
250
-
251
- `0.10` does a good job of discovering serializers for `ActiveRecord` objects.
252
-
253
- ### 8. Rename `ActiveModel::ArraySerializer` to `ActiveModel::V08::CollectionSerializer`
254
- Find/replace uses of `ActiveModel::ArraySerializer` with `ActiveModel::V08::CollectionSerializer`.
255
-
256
- Also, be sure to change the `each_serializer` keyword to `serializer` when calling making the replacement.
257
-
258
- ### 9. Replace uses of `@options` to `instance_options` in serializers
259
- Simple find/replace
260
-
261
- ## Conclusion
262
- After you've done the steps above, you should test your app to ensure that everything is still working properly.
263
-
264
- If you run into issues, please contribute back to this document so others can benefit from your knowledge.
265
-
@@ -1,147 +0,0 @@
1
- [Back to Guides](../README.md)
2
-
3
- # Integrating with Ember and JSON API
4
-
5
- - [Preparation](./ember-and-json-api.md#preparation)
6
- - [Server-Side Changes](./ember-and-json-api.md#server-side-changes)
7
- - [Adapter Changes](./ember-and-json-api.md#adapter-changes)
8
- - [Serializer Changes](./ember-and-json-api.md#serializer-changes)
9
- - [Including Nested Resources](./ember-and-json-api.md#including-nested-resources)
10
-
11
- ## Preparation
12
-
13
- Note: This guide assumes that `ember-cli` is used for your ember app.
14
-
15
- The JSON API specification calls for hyphens for multi-word separators. ActiveModelSerializers uses underscores.
16
- To solve this, in Ember, both the adapter and the serializer will need some modifications:
17
-
18
- ### Server-Side Changes
19
-
20
- First, set the adapter type in an initializer file:
21
-
22
- ```ruby
23
- # config/initializers/active_model_serializers.rb
24
- ActiveModelSerializers.config.adapter = :json_api
25
- ```
26
-
27
- or:
28
-
29
- ```ruby
30
- # config/initializers/active_model_serializers.rb
31
- ActiveModelSerializers.config.adapter = ActiveModelSerializers::Adapter::JsonApi
32
- ```
33
-
34
- You will also want to set the `key_transform` to `:unaltered` since you will adjust the attributes in your Ember serializer to use underscores instead of dashes later. You could also use `:underscore`, but `:unaltered` is better for performance.
35
-
36
- ```ruby
37
- # config/initializers/active_model_serializers.rb
38
- ActiveModelSerializers.config.key_transform = :unaltered
39
- ```
40
-
41
- In order to properly handle JSON API responses, we need to register a JSON API renderer, like so:
42
-
43
- ```ruby
44
- # config/initializers/active_model_serializers.rb
45
- ActiveSupport.on_load(:action_controller) do
46
- require 'active_model_serializers/register_jsonapi_renderer'
47
- end
48
- ```
49
- Rails also requires your controller to tell it that you accept and generate JSONAPI data. To do that, you use `respond_to` in your controller handlers to tell rails you are consuming and returning jsonapi format data. Without this, Rails will refuse to parse the request body into params. You can add `ActionController::MimeResponds` to your application controller to enable this:
50
-
51
- ```ruby
52
- class ApplicationController < ActionController::API
53
- include ActionController::MimeResponds
54
- end
55
- ```
56
- Then, in your controller you can tell rails you're accepting and rendering the jsonapi format:
57
- ```ruby
58
- # POST /post
59
- def create
60
- @post = Post.new(post_params)
61
- respond_to do |format|
62
- if @post.save
63
- format.jsonapi { render jsonapi: @post, status: :created, location: @post }
64
- else
65
- format.jsonapi { render jsonapi: @post.errors, status: :unprocessable_entity }
66
- end
67
- end
68
- end
69
-
70
- # Only allow a trusted parameter "white list" through.
71
- def post_params
72
- ActiveModelSerializers::Deserialization.jsonapi_parse!(params, only: [:title, :body] )
73
- end
74
- end
75
- ```
76
-
77
- #### Note:
78
- In Rails 5, the "unsafe" method ( `jsonapi_parse!` vs the safe `jsonapi_parse`) throws an `InvalidDocument` exception when the payload does not meet basic criteria for JSON API deserialization.
79
-
80
-
81
- ### Adapter Changes
82
-
83
- ```javascript
84
- // app/adapters/application.js
85
- import Ember from 'ember';
86
- import DS from 'ember-data';
87
- import ENV from "../config/environment";
88
- const { underscore, pluralize } = Ember.String;
89
-
90
- export default DS.JSONAPIAdapter.extend({
91
- namespace: 'api',
92
- // if your rails app is on a different port from your ember app
93
- // this can be helpful for development.
94
- // in production, the host for both rails and ember should be the same.
95
- host: ENV.host,
96
-
97
- // allows the multiword paths in urls to be underscored
98
- pathForType: function(type) {
99
- let underscored = underscore(type);
100
- return pluralize(underscored);
101
- },
102
-
103
- });
104
- ```
105
-
106
- ### Serializer Changes
107
-
108
- ```javascript
109
- // app/serializers/application.js
110
- import Ember from 'ember';
111
- import DS from 'ember-data';
112
- var underscore = Ember.String.underscore;
113
-
114
- export default DS.JSONAPISerializer.extend({
115
- keyForAttribute: function(attr) {
116
- return underscore(attr);
117
- },
118
-
119
- keyForRelationship: function(rawKey) {
120
- return underscore(rawKey);
121
- }
122
- });
123
-
124
- ```
125
-
126
-
127
- ## Including Nested Resources
128
-
129
- Ember Data can request related records by using `include`. Below are some examples of how to make Ember Data request the inclusion of related records. For more on `include` usage, see: [The JSON API include examples](./../general/adapters.md#JSON-API)
130
-
131
- ```javascript
132
- store.findRecord('post', postId, { include: 'comments' } );
133
- ```
134
- which will generate the path /posts/{postId}?include='comments'
135
-
136
- So then in your controller, you'll want to be sure to have something like:
137
- ```ruby
138
- render jsonapi: @post, include: params[:include]
139
- ```
140
-
141
- If you want to use `include` on a collection, you'd write something like this:
142
-
143
- ```javascript
144
- store.query('post', { include: 'comments' });
145
- ```
146
-
147
- which will generate the path `/posts?include='comments'`
@@ -1,19 +0,0 @@
1
- # Integration with Grape
2
-
3
- [Grape](https://github.com/ruby-grape/grape) is an opinionated micro-framework for creating REST-like APIs in ruby.
4
-
5
- ActiveModelSerializers currently supports Grape >= 0.13, < 1.0
6
-
7
- To add [Grape](https://github.com/ruby-grape/grape) support, enable the formatter and helper functions by including `Grape::ActiveModelSerializers` in your base endpoint. For example:
8
-
9
- ```ruby
10
- module Example
11
- class Dummy < Grape::API
12
- require 'grape/active_model_serializers'
13
- include Grape::ActiveModelSerializers
14
- mount Example::V1::Base
15
- end
16
- end
17
- ```
18
-
19
- Aside from this, [configuration](../general/configuration_options.md) of ActiveModelSerializers is exactly the same.
@@ -1,56 +0,0 @@
1
- [Back to Guides](../README.md)
2
-
3
- # [JSON API Errors](http://jsonapi.org/format/#errors)
4
-
5
- Rendering error documents requires specifying the error serializer(s):
6
-
7
- - Serializer:
8
- - For a single resource: `serializer: ActiveModel::Serializer::ErrorSerializer`.
9
- - For a collection: `serializer: ActiveModel::Serializer::ErrorsSerializer`, `each_serializer: ActiveModel::Serializer::ErrorSerializer`.
10
-
11
- The resource **MUST** have a non-empty associated `#errors` object.
12
- The `errors` object must have a `#messages` method that returns a hash of error name to array of
13
- descriptions.
14
-
15
- ## Use in controllers
16
-
17
- ```ruby
18
- resource = Profile.new(name: 'Name 1',
19
- description: 'Description 1',
20
- comments: 'Comments 1')
21
- resource.errors.add(:name, 'cannot be nil')
22
- resource.errors.add(:name, 'must be longer')
23
- resource.errors.add(:id, 'must be a uuid')
24
-
25
- render json: resource, status: 422, adapter: :json_api, serializer: ActiveModel::Serializer::ErrorSerializer
26
- # #=>
27
- # { :errors =>
28
- # [
29
- # { :source => { :pointer => '/data/attributes/name' }, :detail => 'cannot be nil' },
30
- # { :source => { :pointer => '/data/attributes/name' }, :detail => 'must be longer' },
31
- # { :source => { :pointer => '/data/attributes/id' }, :detail => 'must be a uuid' }
32
- # ]
33
- # }.to_json
34
- ```
35
-
36
- ## Direct error document generation
37
-
38
- ```ruby
39
- options = nil
40
- resource = ModelWithErrors.new
41
- resource.errors.add(:name, 'must be awesome')
42
-
43
- serializable_resource = ActiveModelSerializers::SerializableResource.new(
44
- resource, {
45
- serializer: ActiveModel::Serializer::ErrorSerializer,
46
- adapter: :json_api
47
- })
48
- serializable_resource.as_json(options)
49
- # #=>
50
- # {
51
- # :errors =>
52
- # [
53
- # { :source => { :pointer => '/data/attributes/name' }, :detail => 'must be awesome' }
54
- # ]
55
- # }
56
- ```