Module: Rack::Handler

Defined in:
rack/rack/handler.rb,
rack/rack/handler/cgi.rb,
rack/rack/handler/lsws.rb,
rack/rack/handler/scgi.rb,
rack/rack/handler/thin.rb,
rack/rack/handler/mongrel.rb,
rack/rack/handler/webrick.rb,
rack/rack/handler/evented_mongrel.rb,
rack/rack/handler/swiftiplied_mongrel.rb,
rack/rack/handler/fastcgi.rb

Overview

Handlers connect web servers with Rack.

Rack includes Handlers for Thin, WEBrick, FastCGI, CGI, SCGI and LiteSpeed.

Handlers usually are activated by calling MyHandler.run(myapp). A second optional hash can be passed to include server-specific configuration.

Defined Under Namespace

Classes: CGI, EventedMongrel, FastCGI, LSWS, Mongrel, SCGI, SwiftipliedMongrel, Thin, WEBrick

Class Method Summary (collapse)

Class Method Details

+ (void) default(options = {})



46
47
48
49
50
51
52
53
54
55
56
57
58
59
# File 'rack/rack/handler.rb', line 46

def self.default(options = {})
  # Guess.
  if ENV.include?("PHP_FCGI_CHILDREN")
    # We already speak FastCGI
    options.delete :File
    options.delete :Port

    Rack::Handler::FastCGI
  elsif ENV.include?("REQUEST_METHOD")
    Rack::Handler::CGI
  else
    pick ['thin', 'puma', 'webrick']
  end
end

+ (void) get(server)



11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
# File 'rack/rack/handler.rb', line 11

def self.get(server)
  return unless server
  server = server.to_s

  unless @handlers.include? server
    load_error = try_require('rack/handler', server)
  end

  if klass = @handlers[server]
    klass.split("::").inject(Object) { |o, x| o.const_get(x) }
  else
    const_get(server)
  end

rescue NameError => name_error
  raise load_error || name_error
end

+ (void) pick(server_names)

Select first available Rack handler given an Array of server names. Raises LoadError if no handler was found.

> pick ['thin', 'webrick'] => Rack::Handler::WEBrick

Raises:

  • (LoadError)


34
35
36
37
38
39
40
41
42
43
44
# File 'rack/rack/handler.rb', line 34

def self.pick(server_names)
  server_names = Array(server_names)
  server_names.each do |server_name|
    begin
      return get(server_name.to_s)
    rescue LoadError, NameError
    end
  end

  raise LoadError, "Couldn't find handler for: #{server_names.join(', ')}."
end

+ (void) register(server, klass)



82
83
84
85
# File 'rack/rack/handler.rb', line 82

def self.register(server, klass)
  @handlers ||= {}
  @handlers[server.to_s] = klass.to_s
end

+ (void) try_require(prefix, const_name)

Transforms server-name constants to their canonical form as filenames, then tries to require them but silences the LoadError if not found

Naming convention:

Foo # => 'foo' FooBar # => 'foo_bar.rb' FooBAR # => 'foobar.rb' FOObar # => 'foobar.rb' FOOBAR # => 'foobar.rb' FooBarBaz # => 'foo_bar_baz.rb'



72
73
74
75
76
77
78
79
80
# File 'rack/rack/handler.rb', line 72

def self.try_require(prefix, const_name)
  file = const_name.gsub(/^[A-Z]+/) { |pre| pre.downcase }.
    gsub(/[A-Z]+[^A-Z]/, '_\&').downcase

  require(::File.join(prefix, file))
  nil
rescue LoadError => error
  error
end