mirror of
https://gitea.invidious.io/iv-org/shard-kemal.git
synced 2024-08-15 00:53:36 +00:00
Add app reference to the handlers which are bound to the app
This commit is contained in:
parent
dc93bb2235
commit
72bcac6dd5
12 changed files with 58 additions and 49 deletions
|
@ -64,7 +64,6 @@ describe "Context" do
|
||||||
io = IO::Memory.new
|
io = IO::Memory.new
|
||||||
response = HTTP::Server::Response.new(io)
|
response = HTTP::Server::Response.new(io)
|
||||||
context = HTTP::Server::Context.new(request, response)
|
context = HTTP::Server::Context.new(request, response)
|
||||||
context.app = app
|
|
||||||
app.filter_handler.call(context)
|
app.filter_handler.call(context)
|
||||||
app.route_handler.call(context)
|
app.route_handler.call(context)
|
||||||
context.store["key"].should eq "value"
|
context.store["key"].should eq "value"
|
||||||
|
|
|
@ -12,11 +12,11 @@ class CustomLogHandler < Kemal::BaseLogHandler
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def create_request_and_return_io(handler, request)
|
def create_request_and_return_io(handler, request, app = Kemal.application)
|
||||||
io = IO::Memory.new
|
io = IO::Memory.new
|
||||||
response = HTTP::Server::Response.new(io)
|
response = HTTP::Server::Response.new(io)
|
||||||
context = HTTP::Server::Context.new(request, response)
|
context = HTTP::Server::Context.new(request, response)
|
||||||
context.app = Kemal.application
|
context.app = app
|
||||||
handler.call(context)
|
handler.call(context)
|
||||||
response.close
|
response.close
|
||||||
io.rewind
|
io.rewind
|
||||||
|
|
|
@ -26,9 +26,8 @@ describe "Kemal::ExceptionHandler" do
|
||||||
app.get "/" do |env|
|
app.get "/" do |env|
|
||||||
env.response.status_code = 403
|
env.response.status_code = 403
|
||||||
end
|
end
|
||||||
context.app = app
|
|
||||||
subject = Kemal::ExceptionHandler.new(app)
|
subject = Kemal::ExceptionHandler.new(app)
|
||||||
subject.next = Kemal::RouteHandler.new
|
subject.next = app.route_handler
|
||||||
subject.call(context)
|
subject.call(context)
|
||||||
response.close
|
response.close
|
||||||
io.rewind
|
io.rewind
|
||||||
|
@ -50,9 +49,8 @@ describe "Kemal::ExceptionHandler" do
|
||||||
app.get "/" do |env|
|
app.get "/" do |env|
|
||||||
env.response.status_code = 500
|
env.response.status_code = 500
|
||||||
end
|
end
|
||||||
context.app = app
|
|
||||||
subject = Kemal::ExceptionHandler.new(app)
|
subject = Kemal::ExceptionHandler.new(app)
|
||||||
subject.next = Kemal::RouteHandler.new
|
subject.next = app.route_handler
|
||||||
subject.call(context)
|
subject.call(context)
|
||||||
response.close
|
response.close
|
||||||
io.rewind
|
io.rewind
|
||||||
|
@ -75,9 +73,8 @@ describe "Kemal::ExceptionHandler" do
|
||||||
env.response.content_type = "application/json"
|
env.response.content_type = "application/json"
|
||||||
env.response.status_code = 500
|
env.response.status_code = 500
|
||||||
end
|
end
|
||||||
context.app = app
|
|
||||||
subject = Kemal::ExceptionHandler.new(app)
|
subject = Kemal::ExceptionHandler.new(app)
|
||||||
subject.next = Kemal::RouteHandler.new
|
subject.next = app.route_handler
|
||||||
subject.call(context)
|
subject.call(context)
|
||||||
response.close
|
response.close
|
||||||
io.rewind
|
io.rewind
|
||||||
|
@ -100,9 +97,8 @@ describe "Kemal::ExceptionHandler" do
|
||||||
env.response.content_type = "application/json"
|
env.response.content_type = "application/json"
|
||||||
env.response.status_code = 500
|
env.response.status_code = 500
|
||||||
end
|
end
|
||||||
context.app = app
|
subject = Kemal::ExceptionHandler.new(app)
|
||||||
subject = Kemal::ExceptionHandler.new(Kemal::Base.new)
|
subject.next = app.route_handler
|
||||||
subject.next = Kemal::RouteHandler.new
|
|
||||||
subject.call(context)
|
subject.call(context)
|
||||||
response.close
|
response.close
|
||||||
io.rewind
|
io.rewind
|
||||||
|
|
|
@ -69,8 +69,8 @@ end
|
||||||
|
|
||||||
describe "Handler" do
|
describe "Handler" do
|
||||||
it "adds custom handler before before_*" do
|
it "adds custom handler before before_*" do
|
||||||
filter_middleware = Kemal::FilterHandler.new
|
app = Kemal::Base.new
|
||||||
Kemal.application.add_filter_handler filter_middleware
|
filter_middleware = Kemal::FilterHandler.new(app)
|
||||||
filter_middleware._add_route_filter("GET", "/", :before) do |env|
|
filter_middleware._add_route_filter("GET", "/", :before) do |env|
|
||||||
env.response << " is"
|
env.response << " is"
|
||||||
end
|
end
|
||||||
|
@ -78,7 +78,6 @@ describe "Handler" do
|
||||||
filter_middleware._add_route_filter("GET", "/", :before) do |env|
|
filter_middleware._add_route_filter("GET", "/", :before) do |env|
|
||||||
env.response << " so"
|
env.response << " so"
|
||||||
end
|
end
|
||||||
app = Kemal::Base.new
|
|
||||||
app.add_filter_handler filter_middleware
|
app.add_filter_handler filter_middleware
|
||||||
|
|
||||||
app.add_handler CustomTestHandler.new
|
app.add_handler CustomTestHandler.new
|
||||||
|
|
|
@ -5,7 +5,7 @@ describe "Kemal::FilterHandler" do
|
||||||
test_filter = FilterTest.new
|
test_filter = FilterTest.new
|
||||||
test_filter.modified = "false"
|
test_filter.modified = "false"
|
||||||
|
|
||||||
filter_middleware = Kemal::FilterHandler.new
|
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||||
filter_middleware._add_route_filter("GET", "/greetings", :before) { test_filter.modified = "true" }
|
filter_middleware._add_route_filter("GET", "/greetings", :before) { test_filter.modified = "true" }
|
||||||
|
|
||||||
kemal = Kemal.application.route_handler
|
kemal = Kemal.application.route_handler
|
||||||
|
@ -23,7 +23,7 @@ describe "Kemal::FilterHandler" do
|
||||||
test_filter = FilterTest.new
|
test_filter = FilterTest.new
|
||||||
test_filter.modified = "false"
|
test_filter.modified = "false"
|
||||||
|
|
||||||
filter_middleware = Kemal::FilterHandler.new
|
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||||
filter_middleware._add_route_filter("GET", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
filter_middleware._add_route_filter("GET", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||||
|
|
||||||
kemal = Kemal.application.route_handler
|
kemal = Kemal.application.route_handler
|
||||||
|
@ -49,7 +49,7 @@ describe "Kemal::FilterHandler" do
|
||||||
test_filter = FilterTest.new
|
test_filter = FilterTest.new
|
||||||
test_filter.modified = "false"
|
test_filter.modified = "false"
|
||||||
|
|
||||||
filter_middleware = Kemal::FilterHandler.new
|
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||||
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||||
filter_middleware._add_route_filter("GET", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
filter_middleware._add_route_filter("GET", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||||
filter_middleware._add_route_filter("POST", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
filter_middleware._add_route_filter("POST", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||||
|
@ -77,7 +77,7 @@ describe "Kemal::FilterHandler" do
|
||||||
test_filter = FilterTest.new
|
test_filter = FilterTest.new
|
||||||
test_filter.modified = "false"
|
test_filter.modified = "false"
|
||||||
|
|
||||||
filter_middleware = Kemal::FilterHandler.new
|
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||||
filter_middleware._add_route_filter("GET", "/greetings", :after) { test_filter.modified = "true" }
|
filter_middleware._add_route_filter("GET", "/greetings", :after) { test_filter.modified = "true" }
|
||||||
|
|
||||||
kemal = Kemal.application.route_handler
|
kemal = Kemal.application.route_handler
|
||||||
|
@ -95,7 +95,7 @@ describe "Kemal::FilterHandler" do
|
||||||
test_filter = FilterTest.new
|
test_filter = FilterTest.new
|
||||||
test_filter.modified = "false"
|
test_filter.modified = "false"
|
||||||
|
|
||||||
filter_middleware = Kemal::FilterHandler.new
|
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||||
filter_middleware._add_route_filter("GET", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
filter_middleware._add_route_filter("GET", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||||
|
|
||||||
kemal = Kemal.application.route_handler
|
kemal = Kemal.application.route_handler
|
||||||
|
@ -121,7 +121,7 @@ describe "Kemal::FilterHandler" do
|
||||||
test_filter = FilterTest.new
|
test_filter = FilterTest.new
|
||||||
test_filter.modified = "false"
|
test_filter.modified = "false"
|
||||||
|
|
||||||
filter_middleware = Kemal::FilterHandler.new
|
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||||
filter_middleware._add_route_filter("ALL", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
filter_middleware._add_route_filter("ALL", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||||
filter_middleware._add_route_filter("GET", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
filter_middleware._add_route_filter("GET", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||||
filter_middleware._add_route_filter("POST", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
filter_middleware._add_route_filter("POST", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||||
|
@ -152,7 +152,7 @@ describe "Kemal::FilterHandler" do
|
||||||
test_filter_third = FilterTest.new
|
test_filter_third = FilterTest.new
|
||||||
test_filter_third.modified = "false"
|
test_filter_third.modified = "false"
|
||||||
|
|
||||||
filter_middleware = Kemal::FilterHandler.new
|
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||||
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||||
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter_second.modified = test_filter_second.modified == "true" ? "false" : "true" }
|
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter_second.modified = test_filter_second.modified == "true" ? "false" : "true" }
|
||||||
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter_third.modified = test_filter_third.modified == "true" ? "false" : "true" }
|
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter_third.modified = test_filter_third.modified == "true" ? "false" : "true" }
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
require "./spec_helper"
|
require "./spec_helper"
|
||||||
|
|
||||||
private def create_ws_request_and_return_io(handler, request, app)
|
private def create_ws_request_and_return_io(handler, request, app = Kemal.application)
|
||||||
io = IO::Memory.new
|
io = IO::Memory.new
|
||||||
response = HTTP::Server::Response.new(io)
|
response = HTTP::Server::Response.new(io)
|
||||||
context = HTTP::Server::Context.new(request, response)
|
context = HTTP::Server::Context.new(request, response)
|
||||||
|
@ -16,8 +16,8 @@ end
|
||||||
describe "Kemal::WebSocketHandler" do
|
describe "Kemal::WebSocketHandler" do
|
||||||
it "doesn't match on wrong route" do
|
it "doesn't match on wrong route" do
|
||||||
app = Kemal::Base.new
|
app = Kemal::Base.new
|
||||||
handler = Kemal::WebSocketHandler.new
|
handler = app.websocket_handler
|
||||||
handler.next = Kemal::RouteHandler.new
|
handler.next = app.route_handler
|
||||||
app.ws "/" { }
|
app.ws "/" { }
|
||||||
headers = HTTP::Headers{
|
headers = HTTP::Headers{
|
||||||
"Upgrade" => "websocket",
|
"Upgrade" => "websocket",
|
||||||
|
@ -28,7 +28,6 @@ describe "Kemal::WebSocketHandler" do
|
||||||
io = IO::Memory.new
|
io = IO::Memory.new
|
||||||
response = HTTP::Server::Response.new(io)
|
response = HTTP::Server::Response.new(io)
|
||||||
context = HTTP::Server::Context.new(request, response)
|
context = HTTP::Server::Context.new(request, response)
|
||||||
context.app = app
|
|
||||||
|
|
||||||
expect_raises(Kemal::Exceptions::RouteNotFound) do
|
expect_raises(Kemal::Exceptions::RouteNotFound) do
|
||||||
handler.call context
|
handler.call context
|
||||||
|
@ -37,7 +36,7 @@ describe "Kemal::WebSocketHandler" do
|
||||||
|
|
||||||
it "matches on given route" do
|
it "matches on given route" do
|
||||||
app = Kemal::Base.new
|
app = Kemal::Base.new
|
||||||
handler = Kemal::WebSocketHandler.new
|
handler = app.websocket_handler
|
||||||
app.ws "/" { |socket, context| socket.send("Match") }
|
app.ws "/" { |socket, context| socket.send("Match") }
|
||||||
app.ws "/no_match" { |socket, context| socket.send "No Match" }
|
app.ws "/no_match" { |socket, context| socket.send "No Match" }
|
||||||
headers = HTTP::Headers{
|
headers = HTTP::Headers{
|
||||||
|
@ -54,7 +53,7 @@ describe "Kemal::WebSocketHandler" do
|
||||||
|
|
||||||
it "fetches named url parameters" do
|
it "fetches named url parameters" do
|
||||||
app = Kemal::Base.new
|
app = Kemal::Base.new
|
||||||
handler = Kemal::WebSocketHandler.new
|
handler = app.websocket_handler
|
||||||
app.ws "/:id" { |s, c| c.params.url["id"] }
|
app.ws "/:id" { |s, c| c.params.url["id"] }
|
||||||
headers = HTTP::Headers{
|
headers = HTTP::Headers{
|
||||||
"Upgrade" => "websocket",
|
"Upgrade" => "websocket",
|
||||||
|
@ -69,15 +68,14 @@ describe "Kemal::WebSocketHandler" do
|
||||||
|
|
||||||
it "matches correct verb" do
|
it "matches correct verb" do
|
||||||
app = Kemal::Base.new
|
app = Kemal::Base.new
|
||||||
handler = Kemal::WebSocketHandler.new
|
handler = app.websocket_handler
|
||||||
handler.next = Kemal::RouteHandler.new
|
handler.next = app.route_handler
|
||||||
app.ws "/" { }
|
app.ws "/" { }
|
||||||
app.get "/" { "get" }
|
app.get "/" { "get" }
|
||||||
request = HTTP::Request.new("GET", "/")
|
request = HTTP::Request.new("GET", "/")
|
||||||
io = IO::Memory.new
|
io = IO::Memory.new
|
||||||
response = HTTP::Server::Response.new(io)
|
response = HTTP::Server::Response.new(io)
|
||||||
context = HTTP::Server::Context.new(request, response)
|
context = HTTP::Server::Context.new(request, response)
|
||||||
context.app = app
|
|
||||||
handler.call(context)
|
handler.call(context)
|
||||||
response.close
|
response.close
|
||||||
io.rewind
|
io.rewind
|
||||||
|
|
|
@ -15,18 +15,19 @@ class Kemal::Base
|
||||||
include Base::Builder
|
include Base::Builder
|
||||||
|
|
||||||
# :nodoc:
|
# :nodoc:
|
||||||
getter route_handler = Kemal::RouteHandler.new
|
# TODO: These ivars are initialized in the constructor, but their values depend on `self`.
|
||||||
|
getter! route_handler : RouteHandler?
|
||||||
# :nodoc:
|
# :nodoc:
|
||||||
getter filter_handler = Kemal::FilterHandler.new
|
getter! filter_handler : FilterHandler?
|
||||||
# :nodoc:
|
# :nodoc:
|
||||||
getter websocket_handler = Kemal::WebSocketHandler.new
|
getter! websocket_handler : WebSocketHandler?
|
||||||
|
|
||||||
getter handlers = [] of HTTP::Handler
|
getter handlers = [] of HTTP::Handler
|
||||||
getter error_handlers = {} of Int32 => HTTP::Server::Context, Exception -> String
|
getter error_handlers = {} of Int32 => HTTP::Server::Context, Exception -> String
|
||||||
|
|
||||||
getter config : Config
|
getter config : Config
|
||||||
|
|
||||||
property! logger : Kemal::BaseLogHandler
|
property! logger : BaseLogHandler
|
||||||
property! server : HTTP::Server
|
property! server : HTTP::Server
|
||||||
property? running = false
|
property? running = false
|
||||||
|
|
||||||
|
|
|
@ -19,16 +19,16 @@ module Kemal
|
||||||
call_exception_with_status_code(context, ex, context.response.status_code)
|
call_exception_with_status_code(context, ex, context.response.status_code)
|
||||||
rescue ex : Exception
|
rescue ex : Exception
|
||||||
log("Exception: #{ex.inspect_with_backtrace}")
|
log("Exception: #{ex.inspect_with_backtrace}")
|
||||||
return call_exception_with_status_code(context, ex, 500) if context.app.error_handlers.has_key?(500)
|
return call_exception_with_status_code(context, ex, 500) if app.error_handlers.has_key?(500)
|
||||||
verbosity = context.app.config.env == "production" ? false : true
|
verbosity = app.config.env == "production" ? false : true
|
||||||
return app.render_500(context, ex.inspect_with_backtrace, verbosity)
|
return app.render_500(context, ex.inspect_with_backtrace, verbosity)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
private def call_exception_with_status_code(context, exception, status_code)
|
private def call_exception_with_status_code(context, exception, status_code)
|
||||||
if context.app.error_handlers.has_key?(status_code)
|
if !app.error_handlers.empty? && app.error_handlers.has_key?(status_code)
|
||||||
context.response.content_type = "text/html" unless context.response.headers.has_key?("Content-Type")
|
context.response.content_type = "text/html" unless context.response.headers.has_key?("Content-Type")
|
||||||
context.response.print context.app.error_handlers[status_code].call(context, exception)
|
context.response.print app.error_handlers[status_code].call(context, exception)
|
||||||
context.response.status_code = status_code
|
context.response.status_code = status_code
|
||||||
context
|
context
|
||||||
end
|
end
|
||||||
|
|
|
@ -3,17 +3,19 @@ module Kemal
|
||||||
class FilterHandler
|
class FilterHandler
|
||||||
include HTTP::Handler
|
include HTTP::Handler
|
||||||
|
|
||||||
|
getter app : Kemal::Base
|
||||||
|
|
||||||
# This middleware is lazily instantiated and added to the handlers as soon as a call to `after_X` or `before_X` is made.
|
# This middleware is lazily instantiated and added to the handlers as soon as a call to `after_X` or `before_X` is made.
|
||||||
def initialize
|
def initialize(@app)
|
||||||
@tree = Radix::Tree(Array(FilterBlock)).new
|
@tree = Radix::Tree(Array(FilterBlock)).new
|
||||||
end
|
end
|
||||||
|
|
||||||
# The call order of the filters is `before_all -> before_x -> X -> after_x -> after_all`.
|
# The call order of the filters is before_all -> before_x -> X -> after_x -> after_all
|
||||||
def call(context : HTTP::Server::Context)
|
def call(context : HTTP::Server::Context)
|
||||||
return call_next(context) unless context.route_found?
|
return call_next(context) unless app.route_handler.route_defined?(context.request)
|
||||||
call_block_for_path_type("ALL", context.request.path, :before, context)
|
call_block_for_path_type("ALL", context.request.path, :before, context)
|
||||||
call_block_for_path_type(context.request.override_method, context.request.path, :before, context)
|
call_block_for_path_type(context.request.override_method, context.request.path, :before, context)
|
||||||
if context.app.error_handlers.has_key?(context.response.status_code)
|
if !app.error_handlers.empty? && app.error_handlers.has_key?(context.response.status_code)
|
||||||
raise Kemal::Exceptions::CustomException.new(context)
|
raise Kemal::Exceptions::CustomException.new(context)
|
||||||
end
|
end
|
||||||
call_next(context)
|
call_next(context)
|
||||||
|
|
|
@ -49,7 +49,7 @@ module Kemal::FileHelpers
|
||||||
end
|
end
|
||||||
|
|
||||||
def send_file(env, path : String, mime_type : String? = nil)
|
def send_file(env, path : String, mime_type : String? = nil)
|
||||||
send_file(env, path, env.app.config, mime_type)
|
send_file(env, path, config, mime_type)
|
||||||
end
|
end
|
||||||
|
|
||||||
private def multipart(file, env : HTTP::Server::Context)
|
private def multipart(file, env : HTTP::Server::Context)
|
||||||
|
|
|
@ -8,7 +8,9 @@ module Kemal
|
||||||
CACHED_ROUTES_LIMIT = 1024
|
CACHED_ROUTES_LIMIT = 1024
|
||||||
property routes, cached_routes
|
property routes, cached_routes
|
||||||
|
|
||||||
def initialize
|
getter app : Kemal::Base
|
||||||
|
|
||||||
|
def initialize(@app)
|
||||||
@routes = Radix::Tree(Route).new
|
@routes = Radix::Tree(Route).new
|
||||||
@cached_routes = Hash(String, Radix::Result(Route)).new
|
@cached_routes = Hash(String, Radix::Result(Route)).new
|
||||||
end
|
end
|
||||||
|
@ -42,12 +44,20 @@ module Kemal
|
||||||
route
|
route
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def lookup_route(request)
|
||||||
|
lookup_route request.override_method.as(String), request.path
|
||||||
|
end
|
||||||
|
|
||||||
|
def route_defined?(request)
|
||||||
|
lookup_route(request).found?
|
||||||
|
end
|
||||||
|
|
||||||
# Processes the route if it's a match. Otherwise renders 404.
|
# Processes the route if it's a match. Otherwise renders 404.
|
||||||
private def process_request(context)
|
private def process_request(context)
|
||||||
raise Kemal::Exceptions::RouteNotFound.new(context) unless context.route_found?
|
raise Kemal::Exceptions::RouteNotFound.new(context) unless context.route_found?
|
||||||
content = context.route.handler.call(context)
|
content = context.route.handler.call(context)
|
||||||
|
|
||||||
if context.app.error_handlers.has_key?(context.response.status_code)
|
if !app.error_handlers.empty? && app.error_handlers.has_key?(context.response.status_code)
|
||||||
raise Kemal::Exceptions::CustomException.new(context)
|
raise Kemal::Exceptions::CustomException.new(context)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -4,13 +4,17 @@ module Kemal
|
||||||
|
|
||||||
property routes
|
property routes
|
||||||
|
|
||||||
def initialize
|
getter app : Kemal::Base
|
||||||
|
|
||||||
|
def initialize(@app)
|
||||||
@routes = Radix::Tree(WebSocket).new
|
@routes = Radix::Tree(WebSocket).new
|
||||||
end
|
end
|
||||||
|
|
||||||
def call(context : HTTP::Server::Context)
|
def call(context : HTTP::Server::Context)
|
||||||
return call_next(context) unless context.ws_route_found? && websocket_upgrade_request?(context)
|
route = lookup_ws_route(context.request.path)
|
||||||
content = context.websocket.call(context)
|
return call_next(context) unless route.found? && websocket_upgrade_request?(context)
|
||||||
|
context.request.url_params ||= route.params
|
||||||
|
content = route.payload.call(context)
|
||||||
context.response.print(content)
|
context.response.print(content)
|
||||||
context
|
context
|
||||||
end
|
end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue