Sinatra-controllers
Sinatra routing done differently. Allows for clean organization across multiple sinatra routes files.
-
this has only been tested with ruby 1.9.2
-
redirect doesn’t work.. yet
Examples
Also see the fixtures folders for what’s used in the tests.
views/index.haml
<!DOCTYPE HTML>
%html
%head
%meta(http-equiv="content-type" content="text/html; charset=utf-8")
%title test page
%body
fly away with sinatra controllers
You can divide your routes cleanly between as many classes as you please. At any time, you can also simply revert back to the plain vanilla sinatra syntax on use get at the top level.
sinatra_controller.rb
#!/usr/bin/env ruby
require 'sinatra'
require 'sinatra-controllers'
class Welcome < Sinatra::Controller
def index
haml :index
end
# this create a route corresponding to `get '/welcome/about'`
# making it a shortcut for common routes. It doesn't handle arguments
# unlike the block syntax.
def get_about
'making controllers in sinatra easy'
end
end
Sinatra::Controllers.register Welcome do
get '/', :index
end
This is a trick for common requests that don’t require arguments. It creates a route corresponding to ‘get ’/welcome/about’‘ in the flavor of Test::Unit where it uses the prefix before the underscore for the route type. The block to register is optional here.
class Welcome < Sinatra::Controller
def get_about
'making controllers in sinatra easy'
end
end
You can also use scopes for your own defined path, either because you’re unhappy with your classname, or because you just want to:
class Fringe < Sinatra::Controller
def get_walternet
'scopes'
end
def peter
'more scopes'
end
def index
'index still if you want'
end
end
Sinatra::Controllers.register(Fringe, :scope => 'fringe') do
get 'peter', :peter
get '/', :index
end
this enables the following routes
get '/fringe/walternet'
get '/fringe/peter'
get '/'