mirror of
https://github.com/sinatra/sinatra
synced 2023-03-27 23:18:01 -04:00
Classy web-development dressed in a DSL (official / canonical repo)
bacfa20d9f
send_file_headers! now accepts nil for :disposition. When nil, omit both the Content-Disposition and Content-Transfer-Encoding headers. Modified Static to specify a nil :disposition. I believe this is more in line with how most web servers serve static directories by default. User agents are free to choose whether the entity should be displayed inline or treated as an attachment. Note that, although files served by the Static handler omit the Content-Disposition header by default, explicit calls to send_file and send_data in events default to :disposition => 'attachment'. |
||
---|---|---|
images | ||
lib | ||
test | ||
.gitignore | ||
Rakefile | ||
README.rdoc |
= Sinatra Sinatra a DSL for quickly creating web-applications in Ruby with minimal effort. = Sample app: # myapp.rb require 'rubygems' require 'sinatra' get '/' do 'Hello world!' end Ruby this as <tt>ruby myapp.rb</tt> and view at <tt>http://localhost:4567</tt> = RESTful get '/' do .. show things .. end post '/' do .. create something .. end put '/' do .. update something .. end delete '/' do .. annihilate something .. end head '/' do end NOTE: <tt>put</tt> and <tt>delete</tt> are triggered when a <tt>_method</tt> param is set to PUT or DELETE and the HTTP_REQUEST_METHOD is a POST = Routes NOTE: Routes are looked up in order of declaration Simple get '/hi' do ... end With params get '/:name' do # matches /sinatra and the like and sets params[:name] end Splat'n get '/message/*' do # matches /message/1/2/3/4/5 end Get an agent! get '/foo', :agent => /Songbird (\d\.\d)[\d\/]*?/ do "You're using Songbird version #{params[:agent][0]}" end get '/foo' do # matches non-songbird browsers end = Views (if you need MVC) All views are looked up in: root | - views/ == Templates === Haml/Sass get '/' do haml :index end This will render <tt>./views/index.haml</tt> === Inline get '/' do haml '%div.title Hello World' end This will render the inlined template string === Accessing Variables Templates are rendered in the context the current Sinatra::EventContext. This means you get all instance/class variables and methods it has access to. get '/:id' do @foo = Foo.find(params[:id]) haml '%h1== @foo.name' end Send local objects like: get '/:id' do localvar = Foo.find(params[:id]) haml '%h1== localvar.name', :locals => { :localvar => localvar } end This is more ideal for rendering templates as partials from within templates === Erb This works like Haml except you use <tt>erb</tt> instead of <tt>haml</tt> === Builder See Sinatra::Builder = Helpers It is ill-advised to create helpers on (main). Use the handy <tt>helpers</tt> to install helper methods on Sinatra::EventContext for use inside events and templates. Example: helpers do def bar(name) "#{name}bar" end end get '/:name' do bar(params[:name]) end = Before filters These are run in Sinatra::EventContext before do .. this code will run before each event .. end = Halt! To immediately stop a request during a before filter or event use: throw :halt === Variations Set the body to the result of a helper method throw :halt, :helper_method Set the body to the result of a helper method after sending it parameters from the local scope throw :halt, [:helper_method, foo, bar] Set the body to a simple string throw :halt, 'this will be the body' Set status then the body throw :halt, [401, 'go away!'] Set the status then call a helper method with params from local scope throw :halt, [401, [:helper_method, foo, bar]] Run a proc inside the Sinatra::EventContext instance and set the body to the result throw :halt, lambda { puts 'In a proc!'; 'I just wrote to $stdout!' } Create you own to_result class MyResultObject def to_result(event_context, *args) event_context.body = 'This will be the body! end end get '/' do throw :halt, MyResultObject.new end Get the gist? If you want more fun with this then checkout <tt>to_result</tt> on Array, Symbol, Fixnum, NilClass. = Configuration & Re-loading Sinatra supports multiple environments and re-loading. Re-loading happens on every request when in :development. Wrap your configurations in <tt>configure</tt> (i.e. Database connections, Constants, etc.) to protect them from re-loading and to only work in certain environments. All environments: configure do end Production configure :production do end Two at a time: configure :production, :test do end This is also really nifty for error handling. = Error handling === Not Found Remember: These are run inside the Sinatra::EventContext which means you get all the goodies is has to offer (i.e. haml, erb, :halt, etc.) Whenever NotFound is raised this will be called not_found do 'This is nowhere to be found' end === Error error do # this is where the error is stored for you to grab name = env['sinatra.error'].class.name 'ah shizzle! ' + name end Because Sinatra give you a default <tt>not_found</tt> and <tt>error</tt> do :production that are secure. If you want to customize only for :production but want to keep the friendly helper screens for :development then do this: configure :production do not_found do "We're so sorry, but we don't what this is" end error do "Something really nasty happened. We're on it!" end end = Testing === Test/Unit require 'my_sinatra_app' require 'sinatra/test/unit' class MyAppTest < Test::Unit::TestCase def test_my_default get_it '/' assert_equal 'My Default Page!', @response.body end def test_with_agent get_it '/', :agent => 'Songbird' assert_equal 'You're in Songbird!', @response.body end ... end === Test/Spec require 'my_sinatra_app' require 'sinatra/test/spec' context 'My app' should "show a default page" do get_it '/' should.be.ok @response.body.should.equal 'My Default Page!' end ... end == Test helpers See Sinatra::Test::Methods = Irb This will be back in soon = Command line Run your sinatra file like: ruby myapp.rb [options] Options are: -h # help -p # set the port (default is 4567) -e # set the environment (default is development) -x # turn on the mutext lock (default is off) = Contribute cd where/you/keep/your/projects git clone git://github.com/bmizerany/sinatra.git cd your_project ln -s ../sinatra/ at the top of your sinatra.rb file $:.unshift File.dirname(__FILE__) + '/sinatra/lib' require 'sinatra' get '/about' do "I'm running on Version " + Sinatra::Version.combined end