Class: Roger::Server

Inherits:
Object
  • Object
show all
Defined in:
lib/roger/server.rb

Overview

The Roger webserver. Initializes a rack server.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(project, options = {}) ⇒ Server

Returns a new instance of Server.



17
18
19
20
21
22
23
24
25
26
27
28
29
30
# File 'lib/roger/server.rb', line 17

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

  @stack = initialize_rack_builder

  @server_options = {}

  # Defaults
  self.port = 9000
  self.handler = nil
  self.host = "0.0.0.0"

  set_options(options)
end

Instance Attribute Details

#handlerObject

Returns the value of attribute handler.



15
16
17
# File 'lib/roger/server.rb', line 15

def handler
  @handler
end

#hostObject

Returns the value of attribute host.



15
16
17
# File 'lib/roger/server.rb', line 15

def host
  @host
end

#portObject

Returns the value of attribute port.



15
16
17
# File 'lib/roger/server.rb', line 15

def port
  @port
end

#projectObject (readonly)

Returns the value of attribute project.



13
14
15
# File 'lib/roger/server.rb', line 13

def project
  @project
end

#server_optionsObject (readonly)

Returns the value of attribute server_options.



11
12
13
# File 'lib/roger/server.rb', line 11

def server_options
  @server_options
end

Instance Method Details

#map(*args, &block) ⇒ Object

Use the map handler to map endpoints to certain urls

See Also:

  • Rack::Builder#map


50
51
52
# File 'lib/roger/server.rb', line 50

def map(*args, &block)
  @stack.map(*args, &block)
end

#run!Object Also known as: run



54
55
56
57
58
59
60
61
62
63
64
65
# File 'lib/roger/server.rb', line 54

def run!
  project.mode = :server
  handler.run application, server_options do |server|
    trap(:INT) do
      ## Use thins' hard #stop! if available, otherwise just #stop
      server.respond_to?(:stop!) ? server.stop! : server.stop
      puts "Roger, out!"
    end
  end
ensure
  project.mode = nil
end

#set_options(options) ⇒ Object

Sets the options, this is a separate method as we want to override certain things set in the rogerfile from the commandline



34
35
36
37
38
# File 'lib/roger/server.rb', line 34

def set_options(options)
  self.port = options[:port] if options.key?(:port)
  self.handler = options[:handler] if options.key?(:handler)
  self.host = options[:host] if options.key?(:host)
end

#use(*args, &block) ⇒ Object

Use the specified Rack middleware

See Also:

  • Rack::Builder#use


43
44
45
# File 'lib/roger/server.rb', line 43

def use(*args, &block)
  @stack.use(*args, &block)
end