Class: Rack::SSL

Inherits:
Object
  • Object
show all
Defined in:
lib/rack/ssl.rb

Constant Summary collapse

YEAR =
31536000

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(app, options = {}) ⇒ SSL

Returns a new instance of SSL.



12
13
14
15
16
17
18
19
20
21
# File 'lib/rack/ssl.rb', line 12

def initialize(app, options = {})
  @app = app

  @hsts = options[:hsts]
  @hsts = {} if @hsts.nil? || @hsts == true
  @hsts = self.class.default_hsts_options.merge(@hsts) if @hsts

  @exclude = options[:exclude]
  @host    = options[:host]
end

Class Method Details

.default_hsts_optionsObject



8
9
10
# File 'lib/rack/ssl.rb', line 8

def self.default_hsts_options
  { :expires => YEAR, :subdomains => false }
end

Instance Method Details

#call(env) ⇒ Object



23
24
25
26
27
28
29
30
31
32
33
34
# File 'lib/rack/ssl.rb', line 23

def call(env)
  if @exclude && @exclude.call(env)
    @app.call(env)
  elsif scheme(env) == 'https'
    status, headers, body = @app.call(env)
    headers = hsts_headers.merge(headers)
    flag_cookies_as_secure!(headers)
    [status, headers, body]
  else
    redirect_to_https(env)
  end
end