mirror of
https://github.com/samsonjs/grape-active_model_serializers.git
synced 2026-03-25 08:45:55 +00:00
3.1 KiB
3.1 KiB
Grape::ActiveModelSerializers
Use active_model_serializers with Grape!
Installation
Add the grape and grape-active_model_serializers gems to Gemfile.
gem 'grape'
gem 'grape-active_model_serializers'
And then execute:
bundle
Usage
Require grape-active_model_serializers
# config.ru
require 'grape/active_model_serializers'
Tell your API to use Grape::Formatter::ActiveModelSerializers
class API < Grape::API
format :json
formatter :json, Grape::Formatter::ActiveModelSerializers
end
Writing serializers
Serializers are inferred by active_record model names
grape-active_model_serializers will search for serializers for the objects returned by your grape API.
namespace :users do
get ":id" do
@user = User.find(params[:id])
end
end
In this case, as User objects are being returned, grape-active_model_serializers will look for a serializer named UserSerializer.
Manually specifying serializer options
# Serializer options can be specified on routes or namespaces.
namespace 'foo', :serializer => :bar do
get "/" do
# will use "bar" serializer
end
# Options specified on a route or namespace override those of the containing namespace.
get "/home", :serializer => :home do
# will use "home" serializer
end
# All standard options for `ActiveModel::Serializers` are supported.
get "/fancy_homes", :root => 'world', :each_serializer => :fancy_homes
...
end
end
Full Example
class User < ActiveRecord::Base
attr_accessor :first_name, :last_name, :password, :email
end
class UserSerializer < ActiveModel::Serializer
attributes :first_name, :last_name
end
class API < Grape::API
get("/home") do
User.new({first_name: 'JR', last_name: 'HE', email: 'contact@jrhe.co.uk'})
end
end
API.new.get "/home" # => '{:user=>{:first_name=>"JR", :last_name=>"HE"}}'
RSpec
See "Writing Tests" in https://github.com/intridea/grape.
Enjoy :)
Contributing
- Fork it
- Create your feature branch (
git checkout -b my-new-feature) - Commit your changes (
git commit -am 'Added some feature') - Push to the branch (
git push origin my-new-feature) - Create new Pull Request
Thanks to
The developers and maintainers of: active_model_serializers Grape!
Structured and based upon grape-rabl.


