Skip to content

4xposed/grape-sideload

Repository files navigation

Grape::Sideload

Gem Version Build Status Dependency Status Code Climate

Add JSON sideloading support to your Grape API so you can deliver multiple resources under one endpoint.

Table of Contents

What is Grape?

Grape is a ruby framework for creating APIs grape

What is Sideloading JSON?

Sideloading allows you to deliver related records as part of a single request.

For example, normally a request to /tickets.json returns ticket resources with a structure similar to:

{
  "tickets": [
    {
      "requester_id": 7,
      ...
    },
    ...
  ]
}

To fetch the requester's data, your consumer then needs to make another request to /users/7.json.

Using sideloading, you can deliver a the user resource along with the ticket in a single request.

The response will include a top-level array of associated data under the appropriate resource key.

{
  "tickets": [
    {
      "requester_id": 7,
      ...
    },
    ...
  ],
  "users": [
    {
      "id": 7,
      "name": "Bob Bobberson",
      ...
    }
  ]
}

Why do I need this gem?

The Grape framework doesn't offer support for sideloading the resources you deliver with your API's response, this gem will help you doing exactly that in a simple manner.

Installation

Add this line to your application's Gemfile:

gem 'grape-sideload'

then execute:

$ bundle

And add to your app.rb

require 'grape-sideload'

Usage

example for sideloading with present_many:

resources :tickets do
  get do
    present_many({ present: current_user.tickets, with: Ticket::Entity },
                 { present: current_user, with: User::Entity})
  end
end

example for sideloading with merge_payloads to sideload using grape's present syntax:

resource :tickets do
  get do
    merge_payloads(present(current_user.tickets, with: Ticket::Entity),
                   present(current_user, with: User::Entity))

  end
end

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/4xposed/grape-sideload. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.

License

The gem is available as open source under the terms of the MIT License.

About

Add support for sideload JSON in your Grape API

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages