rack 1.6.12 → 2.0.7
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of rack might be problematic. Click here for more details.
- checksums.yaml +5 -5
- data/COPYING +1 -1
- data/HISTORY.md +138 -8
- data/README.rdoc +18 -28
- data/Rakefile +6 -14
- data/SPEC +10 -11
- data/contrib/rack_logo.svg +164 -111
- data/example/protectedlobster.rb +1 -1
- data/example/protectedlobster.ru +1 -1
- data/lib/rack.rb +70 -21
- data/lib/rack/auth/abstract/request.rb +5 -1
- data/lib/rack/auth/digest/params.rb +2 -3
- data/lib/rack/auth/digest/request.rb +1 -1
- data/lib/rack/body_proxy.rb +14 -9
- data/lib/rack/builder.rb +3 -3
- data/lib/rack/chunked.rb +5 -5
- data/lib/rack/{commonlogger.rb → common_logger.rb} +3 -3
- data/lib/rack/{conditionalget.rb → conditional_get.rb} +0 -0
- data/lib/rack/content_length.rb +2 -2
- data/lib/rack/deflater.rb +4 -39
- data/lib/rack/directory.rb +66 -54
- data/lib/rack/etag.rb +5 -4
- data/lib/rack/events.rb +154 -0
- data/lib/rack/file.rb +64 -40
- data/lib/rack/handler.rb +3 -25
- data/lib/rack/handler/cgi.rb +15 -16
- data/lib/rack/handler/fastcgi.rb +13 -14
- data/lib/rack/handler/lsws.rb +11 -11
- data/lib/rack/handler/scgi.rb +15 -15
- data/lib/rack/handler/thin.rb +3 -0
- data/lib/rack/handler/webrick.rb +24 -26
- data/lib/rack/head.rb +15 -17
- data/lib/rack/lint.rb +40 -40
- data/lib/rack/lobster.rb +1 -1
- data/lib/rack/lock.rb +15 -10
- data/lib/rack/logger.rb +2 -2
- data/lib/rack/media_type.rb +38 -0
- data/lib/rack/{methodoverride.rb → method_override.rb} +6 -6
- data/lib/rack/mime.rb +18 -5
- data/lib/rack/mock.rb +36 -54
- data/lib/rack/multipart.rb +35 -6
- data/lib/rack/multipart/generator.rb +5 -5
- data/lib/rack/multipart/parser.rb +270 -157
- data/lib/rack/multipart/uploaded_file.rb +1 -2
- data/lib/rack/{nulllogger.rb → null_logger.rb} +1 -1
- data/lib/rack/query_parser.rb +192 -0
- data/lib/rack/recursive.rb +8 -8
- data/lib/rack/request.rb +394 -305
- data/lib/rack/response.rb +130 -57
- data/lib/rack/rewindable_input.rb +1 -12
- data/lib/rack/runtime.rb +10 -18
- data/lib/rack/sendfile.rb +5 -7
- data/lib/rack/server.rb +30 -23
- data/lib/rack/session/abstract/id.rb +108 -138
- data/lib/rack/session/cookie.rb +26 -28
- data/lib/rack/session/memcache.rb +8 -14
- data/lib/rack/session/pool.rb +14 -21
- data/lib/rack/show_exceptions.rb +386 -0
- data/lib/rack/{showstatus.rb → show_status.rb} +3 -3
- data/lib/rack/static.rb +30 -5
- data/lib/rack/tempfile_reaper.rb +2 -2
- data/lib/rack/urlmap.rb +15 -14
- data/lib/rack/utils.rb +136 -211
- data/rack.gemspec +10 -9
- data/test/builder/an_underscore_app.rb +5 -0
- data/test/builder/options.ru +1 -1
- data/test/cgi/test.fcgi +1 -0
- data/test/cgi/test.gz +0 -0
- data/test/helper.rb +34 -0
- data/test/multipart/filename_with_encoded_words +7 -0
- data/test/multipart/filename_with_single_quote +7 -0
- data/test/multipart/quoted +15 -0
- data/test/multipart/rack-logo.png +0 -0
- data/test/multipart/unity3d_wwwform +11 -0
- data/test/registering_handler/rack/handler/registering_myself.rb +1 -1
- data/test/spec_auth_basic.rb +27 -19
- data/test/spec_auth_digest.rb +47 -46
- data/test/spec_body_proxy.rb +27 -27
- data/test/spec_builder.rb +51 -41
- data/test/spec_cascade.rb +24 -22
- data/test/spec_cgi.rb +49 -67
- data/test/spec_chunked.rb +37 -35
- data/test/{spec_commonlogger.rb → spec_common_logger.rb} +23 -21
- data/test/{spec_conditionalget.rb → spec_conditional_get.rb} +29 -28
- data/test/spec_config.rb +3 -2
- data/test/spec_content_length.rb +18 -17
- data/test/spec_content_type.rb +13 -12
- data/test/spec_deflater.rb +85 -49
- data/test/spec_directory.rb +87 -27
- data/test/spec_etag.rb +32 -31
- data/test/spec_events.rb +133 -0
- data/test/spec_fastcgi.rb +50 -72
- data/test/spec_file.rb +120 -77
- data/test/spec_handler.rb +19 -34
- data/test/spec_head.rb +15 -14
- data/test/spec_lint.rb +164 -199
- data/test/spec_lobster.rb +24 -23
- data/test/spec_lock.rb +79 -39
- data/test/spec_logger.rb +4 -3
- data/test/spec_media_type.rb +42 -0
- data/test/{spec_methodoverride.rb → spec_method_override.rb} +34 -35
- data/test/spec_mime.rb +19 -19
- data/test/spec_mock.rb +206 -144
- data/test/spec_multipart.rb +322 -200
- data/test/{spec_nulllogger.rb → spec_null_logger.rb} +5 -4
- data/test/spec_recursive.rb +17 -14
- data/test/spec_request.rb +780 -605
- data/test/spec_response.rb +215 -112
- data/test/spec_rewindable_input.rb +50 -40
- data/test/spec_runtime.rb +11 -10
- data/test/spec_sendfile.rb +30 -35
- data/test/spec_server.rb +78 -52
- data/test/spec_session_abstract_id.rb +11 -33
- data/test/spec_session_abstract_session_hash.rb +45 -0
- data/test/spec_session_cookie.rb +99 -67
- data/test/spec_session_memcache.rb +63 -101
- data/test/spec_session_pool.rb +48 -84
- data/test/{spec_showexceptions.rb → spec_show_exceptions.rb} +23 -28
- data/test/{spec_showstatus.rb → spec_show_status.rb} +36 -35
- data/test/spec_static.rb +71 -32
- data/test/spec_tempfile_reaper.rb +11 -10
- data/test/spec_thin.rb +55 -50
- data/test/spec_urlmap.rb +79 -78
- data/test/spec_utils.rb +441 -346
- data/test/spec_version.rb +2 -8
- data/test/spec_webrick.rb +93 -71
- data/test/static/foo.html +1 -0
- data/test/testrequest.rb +1 -1
- data/test/unregistered_handler/rack/handler/unregistered.rb +1 -1
- data/test/unregistered_handler/rack/handler/unregistered_long_one.rb +1 -1
- metadata +92 -70
- data/KNOWN-ISSUES +0 -44
- data/lib/rack/backports/uri/common_18.rb +0 -56
- data/lib/rack/backports/uri/common_192.rb +0 -52
- data/lib/rack/backports/uri/common_193.rb +0 -29
- data/lib/rack/handler/evented_mongrel.rb +0 -8
- data/lib/rack/handler/mongrel.rb +0 -106
- data/lib/rack/handler/swiftiplied_mongrel.rb +0 -8
- data/lib/rack/showexceptions.rb +0 -387
- data/lib/rack/utils/okjson.rb +0 -600
- data/test/spec_mongrel.rb +0 -182
data/lib/rack/etag.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
|
-
require '
|
1
|
+
require 'rack'
|
2
|
+
require 'digest/sha2'
|
2
3
|
|
3
4
|
module Rack
|
4
5
|
# Automatically sets the ETag header on all String bodies.
|
@@ -11,7 +12,7 @@ module Rack
|
|
11
12
|
# used when Etag is absent and a directive when it is present. The first
|
12
13
|
# defaults to nil, while the second defaults to "max-age=0, private, must-revalidate"
|
13
14
|
class ETag
|
14
|
-
ETAG_STRING =
|
15
|
+
ETAG_STRING = Rack::ETAG
|
15
16
|
DEFAULT_CACHE_CONTROL = "max-age=0, private, must-revalidate".freeze
|
16
17
|
|
17
18
|
def initialize(app, no_cache_control = nil, cache_control = DEFAULT_CACHE_CONTROL)
|
@@ -64,10 +65,10 @@ module Rack
|
|
64
65
|
|
65
66
|
body.each do |part|
|
66
67
|
parts << part
|
67
|
-
(digest ||= Digest::
|
68
|
+
(digest ||= Digest::SHA256.new) << part unless part.empty?
|
68
69
|
end
|
69
70
|
|
70
|
-
[digest && digest.hexdigest, parts]
|
71
|
+
[digest && digest.hexdigest.byteslice(0, 32), parts]
|
71
72
|
end
|
72
73
|
end
|
73
74
|
end
|
data/lib/rack/events.rb
ADDED
@@ -0,0 +1,154 @@
|
|
1
|
+
require 'rack/response'
|
2
|
+
require 'rack/body_proxy'
|
3
|
+
|
4
|
+
module Rack
|
5
|
+
### This middleware provides hooks to certain places in the request /
|
6
|
+
#response lifecycle. This is so that middleware that don't need to filter
|
7
|
+
#the response data can safely leave it alone and not have to send messages
|
8
|
+
#down the traditional "rack stack".
|
9
|
+
#
|
10
|
+
# The events are:
|
11
|
+
#
|
12
|
+
# * on_start(request, response)
|
13
|
+
#
|
14
|
+
# This event is sent at the start of the request, before the next
|
15
|
+
# middleware in the chain is called. This method is called with a request
|
16
|
+
# object, and a response object. Right now, the response object is always
|
17
|
+
# nil, but in the future it may actually be a real response object.
|
18
|
+
#
|
19
|
+
# * on_commit(request, response)
|
20
|
+
#
|
21
|
+
# The response has been committed. The application has returned, but the
|
22
|
+
# response has not been sent to the webserver yet. This method is always
|
23
|
+
# called with a request object and the response object. The response
|
24
|
+
# object is constructed from the rack triple that the application returned.
|
25
|
+
# Changes may still be made to the response object at this point.
|
26
|
+
#
|
27
|
+
# * on_send(request, response)
|
28
|
+
#
|
29
|
+
# The webserver has started iterating over the response body and presumably
|
30
|
+
# has started sending data over the wire. This method is always called with
|
31
|
+
# a request object and the response object. The response object is
|
32
|
+
# constructed from the rack triple that the application returned. Changes
|
33
|
+
# SHOULD NOT be made to the response object as the webserver has already
|
34
|
+
# started sending data. Any mutations will likely result in an exception.
|
35
|
+
#
|
36
|
+
# * on_finish(request, response)
|
37
|
+
#
|
38
|
+
# The webserver has closed the response, and all data has been written to
|
39
|
+
# the response socket. The request and response object should both be
|
40
|
+
# read-only at this point. The body MAY NOT be available on the response
|
41
|
+
# object as it may have been flushed to the socket.
|
42
|
+
#
|
43
|
+
# * on_error(request, response, error)
|
44
|
+
#
|
45
|
+
# An exception has occurred in the application or an `on_commit` event.
|
46
|
+
# This method will get the request, the response (if available) and the
|
47
|
+
# exception that was raised.
|
48
|
+
#
|
49
|
+
# ## Order
|
50
|
+
#
|
51
|
+
# `on_start` is called on the handlers in the order that they were passed to
|
52
|
+
# the constructor. `on_commit`, on_send`, `on_finish`, and `on_error` are
|
53
|
+
# called in the reverse order. `on_finish` handlers are called inside an
|
54
|
+
# `ensure` block, so they are guaranteed to be called even if something
|
55
|
+
# raises an exception. If something raises an exception in a `on_finish`
|
56
|
+
# method, then nothing is guaranteed.
|
57
|
+
|
58
|
+
class Events
|
59
|
+
module Abstract
|
60
|
+
def on_start req, res
|
61
|
+
end
|
62
|
+
|
63
|
+
def on_commit req, res
|
64
|
+
end
|
65
|
+
|
66
|
+
def on_send req, res
|
67
|
+
end
|
68
|
+
|
69
|
+
def on_finish req, res
|
70
|
+
end
|
71
|
+
|
72
|
+
def on_error req, res, e
|
73
|
+
end
|
74
|
+
end
|
75
|
+
|
76
|
+
class EventedBodyProxy < Rack::BodyProxy # :nodoc:
|
77
|
+
attr_reader :request, :response
|
78
|
+
|
79
|
+
def initialize body, request, response, handlers, &block
|
80
|
+
super(body, &block)
|
81
|
+
@request = request
|
82
|
+
@response = response
|
83
|
+
@handlers = handlers
|
84
|
+
end
|
85
|
+
|
86
|
+
def each
|
87
|
+
@handlers.reverse_each { |handler| handler.on_send request, response }
|
88
|
+
super
|
89
|
+
end
|
90
|
+
end
|
91
|
+
|
92
|
+
class BufferedResponse < Rack::Response::Raw # :nodoc:
|
93
|
+
attr_reader :body
|
94
|
+
|
95
|
+
def initialize status, headers, body
|
96
|
+
super(status, headers)
|
97
|
+
@body = body
|
98
|
+
end
|
99
|
+
|
100
|
+
def to_a; [status, headers, body]; end
|
101
|
+
end
|
102
|
+
|
103
|
+
def initialize app, handlers
|
104
|
+
@app = app
|
105
|
+
@handlers = handlers
|
106
|
+
end
|
107
|
+
|
108
|
+
def call env
|
109
|
+
request = make_request env
|
110
|
+
on_start request, nil
|
111
|
+
|
112
|
+
begin
|
113
|
+
status, headers, body = @app.call request.env
|
114
|
+
response = make_response status, headers, body
|
115
|
+
on_commit request, response
|
116
|
+
rescue StandardError => e
|
117
|
+
on_error request, response, e
|
118
|
+
on_finish request, response
|
119
|
+
raise
|
120
|
+
end
|
121
|
+
|
122
|
+
body = EventedBodyProxy.new(body, request, response, @handlers) do
|
123
|
+
on_finish request, response
|
124
|
+
end
|
125
|
+
[response.status, response.headers, body]
|
126
|
+
end
|
127
|
+
|
128
|
+
private
|
129
|
+
|
130
|
+
def on_error request, response, e
|
131
|
+
@handlers.reverse_each { |handler| handler.on_error request, response, e }
|
132
|
+
end
|
133
|
+
|
134
|
+
def on_commit request, response
|
135
|
+
@handlers.reverse_each { |handler| handler.on_commit request, response }
|
136
|
+
end
|
137
|
+
|
138
|
+
def on_start request, response
|
139
|
+
@handlers.each { |handler| handler.on_start request, nil }
|
140
|
+
end
|
141
|
+
|
142
|
+
def on_finish request, response
|
143
|
+
@handlers.reverse_each { |handler| handler.on_finish request, response }
|
144
|
+
end
|
145
|
+
|
146
|
+
def make_request env
|
147
|
+
Rack::Request.new env
|
148
|
+
end
|
149
|
+
|
150
|
+
def make_response status, headers, body
|
151
|
+
BufferedResponse.new status, headers, body
|
152
|
+
end
|
153
|
+
end
|
154
|
+
end
|
data/lib/rack/file.rb
CHANGED
@@ -1,6 +1,8 @@
|
|
1
1
|
require 'time'
|
2
2
|
require 'rack/utils'
|
3
3
|
require 'rack/mime'
|
4
|
+
require 'rack/request'
|
5
|
+
require 'rack/head'
|
4
6
|
|
5
7
|
module Rack
|
6
8
|
# Rack::File serves files below the +root+ directory given, according to the
|
@@ -15,70 +17,70 @@ module Rack
|
|
15
17
|
ALLOWED_VERBS = %w[GET HEAD OPTIONS]
|
16
18
|
ALLOW_HEADER = ALLOWED_VERBS.join(', ')
|
17
19
|
|
18
|
-
|
19
|
-
attr_accessor :path
|
20
|
-
attr_accessor :cache_control
|
21
|
-
|
22
|
-
alias :to_path :path
|
20
|
+
attr_reader :root
|
23
21
|
|
24
22
|
def initialize(root, headers={}, default_mime = 'text/plain')
|
25
23
|
@root = root
|
26
24
|
@headers = headers
|
27
25
|
@default_mime = default_mime
|
26
|
+
@head = Rack::Head.new(lambda { |env| get env })
|
28
27
|
end
|
29
28
|
|
30
29
|
def call(env)
|
31
|
-
|
30
|
+
# HEAD requests drop the response body, including 4xx error messages.
|
31
|
+
@head.call env
|
32
32
|
end
|
33
33
|
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
unless ALLOWED_VERBS.include? env[REQUEST_METHOD]
|
34
|
+
def get(env)
|
35
|
+
request = Rack::Request.new env
|
36
|
+
unless ALLOWED_VERBS.include? request.request_method
|
38
37
|
return fail(405, "Method Not Allowed", {'Allow' => ALLOW_HEADER})
|
39
38
|
end
|
40
39
|
|
41
|
-
path_info = Utils.
|
42
|
-
|
40
|
+
path_info = Utils.unescape_path request.path_info
|
41
|
+
return fail(400, "Bad Request") unless Utils.valid_path?(path_info)
|
43
42
|
|
44
|
-
|
43
|
+
clean_path_info = Utils.clean_path_info(path_info)
|
44
|
+
path = ::File.join(@root, clean_path_info)
|
45
45
|
|
46
46
|
available = begin
|
47
|
-
|
47
|
+
::File.file?(path) && ::File.readable?(path)
|
48
48
|
rescue SystemCallError
|
49
49
|
false
|
50
50
|
end
|
51
51
|
|
52
52
|
if available
|
53
|
-
serving(
|
53
|
+
serving(request, path)
|
54
54
|
else
|
55
55
|
fail(404, "File not found: #{path_info}")
|
56
56
|
end
|
57
57
|
end
|
58
58
|
|
59
|
-
def serving(
|
60
|
-
if
|
59
|
+
def serving(request, path)
|
60
|
+
if request.options?
|
61
61
|
return [200, {'Allow' => ALLOW_HEADER, CONTENT_LENGTH => '0'}, []]
|
62
62
|
end
|
63
|
-
last_modified =
|
64
|
-
return [304, {}, []] if
|
63
|
+
last_modified = ::File.mtime(path).httpdate
|
64
|
+
return [304, {}, []] if request.get_header('HTTP_IF_MODIFIED_SINCE') == last_modified
|
65
65
|
|
66
66
|
headers = { "Last-Modified" => last_modified }
|
67
|
+
mime_type = mime_type path, @default_mime
|
67
68
|
headers[CONTENT_TYPE] = mime_type if mime_type
|
68
69
|
|
69
70
|
# Set custom headers
|
70
71
|
@headers.each { |field, content| headers[field] = content } if @headers
|
71
72
|
|
72
|
-
response = [ 200, headers
|
73
|
+
response = [ 200, headers ]
|
73
74
|
|
74
|
-
size = filesize
|
75
|
+
size = filesize path
|
75
76
|
|
76
|
-
|
77
|
+
range = nil
|
78
|
+
ranges = Rack::Utils.get_byte_ranges(request.get_header('HTTP_RANGE'), size)
|
77
79
|
if ranges.nil? || ranges.length > 1
|
78
80
|
# No ranges, or multiple ranges (which we don't support):
|
79
81
|
# TODO: Support multiple byte-ranges
|
80
82
|
response[0] = 200
|
81
|
-
|
83
|
+
range = 0..size-1
|
82
84
|
elsif ranges.empty?
|
83
85
|
# Unsatisfiable. Return error, and file size:
|
84
86
|
response = fail(416, "Byte range unsatisfiable")
|
@@ -86,36 +88,58 @@ module Rack
|
|
86
88
|
return response
|
87
89
|
else
|
88
90
|
# Partial content:
|
89
|
-
|
91
|
+
range = ranges[0]
|
90
92
|
response[0] = 206
|
91
|
-
response[1]["Content-Range"] = "bytes #{
|
92
|
-
size =
|
93
|
+
response[1]["Content-Range"] = "bytes #{range.begin}-#{range.end}/#{size}"
|
94
|
+
size = range.end - range.begin + 1
|
93
95
|
end
|
94
96
|
|
95
97
|
response[2] = [response_body] unless response_body.nil?
|
96
98
|
|
97
99
|
response[1][CONTENT_LENGTH] = size.to_s
|
100
|
+
response[2] = make_body request, path, range
|
98
101
|
response
|
99
102
|
end
|
100
103
|
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
104
|
+
class Iterator
|
105
|
+
attr_reader :path, :range
|
106
|
+
alias :to_path :path
|
107
|
+
|
108
|
+
def initialize path, range
|
109
|
+
@path = path
|
110
|
+
@range = range
|
111
|
+
end
|
109
112
|
|
110
|
-
|
113
|
+
def each
|
114
|
+
::File.open(path, "rb") do |file|
|
115
|
+
file.seek(range.begin)
|
116
|
+
remaining_len = range.end-range.begin+1
|
117
|
+
while remaining_len > 0
|
118
|
+
part = file.read([8192, remaining_len].min)
|
119
|
+
break unless part
|
120
|
+
remaining_len -= part.length
|
121
|
+
|
122
|
+
yield part
|
123
|
+
end
|
111
124
|
end
|
112
125
|
end
|
126
|
+
|
127
|
+
def close; end
|
113
128
|
end
|
114
129
|
|
115
130
|
private
|
116
131
|
|
132
|
+
def make_body request, path, range
|
133
|
+
if request.head?
|
134
|
+
[]
|
135
|
+
else
|
136
|
+
Iterator.new path, range
|
137
|
+
end
|
138
|
+
end
|
139
|
+
|
117
140
|
def fail(status, body, headers = {})
|
118
141
|
body += "\n"
|
142
|
+
|
119
143
|
[
|
120
144
|
status,
|
121
145
|
{
|
@@ -128,18 +152,18 @@ module Rack
|
|
128
152
|
end
|
129
153
|
|
130
154
|
# The MIME type for the contents of the file located at @path
|
131
|
-
def mime_type
|
132
|
-
Mime.mime_type(
|
155
|
+
def mime_type path, default_mime
|
156
|
+
Mime.mime_type(::File.extname(path), default_mime)
|
133
157
|
end
|
134
158
|
|
135
|
-
def filesize
|
159
|
+
def filesize path
|
136
160
|
# If response_body is present, use its size.
|
137
|
-
return
|
161
|
+
return response_body.bytesize if response_body
|
138
162
|
|
139
163
|
# We check via File::size? whether this file provides size info
|
140
164
|
# via stat (e.g. /proc files often don't), otherwise we have to
|
141
165
|
# figure it out by reading the whole file into memory.
|
142
|
-
|
166
|
+
::File.size?(path) || ::File.read(path).bytesize
|
143
167
|
end
|
144
168
|
|
145
169
|
# By default, the response body for file requests is nil.
|
data/lib/rack/handler.rb
CHANGED
@@ -19,25 +19,13 @@ module Rack
|
|
19
19
|
if klass = @handlers[server]
|
20
20
|
klass.split("::").inject(Object) { |o, x| o.const_get(x) }
|
21
21
|
else
|
22
|
-
|
22
|
+
const_get(server, false)
|
23
23
|
end
|
24
24
|
|
25
25
|
rescue NameError => name_error
|
26
26
|
raise load_error || name_error
|
27
27
|
end
|
28
28
|
|
29
|
-
begin
|
30
|
-
::Object.const_get("Object", false)
|
31
|
-
def self._const_get(str, inherit = true)
|
32
|
-
const_get(str, inherit)
|
33
|
-
end
|
34
|
-
rescue
|
35
|
-
def self._const_get(str, inherit = true)
|
36
|
-
const_get(str)
|
37
|
-
end
|
38
|
-
end
|
39
|
-
|
40
|
-
|
41
29
|
# Select first available Rack handler given an `Array` of server names.
|
42
30
|
# Raises `LoadError` if no handler was found.
|
43
31
|
#
|
@@ -55,20 +43,16 @@ module Rack
|
|
55
43
|
raise LoadError, "Couldn't find handler for: #{server_names.join(', ')}."
|
56
44
|
end
|
57
45
|
|
58
|
-
def self.default
|
46
|
+
def self.default
|
59
47
|
# Guess.
|
60
48
|
if ENV.include?("PHP_FCGI_CHILDREN")
|
61
|
-
# We already speak FastCGI
|
62
|
-
options.delete :File
|
63
|
-
options.delete :Port
|
64
|
-
|
65
49
|
Rack::Handler::FastCGI
|
66
50
|
elsif ENV.include?(REQUEST_METHOD)
|
67
51
|
Rack::Handler::CGI
|
68
52
|
elsif ENV.include?("RACK_HANDLER")
|
69
53
|
self.get(ENV["RACK_HANDLER"])
|
70
54
|
else
|
71
|
-
pick ['
|
55
|
+
pick ['puma', 'thin', 'webrick']
|
72
56
|
end
|
73
57
|
end
|
74
58
|
|
@@ -100,9 +84,6 @@ module Rack
|
|
100
84
|
|
101
85
|
autoload :CGI, "rack/handler/cgi"
|
102
86
|
autoload :FastCGI, "rack/handler/fastcgi"
|
103
|
-
autoload :Mongrel, "rack/handler/mongrel"
|
104
|
-
autoload :EventedMongrel, "rack/handler/evented_mongrel"
|
105
|
-
autoload :SwiftipliedMongrel, "rack/handler/swiftiplied_mongrel"
|
106
87
|
autoload :WEBrick, "rack/handler/webrick"
|
107
88
|
autoload :LSWS, "rack/handler/lsws"
|
108
89
|
autoload :SCGI, "rack/handler/scgi"
|
@@ -110,9 +91,6 @@ module Rack
|
|
110
91
|
|
111
92
|
register 'cgi', 'Rack::Handler::CGI'
|
112
93
|
register 'fastcgi', 'Rack::Handler::FastCGI'
|
113
|
-
register 'mongrel', 'Rack::Handler::Mongrel'
|
114
|
-
register 'emongrel', 'Rack::Handler::EventedMongrel'
|
115
|
-
register 'smongrel', 'Rack::Handler::SwiftipliedMongrel'
|
116
94
|
register 'webrick', 'Rack::Handler::WEBrick'
|
117
95
|
register 'lsws', 'Rack::Handler::LSWS'
|
118
96
|
register 'scgi', 'Rack::Handler::SCGI'
|
data/lib/rack/handler/cgi.rb
CHANGED
@@ -13,22 +13,21 @@ module Rack
|
|
13
13
|
env = ENV.to_hash
|
14
14
|
env.delete "HTTP_CONTENT_LENGTH"
|
15
15
|
|
16
|
-
env[
|
17
|
-
|
18
|
-
env.update(
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
env[
|
30
|
-
env[
|
31
|
-
env["REQUEST_PATH"] ||= "/"
|
16
|
+
env[SCRIPT_NAME] = "" if env[SCRIPT_NAME] == "/"
|
17
|
+
|
18
|
+
env.update(
|
19
|
+
RACK_VERSION => Rack::VERSION,
|
20
|
+
RACK_INPUT => Rack::RewindableInput.new($stdin),
|
21
|
+
RACK_ERRORS => $stderr,
|
22
|
+
RACK_MULTITHREAD => false,
|
23
|
+
RACK_MULTIPROCESS => true,
|
24
|
+
RACK_RUNONCE => true,
|
25
|
+
RACK_URL_SCHEME => ["yes", "on", "1"].include?(ENV[HTTPS]) ? "https" : "http"
|
26
|
+
)
|
27
|
+
|
28
|
+
env[QUERY_STRING] ||= ""
|
29
|
+
env[HTTP_VERSION] ||= env[SERVER_PROTOCOL]
|
30
|
+
env[REQUEST_PATH] ||= "/"
|
32
31
|
|
33
32
|
status, headers, body = app.call(env)
|
34
33
|
begin
|