@eggjs/router 2.0.1 → 3.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +96 -53
- package/dist/commonjs/EggRouter.d.ts +102 -0
- package/dist/commonjs/EggRouter.js +235 -0
- package/dist/commonjs/Layer.d.ts +114 -0
- package/dist/commonjs/Layer.js +237 -0
- package/dist/commonjs/Router.d.ts +494 -0
- package/dist/commonjs/Router.js +760 -0
- package/dist/commonjs/index.d.ts +7 -0
- package/dist/commonjs/index.js +24 -0
- package/dist/commonjs/package.json +3 -0
- package/dist/commonjs/types.d.ts +18 -0
- package/dist/commonjs/types.js +3 -0
- package/dist/esm/EggRouter.d.ts +102 -0
- package/dist/esm/EggRouter.js +228 -0
- package/dist/esm/Layer.d.ts +114 -0
- package/dist/esm/Layer.js +230 -0
- package/dist/esm/Router.d.ts +494 -0
- package/dist/esm/Router.js +753 -0
- package/dist/esm/index.d.ts +7 -0
- package/dist/esm/index.js +7 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/types.d.ts +18 -0
- package/dist/esm/types.js +2 -0
- package/package.json +64 -33
- package/src/EggRouter.ts +338 -0
- package/src/Layer.ts +274 -0
- package/src/Router.ts +1060 -0
- package/src/index.ts +9 -0
- package/src/types.ts +15 -0
- package/History.md +0 -187
- package/index.js +0 -10
- package/lib/egg_router.js +0 -327
- package/lib/layer.js +0 -217
- package/lib/router.js +0 -724
- package/lib/utils.js +0 -18
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.KoaRouter = void 0;
|
|
18
|
+
const Router_js_1 = require("./Router.js");
|
|
19
|
+
__exportStar(require("./Layer.js"), exports);
|
|
20
|
+
__exportStar(require("./Router.js"), exports);
|
|
21
|
+
__exportStar(require("./EggRouter.js"), exports);
|
|
22
|
+
exports.KoaRouter = Router_js_1.Router;
|
|
23
|
+
exports.default = Router_js_1.Router;
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwyQ0FBcUM7QUFHckMsNkNBQTJCO0FBQzNCLDhDQUE0QjtBQUM1QixpREFBK0I7QUFFbEIsUUFBQSxTQUFTLEdBQUcsa0JBQU0sQ0FBQztBQUNoQyxrQkFBZSxrQkFBTSxDQUFDIn0=
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export type Next = () => Promise<void>;
|
|
2
|
+
export type MiddlewareFunc = (ctx: any, next: Next) => Promise<void> | void;
|
|
3
|
+
export type MiddlewareFuncWithParamProperty = MiddlewareFunc & {
|
|
4
|
+
param?: string;
|
|
5
|
+
};
|
|
6
|
+
export type ParamMiddlewareFunc = (param: string, ctx: any, next: Next) => Promise<void> | void;
|
|
7
|
+
export type MiddlewareFuncWithRouter<T> = MiddlewareFunc & {
|
|
8
|
+
router: T;
|
|
9
|
+
};
|
|
10
|
+
export interface ResourcesController {
|
|
11
|
+
index?: MiddlewareFunc;
|
|
12
|
+
new?: MiddlewareFunc;
|
|
13
|
+
create?: MiddlewareFunc;
|
|
14
|
+
show?: MiddlewareFunc;
|
|
15
|
+
edit?: MiddlewareFunc;
|
|
16
|
+
update?: MiddlewareFunc;
|
|
17
|
+
destroy?: MiddlewareFunc;
|
|
18
|
+
}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { RegisterOptions, Router, RouterMethod, RouterOptions } from './Router.js';
|
|
2
|
+
import { MiddlewareFunc, ResourcesController } from './types.js';
|
|
3
|
+
interface Application {
|
|
4
|
+
controller: Record<string, any>;
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* FIXME: move these patch into @eggjs/router
|
|
8
|
+
*/
|
|
9
|
+
export declare class EggRouter extends Router {
|
|
10
|
+
readonly app: Application;
|
|
11
|
+
/**
|
|
12
|
+
* @class
|
|
13
|
+
* @param {Object} opts - Router options.
|
|
14
|
+
* @param {Application} app - Application object.
|
|
15
|
+
*/
|
|
16
|
+
constructor(opts: RouterOptions, app: Application);
|
|
17
|
+
verb(method: RouterMethod | RouterMethod[], nameOrPath: string | RegExp | (string | RegExp)[], pathOrMiddleware: string | RegExp | (string | RegExp)[] | MiddlewareFunc, ...middleware: (MiddlewareFunc | string)[]): this;
|
|
18
|
+
head(path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
19
|
+
head(name: string, path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
20
|
+
options(path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
21
|
+
options(name: string, path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
22
|
+
get(path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
23
|
+
get(name: string, path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
24
|
+
put(path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
25
|
+
put(name: string, path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
26
|
+
patch(path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
27
|
+
patch(name: string, path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
28
|
+
post(path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
29
|
+
post(name: string, path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
30
|
+
delete(path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
31
|
+
delete(name: string, path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
32
|
+
all(path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
33
|
+
all(name: string, path: string | RegExp | (string | RegExp)[], ...middlewares: (MiddlewareFunc | string)[]): Router;
|
|
34
|
+
register(path: string | RegExp | (string | RegExp)[], methods: string[], middleware: MiddlewareFunc | string | (MiddlewareFunc | string | ResourcesController)[], opts?: RegisterOptions): import("./Layer.js").Layer | import("./Layer.js").Layer[];
|
|
35
|
+
/**
|
|
36
|
+
* restful router api
|
|
37
|
+
* @param {String} name - Router name
|
|
38
|
+
* @param {String} prefix - url prefix
|
|
39
|
+
* @param {Function} middleware - middleware or controller
|
|
40
|
+
* @example
|
|
41
|
+
* ```js
|
|
42
|
+
* app.resources('/posts', 'posts')
|
|
43
|
+
* app.resources('posts', '/posts', 'posts')
|
|
44
|
+
* app.resources('posts', '/posts', app.role.can('user'), app.controller.posts)
|
|
45
|
+
* ```
|
|
46
|
+
*
|
|
47
|
+
* Examples:
|
|
48
|
+
*
|
|
49
|
+
* ```js
|
|
50
|
+
* app.resources('/posts', 'posts')
|
|
51
|
+
* ```
|
|
52
|
+
*
|
|
53
|
+
* yield router mapping
|
|
54
|
+
*
|
|
55
|
+
* Method | Path | Route Name | Controller.Action
|
|
56
|
+
* -------|-----------------|----------------|-----------------------------
|
|
57
|
+
* GET | /posts | posts | app.controller.posts.index
|
|
58
|
+
* GET | /posts/new | new_post | app.controller.posts.new
|
|
59
|
+
* GET | /posts/:id | post | app.controller.posts.show
|
|
60
|
+
* GET | /posts/:id/edit | edit_post | app.controller.posts.edit
|
|
61
|
+
* POST | /posts | posts | app.controller.posts.create
|
|
62
|
+
* PATCH | /posts/:id | post | app.controller.posts.update
|
|
63
|
+
* DELETE | /posts/:id | post | app.controller.posts.destroy
|
|
64
|
+
*
|
|
65
|
+
* app.router.url can generate url based on arguments
|
|
66
|
+
* ```js
|
|
67
|
+
* app.router.url('posts')
|
|
68
|
+
* => /posts
|
|
69
|
+
* app.router.url('post', { id: 1 })
|
|
70
|
+
* => /posts/1
|
|
71
|
+
* app.router.url('new_post')
|
|
72
|
+
* => /posts/new
|
|
73
|
+
* app.router.url('edit_post', { id: 1 })
|
|
74
|
+
* => /posts/1/edit
|
|
75
|
+
* ```
|
|
76
|
+
* @return {Router} return route object.
|
|
77
|
+
* @since 1.0.0
|
|
78
|
+
*/
|
|
79
|
+
resources(prefix: string, controller: string | ResourcesController): Router;
|
|
80
|
+
resources(prefix: string, middleware: MiddlewareFunc, controller: string | ResourcesController): Router;
|
|
81
|
+
resources(name: string, prefix: string, controller: string | ResourcesController): Router;
|
|
82
|
+
resources(name: string, prefix: string, middleware: MiddlewareFunc, controller: string | ResourcesController): Router;
|
|
83
|
+
/**
|
|
84
|
+
* @param {String} name - Router name
|
|
85
|
+
* @param {Object} params - more parameters
|
|
86
|
+
* @example
|
|
87
|
+
* ```js
|
|
88
|
+
* router.url('edit_post', { id: 1, name: 'foo', page: 2 })
|
|
89
|
+
* => /posts/1/edit?name=foo&page=2
|
|
90
|
+
* router.url('posts', { name: 'foo&1', page: 2 })
|
|
91
|
+
* => /posts?name=foo%261&page=2
|
|
92
|
+
* ```
|
|
93
|
+
* @return {String} url by path name and query params.
|
|
94
|
+
* @since 1.0.0
|
|
95
|
+
*/
|
|
96
|
+
url(name: string, params?: Record<string, string | number | (string | number)[]>): string;
|
|
97
|
+
/**
|
|
98
|
+
* @alias to url()
|
|
99
|
+
*/
|
|
100
|
+
pathFor(name: string, params?: Record<string, string | number | (string | number)[]>): string;
|
|
101
|
+
}
|
|
102
|
+
export {};
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
import assert from 'node:assert';
|
|
2
|
+
import { encodeURIComponent as safeEncodeURIComponent } from 'utility';
|
|
3
|
+
import inflection from 'inflection';
|
|
4
|
+
import methods from 'methods';
|
|
5
|
+
import { Router } from './Router.js';
|
|
6
|
+
const REST_MAP = {
|
|
7
|
+
index: {
|
|
8
|
+
suffix: '',
|
|
9
|
+
method: 'GET',
|
|
10
|
+
},
|
|
11
|
+
new: {
|
|
12
|
+
namePrefix: 'new_',
|
|
13
|
+
member: true,
|
|
14
|
+
suffix: 'new',
|
|
15
|
+
method: 'GET',
|
|
16
|
+
},
|
|
17
|
+
create: {
|
|
18
|
+
suffix: '',
|
|
19
|
+
method: 'POST',
|
|
20
|
+
},
|
|
21
|
+
show: {
|
|
22
|
+
member: true,
|
|
23
|
+
suffix: ':id',
|
|
24
|
+
method: 'GET',
|
|
25
|
+
},
|
|
26
|
+
edit: {
|
|
27
|
+
member: true,
|
|
28
|
+
namePrefix: 'edit_',
|
|
29
|
+
suffix: ':id/edit',
|
|
30
|
+
method: 'GET',
|
|
31
|
+
},
|
|
32
|
+
update: {
|
|
33
|
+
member: true,
|
|
34
|
+
namePrefix: '',
|
|
35
|
+
suffix: ':id',
|
|
36
|
+
method: ['PATCH', 'PUT'],
|
|
37
|
+
},
|
|
38
|
+
destroy: {
|
|
39
|
+
member: true,
|
|
40
|
+
namePrefix: 'destroy_',
|
|
41
|
+
suffix: ':id',
|
|
42
|
+
method: 'DELETE',
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
/**
|
|
46
|
+
* FIXME: move these patch into @eggjs/router
|
|
47
|
+
*/
|
|
48
|
+
export class EggRouter extends Router {
|
|
49
|
+
app;
|
|
50
|
+
/**
|
|
51
|
+
* @class
|
|
52
|
+
* @param {Object} opts - Router options.
|
|
53
|
+
* @param {Application} app - Application object.
|
|
54
|
+
*/
|
|
55
|
+
constructor(opts, app) {
|
|
56
|
+
super(opts);
|
|
57
|
+
this.app = app;
|
|
58
|
+
}
|
|
59
|
+
verb(method, nameOrPath, pathOrMiddleware, ...middleware) {
|
|
60
|
+
const { path, middlewares, options } = this._formatRouteParams(nameOrPath, pathOrMiddleware, middleware);
|
|
61
|
+
if (typeof method === 'string') {
|
|
62
|
+
method = [method];
|
|
63
|
+
}
|
|
64
|
+
this.register(path, method, middlewares, options);
|
|
65
|
+
return this;
|
|
66
|
+
}
|
|
67
|
+
head(nameOrPath, pathOrMiddleware, ...middlewares) {
|
|
68
|
+
return this.verb('head', nameOrPath, pathOrMiddleware, ...middlewares);
|
|
69
|
+
}
|
|
70
|
+
options(nameOrPath, pathOrMiddleware, ...middlewares) {
|
|
71
|
+
return this.verb('options', nameOrPath, pathOrMiddleware, ...middlewares);
|
|
72
|
+
}
|
|
73
|
+
get(nameOrPath, pathOrMiddleware, ...middlewares) {
|
|
74
|
+
return this.verb('get', nameOrPath, pathOrMiddleware, ...middlewares);
|
|
75
|
+
}
|
|
76
|
+
put(nameOrPath, pathOrMiddleware, ...middlewares) {
|
|
77
|
+
return this.verb('put', nameOrPath, pathOrMiddleware, ...middlewares);
|
|
78
|
+
}
|
|
79
|
+
patch(nameOrPath, pathOrMiddleware, ...middlewares) {
|
|
80
|
+
return this.verb('patch', nameOrPath, pathOrMiddleware, ...middlewares);
|
|
81
|
+
}
|
|
82
|
+
post(nameOrPath, pathOrMiddleware, ...middlewares) {
|
|
83
|
+
return this.verb('post', nameOrPath, pathOrMiddleware, ...middlewares);
|
|
84
|
+
}
|
|
85
|
+
delete(nameOrPath, pathOrMiddleware, ...middlewares) {
|
|
86
|
+
return this.verb('delete', nameOrPath, pathOrMiddleware, ...middlewares);
|
|
87
|
+
}
|
|
88
|
+
all(nameOrPath, pathOrMiddleware, ...middlewares) {
|
|
89
|
+
return this.verb(methods, nameOrPath, pathOrMiddleware, ...middlewares);
|
|
90
|
+
}
|
|
91
|
+
register(path, methods, middleware, opts) {
|
|
92
|
+
// patch register to support generator function middleware and string controller
|
|
93
|
+
middleware = Array.isArray(middleware) ? middleware : [middleware];
|
|
94
|
+
const middlewares = convertMiddlewares(middleware, this.app);
|
|
95
|
+
return super.register(path, methods, middlewares, opts);
|
|
96
|
+
}
|
|
97
|
+
resources(nameOrPath, pathOrMiddleware, ...middleware) {
|
|
98
|
+
const { path, middlewares, options } = this._formatRouteParams(nameOrPath, pathOrMiddleware, middleware);
|
|
99
|
+
// last argument is Controller object
|
|
100
|
+
const controller = resolveController(middlewares.pop(), this.app);
|
|
101
|
+
for (const key in REST_MAP) {
|
|
102
|
+
const action = controller[key];
|
|
103
|
+
if (!action)
|
|
104
|
+
continue;
|
|
105
|
+
const opts = REST_MAP[key];
|
|
106
|
+
let routeName;
|
|
107
|
+
if (opts.member) {
|
|
108
|
+
routeName = inflection.singularize(options.name ?? '');
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
routeName = inflection.pluralize(options.name ?? '');
|
|
112
|
+
}
|
|
113
|
+
if (opts.namePrefix) {
|
|
114
|
+
routeName = opts.namePrefix + routeName;
|
|
115
|
+
}
|
|
116
|
+
const prefix = path.replace(/\/$/, '');
|
|
117
|
+
const urlPath = opts.suffix ? `${prefix}/${opts.suffix}` : prefix;
|
|
118
|
+
const method = Array.isArray(opts.method) ? opts.method : [opts.method];
|
|
119
|
+
this.register(urlPath, method, middlewares.concat(action), { name: routeName });
|
|
120
|
+
}
|
|
121
|
+
return this;
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* @param {String} name - Router name
|
|
125
|
+
* @param {Object} params - more parameters
|
|
126
|
+
* @example
|
|
127
|
+
* ```js
|
|
128
|
+
* router.url('edit_post', { id: 1, name: 'foo', page: 2 })
|
|
129
|
+
* => /posts/1/edit?name=foo&page=2
|
|
130
|
+
* router.url('posts', { name: 'foo&1', page: 2 })
|
|
131
|
+
* => /posts?name=foo%261&page=2
|
|
132
|
+
* ```
|
|
133
|
+
* @return {String} url by path name and query params.
|
|
134
|
+
* @since 1.0.0
|
|
135
|
+
*/
|
|
136
|
+
url(name, params) {
|
|
137
|
+
const route = this.route(name);
|
|
138
|
+
if (!route)
|
|
139
|
+
return '';
|
|
140
|
+
const args = params;
|
|
141
|
+
let url = route.path;
|
|
142
|
+
assert(!(url instanceof RegExp), `Can't get the url for regExp ${url} for by name '${name}'`);
|
|
143
|
+
const queries = [];
|
|
144
|
+
if (typeof args === 'object' && args !== null) {
|
|
145
|
+
const replacedParams = [];
|
|
146
|
+
url = url.replace(/:([a-zA-Z_]\w*)/g, ($0, key) => {
|
|
147
|
+
if (key in args) {
|
|
148
|
+
const values = args[key];
|
|
149
|
+
replacedParams.push(key);
|
|
150
|
+
return safeEncodeURIComponent(Array.isArray(values) ? String(values[0]) : String(values));
|
|
151
|
+
}
|
|
152
|
+
return $0;
|
|
153
|
+
});
|
|
154
|
+
for (const key in args) {
|
|
155
|
+
if (replacedParams.includes(key)) {
|
|
156
|
+
continue;
|
|
157
|
+
}
|
|
158
|
+
const values = args[key];
|
|
159
|
+
const encodedKey = safeEncodeURIComponent(key);
|
|
160
|
+
if (Array.isArray(values)) {
|
|
161
|
+
for (const val of values) {
|
|
162
|
+
queries.push(`${encodedKey}=${safeEncodeURIComponent(String(val))}`);
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
queries.push(`${encodedKey}=${safeEncodeURIComponent(String(values))}`);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
if (queries.length > 0) {
|
|
171
|
+
const queryStr = queries.join('&');
|
|
172
|
+
if (!url.includes('?')) {
|
|
173
|
+
url = `${url}?${queryStr}`;
|
|
174
|
+
}
|
|
175
|
+
else {
|
|
176
|
+
url = `${url}&${queryStr}`;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
return url;
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* @alias to url()
|
|
183
|
+
*/
|
|
184
|
+
pathFor(name, params) {
|
|
185
|
+
return this.url(name, params);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* resolve controller from string to function
|
|
190
|
+
* @param {String|Function} controller input controller
|
|
191
|
+
* @param {Application} app egg application instance
|
|
192
|
+
*/
|
|
193
|
+
function resolveController(controller, app) {
|
|
194
|
+
if (typeof controller === 'string') {
|
|
195
|
+
// resolveController('foo.bar.Home', app)
|
|
196
|
+
const actions = controller.split('.');
|
|
197
|
+
let obj = app.controller;
|
|
198
|
+
actions.forEach(key => {
|
|
199
|
+
obj = obj[key];
|
|
200
|
+
if (!obj)
|
|
201
|
+
throw new Error(`app.controller.${controller} not exists`);
|
|
202
|
+
});
|
|
203
|
+
controller = obj;
|
|
204
|
+
}
|
|
205
|
+
// ensure controller is exists
|
|
206
|
+
if (!controller)
|
|
207
|
+
throw new Error('controller not exists');
|
|
208
|
+
return controller;
|
|
209
|
+
}
|
|
210
|
+
/**
|
|
211
|
+
* 1. ensure controller(last argument) support string
|
|
212
|
+
* - [url, controller]: app.get('/home', 'home');
|
|
213
|
+
* - [name, url, controller(string)]: app.get('posts', '/posts', 'posts.list');
|
|
214
|
+
* - [name, url, controller]: app.get('posts', '/posts', app.controller.posts.list);
|
|
215
|
+
* - [name, url(regexp), controller]: app.get('regRouter', /\/home\/index/, 'home.index');
|
|
216
|
+
* - [name, url, middleware, [...], controller]: `app.get(/user/:id', hasLogin, canGetUser, 'user.show');`
|
|
217
|
+
*
|
|
218
|
+
* 2. make middleware support generator function
|
|
219
|
+
*
|
|
220
|
+
* @param {Array} middlewares middlewares and controller(last middleware)
|
|
221
|
+
* @param {Application} app egg application instance
|
|
222
|
+
*/
|
|
223
|
+
function convertMiddlewares(middlewares, app) {
|
|
224
|
+
// ensure controller is resolved
|
|
225
|
+
const controller = resolveController(middlewares.pop(), app);
|
|
226
|
+
return [...middlewares, controller];
|
|
227
|
+
}
|
|
228
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRWdnUm91dGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL0VnZ1JvdXRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU0sTUFBTSxhQUFhLENBQUM7QUFDakMsT0FBTyxFQUFFLGtCQUFrQixJQUFJLHNCQUFzQixFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ3ZFLE9BQU8sVUFBVSxNQUFNLFlBQVksQ0FBQztBQUNwQyxPQUFPLE9BQU8sTUFBTSxTQUFTLENBQUM7QUFDOUIsT0FBTyxFQUFtQixNQUFNLEVBQStCLE1BQU0sYUFBYSxDQUFDO0FBVW5GLE1BQU0sUUFBUSxHQUFtQztJQUMvQyxLQUFLLEVBQUU7UUFDTCxNQUFNLEVBQUUsRUFBRTtRQUNWLE1BQU0sRUFBRSxLQUFLO0tBQ2Q7SUFDRCxHQUFHLEVBQUU7UUFDSCxVQUFVLEVBQUUsTUFBTTtRQUNsQixNQUFNLEVBQUUsSUFBSTtRQUNaLE1BQU0sRUFBRSxLQUFLO1FBQ2IsTUFBTSxFQUFFLEtBQUs7S0FDZDtJQUNELE1BQU0sRUFBRTtRQUNOLE1BQU0sRUFBRSxFQUFFO1FBQ1YsTUFBTSxFQUFFLE1BQU07S0FDZjtJQUNELElBQUksRUFBRTtRQUNKLE1BQU0sRUFBRSxJQUFJO1FBQ1osTUFBTSxFQUFFLEtBQUs7UUFDYixNQUFNLEVBQUUsS0FBSztLQUNkO0lBQ0QsSUFBSSxFQUFFO1FBQ0osTUFBTSxFQUFFLElBQUk7UUFDWixVQUFVLEVBQUUsT0FBTztRQUNuQixNQUFNLEVBQUUsVUFBVTtRQUNsQixNQUFNLEVBQUUsS0FBSztLQUNkO0lBQ0QsTUFBTSxFQUFFO1FBQ04sTUFBTSxFQUFFLElBQUk7UUFDWixVQUFVLEVBQUUsRUFBRTtRQUNkLE1BQU0sRUFBRSxLQUFLO1FBQ2IsTUFBTSxFQUFFLENBQUUsT0FBTyxFQUFFLEtBQUssQ0FBRTtLQUMzQjtJQUNELE9BQU8sRUFBRTtRQUNQLE1BQU0sRUFBRSxJQUFJO1FBQ1osVUFBVSxFQUFFLFVB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
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { type Key } from 'path-to-regexp';
|
|
2
|
+
import type { MiddlewareFunc, MiddlewareFuncWithParamProperty, ParamMiddlewareFunc } from './types.js';
|
|
3
|
+
export interface LayerOptions {
|
|
4
|
+
prefix?: string;
|
|
5
|
+
/** route name */
|
|
6
|
+
name?: string;
|
|
7
|
+
/** case sensitive (default: false) */
|
|
8
|
+
sensitive?: boolean;
|
|
9
|
+
/** require the trailing slash (default: false) */
|
|
10
|
+
strict?: boolean;
|
|
11
|
+
ignoreCaptures?: boolean;
|
|
12
|
+
end?: boolean;
|
|
13
|
+
}
|
|
14
|
+
export interface LayerURLOptions {
|
|
15
|
+
query?: string | object;
|
|
16
|
+
}
|
|
17
|
+
export declare class Layer {
|
|
18
|
+
readonly opts: LayerOptions;
|
|
19
|
+
readonly name?: string;
|
|
20
|
+
readonly methods: string[];
|
|
21
|
+
readonly stack: MiddlewareFuncWithParamProperty[];
|
|
22
|
+
path: string | RegExp;
|
|
23
|
+
regexp: RegExp;
|
|
24
|
+
paramNames: Key[];
|
|
25
|
+
/**
|
|
26
|
+
* Initialize a new routing Layer with given `method`, `path`, and `middleware`.
|
|
27
|
+
*
|
|
28
|
+
* @param {String|RegExp} path Path string or regular expression.
|
|
29
|
+
* @param {Array} methods Array of HTTP verbs.
|
|
30
|
+
* @param {Array|Function} middlewares Layer callback/middleware or series of.
|
|
31
|
+
* @param {Object=} opts optional params
|
|
32
|
+
* @param {String=} opts.name route name
|
|
33
|
+
* @param {String=} opts.sensitive case sensitive (default: false)
|
|
34
|
+
* @param {String=} opts.strict require the trailing slash (default: false)
|
|
35
|
+
* @private
|
|
36
|
+
*/
|
|
37
|
+
constructor(path: string | RegExp, methods: string[], middlewares: MiddlewareFunc | MiddlewareFunc[], opts?: LayerOptions | string);
|
|
38
|
+
/**
|
|
39
|
+
* Returns whether request `path` matches route.
|
|
40
|
+
*
|
|
41
|
+
* @param {String} path path string
|
|
42
|
+
* @return {Boolean} matched or not
|
|
43
|
+
* @private
|
|
44
|
+
*/
|
|
45
|
+
match(path: string): boolean;
|
|
46
|
+
/**
|
|
47
|
+
* Returns map of URL parameters for given `path` and `paramNames`.
|
|
48
|
+
*
|
|
49
|
+
* @param {String} _path path string
|
|
50
|
+
* @param {Array.<String>} captures captures strings
|
|
51
|
+
* @param {Object=} [existingParams] existing params
|
|
52
|
+
* @return {Object} params object
|
|
53
|
+
* @private
|
|
54
|
+
*/
|
|
55
|
+
params(_path: string, captures: Array<string>, existingParams?: Record<string, string>): Record<string, string>;
|
|
56
|
+
/**
|
|
57
|
+
* Returns array of regexp url path captures.
|
|
58
|
+
*
|
|
59
|
+
* @param {String} path path string
|
|
60
|
+
* @return {Array.<String>} captures strings
|
|
61
|
+
* @private
|
|
62
|
+
*/
|
|
63
|
+
captures(path: string): Array<string>;
|
|
64
|
+
/**
|
|
65
|
+
* Generate URL for route using given `params`.
|
|
66
|
+
*
|
|
67
|
+
* @example
|
|
68
|
+
*
|
|
69
|
+
* ```javascript
|
|
70
|
+
* var route = new Layer(['GET'], '/users/:id', fn);
|
|
71
|
+
*
|
|
72
|
+
* route.url(123); // => "/users/123"
|
|
73
|
+
* route.url('123'); // => "/users/123"
|
|
74
|
+
* route.url({ id: 123 }); // => "/users/123"
|
|
75
|
+
* ```
|
|
76
|
+
*
|
|
77
|
+
* @param {Object} params url parameters
|
|
78
|
+
* @param {Object} paramsOrOptions optional parameters
|
|
79
|
+
* @return {String} url string
|
|
80
|
+
* @private
|
|
81
|
+
*/
|
|
82
|
+
url(params?: string | number | object, ...paramsOrOptions: (string | number | object | LayerURLOptions)[]): string;
|
|
83
|
+
/**
|
|
84
|
+
* Run validations on route named parameters.
|
|
85
|
+
*
|
|
86
|
+
* @example
|
|
87
|
+
*
|
|
88
|
+
* ```javascript
|
|
89
|
+
* router
|
|
90
|
+
* .param('user', function (id, ctx, next) {
|
|
91
|
+
* ctx.user = users[id];
|
|
92
|
+
* if (!user) return ctx.status = 404;
|
|
93
|
+
* next();
|
|
94
|
+
* })
|
|
95
|
+
* .get('/users/:user', function (ctx, next) {
|
|
96
|
+
* ctx.body = ctx.user;
|
|
97
|
+
* });
|
|
98
|
+
* ```
|
|
99
|
+
*
|
|
100
|
+
* @param {String} param param string
|
|
101
|
+
* @param {Function} fn middleware function
|
|
102
|
+
* @return {Layer} layer instance
|
|
103
|
+
* @private
|
|
104
|
+
*/
|
|
105
|
+
param(param: string, fn: ParamMiddlewareFunc): Layer;
|
|
106
|
+
/**
|
|
107
|
+
* Prefix route path.
|
|
108
|
+
*
|
|
109
|
+
* @param {String} prefix prefix string
|
|
110
|
+
* @return {Layer} layer instance
|
|
111
|
+
* @private
|
|
112
|
+
*/
|
|
113
|
+
setPrefix(prefix: string): Layer;
|
|
114
|
+
}
|