From 76b9668919746b219e270d762a158bfe533ac388 Mon Sep 17 00:00:00 2001 From: Thomas Millward Wright Date: Mon, 13 Nov 2017 11:34:30 +0000 Subject: [PATCH] clarify rails controller serialization - add a single resource example - add some explanation around relationship & inclusion --- .../guides/getting_started/rails.html.md.erb | 41 +++++++++++++++++-- 1 file changed, 37 insertions(+), 4 deletions(-) diff --git a/source/guides/getting_started/rails.html.md.erb b/source/guides/getting_started/rails.html.md.erb index 28edf0f..2c2d562 100644 --- a/source/guides/getting_started/rails.html.md.erb +++ b/source/guides/getting_started/rails.html.md.erb @@ -9,14 +9,30 @@ Start by adding the following to your `Gemfile`: gem 'jsonapi-rails' ``` -Then, once your [serializable resources](/guides/serialization) are defined, building +Every object and its relationships that you intend to render will need to be +defined as [serializable resources](/guides/serialization). Then, building a JSON API document from your business objects is straightforward: simply pass them to the `render` method. -For a comprehensive list of renderer options, see -[Renderer options](/guides/serialization/rendering.html). +## Rendering a single resource + +In this example, the `Post` model should have a corresponding `SerializableScan`, +then all that is required for `jsonapi-rails` to render it is the use of the +`:jsonapi` option with `render`: + +```ruby +class PostsController < ActionController::Base + # ... + + def index + render jsonapi: Posts.all + end + + # ... +end +``` -## Rendering resources +## Rendering resources with related resources included. ```ruby class PostsController < ActionController::Base @@ -32,8 +48,16 @@ class PostsController < ActionController::Base end ``` +In this example, `SerializableResource`s should be defined for `Post`, `Comment` +and `User` (the `Author` relationship's class). The include parameter maps to +jsonapi's concept of inclusion, and will produce an `includes` top level member. + + ## Rendering relationships +To render relationships per the `jsonapi` spec, the relationships should be +defined as such and included: + ```ruby class PostsController < ActionController::Base # ... @@ -50,6 +74,12 @@ class PostsController < ActionController::Base end ``` +Again, in this example a `PostSerializer`, `CommentSerializer` and `UserSerializer` +should exist. This will produce a compound document that describes the `Post`, +and its `Comment` relationships, with the serialized `Comment` and author (`User`) +included in the resulting json. + + ## Rendering errors ```ruby @@ -70,6 +100,9 @@ class PostsController < ActionController::Base end ``` +For a comprehensive list of renderer options, see +[Renderer options](/guides/serialization/rendering.html). + ## Configuration ### Application-wide settings