GqlSerializer
GqlSerializer is a gem that makes it easy to serialize ActiveRecord objects, hashes and arrays into JSON using a short syntax similar to GraphQL instead of the more verbose syntax used by the as_json method.
Installation
Add this line to your application's Gemfile:
gem 'gql_serializer'And then run:
$ bundle install
Or install it yourself as:
$ gem install gql_serializer
Basic Usage
Say you have the following User class
class User < ActiveRecord::Base
attribute :email_address, :string
attribute :name, :string
def encoded_id
"User-#{id}"
end
endand you create a user
user = User.create(name: 'Test User', email_address: 'user@test.com')You can call as_gql with no arguments to get:
user.as_gql
=> {
"id"=>1,
"name"=>"Test User",
"email_address"=>"user@test.com"
}By default, all attributes are included in the serialized form but you can create you want with the right arguments and include methods.
user.as_gql('name encoded_id')
=> {
"name" => "Test User",
"encoded_id" => "User-1"
}Advanced Usage
Here's where the library becomes more powerful. The GraphQL-esque syntax allows for aliasing and digging into nested objects.
class User < ActiveRecord::Base
attribute :email_address, :string
attribute :name, :string
has_many :orders
def encoded_id
"User-#{id}"
end
end
class Order < ActiveRecord::Base
belongs_to :user
attribute :total, :float
attribute :placed_at, :date_time
end
user = User.create(name: 'Test User', email_address: 'user@test.com')
order = Order.create(user: user, total: 3.50, placed_at: DateTime.now)
user.as_gql('name orders')
=> {
"name" => "Test User",
"orders" => [{
"id" => 1,
"total" => 3.5,
"placed_at" => "2020-12-23T08:30:00Z"
}]
}
order.as_gql('user { email_address encoded_id:real_id }')
=> {
"id" => 1,
"total" => 3.5,
"placed_at" => "2020-12-23T08:30:00Z",
"user" => {
"email_address" => "user@test.com",
"real_id" => "User-1"
}
}It's also possible to automatically convert the case of the keys into either camel case or snake case. We recommend that you configure this globally (see Configuration section) but it can be done using an optional second argument.
user.as_gql('email_address name:full_name', {case: GqlSerializer::Configuration::CAMEL_CASE})
=> {
"emailAddress" => "user@test.com",
"fullName" => "Test User"
}As of version 3, you can use as_gql on hashes. Optionally, objects can also be serialized.
class Item
attr_accessor :name, :price
def initialize(name, price)
@name = name
@price = price
end
def display
name + ': ' + ("%.2f" % price)
end
end
hash = {
id: 1,
total_price: 11.50,
items: [
Item.new('Thing', 6.00), Item.new('Stuff', 5.50)
]
}
hash.as_gql('total_price items { name:item_name display }')
=> {
"total_price" => 11.5,
"items" => [{
"item_name" => "Thing",
"display" => "Thing: 6.00"
},{
"item_name" => "Stuff",
"display" => "Stuff: 5.50"
}]
}Configuration
In a Rails application, the configuration can be added to an initializer in config/initalizers/gql_serializer.rb. The following is the default configuration (no change):
GqlSerializer.configure do |config|
# no case conversion
config.case = GqlSerializer::Configuration::NONE_CASE
# avoids an additional query in some cases.
# Set to false for compatibility with version <= 2.1
config.preload = true
end
# Optionally add the `as_gql` method to all objects:
# Object.include GqlSerializer::ObjectThe options for case are: NONE_CASE, CAMEL_CASE, SNAKE_CASE.
Compatibility
The current version of this gem has been tested on Rails version up to 8.0, but likely works with newer versions as well.
Development
After checking out the repo, run bin/setup to install dependencies. Then, run rake spec to run the tests. You can also run bin/console for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install. To release a new version, run:
# Build new version of gem
gem build gql_serializer.gemspec
# Create new tag
git tag -a v3.0.1 -m "Version 3.0.1"
git push origin v3.0.1
# Push gem to rubygems.org
gem push gql_serializer-3.0.1.gem
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/TheDro/gql_serializer.
License
The gem is available as open source under the terms of the MIT License.