@eggjs/tegg-controller-plugin 4.0.0-beta.8 → 4.0.0-beta.9
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/dist/app/middleware/tegg_root_proto.d.ts +2 -5
- package/dist/app/middleware/tegg_root_proto.js +7 -11
- package/dist/app.d.ts +23 -5
- package/dist/app.js +76 -17
- package/dist/index.d.ts +1 -5
- package/dist/index.js +2 -18
- package/dist/lib/AppLoadUnitControllerHook.d.ts +9 -14
- package/dist/lib/AppLoadUnitControllerHook.js +29 -7
- package/dist/lib/ControllerLoadUnit.d.ts +20 -24
- package/dist/lib/ControllerLoadUnit.js +72 -3
- package/dist/lib/ControllerLoadUnitHandler.d.ts +11 -15
- package/dist/lib/ControllerLoadUnitHandler.js +29 -4
- package/dist/lib/ControllerLoadUnitInstance.d.ts +16 -20
- package/dist/lib/ControllerLoadUnitInstance.js +36 -40
- package/dist/lib/ControllerMetadataManager.d.ts +7 -11
- package/dist/lib/ControllerMetadataManager.js +27 -3
- package/dist/lib/ControllerRegister.d.ts +5 -3
- package/dist/lib/ControllerRegister.js +3 -4
- package/dist/lib/ControllerRegisterFactory.d.ts +12 -4
- package/dist/lib/ControllerRegisterFactory.js +22 -5
- package/dist/lib/EggControllerLoader.d.ts +6 -10
- package/dist/lib/EggControllerLoader.js +31 -3
- package/dist/lib/EggControllerPrototypeHook.d.ts +4 -8
- package/dist/lib/EggControllerPrototypeHook.js +11 -3
- package/dist/lib/RootProtoManager.d.ts +8 -2
- package/dist/lib/RootProtoManager.js +34 -3
- package/dist/lib/errors.d.ts +3 -7
- package/dist/lib/errors.js +12 -3
- package/dist/lib/impl/http/Acl.d.ts +2 -6
- package/dist/lib/impl/http/Acl.js +33 -3
- package/dist/lib/impl/http/HTTPControllerRegister.d.ts +17 -21
- package/dist/lib/impl/http/HTTPControllerRegister.js +64 -9
- package/dist/lib/impl/http/HTTPMethodRegister.d.ts +18 -22
- package/dist/lib/impl/http/HTTPMethodRegister.js +165 -7
- package/dist/lib/impl/http/Req.d.ts +4 -8
- package/dist/lib/impl/http/Req.js +13 -3
- package/dist/types.d.ts +2 -5
- package/dist/types.js +3 -18
- package/package.json +12 -12
- package/dist/Acl-BF8dxD8f.js +0 -29
- package/dist/AppLoadUnitControllerHook-C3F2NtiE.js +0 -27
- package/dist/ControllerLoadUnit-DWgcQuC0.js +0 -63
- package/dist/ControllerLoadUnitHandler-BiPlOVSN.js +0 -29
- package/dist/ControllerMetadataManager-CC5nmTlv.js +0 -23
- package/dist/ControllerRegister-DDwsWz5F.d.ts +0 -9
- package/dist/ControllerRegister-DPqM08MF.js +0 -3
- package/dist/ControllerRegisterFactory-Bz7bulBg.js +0 -23
- package/dist/ControllerRegisterFactory-DCPVkM4E.d.ts +0 -16
- package/dist/EggControllerLoader-iohfFKpj.js +0 -29
- package/dist/EggControllerPrototypeHook-Djf4Mwvw.js +0 -13
- package/dist/HTTPControllerRegister-CZQJslUT.js +0 -58
- package/dist/HTTPMethodRegister-CHHFV-eT.js +0 -138
- package/dist/Req-D3i-7606.js +0 -16
- package/dist/RootProtoManager-CbLm-PD1.js +0 -28
- package/dist/RootProtoManager-DkqD47oc.d.ts +0 -12
- package/dist/app-CZQLJgoQ.d.ts +0 -27
- package/dist/app-Dq89t2rF.js +0 -67
- package/dist/errors-CnXI09lf.js +0 -16
- package/dist/types-D9vieyYE.d.ts +0 -1
- package/dist/types-DkvgFpN4.js +0 -3
|
@@ -1,3 +1,5 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
export
|
|
1
|
+
import { type LoadUnit } from '@eggjs/tegg-metadata';
|
|
2
|
+
import { RootProtoManager } from './RootProtoManager.ts';
|
|
3
|
+
export interface ControllerRegister {
|
|
4
|
+
register(rootProtoManager: RootProtoManager, loadUnit?: LoadUnit): Promise<void>;
|
|
5
|
+
}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import
|
|
2
|
-
import "
|
|
3
|
-
|
|
4
|
-
export { };
|
|
1
|
+
import {} from '@eggjs/tegg-metadata';
|
|
2
|
+
import { RootProtoManager } from "./RootProtoManager.js";
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29udHJvbGxlclJlZ2lzdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi9Db250cm9sbGVyUmVnaXN0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixNQUFNLHNCQUFzQixDQUFDO0FBRXJELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDIn0=
|
|
@@ -1,4 +1,12 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
|
|
1
|
+
import type { Application } from 'egg';
|
|
2
|
+
import { type ControllerMetadata, type ControllerTypeLike } from '@eggjs/tegg';
|
|
3
|
+
import { type EggPrototype } from '@eggjs/tegg-metadata';
|
|
4
|
+
import { type ControllerRegister } from './ControllerRegister.ts';
|
|
5
|
+
export type RegisterCreator = (proto: EggPrototype, controllerMeta: ControllerMetadata, app: Application) => ControllerRegister;
|
|
6
|
+
export declare class ControllerRegisterFactory {
|
|
7
|
+
private readonly app;
|
|
8
|
+
private registerCreatorMap;
|
|
9
|
+
constructor(app: Application);
|
|
10
|
+
registerControllerRegister(type: ControllerTypeLike, creator: RegisterCreator): void;
|
|
11
|
+
getControllerRegister(proto: EggPrototype, metadata: ControllerMetadata): ControllerRegister | undefined;
|
|
12
|
+
}
|
|
@@ -1,5 +1,22 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import {} from '@eggjs/tegg';
|
|
2
|
+
import {} from '@eggjs/tegg-metadata';
|
|
3
|
+
import {} from "./ControllerRegister.js";
|
|
4
|
+
export class ControllerRegisterFactory {
|
|
5
|
+
app;
|
|
6
|
+
registerCreatorMap;
|
|
7
|
+
constructor(app) {
|
|
8
|
+
this.app = app;
|
|
9
|
+
this.registerCreatorMap = new Map();
|
|
10
|
+
}
|
|
11
|
+
registerControllerRegister(type, creator) {
|
|
12
|
+
this.registerCreatorMap.set(type, creator);
|
|
13
|
+
}
|
|
14
|
+
getControllerRegister(proto, metadata) {
|
|
15
|
+
const creator = this.registerCreatorMap.get(metadata.type);
|
|
16
|
+
if (!creator) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
return creator(proto, metadata, this.app);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29udHJvbGxlclJlZ2lzdGVyRmFjdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvQ29udHJvbGxlclJlZ2lzdGVyRmFjdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQW9ELE1BQU0sYUFBYSxDQUFDO0FBQy9FLE9BQU8sRUFBcUIsTUFBTSxzQkFBc0IsQ0FBQztBQUV6RCxPQUFPLEVBQTJCLE1BQU0seUJBQXlCLENBQUM7QUFJbEUsTUFBTSxPQUFPLHlCQUF5QjtJQUNuQixHQUFHLENBQWM7SUFDMUIsa0JBQWtCLENBQTJDO0lBRXJFLFlBQVksR0FBZ0I7UUFDMUIsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7UUFDZixJQUFJLENBQUMsa0JBQWtCLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztJQUN0QyxDQUFDO0lBRUQsMEJBQTBCLENBQUMsSUFBd0IsRUFBRSxPQUF3QjtRQUMzRSxJQUFJLENBQUMsa0JBQWtCLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQscUJBQXFCLENBQUMsS0FBbUIsRUFBRSxRQUE0QjtRQUNyRSxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMzRCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDYixPQUFPO1FBQ1QsQ0FBQztRQUNELE9BQU8sT0FBTyxDQUFDLEtBQUssRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzVDLENBQUM7Q0FDRiJ9
|
|
@@ -1,11 +1,7 @@
|
|
|
1
|
-
import { EggProtoImplClass } from
|
|
2
|
-
import { Loader } from
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
constructor(controllerDir: string);
|
|
8
|
-
load(): Promise<EggProtoImplClass[]>;
|
|
1
|
+
import type { EggProtoImplClass } from '@eggjs/tegg';
|
|
2
|
+
import type { Loader } from '@eggjs/tegg-types';
|
|
3
|
+
export declare class EggControllerLoader implements Loader {
|
|
4
|
+
private readonly controllerDir;
|
|
5
|
+
constructor(controllerDir: string);
|
|
6
|
+
load(): Promise<EggProtoImplClass[]>;
|
|
9
7
|
}
|
|
10
|
-
//#endregion
|
|
11
|
-
export { EggControllerLoader };
|
|
@@ -1,3 +1,31 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import { globby } from 'globby';
|
|
3
|
+
import { LoaderUtil } from '@eggjs/tegg-loader';
|
|
4
|
+
export class EggControllerLoader {
|
|
5
|
+
controllerDir;
|
|
6
|
+
constructor(controllerDir) {
|
|
7
|
+
this.controllerDir = controllerDir;
|
|
8
|
+
}
|
|
9
|
+
async load() {
|
|
10
|
+
const filePattern = LoaderUtil.filePattern();
|
|
11
|
+
let files;
|
|
12
|
+
try {
|
|
13
|
+
const httpControllers = (await globby(filePattern, { cwd: this.controllerDir }))
|
|
14
|
+
.map(file => path.join(this.controllerDir, file));
|
|
15
|
+
files = httpControllers;
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
files = [];
|
|
19
|
+
// app/controller dir not exists
|
|
20
|
+
}
|
|
21
|
+
const protoClassList = [];
|
|
22
|
+
for (const file of files) {
|
|
23
|
+
const fileClazzList = await LoaderUtil.loadFile(file);
|
|
24
|
+
for (const clazz of fileClazzList) {
|
|
25
|
+
protoClassList.push(clazz);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return protoClassList;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRWdnQ29udHJvbGxlckxvYWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvRWdnQ29udHJvbGxlckxvYWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLElBQUksTUFBTSxXQUFXLENBQUM7QUFFN0IsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUNoQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFJaEQsTUFBTSxPQUFPLG1CQUFtQjtJQUNiLGFBQWEsQ0FBUztJQUV2QyxZQUFZLGFBQXFCO1FBQy9CLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxLQUFLLENBQUMsSUFBSTtRQUNSLE1BQU0sV0FBVyxHQUFHLFVBQVUsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUM3QyxJQUFJLEtBQWUsQ0FBQztRQUNwQixJQUFJLENBQUM7WUFDSCxNQUFNLGVBQWUsR0FBRyxDQUFDLE1BQU0sTUFBTSxDQUFDLFdBQVcsRUFBRSxFQUFFLEdBQUcsRUFBRSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUMsQ0FBQztpQkFDN0UsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7WUFDcEQsS0FBSyxHQUFHLGVBQWUsQ0FBQztRQUMxQixDQUFDO1FBQUMsTUFBTSxDQUFDO1lBQ1AsS0FBSyxHQUFHLEVBQUUsQ0FBQztZQUNYLGdDQUFnQztRQUNsQyxDQUFDO1FBQ0QsTUFBTSxjQUFjLEdBQXdCLEVBQUUsQ0FBQztRQUMvQyxLQUFLLE1BQU0sSUFBSSxJQUFJLEtBQUssRUFBRSxDQUFDO1lBQ3pCLE1BQU0sYUFBYSxHQUFHLE1BQU0sVUFBVSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUN0RCxLQUFLLE1BQU0sS0FBSyxJQUFJLGFBQWEsRUFBRSxDQUFDO2dCQUNsQyxjQUFjLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzdCLENBQUM7UUFDSCxDQUFDO1FBQ0QsT0FBTyxjQUFjLENBQUM7SUFDeEIsQ0FBQztDQUNGIn0=
|
|
@@ -1,9 +1,5 @@
|
|
|
1
|
-
import { EggPrototype, EggPrototypeLifecycleContext } from
|
|
2
|
-
import { LifecycleHook } from
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
declare class EggControllerPrototypeHook implements LifecycleHook<EggPrototypeLifecycleContext, EggPrototype> {
|
|
6
|
-
postCreate(ctx: EggPrototypeLifecycleContext): Promise<void>;
|
|
1
|
+
import { type EggPrototype, type EggPrototypeLifecycleContext } from '@eggjs/tegg-metadata';
|
|
2
|
+
import { type LifecycleHook } from '@eggjs/tegg';
|
|
3
|
+
export declare class EggControllerPrototypeHook implements LifecycleHook<EggPrototypeLifecycleContext, EggPrototype> {
|
|
4
|
+
postCreate(ctx: EggPrototypeLifecycleContext): Promise<void>;
|
|
7
5
|
}
|
|
8
|
-
//#endregion
|
|
9
|
-
export { EggControllerPrototypeHook };
|
|
@@ -1,3 +1,11 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
export
|
|
1
|
+
import {} from '@eggjs/tegg-metadata';
|
|
2
|
+
import { ControllerMetaBuilderFactory, ControllerMetadataUtil, } from '@eggjs/tegg';
|
|
3
|
+
export class EggControllerPrototypeHook {
|
|
4
|
+
async postCreate(ctx) {
|
|
5
|
+
const metadata = ControllerMetaBuilderFactory.build(ctx.clazz);
|
|
6
|
+
if (metadata) {
|
|
7
|
+
ControllerMetadataUtil.setControllerMetadata(ctx.clazz, metadata);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRWdnQ29udHJvbGxlclByb3RvdHlwZUhvb2suanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGliL0VnZ0NvbnRyb2xsZXJQcm90b3R5cGVIb29rLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBd0QsTUFBTSxzQkFBc0IsQ0FBQztBQUM1RixPQUFPLEVBQ0wsNEJBQTRCLEVBQzVCLHNCQUFzQixHQUV2QixNQUFNLGFBQWEsQ0FBQztBQUVyQixNQUFNLE9BQU8sMEJBQTBCO0lBQ3JDLEtBQUssQ0FBQyxVQUFVLENBQUMsR0FBaUM7UUFDaEQsTUFBTSxRQUFRLEdBQUcsNEJBQTRCLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvRCxJQUFJLFFBQVEsRUFBRSxDQUFDO1lBQ2Isc0JBQXNCLENBQUMscUJBQXFCLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxRQUFRLENBQUMsQ0FBQztRQUNwRSxDQUFDO0lBQ0gsQ0FBQztDQUNGIn0=
|
|
@@ -1,2 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import { type EggPrototype } from '@eggjs/tegg-metadata';
|
|
2
|
+
import { type EggContext } from '@eggjs/tegg';
|
|
3
|
+
export type GetRootProtoCallback = (ctx: EggContext) => EggPrototype | undefined;
|
|
4
|
+
export declare class RootProtoManager {
|
|
5
|
+
protoMap: Map<string, GetRootProtoCallback[]>;
|
|
6
|
+
registerRootProto(method: string, cb: GetRootProtoCallback, host: string): void;
|
|
7
|
+
getRootProto(ctx: EggContext): EggPrototype | undefined;
|
|
8
|
+
}
|
|
@@ -1,3 +1,34 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import {} from '@eggjs/tegg-metadata';
|
|
2
|
+
import {} from '@eggjs/tegg';
|
|
3
|
+
import { MapUtil } from '@eggjs/tegg-common-util';
|
|
4
|
+
export class RootProtoManager {
|
|
5
|
+
// <method, GetRootProtoCallback[]>
|
|
6
|
+
protoMap = new Map();
|
|
7
|
+
registerRootProto(method, cb, host) {
|
|
8
|
+
host = host || '';
|
|
9
|
+
const cbList = MapUtil.getOrStore(this.protoMap, method + host, []);
|
|
10
|
+
cbList.push(cb);
|
|
11
|
+
}
|
|
12
|
+
getRootProto(ctx) {
|
|
13
|
+
const hostCbList = this.protoMap.get(ctx.method + ctx.host);
|
|
14
|
+
if (hostCbList) {
|
|
15
|
+
for (const cb of hostCbList) {
|
|
16
|
+
const proto = cb(ctx);
|
|
17
|
+
if (proto) {
|
|
18
|
+
return proto;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
const cbList = this.protoMap.get(ctx.method);
|
|
23
|
+
if (!cbList) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
for (const cb of cbList) {
|
|
27
|
+
const proto = cb(ctx);
|
|
28
|
+
if (proto) {
|
|
29
|
+
return proto;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUm9vdFByb3RvTWFuYWdlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvUm9vdFByb3RvTWFuYWdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFCLE1BQU0sc0JBQXNCLENBQUM7QUFDekQsT0FBTyxFQUFtQixNQUFNLGFBQWEsQ0FBQztBQUM5QyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFJbEQsTUFBTSxPQUFPLGdCQUFnQjtJQUMzQixtQ0FBbUM7SUFDbkMsUUFBUSxHQUF3QyxJQUFJLEdBQUcsRUFBRSxDQUFDO0lBRTFELGlCQUFpQixDQUFDLE1BQWMsRUFBRSxFQUF3QixFQUFFLElBQVk7UUFDdEUsSUFBSSxHQUFHLElBQUksSUFBSSxFQUFFLENBQUM7UUFDbEIsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sR0FBRyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDcEUsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNsQixDQUFDO0lBRUQsWUFBWSxDQUFDLEdBQWU7UUFDMUIsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLE1BQU0sR0FBRyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDNUQsSUFBSSxVQUFVLEVBQUUsQ0FBQztZQUNmLEtBQUssTUFBTSxFQUFFLElBQUksVUFBVSxFQUFFLENBQUM7Z0JBQzVCLE1BQU0sS0FBSyxHQUFHLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDdEIsSUFBSSxLQUFLLEVBQUUsQ0FBQztvQkFDVixPQUFPLEtBQUssQ0FBQztnQkFDZixDQUFDO1lBQ0gsQ0FBQztRQUNILENBQUM7UUFFRCxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDN0MsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ1osT0FBTztRQUNULENBQUM7UUFDRCxLQUFLLE1BQU0sRUFBRSxJQUFJLE1BQU0sRUFBRSxDQUFDO1lBQ3hCLE1BQU0sS0FBSyxHQUFHLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUN0QixJQUFJLEtBQUssRUFBRSxDQUFDO2dCQUNWLE9BQU8sS0FBSyxDQUFDO1lBQ2YsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0NBQ0YifQ==
|
package/dist/lib/errors.d.ts
CHANGED
|
@@ -1,9 +1,5 @@
|
|
|
1
|
-
import { TeggError } from
|
|
2
|
-
|
|
3
|
-
//#region src/lib/errors.d.ts
|
|
1
|
+
import { TeggError } from '@eggjs/tegg-metadata';
|
|
4
2
|
/** 路由冲突错误 */
|
|
5
|
-
declare class RouterConflictError extends TeggError {
|
|
6
|
-
|
|
3
|
+
export declare class RouterConflictError extends TeggError {
|
|
4
|
+
constructor(msg: string);
|
|
7
5
|
}
|
|
8
|
-
//#endregion
|
|
9
|
-
export { RouterConflictError };
|
package/dist/lib/errors.js
CHANGED
|
@@ -1,3 +1,12 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { TeggError } from '@eggjs/tegg-metadata';
|
|
2
|
+
var ErrorCodes;
|
|
3
|
+
(function (ErrorCodes) {
|
|
4
|
+
ErrorCodes["ROUTER_CONFLICT"] = "ROUTER_CONFLICT";
|
|
5
|
+
})(ErrorCodes || (ErrorCodes = {}));
|
|
6
|
+
/** 路由冲突错误 */
|
|
7
|
+
export class RouterConflictError extends TeggError {
|
|
8
|
+
constructor(msg) {
|
|
9
|
+
super(msg, ErrorCodes.ROUTER_CONFLICT);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi9lcnJvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRWpELElBQUssVUFFSjtBQUZELFdBQUssVUFBVTtJQUNiLGlEQUFtQyxDQUFBO0FBQ3JDLENBQUMsRUFGSSxVQUFVLEtBQVYsVUFBVSxRQUVkO0FBRUQsYUFBYTtBQUNiLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxTQUFTO0lBQ2hELFlBQVksR0FBVztRQUNyQixLQUFLLENBQUMsR0FBRyxFQUFFLFVBQVUsQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUN6QyxDQUFDO0NBQ0YifQ==
|
|
@@ -1,6 +1,2 @@
|
|
|
1
|
-
import { EggContext, HTTPControllerMeta, HTTPMethodMeta
|
|
2
|
-
|
|
3
|
-
//#region src/lib/impl/http/Acl.d.ts
|
|
4
|
-
declare function aclMiddlewareFactory(controllerMeta: HTTPControllerMeta, methodMeta: HTTPMethodMeta): (ctx: EggContext, next: Next) => Promise<void>;
|
|
5
|
-
//#endregion
|
|
6
|
-
export { aclMiddlewareFactory };
|
|
1
|
+
import { type Next, type EggContext, type HTTPControllerMeta, type HTTPMethodMeta } from '@eggjs/tegg';
|
|
2
|
+
export declare function aclMiddlewareFactory(controllerMeta: HTTPControllerMeta, methodMeta: HTTPMethodMeta): (ctx: EggContext, next: Next) => Promise<void>;
|
|
@@ -1,3 +1,33 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import {} from '@eggjs/tegg';
|
|
2
|
+
export function aclMiddlewareFactory(controllerMeta, methodMeta) {
|
|
3
|
+
if (!controllerMeta.hasMethodAcl(methodMeta)) {
|
|
4
|
+
return;
|
|
5
|
+
}
|
|
6
|
+
const code = controllerMeta.getMethodAcl(methodMeta);
|
|
7
|
+
return async function aclMiddleware(ctx, next) {
|
|
8
|
+
try {
|
|
9
|
+
// @ts-expect-error ctx.acl is implemented in extend/context.ts on top level plugin, framework or app
|
|
10
|
+
await ctx.acl(code);
|
|
11
|
+
}
|
|
12
|
+
catch (e) {
|
|
13
|
+
const { redirectUrl, status } = e.data || {};
|
|
14
|
+
if (!redirectUrl) {
|
|
15
|
+
throw e;
|
|
16
|
+
}
|
|
17
|
+
if (ctx.acceptJSON) {
|
|
18
|
+
ctx.body = {
|
|
19
|
+
target: redirectUrl,
|
|
20
|
+
stat: 'deny',
|
|
21
|
+
};
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
if (status) {
|
|
25
|
+
ctx.realStatus = status;
|
|
26
|
+
}
|
|
27
|
+
ctx.redirect(redirectUrl);
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
return next();
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWNsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9pbXBsL2h0dHAvQWNsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBNEUsTUFBTSxhQUFhLENBQUM7QUFFdkcsTUFBTSxVQUFVLG9CQUFvQixDQUFDLGNBQWtDLEVBQUUsVUFBMEI7SUFDakcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQztRQUM3QyxPQUFPO0lBQ1QsQ0FBQztJQUNELE1BQU0sSUFBSSxHQUFHLGNBQWMsQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDckQsT0FBTyxLQUFLLFVBQVUsYUFBYSxDQUFDLEdBQWUsRUFBRSxJQUFVO1FBQzdELElBQUksQ0FBQztZQUNILHFHQUFxRztZQUNyRyxNQUFNLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdEIsQ0FBQztRQUFDLE9BQU8sQ0FBTSxFQUFFLENBQUM7WUFDaEIsTUFBTSxFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsR0FBRyxDQUFDLENBQUMsSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUM3QyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7Z0JBQ2pCLE1BQU0sQ0FBQyxDQUFDO1lBQ1YsQ0FBQztZQUNELElBQUksR0FBRyxDQUFDLFVBQVUsRUFBRSxDQUFDO2dCQUNuQixHQUFHLENBQUMsSUFBSSxHQUFHO29CQUNULE1BQU0sRUFBRSxXQUFXO29CQUNuQixJQUFJLEVBQUUsTUFBTTtpQkFDYixDQUFDO2dCQUNGLE9BQU87WUFDVCxDQUFDO1lBQ0QsSUFBSSxNQUFNLEVBQUUsQ0FBQztnQkFDWCxHQUFHLENBQUMsVUFBVSxHQUFHLE1BQU0sQ0FBQztZQUMxQixDQUFDO1lBQ0QsR0FBRyxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUMxQixPQUFPO1FBRVQsQ0FBQztRQUNELE9BQU8sSUFBSSxFQUFFLENBQUM7SUFDaEIsQ0FBQyxDQUFDO0FBQ0osQ0FBQyJ9
|
|
@@ -1,22 +1,18 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { EggPrototype } from
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
static clean(): void;
|
|
19
|
-
doRegister(rootProtoManager: RootProtoManager): void;
|
|
1
|
+
import { Application, Router } from 'egg';
|
|
2
|
+
import { type ControllerMetadata } from '@eggjs/tegg';
|
|
3
|
+
import { type EggPrototype } from '@eggjs/tegg-metadata';
|
|
4
|
+
import { EggContainerFactory } from '@eggjs/tegg-runtime';
|
|
5
|
+
import { type ControllerRegister } from '../../ControllerRegister.ts';
|
|
6
|
+
import { RootProtoManager } from '../../RootProtoManager.ts';
|
|
7
|
+
export declare class HTTPControllerRegister implements ControllerRegister {
|
|
8
|
+
static instance?: HTTPControllerRegister;
|
|
9
|
+
private readonly router;
|
|
10
|
+
private readonly checkRouters;
|
|
11
|
+
private readonly eggContainerFactory;
|
|
12
|
+
private controllerProtos;
|
|
13
|
+
static create(proto: EggPrototype, controllerMeta: ControllerMetadata, app: Application): HTTPControllerRegister;
|
|
14
|
+
constructor(router: Router, eggContainerFactory: typeof EggContainerFactory);
|
|
15
|
+
register(): Promise<void>;
|
|
16
|
+
static clean(): void;
|
|
17
|
+
doRegister(rootProtoManager: RootProtoManager): void;
|
|
20
18
|
}
|
|
21
|
-
//#endregion
|
|
22
|
-
export { HTTPControllerRegister };
|
|
@@ -1,9 +1,64 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
import "
|
|
7
|
-
import {
|
|
8
|
-
|
|
9
|
-
export
|
|
1
|
+
import assert from 'node:assert/strict';
|
|
2
|
+
import { Application, Router } from 'egg';
|
|
3
|
+
import { CONTROLLER_META_DATA, ControllerType, HTTPControllerMeta, HTTPMethodMeta, } from '@eggjs/tegg';
|
|
4
|
+
import {} from '@eggjs/tegg-metadata';
|
|
5
|
+
import { EggContainerFactory } from '@eggjs/tegg-runtime';
|
|
6
|
+
import {} from "../../ControllerRegister.js";
|
|
7
|
+
import { HTTPMethodRegister } from "./HTTPMethodRegister.js";
|
|
8
|
+
import { RootProtoManager } from "../../RootProtoManager.js";
|
|
9
|
+
export class HTTPControllerRegister {
|
|
10
|
+
static instance;
|
|
11
|
+
router;
|
|
12
|
+
checkRouters;
|
|
13
|
+
eggContainerFactory;
|
|
14
|
+
controllerProtos = [];
|
|
15
|
+
static create(proto, controllerMeta, app) {
|
|
16
|
+
assert(controllerMeta.type === ControllerType.HTTP, 'controller meta type is not HTTP');
|
|
17
|
+
if (!HTTPControllerRegister.instance) {
|
|
18
|
+
HTTPControllerRegister.instance = new HTTPControllerRegister(app.router, app.eggContainerFactory);
|
|
19
|
+
}
|
|
20
|
+
HTTPControllerRegister.instance.controllerProtos.push(proto);
|
|
21
|
+
return HTTPControllerRegister.instance;
|
|
22
|
+
}
|
|
23
|
+
constructor(router, eggContainerFactory) {
|
|
24
|
+
this.router = router;
|
|
25
|
+
this.checkRouters = new Map();
|
|
26
|
+
this.checkRouters.set('default', router);
|
|
27
|
+
this.eggContainerFactory = eggContainerFactory;
|
|
28
|
+
}
|
|
29
|
+
register() {
|
|
30
|
+
// do noting
|
|
31
|
+
return Promise.resolve();
|
|
32
|
+
}
|
|
33
|
+
static clean() {
|
|
34
|
+
if (this.instance) {
|
|
35
|
+
this.instance.controllerProtos = [];
|
|
36
|
+
this.instance.checkRouters.clear();
|
|
37
|
+
}
|
|
38
|
+
this.instance = undefined;
|
|
39
|
+
}
|
|
40
|
+
doRegister(rootProtoManager) {
|
|
41
|
+
const methodMap = new Map();
|
|
42
|
+
for (const proto of this.controllerProtos) {
|
|
43
|
+
const metadata = proto.getMetaData(CONTROLLER_META_DATA);
|
|
44
|
+
for (const method of metadata.methods) {
|
|
45
|
+
methodMap.set(method, proto);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
const allMethods = Array.from(methodMap.keys())
|
|
49
|
+
.sort((a, b) => b.priority - a.priority);
|
|
50
|
+
for (const method of allMethods) {
|
|
51
|
+
const controllerProto = methodMap.get(method);
|
|
52
|
+
const controllerMeta = controllerProto.getMetaData(CONTROLLER_META_DATA);
|
|
53
|
+
const methodRegister = new HTTPMethodRegister(controllerProto, controllerMeta, method, this.router, this.checkRouters, this.eggContainerFactory);
|
|
54
|
+
methodRegister.checkDuplicate();
|
|
55
|
+
}
|
|
56
|
+
for (const method of allMethods) {
|
|
57
|
+
const controllerProto = methodMap.get(method);
|
|
58
|
+
const controllerMeta = controllerProto.getMetaData(CONTROLLER_META_DATA);
|
|
59
|
+
const methodRegister = new HTTPMethodRegister(controllerProto, controllerMeta, method, this.router, this.checkRouters, this.eggContainerFactory);
|
|
60
|
+
methodRegister.register(rootProtoManager);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSFRUUENvbnRyb2xsZXJSZWdpc3Rlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvaW1wbC9odHRwL0hUVFBDb250cm9sbGVyUmVnaXN0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxNQUFNLE1BQU0sb0JBQW9CLENBQUM7QUFFeEMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsTUFBTSxLQUFLLENBQUM7QUFDMUMsT0FBTyxFQUNMLG9CQUFvQixFQUVwQixjQUFjLEVBQ2Qsa0JBQWtCLEVBQ2xCLGNBQWMsR0FDZixNQUFNLGFBQWEsQ0FBQztBQUNyQixPQUFPLEVBQXFCLE1BQU0sc0JBQXNCLENBQUM7QUFDekQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFMUQsT0FBTyxFQUEyQixNQUFNLDZCQUE2QixDQUFDO0FBQ3RFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzdELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBRTdELE1BQU0sT0FBTyxzQkFBc0I7SUFDakMsTUFBTSxDQUFDLFFBQVEsQ0FBMEI7SUFFeEIsTUFBTSxDQUFTO0lBQ2YsWUFBWSxDQUFzQjtJQUNsQyxtQkFBbUIsQ0FBNkI7SUFDekQsZ0JBQWdCLEdBQW1CLEVBQUUsQ0FBQztJQUU5QyxNQUFNLENBQUMsTUFBTSxDQUFDLEtBQW1CLEVBQUUsY0FBa0MsRUFBRSxHQUFnQjtRQUNyRixNQUFNLENBQUMsY0FBYyxDQUFDLElBQUksS0FBSyxjQUFjLENBQUMsSUFBSSxFQUFFLGtDQUFrQyxDQUFDLENBQUM7UUFDeEYsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ3JDLHNCQUFzQixDQUFDLFFBQVEsR0FBRyxJQUFJLHNCQUFzQixDQUFDLEdBQUcsQ0FBQyxNQUFNLEVBQUUsR0FBRyxDQUFDLG1CQUFt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
|
|
@@ -1,23 +1,19 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
private checkDuplicateInRouter;
|
|
20
|
-
register(rootProtoManager: RootProtoManager): void;
|
|
1
|
+
import { Router } from 'egg';
|
|
2
|
+
import { HTTPControllerMeta, HTTPMethodMeta } from '@eggjs/tegg';
|
|
3
|
+
import { EggContainerFactory } from '@eggjs/tegg-runtime';
|
|
4
|
+
import { type EggPrototype } from '@eggjs/tegg-metadata';
|
|
5
|
+
import { RootProtoManager } from '../../RootProtoManager.ts';
|
|
6
|
+
export declare class HTTPMethodRegister {
|
|
7
|
+
private readonly router;
|
|
8
|
+
private readonly checkRouters;
|
|
9
|
+
private readonly controllerMeta;
|
|
10
|
+
private readonly methodMeta;
|
|
11
|
+
private readonly proto;
|
|
12
|
+
private readonly eggContainerFactory;
|
|
13
|
+
constructor(proto: EggPrototype, controllerMeta: HTTPControllerMeta, methodMeta: HTTPMethodMeta, router: Router, checkRouters: Map<string, Router>, eggContainerFactory: typeof EggContainerFactory);
|
|
14
|
+
private createHandler;
|
|
15
|
+
checkDuplicate(): void;
|
|
16
|
+
private registerToRouter;
|
|
17
|
+
private checkDuplicateInRouter;
|
|
18
|
+
register(rootProtoManager: RootProtoManager): void;
|
|
21
19
|
}
|
|
22
|
-
//#endregion
|
|
23
|
-
export { HTTPMethodRegister };
|