Module: Rackup::Handler

Defined in:
lib/rackup/handler.rb,
lib/rackup/handler/cgi.rb,
lib/rackup/handler/webrick.rb

Overview

Handlers connect web servers with Rack.

Rackup includes Handlers for WEBrick and CGI.

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, WEBrick

Constant Summary collapse

RACK_HANDLER =
'RACK_HANDLER'
RACKUP_HANDLER =
'RACKUP_HANDLER'

Class Method Summary collapse

Class Method Details

.[](name) ⇒ Object



27
28
29
30
31
32
33
34
35
# File 'lib/rackup/handler.rb', line 27

def self.[](name)
  name = name.to_sym

  begin
    @handlers[name] || self.const_get(name, false)
  rescue NameError
    # Ignore.
  end
end

.defaultObject



81
82
83
84
85
86
87
88
89
90
# File 'lib/rackup/handler.rb', line 81

def self.default
  if rack_handler = ENV[RACKUP_HANDLER]
    self.get(rack_handler)
  elsif rack_handler = ENV[RACK_HANDLER]
    warn "RACK_HANDLER is deprecated, use RACKUP_HANDLER."
    self.get(rack_handler)
  else
    pick SERVER_NAMES
  end
end

.get(name) ⇒ Object



37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# File 'lib/rackup/handler.rb', line 37

def self.get(name)
  return nil unless name

  name = name.to_sym

  if server = self[name]
    return server
  end

  begin
    require_handler("rackup/handler", name)
  rescue LoadError
    require_handler("rack/handler", name)
  end

  return self[name]
end

.pick(server_names) ⇒ Object

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

> pick ['puma', 'webrick']
=> Rackup::Handler::WEBrick

Raises:

  • (LoadError)


66
67
68
69
70
71
72
73
74
75
76
77
78
79
# File 'lib/rackup/handler.rb', line 66

def self.pick(server_names)
  server_names = Array(server_names)

  server_names.each do |server_name|
    begin
      server = self.get(server_name)
     return server if server
    rescue LoadError
      # Ignore.
    end
  end

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

.register(name, klass) ⇒ Object

Register a named handler class.



15
16
17
18
19
20
21
22
23
24
25
# File 'lib/rackup/handler.rb', line 15

def self.register(name, klass)
  if klass.is_a?(String)
    warn "Calling Rackup::Handler.register with a string is deprecated, use the class/module itself.", uplevel: 1

    klass = self.const_get(klass, false)
  end

  name = name.to_sym

  @handlers[name] = klass
end

.require_handler(prefix, const_name) ⇒ Object

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'


103
104
105
106
107
108
# File 'lib/rackup/handler.rb', line 103

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

  require(::File.join(prefix, file))
end