Skip to content
This repository has been archived by the owner on Mar 2, 2020. It is now read-only.

Latest commit

 

History

History
73 lines (52 loc) · 2.14 KB

README.md

File metadata and controls

73 lines (52 loc) · 2.14 KB

ivy-serializers-rails

Build Status

Rails integration for ivy-serializers.

Installation

Add this line to your application's Gemfile:

gem 'ivy-serializers-rails'

And then execute:

bundle

Or install it yourself with:

gem install ivy-serializers-rails

Usage

See the ivy-serializers docs for how to define a serializer. Once you've done that, set up your controller(s) to use your serializer:

class ApplicationController < ActionController::Base
  self.serializer = MySerializer
end

Note that you're not limited to a single serializer. If you have multiple serialization formats, such as one for admin and one for public-facing, you can define alternate serializers in app/serializers and use them as well.

Alternate Output Formats

By default the ActiveModel::Serializers output format is used. If you'd rather use JSON-API (or a custom format), you can do so by setting serialization_format in your controller. For instance, to use JSON-API:

class ApplicationController < ActionController::Base
  self.serialization_format = Ivy::Serializers::Formats::JSONAPI
end

Development

After checking out the repo, run bin/setup to install dependencies. Then, 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, update the version number in version.rb, and then run bundle exec rake release to create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.

Contributing

  1. Fork it ( https://github.com/[my-github-username]/ivy-serializers-rails/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request