Class: Bjork::TryStatic

Inherits:
Object
  • Object
show all
Defined in:
lib/bjork/try_static.rb

Overview

The Bjork::TryStatic middleware delegates requests to Rack::Static middleware trying to match a static file

Examples

use Bjork::TryStatic,

:root => "public",  # static files root dir
:urls => %w[/],     # match all requests
:try => ['.html', 'index.html', '/index.html'] # try these postfixes sequentially

uses same options as Rack::Static with extra :try option which is an array
of postfixes to find desired file

Instance Method Summary collapse

Constructor Details

#initialize(app, options) ⇒ TryStatic

Returns a new instance of TryStatic.



18
19
20
21
22
23
24
25
# File 'lib/bjork/try_static.rb', line 18

def initialize(app, options)
  @app = app
  @try = ['', *options[:try]]
  @static = ::Rack::Static.new(
    lambda { |_| [404, {}, []] },
    options
  )
end

Instance Method Details

#call(env) ⇒ Object



27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
# File 'lib/bjork/try_static.rb', line 27

def call(env)
  # TODO: Should we skip for all non-GET methods?
  # Skip for POST
  return @app.call(env) if env["REQUEST_METHOD"] == "POST"

  orig_path = env['PATH_INFO']
  found = nil

  @try.each do |path|
    resp = @static.call(env.merge!({'PATH_INFO' => orig_path + path}))
    break if 404 != resp[0] && found = resp
  end

  found or @app.call(env.merge!('PATH_INFO' => orig_path))
end