refactor router to improve route registration and handler management
This commit is contained in:
parent
0415507c48
commit
ce9f313220
20
dist/router.js
vendored
20
dist/router.js
vendored
@ -101,20 +101,24 @@ export default class Router {
|
|||||||
this.registerRoute(path, "patch", cb);
|
this.registerRoute(path, "patch", cb);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
registerRoute(path, method, handlers) {
|
registerRoute(path, method, handler) {
|
||||||
if (!this.routes.has(path)) {
|
var _a;
|
||||||
this.routes.set(path, {});
|
const route = (_a = this.routes.get(path)) !== null && _a !== void 0 ? _a : {
|
||||||
}
|
[method]: handler
|
||||||
this.routes.get(path)[method] = handlers.flat();
|
};
|
||||||
|
this.routes.set(path, route);
|
||||||
console.log("route set:", method.toUpperCase(), path);
|
console.log("route set:", method.toUpperCase(), path);
|
||||||
this.sortRoutes();
|
this.sortRoutes();
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
getRoute(path, method) {
|
getRoute(path, method) {
|
||||||
method = method.toLowerCase();
|
return [...this.routes.entries()]
|
||||||
return [...this.routes.entries()].find(r => {
|
.find(r => {
|
||||||
var _a, _b;
|
var _a, _b;
|
||||||
return (typeof r[0] === "string" ? r[0] === path : (_b = (_a = r[0]).exec) === null || _b === void 0 ? void 0 : _b.call(_a, path)) && r[1][method];
|
return typeof r[0] === "string"
|
||||||
|
? r[0] === path
|
||||||
|
: ((_b = (_a = r[0]).exec) === null || _b === void 0 ? void 0 : _b.call(_a, path))
|
||||||
|
&& r[1][method.toLowerCase()];
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
sortRoutes() {
|
sortRoutes() {
|
||||||
|
@ -5,7 +5,7 @@ import Tpl from "./template.js";
|
|||||||
import { Request, Response, Handler } from "./types.js";
|
import { Request, Response, Handler } from "./types.js";
|
||||||
|
|
||||||
export default class Router {
|
export default class Router {
|
||||||
private routes: Map<RegExp | string, { [key: string]: Handler | Handler[] }>;
|
private routes: Map<RegExp | string, { [key: string]: Handler[] }>;
|
||||||
private tpl?: Tpl;
|
private tpl?: Tpl;
|
||||||
private mimes: Map<string, string>;
|
private mimes: Map<string, string>;
|
||||||
|
|
||||||
@ -42,7 +42,7 @@ export default class Router {
|
|||||||
*/
|
*/
|
||||||
group(basePath: string | RegExp, callback: (methods: any) => void): this {
|
group(basePath: string | RegExp, callback: (methods: any) => void): this {
|
||||||
const self = this;
|
const self = this;
|
||||||
|
|
||||||
const methods = {
|
const methods = {
|
||||||
get(path: string | RegExp, ...handlers: Handler[]) {
|
get(path: string | RegExp, ...handlers: Handler[]) {
|
||||||
const fullPath = self.combinePaths(basePath, path);
|
const fullPath = self.combinePaths(basePath, path);
|
||||||
@ -67,10 +67,10 @@ export default class Router {
|
|||||||
};
|
};
|
||||||
|
|
||||||
callback(methods);
|
callback(methods);
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Combines a base path and a sub path into a single path.
|
* Combines a base path and a sub path into a single path.
|
||||||
* @param basePath - The base path or RegExp.
|
* @param basePath - The base path or RegExp.
|
||||||
@ -86,7 +86,7 @@ export default class Router {
|
|||||||
return new RegExp(`${basePath.replace(/\/$/, "")}${subPath.source}`);
|
return new RegExp(`${basePath.replace(/\/$/, "")}${subPath.source}`);
|
||||||
if(basePath instanceof RegExp && subPath instanceof RegExp)
|
if(basePath instanceof RegExp && subPath instanceof RegExp)
|
||||||
return new RegExp(`${basePath.source}${subPath.source}`);
|
return new RegExp(`${basePath.source}${subPath.source}`);
|
||||||
|
|
||||||
throw new TypeError("Invalid path types. Both basePath and subPath must be either string or RegExp.");
|
throw new TypeError("Invalid path types. Both basePath and subPath must be either string or RegExp.");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -179,14 +179,13 @@ export default class Router {
|
|||||||
private registerRoute(
|
private registerRoute(
|
||||||
path: string | RegExp,
|
path: string | RegExp,
|
||||||
method: string,
|
method: string,
|
||||||
handlers: Handler[]
|
handler: Handler[]
|
||||||
): this {
|
): this {
|
||||||
if(!this.routes.has(path)) {
|
const route: { [key: string]: Handler[] } = this.routes.get(path) ?? {
|
||||||
this.routes.set(path, {});
|
[ method ]: handler
|
||||||
}
|
};
|
||||||
|
this.routes.set(path, route);
|
||||||
this.routes.get(path)![method] = handlers.flat();
|
|
||||||
|
|
||||||
console.log("route set:", method.toUpperCase(), path);
|
console.log("route set:", method.toUpperCase(), path);
|
||||||
this.sortRoutes();
|
this.sortRoutes();
|
||||||
return this;
|
return this;
|
||||||
@ -199,10 +198,12 @@ export default class Router {
|
|||||||
* @returns The matching route or undefined.
|
* @returns The matching route or undefined.
|
||||||
*/
|
*/
|
||||||
getRoute(path: string, method: string): any {
|
getRoute(path: string, method: string): any {
|
||||||
method = method.toLowerCase();
|
return [...this.routes.entries()]
|
||||||
return [...this.routes.entries()].find(r => {
|
.find(r => typeof r[0] === "string"
|
||||||
return (typeof r[0] === "string" ? r[0] === path : r[0].exec?.(path)) && r[1][method];
|
? r[0] === path
|
||||||
});
|
: r[0].exec?.(path)
|
||||||
|
&& r[1][method.toLowerCase()]
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user