Skip to content

krim/light_serializer

Repository files navigation

Light Serializer

Light and Fast serializer

Gem Version Build Status Maintainability Test Coverage

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.

Performant comparison

All performant comparison results are available here. You can run benchmark by yourself.

git clone [email protected]:krim/light_serializer.git
cd light_serializer
ruby bench.rb

Table of Contents

Install

Add this line to your application's Gemfile:

gem 'light_serializer'

Execute:

$ bundle install

Usage

Basic

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": "[email protected]"
}

Custom method names

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": "[email protected]"
}

Associations

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": "[email protected]",
  "projects": [
    {
      "uuid": "dca94051-4195-42bc-a9aa-eb99f7723c82",
      "name": "Beach Cleanup"
    },
    {
      "uuid": "eb881bb5-9a51-4d27-8a29-b264c30e6160",
      "name": "Storefront Revamp"
    }
  ]
}

Custom root

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": "[email protected]"
  }
}

Collection serializer

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": "[email protected]"
    },
    {
      "uuid": "262c3ec743af-4719-4719-8f21-733f0758",
      "first_name": "Foo",
      "last_name": "Bar",
      "email": "[email protected]"
    },
    {
      ...
    }
  ]
}

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •