falcon 0.37.0 → 0.38.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/bin/falcon +1 -1
- data/lib/falcon/adapters/rack.rb +9 -8
- data/lib/falcon/adapters/response.rb +3 -3
- data/lib/falcon/command/host.rb +10 -2
- data/lib/falcon/command/proxy.rb +1 -1
- data/lib/falcon/command/redirect.rb +1 -1
- data/lib/falcon/command/serve.rb +6 -2
- data/lib/falcon/command/virtual.rb +3 -1
- data/lib/falcon/controller/proxy.rb +7 -3
- data/lib/falcon/controller/serve.rb +3 -3
- data/lib/falcon/middleware/proxy.rb +2 -2
- data/lib/falcon/middleware/verbose.rb +2 -2
- data/lib/falcon/service/application.rb +4 -4
- data/lib/falcon/service/generic.rb +1 -1
- data/lib/falcon/service/supervisor.rb +1 -1
- data/lib/falcon/services.rb +4 -4
- data/lib/falcon/version.rb +1 -1
- metadata +6 -6
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 528715bbefa4d1a6ac67c1ee8cf3776ba2e5dbd30b55cf1a7f8cac24b8644e03
|
4
|
+
data.tar.gz: dbaa0c70e17e2c1e2dbd29f21cad6ac64d7959685847341d7bfb5e69c0867f08
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c793d6ea24c5ddbe15e157d9958f62b0d88529beb79547d72744a93bf51ecafe7693ab54c9aaaba576d8c502b639744c6309faf97ceeeb271addf9b7ee86ea69
|
7
|
+
data.tar.gz: bbe4e7e16a0a937d2564771cd4503436302236e0b87d65813767b056da34d58a15808917b57cf4e602fec02faff53158f385e850ab3799dc561b79e797857cdb
|
data/bin/falcon
CHANGED
data/lib/falcon/adapters/rack.rb
CHANGED
@@ -25,7 +25,7 @@ require 'rack'
|
|
25
25
|
require_relative 'input'
|
26
26
|
require_relative 'response'
|
27
27
|
|
28
|
-
require '
|
28
|
+
require 'console'
|
29
29
|
|
30
30
|
module Falcon
|
31
31
|
module Adapters
|
@@ -60,6 +60,10 @@ module Falcon
|
|
60
60
|
RACK_IS_HIJACK = 'rack.hijack?'
|
61
61
|
RACK_HIJACK_IO = 'rack.hijack_io'
|
62
62
|
|
63
|
+
# Raised back up through the middleware when the underlying connection is hijacked.
|
64
|
+
class FullHijack < StandardError
|
65
|
+
end
|
66
|
+
|
63
67
|
# Async::HTTP specific metadata:
|
64
68
|
|
65
69
|
ASYNC_HTTP_REQUEST = "async.http.request"
|
@@ -70,13 +74,10 @@ module Falcon
|
|
70
74
|
|
71
75
|
# Initialize the rack adaptor middleware.
|
72
76
|
# @parameter app [Object] The rack middleware.
|
73
|
-
|
74
|
-
def initialize(app, logger = Async.logger)
|
77
|
+
def initialize(app)
|
75
78
|
@app = app
|
76
79
|
|
77
80
|
raise ArgumentError, "App must be callable!" unless @app.respond_to?(:call)
|
78
|
-
|
79
|
-
@logger = logger
|
80
81
|
end
|
81
82
|
|
82
83
|
# Unwrap raw HTTP headers into the CGI-style expected by Rack middleware.
|
@@ -146,7 +147,7 @@ module Falcon
|
|
146
147
|
|
147
148
|
RACK_INPUT => Input.new(request.body),
|
148
149
|
RACK_ERRORS => $stderr,
|
149
|
-
RACK_LOGGER =>
|
150
|
+
RACK_LOGGER => Console.logger,
|
150
151
|
|
151
152
|
RACK_MULTITHREAD => true,
|
152
153
|
RACK_MULTIPROCESS => true,
|
@@ -202,12 +203,12 @@ module Falcon
|
|
202
203
|
|
203
204
|
# If there was a full hijack:
|
204
205
|
if full_hijack
|
205
|
-
|
206
|
+
raise FullHijack, "The connection was hijacked."
|
206
207
|
else
|
207
208
|
return Response.wrap(status, headers, body, request)
|
208
209
|
end
|
209
210
|
rescue => exception
|
210
|
-
|
211
|
+
Console.logger.error(self) {exception}
|
211
212
|
|
212
213
|
return failure_response(exception)
|
213
214
|
end
|
@@ -78,7 +78,7 @@ module Falcon
|
|
78
78
|
ignored = headers.extract(IGNORE_HEADERS)
|
79
79
|
|
80
80
|
unless ignored.empty?
|
81
|
-
|
81
|
+
Console.logger.warn("Ignoring protocol-level headers: #{ignored.inspect}")
|
82
82
|
end
|
83
83
|
|
84
84
|
body = Output.wrap(status, headers, body)
|
@@ -92,10 +92,10 @@ module Falcon
|
|
92
92
|
protocol = meta['rack.protocol']
|
93
93
|
|
94
94
|
# https://tools.ietf.org/html/rfc7231#section-7.4.2
|
95
|
-
headers.add('server', "falcon/#{Falcon::VERSION}")
|
95
|
+
# headers.add('server', "falcon/#{Falcon::VERSION}")
|
96
96
|
|
97
97
|
# https://tools.ietf.org/html/rfc7231#section-7.1.1.2
|
98
|
-
headers.add('date', Time.now.httpdate)
|
98
|
+
# headers.add('date', Time.now.httpdate)
|
99
99
|
|
100
100
|
return self.new(status, headers, body, protocol)
|
101
101
|
end
|
data/lib/falcon/command/host.rb
CHANGED
@@ -64,14 +64,22 @@ module Falcon
|
|
64
64
|
|
65
65
|
# Prepare the environment and run the controller.
|
66
66
|
def call
|
67
|
-
|
67
|
+
Console.logger.info(self) do |buffer|
|
68
68
|
buffer.puts "Falcon Host v#{VERSION} taking flight!"
|
69
69
|
buffer.puts "- Configuration: #{@paths.join(', ')}"
|
70
70
|
buffer.puts "- To terminate: Ctrl-C or kill #{Process.pid}"
|
71
71
|
buffer.puts "- To reload: kill -HUP #{Process.pid}"
|
72
72
|
end
|
73
73
|
|
74
|
-
|
74
|
+
begin
|
75
|
+
Bundler.require(:preload)
|
76
|
+
rescue Bundler::GemfileNotFound
|
77
|
+
# Ignore.
|
78
|
+
end
|
79
|
+
|
80
|
+
if GC.respond_to?(:compact)
|
81
|
+
GC.compact
|
82
|
+
end
|
75
83
|
|
76
84
|
self.controller.run
|
77
85
|
end
|
data/lib/falcon/command/proxy.rb
CHANGED
@@ -66,7 +66,7 @@ module Falcon
|
|
66
66
|
|
67
67
|
# Prepare the environment and run the controller.
|
68
68
|
def call
|
69
|
-
|
69
|
+
Console.logger.info(self) do |buffer|
|
70
70
|
buffer.puts "Falcon Proxy v#{VERSION} taking flight!"
|
71
71
|
buffer.puts "- Binding to: #{@options[:bind]}"
|
72
72
|
buffer.puts "- To terminate: Ctrl-C or kill #{Process.pid}"
|
@@ -64,7 +64,7 @@ module Falcon
|
|
64
64
|
|
65
65
|
# Prepare the environment and run the controller.
|
66
66
|
def call
|
67
|
-
|
67
|
+
Console.logger.info(self) do |buffer|
|
68
68
|
buffer.puts "Falcon Redirect v#{VERSION} taking flight!"
|
69
69
|
buffer.puts "- Binding to: #{@options[:bind]}"
|
70
70
|
buffer.puts "- To terminate: Ctrl-C or kill #{Process.pid}"
|
data/lib/falcon/command/serve.rb
CHANGED
@@ -133,7 +133,7 @@ module Falcon
|
|
133
133
|
|
134
134
|
# Prepare the environment and run the controller.
|
135
135
|
def call
|
136
|
-
|
136
|
+
Console.logger.info(self) do |buffer|
|
137
137
|
buffer.puts "Falcon v#{VERSION} taking flight! Using #{self.container_class} #{self.container_options}."
|
138
138
|
buffer.puts "- Binding to: #{self.endpoint}"
|
139
139
|
buffer.puts "- To terminate: Ctrl-C or kill #{Process.pid}"
|
@@ -145,7 +145,11 @@ module Falcon
|
|
145
145
|
load(full_path)
|
146
146
|
end
|
147
147
|
|
148
|
-
|
148
|
+
begin
|
149
|
+
Bundler.require(:preload)
|
150
|
+
rescue Bundler::GemfileNotFound
|
151
|
+
# Ignore.
|
152
|
+
end
|
149
153
|
|
150
154
|
if GC.respond_to?(:compact)
|
151
155
|
GC.compact
|
@@ -71,12 +71,14 @@ module Falcon
|
|
71
71
|
|
72
72
|
# Prepare the environment and run the controller.
|
73
73
|
def call
|
74
|
-
|
74
|
+
Console.logger.info(self) do |buffer|
|
75
75
|
buffer.puts "Falcon Virtual v#{VERSION} taking flight!"
|
76
76
|
buffer.puts "- To terminate: Ctrl-C or kill #{Process.pid}"
|
77
77
|
buffer.puts "- To reload all sites: kill -HUP #{Process.pid}"
|
78
78
|
end
|
79
79
|
|
80
|
+
ENV['CONSOLE_LEVEL'] = 'debug'
|
81
|
+
|
80
82
|
self.controller.run
|
81
83
|
end
|
82
84
|
|
@@ -60,13 +60,13 @@ module Falcon
|
|
60
60
|
# @parameter hostname [String] The negotiated hostname.
|
61
61
|
def host_context(socket, hostname)
|
62
62
|
if host = @hosts[hostname]
|
63
|
-
|
63
|
+
Console.logger.debug(self) {"Resolving #{hostname} -> #{host}"}
|
64
64
|
|
65
65
|
socket.hostname = hostname
|
66
66
|
|
67
67
|
return host.ssl_context
|
68
68
|
else
|
69
|
-
|
69
|
+
Console.logger.warn(self) {"Unable to resolve #{hostname}!"}
|
70
70
|
|
71
71
|
return nil
|
72
72
|
end
|
@@ -110,8 +110,12 @@ module Falcon
|
|
110
110
|
|
111
111
|
services.each do |service|
|
112
112
|
if service.is_a?(Service::Proxy)
|
113
|
-
|
113
|
+
Console.logger.info(self) {"Proxying #{service.authority} to #{service.endpoint}"}
|
114
114
|
@hosts[service.authority] = service
|
115
|
+
|
116
|
+
# Pre-cache the ssl contexts:
|
117
|
+
# It seems some OpenSSL objects don't like event-driven I/O.
|
118
|
+
service.ssl_context
|
115
119
|
end
|
116
120
|
end
|
117
121
|
|
@@ -68,7 +68,7 @@ module Falcon
|
|
68
68
|
Async::IO::SharedEndpoint.bound(@endpoint)
|
69
69
|
end.wait
|
70
70
|
|
71
|
-
|
71
|
+
Console.logger.info(self) { "Starting #{name} on #{@endpoint.to_url}" }
|
72
72
|
|
73
73
|
@debug_trap.ignore!
|
74
74
|
|
@@ -90,13 +90,13 @@ module Falcon
|
|
90
90
|
|
91
91
|
task.async do
|
92
92
|
if @debug_trap.install!
|
93
|
-
|
93
|
+
Console.logger.info(instance) do
|
94
94
|
"- Per-process status: kill -USR1 #{Process.pid}"
|
95
95
|
end
|
96
96
|
end
|
97
97
|
|
98
98
|
@debug_trap.trap do
|
99
|
-
|
99
|
+
Console.logger.info(self) do |buffer|
|
100
100
|
task.reactor.print_hierarchy(buffer)
|
101
101
|
end
|
102
102
|
end
|
@@ -112,7 +112,7 @@ module Falcon
|
|
112
112
|
def prepare_request(request, host)
|
113
113
|
forwarded = []
|
114
114
|
|
115
|
-
|
115
|
+
Console.logger.debug(self) do |buffer|
|
116
116
|
buffer.puts "Request authority: #{request.authority}"
|
117
117
|
buffer.puts "Host authority: #{host.authority}"
|
118
118
|
buffer.puts "Request: #{request.method} #{request.path} #{request.version}"
|
@@ -158,7 +158,7 @@ module Falcon
|
|
158
158
|
super
|
159
159
|
end
|
160
160
|
rescue
|
161
|
-
|
161
|
+
Console.logger.error(self) {$!}
|
162
162
|
return Protocol::HTTP::Response[502, {'content-type' => 'text/plain'}, ["#{$!.inspect}: #{$!.backtrace.join("\n")}"]]
|
163
163
|
end
|
164
164
|
end
|
@@ -20,7 +20,7 @@
|
|
20
20
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
21
21
|
# THE SOFTWARE.
|
22
22
|
|
23
|
-
require '
|
23
|
+
require 'console'
|
24
24
|
require 'async/http/statistics'
|
25
25
|
|
26
26
|
module Falcon
|
@@ -30,7 +30,7 @@ module Falcon
|
|
30
30
|
# Initialize the verbose middleware.
|
31
31
|
# @parameter app [Protocol::HTTP::Middleware] The middleware to wrap.
|
32
32
|
# @parameter logger [Console::Logger] The logger to use.
|
33
|
-
def initialize(app, logger =
|
33
|
+
def initialize(app, logger = Console.logger)
|
34
34
|
super(app)
|
35
35
|
|
36
36
|
@logger = logger
|
@@ -52,7 +52,7 @@ module Falcon
|
|
52
52
|
def preload!
|
53
53
|
if scripts = @evaluator.preload
|
54
54
|
scripts.each do |path|
|
55
|
-
|
55
|
+
Console.logger.info(self) {"Preloading #{path}..."}
|
56
56
|
full_path = File.expand_path(path, self.root)
|
57
57
|
load(full_path)
|
58
58
|
end
|
@@ -62,7 +62,7 @@ module Falcon
|
|
62
62
|
# Prepare the bound endpoint for the application instances.
|
63
63
|
# Invoke {preload!} to load shared resources into the parent process.
|
64
64
|
def start
|
65
|
-
|
65
|
+
Console.logger.info(self) {"Binding to #{self.endpoint}..."}
|
66
66
|
|
67
67
|
@bound_endpoint = Async::Reactor.run do
|
68
68
|
Async::IO::SharedEndpoint.bound(self.endpoint)
|
@@ -87,8 +87,8 @@ module Falcon
|
|
87
87
|
run_options[:count] = count unless count.nil?
|
88
88
|
|
89
89
|
container.run(**run_options) do |instance|
|
90
|
-
Async
|
91
|
-
|
90
|
+
Async do |task|
|
91
|
+
Console.logger.info(self) {"Starting application server for #{self.root}..."}
|
92
92
|
|
93
93
|
server = Server.new(self.middleware, @bound_endpoint, protocol: protocol, scheme: scheme)
|
94
94
|
|
@@ -74,7 +74,7 @@ module Falcon
|
|
74
74
|
|
75
75
|
# Bind the supervisor to the specified endpoint.
|
76
76
|
def start
|
77
|
-
|
77
|
+
Console.logger.info(self) {"Binding to #{self.endpoint}..."}
|
78
78
|
|
79
79
|
@bound_endpoint = Async::Reactor.run do
|
80
80
|
Async::IO::SharedEndpoint.bound(self.endpoint)
|
data/lib/falcon/services.rb
CHANGED
@@ -61,7 +61,7 @@ module Falcon
|
|
61
61
|
# Start all named services.
|
62
62
|
def start
|
63
63
|
@named.each do |name, service|
|
64
|
-
|
64
|
+
Console.logger.debug(self) {"Starting #{name}..."}
|
65
65
|
service.start
|
66
66
|
end
|
67
67
|
end
|
@@ -71,7 +71,7 @@ module Falcon
|
|
71
71
|
# @parameter container [Async::Container::Generic]
|
72
72
|
def setup(container)
|
73
73
|
@named.each do |name, service|
|
74
|
-
|
74
|
+
Console.logger.debug(self) {"Setup #{name} into #{container}..."}
|
75
75
|
service.setup(container)
|
76
76
|
end
|
77
77
|
|
@@ -83,13 +83,13 @@ module Falcon
|
|
83
83
|
failed = false
|
84
84
|
|
85
85
|
@named.each do |name, service|
|
86
|
-
|
86
|
+
Console.logger.debug(self) {"Stopping #{name}..."}
|
87
87
|
|
88
88
|
begin
|
89
89
|
service.stop
|
90
90
|
rescue
|
91
91
|
failed = true
|
92
|
-
|
92
|
+
Console.logger.error(self, $!)
|
93
93
|
end
|
94
94
|
end
|
95
95
|
|
data/lib/falcon/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: falcon
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.38.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Samuel Williams
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2021-05-08 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: async
|
@@ -44,28 +44,28 @@ dependencies:
|
|
44
44
|
requirements:
|
45
45
|
- - "~>"
|
46
46
|
- !ruby/object:Gem::Version
|
47
|
-
version: 0.
|
47
|
+
version: 0.56.0
|
48
48
|
type: :runtime
|
49
49
|
prerelease: false
|
50
50
|
version_requirements: !ruby/object:Gem::Requirement
|
51
51
|
requirements:
|
52
52
|
- - "~>"
|
53
53
|
- !ruby/object:Gem::Version
|
54
|
-
version: 0.
|
54
|
+
version: 0.56.0
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
56
|
name: async-http-cache
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|
58
58
|
requirements:
|
59
59
|
- - "~>"
|
60
60
|
- !ruby/object:Gem::Version
|
61
|
-
version: 0.
|
61
|
+
version: 0.4.0
|
62
62
|
type: :runtime
|
63
63
|
prerelease: false
|
64
64
|
version_requirements: !ruby/object:Gem::Requirement
|
65
65
|
requirements:
|
66
66
|
- - "~>"
|
67
67
|
- !ruby/object:Gem::Version
|
68
|
-
version: 0.
|
68
|
+
version: 0.4.0
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
70
|
name: async-io
|
71
71
|
requirement: !ruby/object:Gem::Requirement
|