Project

grape-hal

0.0
No commit activity in last 3 years
No release in over 3 years
Provides the HAL response for Grape API application
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.3
>= 0
~> 10.0.4
>= 0

Runtime

>= 0
>= 0
 Project Readme

Grape Hal

Description

A ruby gem which adds HAL support to ruby Grape Api.

HAL

HAL is a simple format that gives a consistent and easy way to hyperlink between resources in your API. See HAL (Hyperlink Application Language)

Ruby Grape

github: ruby grape api

Installation

Install the gem by:

gem install grape-hal

Or add the gem to your Gemfile

gem 'grape-hal'

Use it in code by

require 'grape/hal'

Examples

If you want to add Hal response to your exist Grape Api, just simply include Grape::Hal and then use the dsl to describe your Apis.

Here are some Grape Apis. Note the include Grape::Hal and hal_for block.

require 'grape/hal'

class FooApi < ::Grape::API
  desc 'foo api description', rel: 'foo api'
  get '/foo_path/'
end

class SubApi < ::Grape::API
  desc 'bar api description with {param}', rel: 'bar api'
  get 'bar_path/:param'

  desc 'qux api description', rel: 'qux api'
  get 'qux_path'
end

class BazApi < ::Grape::API

  include Grape::Hal

  mount FooApi
  mount SubApi

  hal_for '/' do
    hal_for '/sub', rel: 'sub', title: 'a sub api module' do
      mount SubApi
    end
    mount FooApi
  end

end

After this, when a http request to specific path with json format accept headers.

GET / HTTP/1.1
Accept: application/hal+json, application/json, */*; q=0.01

grape/hal will response with the Hal data for you.

HTTP/1.1 200 OK
Content-Type: application/hal+json

{
  "_links": {
    "self": {
      "href": "/"
    },
    "sub": {
      "href": "/sub",
      "title": "a sub api module"
    },
    "foo api": {
      "href": "/foo_path",
      "title": "foo api description"
    }
  }
}

Footer

Feng Zhichao flankerfc(at)gmail.com