Porth (Plain Old Ruby Template Handler)
Write your views using plain old Ruby. Views are for representation, not defining
#as_json
in a model. There's no need to learn a DSL for building arrays and hashes.
Just use Ruby. Views are written once and rendered in JSON(P) or XML based on
the requested format. Porth makes few assumptions and can be configured.
Installation
Add this to your project's Gemfile and run $ bundle install
gem 'porth'
Usage
Create a controller that responds to JSON, XML or both.
# app/controllers/transmitters_controller.rb
class TransmittersController < ApplicationController
respond_to :json, :xml
def index
@transmitters = Transmitter.all
respond_with @transmitters
end
# ...
end
Create a template with a .rb
extension. Write plain old Ruby. Objects
must respond to #to_json
or #to_xml
. Arrays and hashes are best.
# app/views/transmitters/index.rb
@transmitters.map do |t|
{
name: t.area_served,
latitude: t.latitude,
longitude: t.longitude,
nearby: t.nearby.size
}
end
GET /transmitters.json
[{"name":"Brisbane","latitude":-27.4661111111111,"longitude":152.946388888889,"nearby":11}]
GET /transmitters.json?callback=myFunction
myFunction([{"name":"Brisbane","latitude":-27.4661111111111,"longitude":152.946388888889,"nearby":11}])
GET /transmitters.xml
<?xml version="1.0" encoding="UTF-8"?>
<transmitters type="array">
<transmitter>
<name>Brisbane</name>
<latitude type="float">-27.4661111111111</latitude>
<longitude type="float">152.946388888889</longitude>
<nearby type="integer">11</nearby>
</transmitter>
</transmitters>
Porth::UnknownFormatError
is raised when the requested format is not supported.
JSONP
Porth calls #json_callback
to get the function name for JSONP responses. By default
this method is added to ActionController::Base
and returns params[:callback]
. Override
#json_callback
to get different behaviour.
class ApplicationController < ActionController::Base
# ...
protected
def json_callback
nil # Ignore JSONP requests
end
end
XML
Porth guesses the resource's name from the controller's class. Foo::BarsController
becomes bars
. Override #xml_root
to explicitly set the resource name.
class TransmittersController < ApplicationController
# ...
protected
def xml_root
'sites'
end
end
Compatibility
- ActionPack 3.1.0
- JRuby 1.6.4
- Ruby 1.9.2
Contributing
- Fork
- Install dependancies by running
$ bundle install
- Write tests and code
- Make sure the tests pass by running
$ rake
- Push and send a pull request on GitHub
Credits
Porth is the result of numerous discussions at Everyday Hero around better API design.
Copyright
Copyright © 2011 Tate Johnson. Released under the MIT license. See LICENSE.