active_model_serializers 0.10.3 → 0.10.12

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 (224) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG.md +154 -2
  3. data/README.md +153 -15
  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.rb +275 -81
  7. data/lib/active_model/serializer/adapter.rb +2 -0
  8. data/lib/active_model/serializer/adapter/attributes.rb +2 -0
  9. data/lib/active_model/serializer/adapter/base.rb +2 -0
  10. data/lib/active_model/serializer/adapter/json.rb +2 -0
  11. data/lib/active_model/serializer/adapter/json_api.rb +2 -0
  12. data/lib/active_model/serializer/adapter/null.rb +2 -0
  13. data/lib/active_model/serializer/array_serializer.rb +2 -0
  14. data/lib/active_model/serializer/association.rb +53 -14
  15. data/lib/active_model/serializer/attribute.rb +2 -0
  16. data/lib/active_model/serializer/belongs_to_reflection.rb +7 -1
  17. data/lib/active_model/serializer/collection_serializer.rb +8 -5
  18. data/lib/active_model/serializer/concerns/caching.rb +36 -23
  19. data/lib/active_model/serializer/error_serializer.rb +2 -0
  20. data/lib/active_model/serializer/errors_serializer.rb +2 -0
  21. data/lib/active_model/serializer/field.rb +2 -0
  22. data/lib/active_model/serializer/fieldset.rb +3 -1
  23. data/lib/active_model/serializer/has_many_reflection.rb +6 -1
  24. data/lib/active_model/serializer/has_one_reflection.rb +3 -1
  25. data/lib/active_model/serializer/lazy_association.rb +99 -0
  26. data/lib/active_model/serializer/link.rb +23 -0
  27. data/lib/active_model/serializer/lint.rb +2 -0
  28. data/lib/active_model/serializer/null.rb +2 -0
  29. data/lib/active_model/serializer/reflection.rb +122 -73
  30. data/lib/active_model/serializer/version.rb +3 -1
  31. data/lib/active_model_serializers.rb +29 -11
  32. data/lib/active_model_serializers/adapter.rb +3 -1
  33. data/lib/active_model_serializers/adapter/attributes.rb +23 -0
  34. data/lib/active_model_serializers/adapter/base.rb +4 -2
  35. data/lib/active_model_serializers/adapter/json.rb +2 -0
  36. data/lib/active_model_serializers/adapter/json_api.rb +44 -26
  37. data/lib/active_model_serializers/adapter/json_api/deserialization.rb +4 -2
  38. data/lib/active_model_serializers/adapter/json_api/error.rb +2 -0
  39. data/lib/active_model_serializers/adapter/json_api/jsonapi.rb +2 -0
  40. data/lib/active_model_serializers/adapter/json_api/link.rb +2 -0
  41. data/lib/active_model_serializers/adapter/json_api/meta.rb +2 -0
  42. data/lib/active_model_serializers/adapter/json_api/pagination_links.rb +42 -21
  43. data/lib/active_model_serializers/adapter/json_api/relationship.rb +52 -9
  44. data/lib/active_model_serializers/adapter/json_api/resource_identifier.rb +35 -18
  45. data/lib/active_model_serializers/adapter/null.rb +2 -0
  46. data/lib/active_model_serializers/callbacks.rb +2 -0
  47. data/lib/active_model_serializers/deprecate.rb +2 -0
  48. data/lib/active_model_serializers/deserialization.rb +2 -0
  49. data/lib/active_model_serializers/json_pointer.rb +2 -0
  50. data/lib/active_model_serializers/logging.rb +2 -0
  51. data/lib/active_model_serializers/lookup_chain.rb +2 -0
  52. data/lib/active_model_serializers/model.rb +111 -30
  53. data/lib/active_model_serializers/model/caching.rb +25 -0
  54. data/lib/active_model_serializers/railtie.rb +4 -0
  55. data/lib/active_model_serializers/register_jsonapi_renderer.rb +2 -0
  56. data/lib/active_model_serializers/serializable_resource.rb +4 -2
  57. data/lib/active_model_serializers/serialization_context.rb +2 -0
  58. data/lib/active_model_serializers/test.rb +2 -0
  59. data/lib/active_model_serializers/test/schema.rb +4 -2
  60. data/lib/active_model_serializers/test/serializer.rb +2 -0
  61. data/lib/generators/rails/resource_override.rb +3 -1
  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 +55 -0
  67. metadata +74 -291
  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 -102
  72. data/.simplecov +0 -110
  73. data/.travis.yml +0 -51
  74. data/CODE_OF_CONDUCT.md +0 -74
  75. data/CONTRIBUTING.md +0 -105
  76. data/Gemfile +0 -56
  77. data/Rakefile +0 -103
  78. data/active_model_serializers.gemspec +0 -62
  79. data/appveyor.yml +0 -24
  80. data/bin/bench +0 -171
  81. data/bin/bench_regression +0 -316
  82. data/bin/serve_benchmark +0 -39
  83. data/docs/ARCHITECTURE.md +0 -125
  84. data/docs/README.md +0 -42
  85. data/docs/STYLE.md +0 -58
  86. data/docs/general/adapters.md +0 -247
  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 -14
  95. data/docs/general/rendering.md +0 -294
  96. data/docs/general/serializers.md +0 -461
  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 -137
  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 -65
  103. data/docs/howto/passing_arbitrary_options.md +0 -27
  104. data/docs/howto/serialize_poro.md +0 -32
  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 -144
  108. data/docs/integrations/grape.md +0 -19
  109. data/docs/jsonapi/errors.md +0 -56
  110. data/docs/jsonapi/schema.md +0 -151
  111. data/docs/jsonapi/schema/schema.json +0 -366
  112. data/docs/rfcs/0000-namespace.md +0 -106
  113. data/docs/rfcs/template.md +0 -15
  114. data/lib/active_model/serializer/collection_reflection.rb +0 -7
  115. data/lib/active_model/serializer/concerns/associations.rb +0 -102
  116. data/lib/active_model/serializer/concerns/attributes.rb +0 -82
  117. data/lib/active_model/serializer/concerns/configuration.rb +0 -59
  118. data/lib/active_model/serializer/concerns/links.rb +0 -35
  119. data/lib/active_model/serializer/concerns/meta.rb +0 -29
  120. data/lib/active_model/serializer/concerns/type.rb +0 -25
  121. data/lib/active_model/serializer/singular_reflection.rb +0 -7
  122. data/lib/active_model_serializers/key_transform.rb +0 -74
  123. data/test/action_controller/adapter_selector_test.rb +0 -53
  124. data/test/action_controller/explicit_serializer_test.rb +0 -135
  125. data/test/action_controller/json/include_test.rb +0 -246
  126. data/test/action_controller/json_api/deserialization_test.rb +0 -112
  127. data/test/action_controller/json_api/errors_test.rb +0 -40
  128. data/test/action_controller/json_api/fields_test.rb +0 -57
  129. data/test/action_controller/json_api/linked_test.rb +0 -202
  130. data/test/action_controller/json_api/pagination_test.rb +0 -116
  131. data/test/action_controller/json_api/transform_test.rb +0 -181
  132. data/test/action_controller/lookup_proc_test.rb +0 -49
  133. data/test/action_controller/namespace_lookup_test.rb +0 -226
  134. data/test/action_controller/serialization_scope_name_test.rb +0 -229
  135. data/test/action_controller/serialization_test.rb +0 -472
  136. data/test/active_model_serializers/adapter_for_test.rb +0 -208
  137. data/test/active_model_serializers/json_pointer_test.rb +0 -22
  138. data/test/active_model_serializers/key_transform_test.rb +0 -297
  139. data/test/active_model_serializers/logging_test.rb +0 -77
  140. data/test/active_model_serializers/model_test.rb +0 -22
  141. data/test/active_model_serializers/railtie_test_isolated.rb +0 -63
  142. data/test/active_model_serializers/register_jsonapi_renderer_test_isolated.rb +0 -143
  143. data/test/active_model_serializers/serialization_context_test_isolated.rb +0 -71
  144. data/test/active_model_serializers/test/schema_test.rb +0 -130
  145. data/test/active_model_serializers/test/serializer_test.rb +0 -62
  146. data/test/active_record_test.rb +0 -9
  147. data/test/adapter/attributes_test.rb +0 -43
  148. data/test/adapter/deprecation_test.rb +0 -100
  149. data/test/adapter/json/belongs_to_test.rb +0 -45
  150. data/test/adapter/json/collection_test.rb +0 -104
  151. data/test/adapter/json/has_many_test.rb +0 -45
  152. data/test/adapter/json/transform_test.rb +0 -93
  153. data/test/adapter/json_api/belongs_to_test.rb +0 -155
  154. data/test/adapter/json_api/collection_test.rb +0 -96
  155. data/test/adapter/json_api/errors_test.rb +0 -76
  156. data/test/adapter/json_api/fields_test.rb +0 -88
  157. data/test/adapter/json_api/has_many_embed_ids_test.rb +0 -43
  158. data/test/adapter/json_api/has_many_explicit_serializer_test.rb +0 -96
  159. data/test/adapter/json_api/has_many_test.rb +0 -165
  160. data/test/adapter/json_api/has_one_test.rb +0 -80
  161. data/test/adapter/json_api/include_data_if_sideloaded_test.rb +0 -166
  162. data/test/adapter/json_api/json_api_test.rb +0 -33
  163. data/test/adapter/json_api/linked_test.rb +0 -413
  164. data/test/adapter/json_api/links_test.rb +0 -95
  165. data/test/adapter/json_api/pagination_links_test.rb +0 -193
  166. data/test/adapter/json_api/parse_test.rb +0 -137
  167. data/test/adapter/json_api/relationship_test.rb +0 -397
  168. data/test/adapter/json_api/resource_identifier_test.rb +0 -110
  169. data/test/adapter/json_api/resource_meta_test.rb +0 -100
  170. data/test/adapter/json_api/toplevel_jsonapi_test.rb +0 -82
  171. data/test/adapter/json_api/transform_test.rb +0 -504
  172. data/test/adapter/json_api/type_test.rb +0 -61
  173. data/test/adapter/json_test.rb +0 -46
  174. data/test/adapter/null_test.rb +0 -22
  175. data/test/adapter/polymorphic_test.rb +0 -171
  176. data/test/adapter_test.rb +0 -67
  177. data/test/array_serializer_test.rb +0 -22
  178. data/test/benchmark/app.rb +0 -65
  179. data/test/benchmark/benchmarking_support.rb +0 -67
  180. data/test/benchmark/bm_active_record.rb +0 -81
  181. data/test/benchmark/bm_adapter.rb +0 -38
  182. data/test/benchmark/bm_caching.rb +0 -119
  183. data/test/benchmark/bm_lookup_chain.rb +0 -83
  184. data/test/benchmark/bm_transform.rb +0 -45
  185. data/test/benchmark/config.ru +0 -3
  186. data/test/benchmark/controllers.rb +0 -83
  187. data/test/benchmark/fixtures.rb +0 -219
  188. data/test/cache_test.rb +0 -579
  189. data/test/collection_serializer_test.rb +0 -110
  190. data/test/fixtures/active_record.rb +0 -78
  191. data/test/fixtures/poro.rb +0 -286
  192. data/test/generators/scaffold_controller_generator_test.rb +0 -24
  193. data/test/generators/serializer_generator_test.rb +0 -74
  194. data/test/grape_test.rb +0 -178
  195. data/test/lint_test.rb +0 -49
  196. data/test/logger_test.rb +0 -20
  197. data/test/poro_test.rb +0 -9
  198. data/test/serializable_resource_test.rb +0 -79
  199. data/test/serializers/association_macros_test.rb +0 -37
  200. data/test/serializers/associations_test.rb +0 -370
  201. data/test/serializers/attribute_test.rb +0 -151
  202. data/test/serializers/attributes_test.rb +0 -52
  203. data/test/serializers/caching_configuration_test_isolated.rb +0 -170
  204. data/test/serializers/configuration_test.rb +0 -32
  205. data/test/serializers/fieldset_test.rb +0 -14
  206. data/test/serializers/meta_test.rb +0 -202
  207. data/test/serializers/options_test.rb +0 -21
  208. data/test/serializers/read_attribute_for_serialization_test.rb +0 -79
  209. data/test/serializers/root_test.rb +0 -21
  210. data/test/serializers/serialization_test.rb +0 -55
  211. data/test/serializers/serializer_for_test.rb +0 -136
  212. data/test/serializers/serializer_for_with_namespace_test.rb +0 -87
  213. data/test/support/custom_schemas/active_model_serializers/test/schema_test/my/index.json +0 -6
  214. data/test/support/isolated_unit.rb +0 -82
  215. data/test/support/rails5_shims.rb +0 -53
  216. data/test/support/rails_app.rb +0 -36
  217. data/test/support/schemas/active_model_serializers/test/schema_test/my/index.json +0 -6
  218. data/test/support/schemas/active_model_serializers/test/schema_test/my/show.json +0 -6
  219. data/test/support/schemas/custom/show.json +0 -7
  220. data/test/support/schemas/hyper_schema.json +0 -93
  221. data/test/support/schemas/render_using_json_api.json +0 -43
  222. data/test/support/schemas/simple_json_pointers.json +0 -10
  223. data/test/support/serialization_testing.rb +0 -71
  224. data/test/test_helper.rb +0 -58
@@ -1,58 +0,0 @@
1
- [Back to Guides](../README.md)
2
-
3
- # Caching
4
-
5
- ## Warning
6
-
7
- There is currently a problem with caching in AMS [Caching doesn't improve performance](https://github.com/rails-api/active_model_serializers/issues/1586). Adding caching _may_ slow down your application, rather than speeding it up. We suggest you benchmark any caching you implement before using in a production enviroment
8
-
9
- ___
10
-
11
- To cache a serializer, call ```cache``` and pass its options.
12
- The options are the same options of ```ActiveSupport::Cache::Store```, plus
13
- a ```key``` option that will be the prefix of the object cache
14
- on a pattern ```"#{key}/#{object.id}-#{object.updated_at}"```.
15
-
16
- The cache support is optimized to use the cached object in multiple request. An object cached on a ```show``` request will be reused at the ```index```. If there is a relationship with another cached serializer it will also be created and reused automatically.
17
-
18
- **[NOTE] Every object is individually cached.**
19
-
20
- **[NOTE] The cache is automatically expired after an object is updated, but it's not deleted.**
21
-
22
- ```ruby
23
- cache(options = nil) # options: ```{key, expires_in, compress, force, race_condition_ttl}```
24
- ```
25
-
26
- Take the example below:
27
-
28
- ```ruby
29
- class PostSerializer < ActiveModel::Serializer
30
- cache key: 'post', expires_in: 3.hours
31
- attributes :title, :body
32
-
33
- has_many :comments
34
- end
35
- ```
36
-
37
- On this example every ```Post``` object will be cached with
38
- the key ```"post/#{post.id}-#{post.updated_at}"```. You can use this key to expire it as you want,
39
- but in this case it will be automatically expired after 3 hours.
40
-
41
- ## Fragment Caching
42
-
43
- If there is some API endpoint that shouldn't be fully cached, you can still optimise it, using Fragment Cache on the attributes and relationships that you want to cache.
44
-
45
- You can define the attribute by using ```only``` or ```except``` option on cache method.
46
-
47
- **[NOTE] Cache serializers will be used at their relationships**
48
-
49
- Example:
50
-
51
- ```ruby
52
- class PostSerializer < ActiveModel::Serializer
53
- cache key: 'post', expires_in: 3.hours, only: [:title]
54
- attributes :title, :body
55
-
56
- has_many :comments
57
- end
58
- ```
@@ -1,169 +0,0 @@
1
- [Back to Guides](../README.md)
2
-
3
- # Configuration Options
4
-
5
- The following configuration options can be set on
6
- `ActiveModelSerializers.config`, preferably inside an initializer.
7
-
8
- ## General
9
-
10
- ##### adapter
11
-
12
- The [adapter](adapters.md) to use.
13
-
14
- Possible values:
15
-
16
- - `:attributes` (default)
17
- - `:json`
18
- - `:json_api`
19
-
20
- ##### serializer_lookup_enabled
21
-
22
- Enable automatic serializer lookup.
23
-
24
- Possible values:
25
-
26
- - `true` (default)
27
- - `false`
28
-
29
- When `false`, serializers must be explicitly specified.
30
-
31
- ##### key_transform
32
-
33
- The [key transform](key_transforms.md) to use.
34
-
35
-
36
- | Option | Result |
37
- |----|----|
38
- | `:camel` | ExampleKey |
39
- | `:camel_lower` | exampleKey |
40
- | `:dash` | example-key |
41
- | `:unaltered` | the original, unaltered key |
42
- | `:underscore` | example_key |
43
- | `nil` | use the adapter default |
44
-
45
- Each adapter has a default key transform configured:
46
-
47
- | Adapter | Default Key Transform |
48
- |----|----|
49
- | `Attributes` | `:unaltered` |
50
- | `Json` | `:unaltered` |
51
- | `JsonApi` | `:dash` |
52
-
53
- `config.key_transform` is a global override of the adapter default. Adapters
54
- still prefer the render option `:key_transform` over this setting.
55
-
56
- *NOTE: Key transforms can be expensive operations. If key transforms are unnecessary for the
57
- application, setting `config.key_transform` to `:unaltered` will provide a performance boost.*
58
-
59
- ##### default_includes
60
- What relationships to serialize by default. Default: `'*'`, which includes one level of related
61
- objects. See [includes](adapters.md#included) for more info.
62
-
63
-
64
- ##### serializer_lookup_chain
65
-
66
- Configures how serializers are searched for. By default, the lookup chain is
67
-
68
- ```ruby
69
- ActiveModelSerializers::LookupChain::DEFAULT
70
- ```
71
-
72
- which is shorthand for
73
-
74
- ```ruby
75
- [
76
- ActiveModelSerializers::LookupChain::BY_PARENT_SERIALIZER,
77
- ActiveModelSerializers::LookupChain::BY_NAMESPACE,
78
- ActiveModelSerializers::LookupChain::BY_RESOURCE_NAMESPACE,
79
- ActiveModelSerializers::LookupChain::BY_RESOURCE
80
- ]
81
- ```
82
-
83
- Each of the array entries represent a proc. A serializer lookup proc will be yielded 3 arguments. `resource_class`, `serializer_class`, and `namespace`.
84
-
85
- Note that:
86
- - `resource_class` is the class of the resource being rendered
87
- - by default `serializer_class` is `ActiveModel::Serializer`
88
- - for association lookup it's the "parent" serializer
89
- - `namespace` correspond to either the controller namespace or the [optionally] specified [namespace render option](./rendering.md#namespace)
90
-
91
- An example config could be:
92
-
93
- ```ruby
94
- ActiveModelSerializers.config.serializer_lookup_chain = [
95
- lambda do |resource_class, serializer_class, namespace|
96
- "API::#{namespace}::#{resource_class}"
97
- end
98
- ]
99
- ```
100
-
101
- If you simply want to add to the existing lookup_chain. Use `unshift`.
102
-
103
- ```ruby
104
- ActiveModelSerializers.config.serializer_lookup_chain.unshift(
105
- lambda do |resource_class, serializer_class, namespace|
106
- # ...
107
- end
108
- )
109
- ```
110
-
111
- See [lookup_chain.rb](https://github.com/rails-api/active_model_serializers/blob/master/lib/active_model_serializers/lookup_chain.rb) for further explanations and examples.
112
-
113
- ## JSON API
114
-
115
- ##### jsonapi_resource_type
116
-
117
- Sets whether the [type](http://jsonapi.org/format/#document-resource-identifier-objects)
118
- of the resource should be `singularized` or `pluralized` when it is not
119
- [explicitly specified by the serializer](https://github.com/rails-api/active_model_serializers/blob/master/docs/general/serializers.md#type)
120
-
121
- Possible values:
122
-
123
- - `:singular`
124
- - `:plural` (default)
125
-
126
- ##### jsonapi_namespace_separator
127
-
128
- Sets separator string for namespaced models to render `type` attribute.
129
-
130
-
131
- | Separator | Example: Admin::User |
132
- |----|----|
133
- | `'-'` (default) | 'admin-users'
134
- | `'--'` (recommended) | 'admin--users'
135
-
136
- See [Recommendation for dasherizing (kebab-case-ing) namespaced object, such as `Admin::User`](https://github.com/json-api/json-api/issues/850)
137
- for more discussion.
138
-
139
- ##### jsonapi_include_toplevel_object
140
-
141
- Include a [top level jsonapi member](http://jsonapi.org/format/#document-jsonapi-object)
142
- in the response document.
143
-
144
- Possible values:
145
-
146
- - `true`
147
- - `false` (default)
148
-
149
- ##### jsonapi_version
150
-
151
- The latest version of the spec to which the API conforms.
152
-
153
- Default: `'1.0'`.
154
-
155
- *Used when `jsonapi_include_toplevel_object` is `true`*
156
-
157
- ##### jsonapi_toplevel_meta
158
-
159
- Optional top-level metadata. Not included if empty.
160
-
161
- Default: `{}`.
162
-
163
- *Used when `jsonapi_include_toplevel_object` is `true`*
164
-
165
-
166
- ## Hooks
167
-
168
- To run a hook when ActiveModelSerializers is loaded, use
169
- `ActiveSupport.on_load(:action_controller) do end`
@@ -1,100 +0,0 @@
1
- [Back to Guides](../README.md)
2
-
3
- # Deserialization
4
-
5
- This is currently an *experimental* feature. The interface may change.
6
-
7
- ## JSON API
8
-
9
- The `ActiveModelSerializers::Deserialization` defines two methods (namely `jsonapi_parse` and `jsonapi_parse!`), which take a `Hash` or an instance of `ActionController::Parameters` representing a JSON API payload, and return a hash that can directly be used to create/update models. The bang version throws an `InvalidDocument` exception when parsing fails, whereas the "safe" version simply returns an empty hash.
10
-
11
- - Parameters
12
- - document: `Hash` or `ActionController::Parameters` instance
13
- - options:
14
- - only: `Array` of whitelisted fields
15
- - except: `Array` of blacklisted fields
16
- - keys: `Hash` of fields the name of which needs to be modified (e.g. `{ :author => :user, :date => :created_at }`)
17
-
18
- Examples:
19
-
20
- ```ruby
21
- class PostsController < ActionController::Base
22
- def create
23
- Post.create(create_params)
24
- end
25
-
26
- def create_params
27
- ActiveModelSerializers::Deserialization.jsonapi_parse(params, only: [:title, :content, :author])
28
- end
29
- end
30
- ```
31
-
32
-
33
-
34
- Given a JSON API document,
35
-
36
- ```
37
- document = {
38
- 'data' => {
39
- 'id' => 1,
40
- 'type' => 'post',
41
- 'attributes' => {
42
- 'title' => 'Title 1',
43
- 'date' => '2015-12-20'
44
- },
45
- 'relationships' => {
46
- 'author' => {
47
- 'data' => {
48
- 'type' => 'user',
49
- 'id' => '2'
50
- }
51
- },
52
- 'second_author' => {
53
- 'data' => nil
54
- },
55
- 'comments' => {
56
- 'data' => [{
57
- 'type' => 'comment',
58
- 'id' => '3'
59
- },{
60
- 'type' => 'comment',
61
- 'id' => '4'
62
- }]
63
- }
64
- }
65
- }
66
- }
67
- ```
68
-
69
- The entire document can be parsed without specifying any options:
70
- ```ruby
71
- ActiveModelSerializers::Deserialization.jsonapi_parse(document)
72
- #=>
73
- # {
74
- # title: 'Title 1',
75
- # date: '2015-12-20',
76
- # author_id: 2,
77
- # second_author_id: nil
78
- # comment_ids: [3, 4]
79
- # }
80
- ```
81
-
82
- and fields, relationships, and polymorphic relationships can be specified via the options:
83
-
84
- ```ruby
85
- ActiveModelSerializers::Deserialization
86
- .jsonapi_parse(document, only: [:title, :date, :author],
87
- keys: { date: :published_at },
88
- polymorphic: [:author])
89
- #=>
90
- # {
91
- # title: 'Title 1',
92
- # published_at: '2015-12-20',
93
- # author_id: '2',
94
- # author_type: 'user'
95
- # }
96
- ```
97
-
98
- ## Attributes/Json
99
-
100
- There is currently no deserialization for those adapters.
@@ -1,31 +0,0 @@
1
- [Back to Guides](../README.md)
2
-
3
- # Fields
4
-
5
- If for any reason, you need to restrict the fields returned, you should use `fields` option.
6
-
7
- For example, if you have a serializer like this
8
-
9
- ```ruby
10
- class UserSerializer < ActiveModel::Serializer
11
- attributes :access_token, :first_name, :last_name
12
- end
13
- ```
14
-
15
- and in a specific controller, you want to return `access_token` only, `fields` will help you:
16
-
17
- ```ruby
18
- class AnonymousController < ApplicationController
19
- def create
20
- render json: User.create(activation_state: 'anonymous'), fields: [:access_token], status: 201
21
- end
22
- end
23
- ```
24
-
25
- Note that this is only valid for the `json` and `attributes` adapter. For the `json_api` adapter, you would use
26
-
27
- ```ruby
28
- render json: @user, fields: { users: [:access_token] }
29
- ```
30
-
31
- Where `users` is the JSONAPI type.
@@ -1,133 +0,0 @@
1
- [Back to Guides](../README.md)
2
-
3
- # Getting Started
4
-
5
- ## Creating a Serializer
6
-
7
- The easiest way to create a new serializer is to generate a new resource, which
8
- will generate a serializer at the same time:
9
-
10
- ```
11
- $ rails g resource post title:string body:string
12
- ```
13
-
14
- This will generate a serializer in `app/serializers/post_serializer.rb` for
15
- your new model. You can also generate a serializer for an existing model with
16
- the serializer generator:
17
-
18
- ```
19
- $ rails g serializer post
20
- ```
21
-
22
- The generated serializer will contain basic `attributes` and
23
- `has_many`/`has_one`/`belongs_to` declarations, based on the model. For example:
24
-
25
- ```ruby
26
- class PostSerializer < ActiveModel::Serializer
27
- attributes :title, :body
28
-
29
- has_many :comments
30
- has_one :author
31
- end
32
- ```
33
-
34
- and
35
-
36
- ```ruby
37
- class CommentSerializer < ActiveModel::Serializer
38
- attributes :name, :body
39
-
40
- belongs_to :post_id
41
- end
42
- ```
43
-
44
- The attribute names are a **whitelist** of attributes to be serialized.
45
-
46
- The `has_many`, `has_one`, and `belongs_to` declarations describe relationships between
47
- resources. By default, when you serialize a `Post`, you will get its `Comments`
48
- as well.
49
-
50
- For more information, see [Serializers](/docs/general/serializers.md).
51
-
52
- ### Namespaced Models
53
-
54
- When serializing a model inside a namespace, such as `Api::V1::Post`, ActiveModelSerializers will expect the corresponding serializer to be inside the same namespace (namely `Api::V1::PostSerializer`).
55
-
56
- ### Model Associations and Nested Serializers
57
-
58
- When declaring a serializer for a model with associations, such as:
59
- ```ruby
60
- class PostSerializer < ActiveModel::Serializer
61
- has_many :comments
62
- end
63
- ```
64
- ActiveModelSerializers will look for `PostSerializer::CommentSerializer` in priority, and fall back to `::CommentSerializer` in case the former does not exist. This allows for more control over the way a model gets serialized as an association of an other model.
65
-
66
- For example, in the following situation:
67
-
68
- ```ruby
69
- class CommentSerializer < ActiveModel::Serializer
70
- attributes :body, :date, :nb_likes
71
- end
72
-
73
- class PostSerializer < ActiveModel::Serializer
74
- has_many :comments
75
- class CommentSerializer < ActiveModel::Serializer
76
- attributes :body_short
77
- end
78
- end
79
- ```
80
-
81
- ActiveModelSerializers will use `PostSerializer::CommentSerializer` (thus including only the `:body_short` attribute) when serializing a `Comment` as part of a `Post`, but use `::CommentSerializer` when serializing a `Comment` directly (thus including `:body, :date, :nb_likes`).
82
-
83
- ### Extending a Base `ApplicationSerializer`
84
-
85
- By default, new serializers descend from `ActiveModel::Serializer`. However, if
86
- you wish to share behavior across your serializers, you can create an
87
- `ApplicationSerializer` at `app/serializers/application_serializer.rb`:
88
-
89
- ```ruby
90
- class ApplicationSerializer < ActiveModel::Serializer
91
- end
92
- ```
93
-
94
- Then any newly-generated serializers will automatically descend from
95
- `ApplicationSerializer`.
96
-
97
- ```
98
- $ rails g serializer post
99
- ```
100
-
101
- Now generates:
102
-
103
- ```ruby
104
- class PostSerializer < ApplicationSerializer
105
- attributes :id
106
- end
107
- ````
108
-
109
- ## Rails Integration
110
-
111
- ActiveModelSerializers will automatically integrate with your Rails app,
112
- so you won't need to update your controller.
113
- This is a example of how the controller will look:
114
-
115
- ```ruby
116
- class PostsController < ApplicationController
117
-
118
- def show
119
- @post = Post.find(params[:id])
120
- render json: @post
121
- end
122
-
123
- end
124
- ```
125
-
126
- If you wish to use Rails url helpers for link generation, e.g., `link(:resources) { resources_url }`, ensure your application sets
127
- `Rails.application.routes.default_url_options`.
128
-
129
- ```ruby
130
- Rails.application.routes.default_url_options = {
131
- host: 'example.com'
132
- }
133
- ```