@eggjs/aop-plugin 4.0.0-beta.35 → 4.0.0-beta.36
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.d.ts +16 -12
- package/dist/app.js +43 -39
- package/dist/index.d.ts +1 -1
- package/dist/index.js +2 -1
- package/dist/lib/AopContextHook.d.ts +19 -15
- package/dist/lib/AopContextHook.js +35 -45
- package/dist/types.d.ts +1 -1
- package/dist/types.js +3 -2
- package/package.json +45 -49
package/dist/app.d.ts
CHANGED
|
@@ -1,13 +1,17 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
1
|
+
import { Application, ILifecycleBoot } from "egg";
|
|
2
|
+
|
|
3
|
+
//#region src/app.d.ts
|
|
4
|
+
declare class AopAppHook implements ILifecycleBoot {
|
|
5
|
+
private readonly app;
|
|
6
|
+
private readonly crosscutAdviceFactory;
|
|
7
|
+
private readonly loadUnitAopHook;
|
|
8
|
+
private readonly eggPrototypeCrossCutHook;
|
|
9
|
+
private readonly eggObjectAopHook;
|
|
10
|
+
private aopContextHook;
|
|
11
|
+
constructor(app: Application);
|
|
12
|
+
configDidLoad(): void;
|
|
13
|
+
didLoad(): Promise<void>;
|
|
14
|
+
beforeClose(): Promise<void>;
|
|
13
15
|
}
|
|
16
|
+
//#endregion
|
|
17
|
+
export { AopAppHook as default };
|
package/dist/app.js
CHANGED
|
@@ -1,40 +1,44 @@
|
|
|
1
|
-
import assert from 'node:assert';
|
|
2
|
-
import { CrosscutAdviceFactory } from '@eggjs/aop-decorator';
|
|
3
|
-
import { crossCutGraphHook, EggObjectAopHook, EggPrototypeCrossCutHook, LoadUnitAopHook, pointCutGraphHook, } from '@eggjs/aop-runtime';
|
|
4
|
-
import { GlobalGraph } from '@eggjs/metadata';
|
|
5
1
|
import { AopContextHook } from "./lib/AopContextHook.js";
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
2
|
+
import assert from "node:assert";
|
|
3
|
+
import { CrosscutAdviceFactory } from "@eggjs/aop-decorator";
|
|
4
|
+
import { EggObjectAopHook, EggPrototypeCrossCutHook, LoadUnitAopHook, crossCutGraphHook, pointCutGraphHook } from "@eggjs/aop-runtime";
|
|
5
|
+
import { GlobalGraph } from "@eggjs/metadata";
|
|
6
|
+
|
|
7
|
+
//#region src/app.ts
|
|
8
|
+
var AopAppHook = class {
|
|
9
|
+
app;
|
|
10
|
+
crosscutAdviceFactory;
|
|
11
|
+
loadUnitAopHook;
|
|
12
|
+
eggPrototypeCrossCutHook;
|
|
13
|
+
eggObjectAopHook;
|
|
14
|
+
aopContextHook;
|
|
15
|
+
constructor(app) {
|
|
16
|
+
this.app = app;
|
|
17
|
+
this.crosscutAdviceFactory = new CrosscutAdviceFactory();
|
|
18
|
+
this.loadUnitAopHook = new LoadUnitAopHook(this.crosscutAdviceFactory);
|
|
19
|
+
this.eggPrototypeCrossCutHook = new EggPrototypeCrossCutHook(this.crosscutAdviceFactory);
|
|
20
|
+
this.eggObjectAopHook = new EggObjectAopHook();
|
|
21
|
+
}
|
|
22
|
+
configDidLoad() {
|
|
23
|
+
this.app.eggPrototypeLifecycleUtil.registerLifecycle(this.eggPrototypeCrossCutHook);
|
|
24
|
+
this.app.loadUnitLifecycleUtil.registerLifecycle(this.loadUnitAopHook);
|
|
25
|
+
this.app.eggObjectLifecycleUtil.registerLifecycle(this.eggObjectAopHook);
|
|
26
|
+
}
|
|
27
|
+
async didLoad() {
|
|
28
|
+
await this.app.moduleHandler.ready();
|
|
29
|
+
assert(GlobalGraph.instance, "GlobalGraph.instance is not set");
|
|
30
|
+
GlobalGraph.instance.registerBuildHook(crossCutGraphHook);
|
|
31
|
+
GlobalGraph.instance.registerBuildHook(pointCutGraphHook);
|
|
32
|
+
this.aopContextHook = new AopContextHook(this.app.moduleHandler);
|
|
33
|
+
this.app.eggContextLifecycleUtil.registerLifecycle(this.aopContextHook);
|
|
34
|
+
}
|
|
35
|
+
async beforeClose() {
|
|
36
|
+
this.app.eggPrototypeLifecycleUtil.deleteLifecycle(this.eggPrototypeCrossCutHook);
|
|
37
|
+
this.app.loadUnitLifecycleUtil.deleteLifecycle(this.loadUnitAopHook);
|
|
38
|
+
this.app.eggObjectLifecycleUtil.deleteLifecycle(this.eggObjectAopHook);
|
|
39
|
+
this.app.eggContextLifecycleUtil.deleteLifecycle(this.aopContextHook);
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
//#endregion
|
|
44
|
+
export { AopAppHook as default };
|
package/dist/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import
|
|
1
|
+
import "./types.js";
|
package/dist/index.js
CHANGED
|
@@ -1,18 +1,22 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
import { EggPrototype } from "@eggjs/metadata";
|
|
2
|
+
import { EggProtoImplClass } from "@eggjs/core-decorator";
|
|
3
|
+
import { Application } from "egg";
|
|
4
|
+
import { LifecycleHook } from "@eggjs/lifecycle";
|
|
5
|
+
import { EggContext, EggContextLifecycleContext } from "@eggjs/tegg-runtime";
|
|
6
|
+
|
|
7
|
+
//#region src/lib/AopContextHook.d.ts
|
|
8
|
+
interface EggPrototypeWithClazz extends EggPrototype {
|
|
9
|
+
clazz?: EggProtoImplClass;
|
|
8
10
|
}
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
11
|
+
interface ProtoToCreate {
|
|
12
|
+
name: string;
|
|
13
|
+
proto: EggPrototype;
|
|
12
14
|
}
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
15
|
+
declare class AopContextHook implements LifecycleHook<EggContextLifecycleContext, EggContext> {
|
|
16
|
+
private readonly moduleHandler;
|
|
17
|
+
private requestProtoList;
|
|
18
|
+
constructor(moduleHandler: Application["moduleHandler"]);
|
|
19
|
+
preCreate(_: unknown, ctx: EggContext): Promise<void>;
|
|
18
20
|
}
|
|
21
|
+
//#endregion
|
|
22
|
+
export { AopContextHook, EggPrototypeWithClazz, ProtoToCreate };
|
|
@@ -1,45 +1,35 @@
|
|
|
1
|
-
import { AspectInfoUtil } from
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { ROOT_PROTO } from
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
// compatible with egg controller
|
|
37
|
-
// add context aspect to ctx
|
|
38
|
-
if (!ctx.get(ROOT_PROTO)) {
|
|
39
|
-
for (const proto of this.requestProtoList) {
|
|
40
|
-
ctx.addProtoToCreate(proto.name, proto.proto);
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQW9wQ29udGV4dEhvb2suanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGliL0FvcENvbnRleHRIb29rLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN0RCxPQUFPLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBMEIsTUFBTSx1QkFBdUIsQ0FBQztBQUU5RixPQUFPLEVBQXFCLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQWFsRCxNQUFNLE9BQU8sY0FBYztJQUNSLGFBQWEsQ0FBK0I7SUFDckQsZ0JBQWdCLEdBQXlCLEVBQUUsQ0FBQztJQUVwRCxZQUFZLGFBQTJDO1FBQ3JELElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO1FBQ25DLEtBQUssTUFBTSxnQkFBZ0IsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLGlCQUFpQixFQUFFLENBQUM7WUFDcEUsTUFBTSxRQUFRLEdBQUcsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLG1CQUFtQixFQUFFLENBQUM7WUFDakUsS0FBSyxNQUFNLEtBQUssSUFBSSxRQUFRLEVBQUUsQ0FBQztnQkFDN0IsTUFBTSxjQUFjLEdBQUcsS0FBOEIsQ0FBQztnQkFDdEQsTUFBTSxLQUFLLEdBQUcsY0FBYyxDQUFDLEtBQUssQ0FBQztnQkFDbkMsSUFBSSxDQUFDLEtBQUs7b0JBQUUsU0FBUztnQkFDckIsTUFBTSxPQUFPLEdBQUcsY0FBYyxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDcEQsS0FBSyxNQUFNLE1BQU0sSUFBSSxPQUFPLEVBQUUsQ0FBQztvQkFDN0IsS0FBSyxNQUFNLE1BQU0sSUFBSSxNQUFNLENBQUMsVUFBVSxFQUFFLENBQUM7d0JBQ3ZDLE1BQU0sV0FBVyxHQUFHLGFBQWEsQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBNkIsQ0FBQzt3QkFDMUYsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDOzRCQUNqQixNQUFNLFNBQVMsQ0FBQyxNQUFNLENBQUMsY0FBYyxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksMEJBQTBCLEVBQUUsa0JBQWtCLENBQUMsQ0FBQzt3QkFDeEcsQ0FBQzt3QkFDRCxJQUFJLFdBQVcsQ0FBQyxRQUFRLEtBQUssY0FBYyxDQUFDLE9BQU8sRUFBRSxDQUFDOzRCQUNwRCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDO2dDQUN6QixJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUk7Z0NBQ2pCLEtBQUssRUFBRSxXQUFXOzZCQUNuQixDQUFDLENBQUM7d0JBQ0wsQ0FBQztvQkFDSCxDQUFDO2dCQUNILENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFFRCxLQUFLLENBQUMsU0FBUyxDQUFDLENBQVUsRUFBRSxHQUFlO1FBQ3pDLGlDQUFpQztRQUNqQyw0QkFBNEI7UUFDNUIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQztZQUN6QixLQUFLLE1BQU0sS0FBSyxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO2dCQUMxQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDaEQsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0NBQ0YifQ==
|
|
1
|
+
import { AspectInfoUtil } from "@eggjs/aop-decorator";
|
|
2
|
+
import { TeggError } from "@eggjs/metadata";
|
|
3
|
+
import { ObjectInitType, PrototypeUtil } from "@eggjs/core-decorator";
|
|
4
|
+
import { ROOT_PROTO } from "@eggjs/module-common";
|
|
5
|
+
|
|
6
|
+
//#region src/lib/AopContextHook.ts
|
|
7
|
+
var AopContextHook = class {
|
|
8
|
+
moduleHandler;
|
|
9
|
+
requestProtoList = [];
|
|
10
|
+
constructor(moduleHandler) {
|
|
11
|
+
this.moduleHandler = moduleHandler;
|
|
12
|
+
for (const loadUnitInstance of this.moduleHandler.loadUnitInstances) {
|
|
13
|
+
const iterator = loadUnitInstance.loadUnit.iterateEggPrototype();
|
|
14
|
+
for (const proto of iterator) {
|
|
15
|
+
const clazz = proto.clazz;
|
|
16
|
+
if (!clazz) continue;
|
|
17
|
+
const aspects = AspectInfoUtil.getAspectList(clazz);
|
|
18
|
+
for (const aspect of aspects) for (const advice of aspect.adviceList) {
|
|
19
|
+
const adviceProto = PrototypeUtil.getClazzProto(advice.clazz);
|
|
20
|
+
if (!adviceProto) throw TeggError.create(`Aop Advice(${advice.clazz.name}) not found in loadUnits`, "advice_not_found");
|
|
21
|
+
if (adviceProto.initType === ObjectInitType.CONTEXT) this.requestProtoList.push({
|
|
22
|
+
name: advice.name,
|
|
23
|
+
proto: adviceProto
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
async preCreate(_, ctx) {
|
|
30
|
+
if (!ctx.get(ROOT_PROTO)) for (const proto of this.requestProtoList) ctx.addProtoToCreate(proto.name, proto.proto);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
//#endregion
|
|
35
|
+
export { AopContextHook };
|
package/dist/types.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import
|
|
1
|
+
import "@eggjs/tegg-plugin/types";
|
package/dist/types.js
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
1
|
+
import "@eggjs/tegg-plugin/types";
|
|
2
|
+
|
|
3
|
+
export { };
|
package/package.json
CHANGED
|
@@ -1,25 +1,30 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@eggjs/aop-plugin",
|
|
3
|
-
"version": "4.0.0-beta.
|
|
4
|
-
"eggPlugin": {
|
|
5
|
-
"name": "teggAop",
|
|
6
|
-
"dependencies": [
|
|
7
|
-
"tegg"
|
|
8
|
-
]
|
|
9
|
-
},
|
|
10
|
-
"types": "./dist/index.d.ts",
|
|
3
|
+
"version": "4.0.0-beta.36",
|
|
11
4
|
"description": "tegg aop plugin",
|
|
12
5
|
"keywords": [
|
|
13
|
-
"egg",
|
|
14
|
-
"typescript",
|
|
15
|
-
"decorator",
|
|
16
6
|
"aop",
|
|
17
|
-
"
|
|
7
|
+
"decorator",
|
|
8
|
+
"egg",
|
|
9
|
+
"tegg",
|
|
10
|
+
"typescript"
|
|
18
11
|
],
|
|
12
|
+
"homepage": "https://github.com/eggjs/egg/tree/next/tegg/plugin/aop",
|
|
13
|
+
"bugs": {
|
|
14
|
+
"url": "https://github.com/eggjs/egg/issues"
|
|
15
|
+
},
|
|
16
|
+
"repository": {
|
|
17
|
+
"type": "git",
|
|
18
|
+
"url": "git+https://github.com/eggjs/egg.git",
|
|
19
|
+
"directory": "tegg/plugin/aop"
|
|
20
|
+
},
|
|
19
21
|
"files": [
|
|
20
22
|
"dist"
|
|
21
23
|
],
|
|
22
24
|
"type": "module",
|
|
25
|
+
"main": "./dist/index.js",
|
|
26
|
+
"module": "./dist/index.js",
|
|
27
|
+
"types": "./dist/index.d.ts",
|
|
23
28
|
"exports": {
|
|
24
29
|
".": "./dist/index.js",
|
|
25
30
|
"./app": "./dist/app.js",
|
|
@@ -27,50 +32,41 @@
|
|
|
27
32
|
"./types": "./dist/types.js",
|
|
28
33
|
"./package.json": "./package.json"
|
|
29
34
|
},
|
|
30
|
-
"
|
|
31
|
-
|
|
32
|
-
"url": "https://github.com/eggjs/egg/issues"
|
|
33
|
-
},
|
|
34
|
-
"repository": {
|
|
35
|
-
"type": "git",
|
|
36
|
-
"url": "git+https://github.com/eggjs/egg.git",
|
|
37
|
-
"directory": "tegg/plugin/aop"
|
|
38
|
-
},
|
|
39
|
-
"engines": {
|
|
40
|
-
"node": ">=22.18.0"
|
|
35
|
+
"publishConfig": {
|
|
36
|
+
"access": "public"
|
|
41
37
|
},
|
|
42
38
|
"dependencies": {
|
|
43
|
-
"@eggjs/aop-decorator": "4.0.0-beta.
|
|
44
|
-
"@eggjs/core-decorator": "4.0.0-beta.
|
|
45
|
-
"@eggjs/
|
|
46
|
-
"@eggjs/
|
|
47
|
-
"@eggjs/lifecycle": "4.0.0-beta.
|
|
48
|
-
"@eggjs/
|
|
49
|
-
"@eggjs/
|
|
50
|
-
},
|
|
51
|
-
"peerDependencies": {
|
|
52
|
-
"@eggjs/tegg-plugin": "4.0.0-beta.35",
|
|
53
|
-
"egg": "4.1.0-beta.35"
|
|
39
|
+
"@eggjs/aop-decorator": "4.0.0-beta.36",
|
|
40
|
+
"@eggjs/core-decorator": "4.0.0-beta.36",
|
|
41
|
+
"@eggjs/metadata": "4.0.0-beta.36",
|
|
42
|
+
"@eggjs/aop-runtime": "4.0.0-beta.36",
|
|
43
|
+
"@eggjs/lifecycle": "4.0.0-beta.36",
|
|
44
|
+
"@eggjs/module-common": "4.0.0-beta.36",
|
|
45
|
+
"@eggjs/tegg-runtime": "4.0.0-beta.36"
|
|
54
46
|
},
|
|
55
47
|
"devDependencies": {
|
|
56
|
-
"@types/node": "^24.10.
|
|
57
|
-
"tsdown": "^0.17.0",
|
|
48
|
+
"@types/node": "^24.10.2",
|
|
58
49
|
"typescript": "^5.9.3",
|
|
59
|
-
"
|
|
60
|
-
"@eggjs/mock": "7.0.0-beta.
|
|
61
|
-
"@eggjs/tegg": "4.0.0-beta.
|
|
62
|
-
"
|
|
63
|
-
"@eggjs/tegg-
|
|
64
|
-
"egg": "4.1.0-beta.35"
|
|
50
|
+
"@eggjs/tegg": "4.0.0-beta.36",
|
|
51
|
+
"@eggjs/mock": "7.0.0-beta.36",
|
|
52
|
+
"@eggjs/tegg-plugin": "4.0.0-beta.36",
|
|
53
|
+
"egg": "4.1.0-beta.36",
|
|
54
|
+
"@eggjs/tegg-config": "4.0.0-beta.36"
|
|
65
55
|
},
|
|
66
|
-
"
|
|
67
|
-
"
|
|
56
|
+
"peerDependencies": {
|
|
57
|
+
"@eggjs/tegg-plugin": "4.0.0-beta.36",
|
|
58
|
+
"egg": "4.1.0-beta.36"
|
|
59
|
+
},
|
|
60
|
+
"engines": {
|
|
61
|
+
"node": ">=22.18.0"
|
|
62
|
+
},
|
|
63
|
+
"eggPlugin": {
|
|
64
|
+
"name": "teggAop",
|
|
65
|
+
"dependencies": [
|
|
66
|
+
"tegg"
|
|
67
|
+
]
|
|
68
68
|
},
|
|
69
|
-
"main": "./dist/index.js",
|
|
70
|
-
"module": "./dist/index.js",
|
|
71
69
|
"scripts": {
|
|
72
|
-
"
|
|
73
|
-
"build": "tsdown && npm run clean && tsc -p tsconfig.build.json",
|
|
74
|
-
"typecheck": "tsc --noEmit"
|
|
70
|
+
"typecheck": "tsgo --noEmit"
|
|
75
71
|
}
|
|
76
72
|
}
|