mirror of
https://gitea.invidious.io/iv-org/shard-kemal.git
synced 2024-08-15 00:53:36 +00:00
Refactour handler radix names
This commit is contained in:
parent
63e613a439
commit
84839f4da7
3 changed files with 16 additions and 16 deletions
|
@ -81,6 +81,6 @@ end
|
|||
|
||||
Spec.after_each do
|
||||
Kemal.config.clear
|
||||
Kemal::RouteHandler::INSTANCE.http_routes = Radix::Tree(Route).new
|
||||
Kemal::WebSocketHandler::INSTANCE.ws_routes = Radix::Tree(WebSocket).new
|
||||
Kemal::RouteHandler::INSTANCE.routes = Radix::Tree(Route).new
|
||||
Kemal::WebSocketHandler::INSTANCE.routes = Radix::Tree(WebSocket).new
|
||||
end
|
||||
|
|
|
@ -6,10 +6,10 @@ module Kemal
|
|||
class RouteHandler
|
||||
include HTTP::Handler
|
||||
INSTANCE = new
|
||||
property http_routes
|
||||
property routes
|
||||
|
||||
def initialize
|
||||
@http_routes = Radix::Tree(Route).new
|
||||
@routes = Radix::Tree(Route).new
|
||||
end
|
||||
|
||||
def call(context : HTTP::Server::Context)
|
||||
|
@ -19,13 +19,13 @@ module Kemal
|
|||
# Adds a given route to routing tree. As an exception each `GET` route additionaly defines
|
||||
# a corresponding `HEAD` route.
|
||||
def add_route(method : String, path : String, &handler : HTTP::Server::Context -> _)
|
||||
add_to_http_radix_tree method, path, Route.new(method, path, &handler)
|
||||
add_to_http_radix_tree("HEAD", path, Route.new("HEAD", path) { |ctx| "" }) if method == "GET"
|
||||
add_to_radix_tree method, path, Route.new(method, path, &handler)
|
||||
add_to_radix_tree("HEAD", path, Route.new("HEAD", path) { |ctx| "" }) if method == "GET"
|
||||
end
|
||||
|
||||
# Check if a route is defined and returns the lookup
|
||||
def lookup_route(verb : String, path : String)
|
||||
@http_routes.find radix_path(verb, path)
|
||||
@routes.find radix_path(verb, path)
|
||||
end
|
||||
|
||||
# Processes the route if it's a match. Otherwise renders 404.
|
||||
|
@ -45,9 +45,9 @@ module Kemal
|
|||
"/#{method.downcase}#{path}"
|
||||
end
|
||||
|
||||
private def add_to_http_radix_tree(method, path, route)
|
||||
private def add_to_radix_tree(method, path, route)
|
||||
node = radix_path method, path
|
||||
@http_routes.add node, route
|
||||
@routes.add node, route
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -4,10 +4,10 @@ module Kemal
|
|||
class WebSocketHandler
|
||||
include HTTP::Handler
|
||||
INSTANCE = new
|
||||
property ws_routes
|
||||
property routes
|
||||
|
||||
def initialize
|
||||
@ws_routes = Radix::Tree(WebSocket).new
|
||||
@routes = Radix::Tree(WebSocket).new
|
||||
end
|
||||
|
||||
def call(context : HTTP::Server::Context)
|
||||
|
@ -19,16 +19,16 @@ module Kemal
|
|||
end
|
||||
|
||||
def lookup_ws_route(path : String)
|
||||
@ws_routes.find "/ws#{path}"
|
||||
@routes.find "/ws#{path}"
|
||||
end
|
||||
|
||||
def add_route(path : String, &handler : HTTP::WebSocket, HTTP::Server::Context -> Void)
|
||||
add_to_ws_radix_tree path, WebSocket.new(path, &handler)
|
||||
add_to_radix_tree path, WebSocket.new(path, &handler)
|
||||
end
|
||||
|
||||
private def add_to_ws_radix_tree(path, websocket)
|
||||
private def add_to_radix_tree(path, websocket)
|
||||
node = radix_path "ws", path
|
||||
@ws_routes.add node, websocket
|
||||
@routes.add node, websocket
|
||||
end
|
||||
|
||||
private def radix_path(method, path)
|
||||
|
|
Loading…
Reference in a new issue