Light and Fast serializer
LS is a JSON Object Presenter that takes business objects and breaks them down into simple hashes and serializes them to JSON. It can be used in Rails(or other ruby application) in place of other serializers (like JBuilder or ActiveModelSerializers). It is designed to be simple, direct, and performant.
All performant comparison results are available here. You can run benchmark by yourself.
git clone git@github.com:krim/light_serializer.git
cd light_serializer
ruby bench.rb
Add this line to your application's Gemfile:
gem 'light_serializer'
Execute:
$ bundle install
If you have an object you would like serialized, simply create a serializer. Say, for example, you have a User record with the following attributes [:uuid, :email, :first_name, :last_name, :address]
.
You may define a simple serializer like so:
class UserSeriaizer < LightSerializer::Serializer
attributes :uuid, :first_name, :last_name, :email
end
and then, in your code:
puts UserSeriaizer.new(user).to_json # Output is a JSON string
And the output would look like:
{
"uuid": "733f0758-8f21-4719-875f-262c3ec743af",
"first_name": "John",
"last_name": "Doe",
"email": "john.doe@some.fake.email.domain"
}
You can rename the resulting JSON keys in both fields and associations by defining custom method:
class UserSeriaizer < LightSerializer::Serializer
attributes :id, :first_name, :last_name, :email
def id
object.uuid
end
end
This will result in JSON that looks something like this:
{
"id": "92a5c732-2874-41e4-98fc-4123cd6cfa86",
"first_name": "John",
"last_name": "Doe",
"email": "john.doe@some.fake.email.domain"
}
You may include associated objects. Say, for example, a user has projects:
class ProjectSerializer < LightSerializer::Serializer
attributes :uuid, :name
end
class UserSeriaizer < LightSerializer::Serializer
attributes(
:uuid,
:first_name,
:last_name,
:email,
{ projects: ProjectSerializer }
)
end
Usage:
puts UserSeriaizer.new(user).to_json
Output:
{
"uuid": "733f0758-8f21-4719-875f-262c3ec743af",
"first_name": "John",
"last_name": "Doe",
"email": "john.doe@some.fake.email.domain",
"projects": [
{
"uuid": "dca94051-4195-42bc-a9aa-eb99f7723c82",
"name": "Beach Cleanup"
},
{
"uuid": "eb881bb5-9a51-4d27-8a29-b264c30e6160",
"name": "Storefront Revamp"
}
]
}
By default, returned JSON doesn't have root. You may specify it by the option in serializer's initializer:
puts UserSeriaizer.new(user, root: :person).to_json
Output:
{
"person": {
"uuid": "733f0758-8f21-4719-875f-262c3ec743af",
"first_name": "John",
"last_name": "Doe",
"email": "john.doe@some.fake.email.domain"
}
}
Use LightSerializer::SerializeCollection
to serialize collection of objects. You have to specify seriaizer, and can specify root and context.
puts LightSerializer::SerializeCollection.new(users, serializer: UserSerializer, root: :users).to_json
Output:
{
"users": [
{
"uuid": "733f0758-8f21-4719-875f-262c3ec743af",
"first_name": "John",
"last_name": "Doe",
"email": "john.doe@some.fake.email.domain"
},
{
"uuid": "262c3ec743af-4719-4719-8f21-733f0758",
"first_name": "Foo",
"last_name": "Bar",
"email": "foo.bar@some.fake.email.domain"
},
{
...
}
]
}