Skip to content

kitop/rack-transform

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Rack::Transform

Rack::Transform is a middleware that attemps to make a compatibility layer between two different request/responses that should hit the same endpoint.

The need arouse when migrating an API from PHP to Ruby, where the URLs were different and the response body used to have more metadata that was moved to headers.

Build Status Code Climate


Usage

use Rack::Transform do |map|
  map.on "playlist-get-cues" do |transformer|
    transformer.request = proc do |env|
      ...
    end
    transformer.response = proc do |status, header, body|
      ...
    end
  end

  map.on "search" do |transformer|
    ...
  end
  ...
end

map.on will receive a string that should match the type parameter from the URL and then a block to set the request and response transformers. For more information, see Rack::Transform::Transformer

Rack::Transform::Transformer

Rack:Transform::Transformer intent is to transform rack requests and/or responses into a different format. It can manipulate the request, the response, or both.

Usage:

Transformer.new do |transformer|
  transformer.request = proc do |env|
    ...
  end
  transformer.response = proc do |status, header, body|
    ...
  end
end

request and response methods should receive an object that responds to call, it can be a proc or and object. And they will receive an env object and status, header, body tuple accordingly. Should return the same modified as needed. You can use the base transformers if you prefer to use actual classes instead of procs.

Base Transformer

To help with boilerplate code, base transformer request and response classes were added. More info.

Contributing

See the contributing guide.

About

Middleware to make a compatibility layer between two different requests that should hit the same endpoint.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages