@eggjs/aop-plugin 4.0.0-beta.34 → 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 {
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQW9wQ29udGV4dEhvb2suanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGliL0FvcENvbnRleHRIb29rLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE9BQU8sRUFBRSxhQUFhLEVBQUUsY0FBYyxFQUEwQixNQUFNLHVCQUF1QixDQUFDO0FBQzlGLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN0RCxPQUFPLEVBQXFCLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQVdsRCxNQUFNLE9BQU8sY0FBYztJQUNSLGFBQWEsQ0FBK0I7SUFDckQsZ0JBQWdCLEdBQXlCLEVBQUUsQ0FBQztJQUVwRCxZQUFZLGFBQTJDO1FBQ3JELElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO1FBQ25DLEtBQUssTUFBTSxnQkFBZ0IsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLGlCQUFpQixFQUFFLENBQUM7WUFDcEUsTUFBTSxRQUFRLEdBQUcsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLG1CQUFtQixFQUFFLENBQUM7WUFDakUsS0FBSyxNQUFNLEtBQUssSUFBSSxRQUFRLEVBQUUsQ0FBQztnQkFDN0IsTUFBTSxjQUFjLEdBQUcsS0FBOEIsQ0FBQztnQkFDdEQsTUFBTSxLQUFLLEdBQUcsY0FBYyxDQUFDLEtBQUssQ0FBQztnQkFDbkMsSUFBSSxDQUFDLEtBQUs7b0JBQUUsU0FBUztnQkFDckIsTUFBTSxPQUFPLEdBQUcsY0FBYyxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDcEQsS0FBSyxNQUFNLE1BQU0sSUFBSSxPQUFPLEVBQUUsQ0FBQztvQkFDN0IsS0FBSyxNQUFNLE1BQU0sSUFBSSxNQUFNLENBQUMsVUFBVSxFQUFFLENBQUM7d0JBQ3ZDLE1BQU0sV0FBVyxHQUFHLGFBQWEsQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBNkIsQ0FBQzt3QkFDMUYsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDOzRCQUNqQixNQUFNLFNBQVMsQ0FBQyxNQUFNLENBQUMsY0FBYyxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksMEJBQTBCLEVBQUUsa0JBQWtCLENBQUMsQ0FBQzt3QkFDeEcsQ0FBQzt3QkFDRCxJQUFJLFdBQVcsQ0FBQyxRQUFRLEtBQUssY0FBYyxDQUFDLE9BQU8sRUFBRSxDQUFDOzRCQUNwRCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDO2dDQUN6QixJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUk7Z0NBQ2pCLEtBQUssRUFBRSxXQUFXOzZCQUNuQixDQUFDLENBQUM7d0JBQ0wsQ0FBQztvQkFDSCxDQUFDO2dCQUNILENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFFRCxLQUFLLENBQUMsU0FBUyxDQUFDLENBQVUsRUFBRSxHQUFlO1FBQ3pDLGlDQUFpQztRQUNqQyw0QkFBNEI7UUFDNUIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQztZQUN6QixLQUFLLE1BQU0sS0FBSyxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO2dCQUMxQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDaEQsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0NBQ0YifQ==
|
|
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@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/aop-runtime": "4.0.0-beta.
|
|
47
|
-
"@eggjs/
|
|
48
|
-
"@eggjs/
|
|
49
|
-
"@eggjs/
|
|
50
|
-
},
|
|
51
|
-
"peerDependencies": {
|
|
52
|
-
"@eggjs/tegg-plugin": "4.0.0-beta.34",
|
|
53
|
-
"egg": "4.1.0-beta.34"
|
|
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.
|
|
57
|
-
"tsdown": "0.15.11",
|
|
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-config": "4.0.0-beta.
|
|
64
|
-
"egg": "4.1.0-beta.34"
|
|
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
|
}
|