@eggjs/tegg-aop-runtime 4.0.0-beta.4 → 4.0.0-beta.6
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 +13 -1
- package/dist/AspectExecutor.d.ts +27 -0
- package/dist/AspectExecutor.js +113 -0
- package/dist/CrossCutGraphHook.d.ts +6 -0
- package/dist/CrossCutGraphHook.js +38 -0
- package/dist/EggObjectAopHook.d.ts +10 -0
- package/dist/EggObjectAopHook.js +54 -0
- package/dist/EggPrototypeCrossCutHook.d.ts +11 -0
- package/dist/EggPrototypeCrossCutHook.js +15 -0
- package/dist/LoadUnitAopHook.d.ts +11 -0
- package/dist/LoadUnitAopHook.js +32 -0
- package/dist/PointCutGraphHook.d.ts +6 -0
- package/dist/PointCutGraphHook.js +37 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +8 -0
- package/package.json +29 -31
- package/src/AspectExecutor.d.ts +0 -24
- package/src/AspectExecutor.js +0 -117
- package/src/CrossCutGraphHook.d.ts +0 -2
- package/src/CrossCutGraphHook.js +0 -53
- package/src/EggObjectAopHook.d.ts +0 -6
- package/src/EggObjectAopHook.js +0 -59
- package/src/EggPrototypeCrossCutHook.d.ts +0 -7
- package/src/EggPrototypeCrossCutHook.js +0 -13
- package/src/LoadUnitAopHook.d.ts +0 -7
- package/src/LoadUnitAopHook.js +0 -37
- package/src/PointCutGraphHook.d.ts +0 -2
- package/src/PointCutGraphHook.js +0 -41
- package/src/index.d.ts +0 -6
- package/src/index.js +0 -7
package/README.md
CHANGED
|
@@ -1,4 +1,16 @@
|
|
|
1
|
-
#
|
|
1
|
+
# `@eggjs/tegg-aop-runtime`
|
|
2
|
+
|
|
3
|
+
[![NPM version][npm-image]][npm-url]
|
|
4
|
+
[![Known Vulnerabilities][snyk-image]][snyk-url]
|
|
5
|
+
[![npm download][download-image]][download-url]
|
|
6
|
+
[](https://nodejs.org/en/download/)
|
|
7
|
+
|
|
8
|
+
[npm-image]: https://img.shields.io/npm/v/@eggjs/tegg-aop-runtime.svg?style=flat-square
|
|
9
|
+
[npm-url]: https://npmjs.org/package/@eggjs/tegg-aop-runtime
|
|
10
|
+
[snyk-image]: https://snyk.io/test/npm/@eggjs/tegg-aop-runtime/badge.svg?style=flat-square
|
|
11
|
+
[snyk-url]: https://snyk.io/test/npm/@eggjs/tegg-aop-runtime
|
|
12
|
+
[download-image]: https://img.shields.io/npm/dm/@eggjs/tegg-aop-runtime.svg?style=flat-square
|
|
13
|
+
[download-url]: https://npmjs.org/package/@eggjs/tegg-aop-runtime
|
|
2
14
|
|
|
3
15
|
## Usage
|
|
4
16
|
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { AdviceContext, AspectAdvice, IAdvice } from "@eggjs/tegg-types";
|
|
2
|
+
|
|
3
|
+
//#region src/AspectExecutor.d.ts
|
|
4
|
+
declare class InternalAdviceContext<T = Record<string, IAdvice>> {
|
|
5
|
+
private readonly state;
|
|
6
|
+
that: T;
|
|
7
|
+
method: PropertyKey;
|
|
8
|
+
args: any[];
|
|
9
|
+
constructor(that: T, method: PropertyKey, args: any[]);
|
|
10
|
+
get(key: PropertyKey): any;
|
|
11
|
+
set(key: PropertyKey, value: any): this;
|
|
12
|
+
createCallContext(adviceParams?: any): AdviceContext<T>;
|
|
13
|
+
}
|
|
14
|
+
declare class AspectExecutor {
|
|
15
|
+
obj: object;
|
|
16
|
+
method: PropertyKey;
|
|
17
|
+
aspectAdviceList: readonly AspectAdvice[];
|
|
18
|
+
constructor(obj: object, method: PropertyKey, aspectAdviceList: readonly AspectAdvice[]);
|
|
19
|
+
execute(...args: any[]): Promise<void>;
|
|
20
|
+
beforeCall(ctx: InternalAdviceContext): Promise<void>;
|
|
21
|
+
afterReturn(ctx: InternalAdviceContext, result: any): Promise<void>;
|
|
22
|
+
afterThrow(ctx: InternalAdviceContext, error: Error): Promise<void>;
|
|
23
|
+
afterFinally(ctx: InternalAdviceContext): Promise<void>;
|
|
24
|
+
doExecute(ctx: InternalAdviceContext): Promise<void>;
|
|
25
|
+
}
|
|
26
|
+
//#endregion
|
|
27
|
+
export { AspectExecutor };
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import compose from "koa-compose";
|
|
2
|
+
|
|
3
|
+
//#region src/AspectExecutor.ts
|
|
4
|
+
var InternalAdviceContext = class {
|
|
5
|
+
state;
|
|
6
|
+
that;
|
|
7
|
+
method;
|
|
8
|
+
args;
|
|
9
|
+
constructor(that, method, args) {
|
|
10
|
+
this.state = /* @__PURE__ */ new Map();
|
|
11
|
+
this.that = that;
|
|
12
|
+
this.method = method;
|
|
13
|
+
this.args = args;
|
|
14
|
+
}
|
|
15
|
+
get(key) {
|
|
16
|
+
return this.state.get(key);
|
|
17
|
+
}
|
|
18
|
+
set(key, value) {
|
|
19
|
+
this.state.set(key, value);
|
|
20
|
+
return this;
|
|
21
|
+
}
|
|
22
|
+
createCallContext(adviceParams) {
|
|
23
|
+
return Object.create(this, { adviceParams: { value: adviceParams } });
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
var AspectExecutor = class {
|
|
27
|
+
obj;
|
|
28
|
+
method;
|
|
29
|
+
aspectAdviceList;
|
|
30
|
+
constructor(obj, method, aspectAdviceList) {
|
|
31
|
+
this.obj = obj;
|
|
32
|
+
this.method = method;
|
|
33
|
+
this.aspectAdviceList = aspectAdviceList;
|
|
34
|
+
}
|
|
35
|
+
async execute(...args) {
|
|
36
|
+
const ctx = new InternalAdviceContext(this.obj, this.method, args);
|
|
37
|
+
await this.beforeCall(ctx);
|
|
38
|
+
try {
|
|
39
|
+
const result = await this.doExecute(ctx);
|
|
40
|
+
await this.afterReturn(ctx, result);
|
|
41
|
+
return result;
|
|
42
|
+
} catch (e) {
|
|
43
|
+
await this.afterThrow(ctx, e);
|
|
44
|
+
throw e;
|
|
45
|
+
} finally {
|
|
46
|
+
await this.afterFinally(ctx);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
async beforeCall(ctx) {
|
|
50
|
+
for (const aspectAdvice of this.aspectAdviceList) {
|
|
51
|
+
const advice = ctx.that[aspectAdvice.name];
|
|
52
|
+
if (advice.beforeCall) {
|
|
53
|
+
/**
|
|
54
|
+
* 这里...写法使传入的参数变成了一个新的对象
|
|
55
|
+
* 因此beforeCall里面如果修改了ctx.args
|
|
56
|
+
* 最新的args是不会在方法里生效的
|
|
57
|
+
* 先保证args可以生效
|
|
58
|
+
* 不改动其余地方
|
|
59
|
+
*/
|
|
60
|
+
const fnCtx = ctx.createCallContext(aspectAdvice.adviceParams);
|
|
61
|
+
await advice.beforeCall(fnCtx);
|
|
62
|
+
ctx.args = fnCtx.args;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
async afterReturn(ctx, result) {
|
|
67
|
+
for (const aspectAdvice of this.aspectAdviceList) {
|
|
68
|
+
const advice = ctx.that[aspectAdvice.name];
|
|
69
|
+
if (advice.afterReturn) {
|
|
70
|
+
const fnCtx = ctx.createCallContext(aspectAdvice.adviceParams);
|
|
71
|
+
await advice.afterReturn(fnCtx, result);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
async afterThrow(ctx, error) {
|
|
76
|
+
for (const aspectAdvice of this.aspectAdviceList) {
|
|
77
|
+
const advice = ctx.that[aspectAdvice.name];
|
|
78
|
+
if (advice.afterThrow) {
|
|
79
|
+
const fnCtx = ctx.createCallContext(aspectAdvice.adviceParams);
|
|
80
|
+
await advice.afterThrow(fnCtx, error);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
async afterFinally(ctx) {
|
|
85
|
+
for (const aspectAdvice of this.aspectAdviceList) {
|
|
86
|
+
const advice = ctx.that[aspectAdvice.name];
|
|
87
|
+
if (advice.afterFinally) {
|
|
88
|
+
const fnCtx = ctx.createCallContext(aspectAdvice.adviceParams);
|
|
89
|
+
await advice.afterFinally(fnCtx);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
async doExecute(ctx) {
|
|
94
|
+
const lastCall = () => {
|
|
95
|
+
const originMethod = Object.getPrototypeOf(this.obj)[this.method];
|
|
96
|
+
return Reflect.apply(originMethod, ctx.that, ctx.args);
|
|
97
|
+
};
|
|
98
|
+
const functions = [];
|
|
99
|
+
for (const aspectAdvice of this.aspectAdviceList) {
|
|
100
|
+
const advice = ctx.that[aspectAdvice.name];
|
|
101
|
+
const fn = advice.around;
|
|
102
|
+
if (fn) functions.push(async (ctx$1, next) => {
|
|
103
|
+
const fnCtx = ctx$1.createCallContext(aspectAdvice.adviceParams);
|
|
104
|
+
return await fn.call(advice, fnCtx, next);
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
functions.push(lastCall);
|
|
108
|
+
return compose(functions)(ctx);
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
|
|
112
|
+
//#endregion
|
|
113
|
+
export { AspectExecutor };
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { AspectMetaBuilder, CrosscutInfoUtil } from "@eggjs/aop-decorator";
|
|
2
|
+
import "@eggjs/tegg-common-util";
|
|
3
|
+
import { ClassProtoDescriptor, GlobalGraph } from "@eggjs/tegg-metadata";
|
|
4
|
+
|
|
5
|
+
//#region src/CrossCutGraphHook.ts
|
|
6
|
+
function crossCutGraphHook(globalGraph) {
|
|
7
|
+
for (const moduleNode of globalGraph.moduleGraph.nodes.values()) for (const crossCutProtoNode of moduleNode.val.protos) {
|
|
8
|
+
const protoNodes = findCrossCuttedClazz(globalGraph, crossCutProtoNode);
|
|
9
|
+
if (!protoNodes) continue;
|
|
10
|
+
for (const crossCuttedProtoNode of protoNodes) {
|
|
11
|
+
const crossCuttedModuleNode = globalGraph.findModuleNode(crossCuttedProtoNode.val.proto.instanceModuleName);
|
|
12
|
+
if (!crossCuttedModuleNode) continue;
|
|
13
|
+
globalGraph.addInject(crossCuttedModuleNode, crossCuttedProtoNode, crossCutProtoNode, crossCutProtoNode.val.proto.name);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
function findCrossCuttedClazz(globalGraph, protoNode) {
|
|
18
|
+
const proto = protoNode.val.proto;
|
|
19
|
+
if (!ClassProtoDescriptor.isClassProtoDescriptor(proto)) return;
|
|
20
|
+
if (!CrosscutInfoUtil.isCrosscutAdvice(proto.clazz)) return;
|
|
21
|
+
const crosscutInfoList = CrosscutInfoUtil.getCrosscutInfoList(proto.clazz);
|
|
22
|
+
const result = [];
|
|
23
|
+
crosscut: for (const crosscutInfo of crosscutInfoList) for (const protoNode$1 of globalGraph.protoGraph.nodes.values()) if (checkClazzMatchCrossCut(protoNode$1, crosscutInfo)) {
|
|
24
|
+
result.push(protoNode$1);
|
|
25
|
+
break crosscut;
|
|
26
|
+
}
|
|
27
|
+
return result;
|
|
28
|
+
}
|
|
29
|
+
function checkClazzMatchCrossCut(protoNode, crosscutInfo) {
|
|
30
|
+
const proto = protoNode.val.proto;
|
|
31
|
+
if (!ClassProtoDescriptor.isClassProtoDescriptor(proto)) return;
|
|
32
|
+
const allMethods = AspectMetaBuilder.getAllMethods(proto.clazz);
|
|
33
|
+
for (const method of allMethods) if (crosscutInfo.pointcutInfo.match(proto.clazz, method)) return true;
|
|
34
|
+
return false;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
//#endregion
|
|
38
|
+
export { crossCutGraphHook };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { EggObject, EggObjectLifeCycleContext, LifecycleHook } from "@eggjs/tegg-types";
|
|
2
|
+
|
|
3
|
+
//#region src/EggObjectAopHook.d.ts
|
|
4
|
+
declare class EggObjectAopHook implements LifecycleHook<EggObjectLifeCycleContext, EggObject> {
|
|
5
|
+
private hijackMethods;
|
|
6
|
+
private injectAdvice;
|
|
7
|
+
postCreate(_: EggObjectLifeCycleContext, eggObject: EggObject): Promise<void>;
|
|
8
|
+
}
|
|
9
|
+
//#endregion
|
|
10
|
+
export { EggObjectAopHook };
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { AspectExecutor } from "./AspectExecutor.js";
|
|
2
|
+
import "@eggjs/aop-decorator";
|
|
3
|
+
import assert from "node:assert";
|
|
4
|
+
import { ASPECT_LIST, InjectType } from "@eggjs/tegg-types";
|
|
5
|
+
import { PrototypeUtil } from "@eggjs/core-decorator";
|
|
6
|
+
import { EggContainerFactory } from "@eggjs/tegg-runtime";
|
|
7
|
+
|
|
8
|
+
//#region src/EggObjectAopHook.ts
|
|
9
|
+
var EggObjectAopHook = class {
|
|
10
|
+
hijackMethods(obj, aspectList) {
|
|
11
|
+
for (const aspect of aspectList) {
|
|
12
|
+
const newExecutor = new AspectExecutor(obj, aspect.method, aspect.adviceList);
|
|
13
|
+
obj[aspect.method] = newExecutor.execute.bind(newExecutor);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
injectAdvice(eggObject, obj, aspectList) {
|
|
17
|
+
if (eggObject.proto.getMetaData(PrototypeUtil.INJECT_TYPE) !== InjectType.CONSTRUCTOR) return;
|
|
18
|
+
for (const aspect of aspectList) for (const advice of aspect.adviceList) {
|
|
19
|
+
const injectObject = eggObject.proto.injectObjects.find((t) => t.objName === advice.name);
|
|
20
|
+
assert(injectObject, `not found inject advice ${advice.name}`);
|
|
21
|
+
const adviceObj = EggContainerFactory.getEggObject(injectObject.proto, advice.name);
|
|
22
|
+
Object.defineProperty(obj, advice.name, {
|
|
23
|
+
value: adviceObj.obj,
|
|
24
|
+
enumerable: false
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
async postCreate(_, eggObject) {
|
|
29
|
+
const aspectList = eggObject.proto.getMetaData(ASPECT_LIST);
|
|
30
|
+
if (!aspectList || !aspectList.length) return;
|
|
31
|
+
const propertyDesc = eggObject.constructor && Reflect.getOwnPropertyDescriptor(eggObject.constructor.prototype, "obj");
|
|
32
|
+
if (propertyDesc?.get) {
|
|
33
|
+
let obj;
|
|
34
|
+
const self = this;
|
|
35
|
+
Object.defineProperty(eggObject, "obj", {
|
|
36
|
+
...propertyDesc,
|
|
37
|
+
get() {
|
|
38
|
+
if (!obj) {
|
|
39
|
+
obj = Reflect.apply(propertyDesc.get, eggObject, []);
|
|
40
|
+
self.hijackMethods(obj, aspectList);
|
|
41
|
+
self.injectAdvice(eggObject, obj, aspectList);
|
|
42
|
+
}
|
|
43
|
+
return obj;
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
} else {
|
|
47
|
+
this.hijackMethods(eggObject.obj, aspectList);
|
|
48
|
+
this.injectAdvice(eggObject, eggObject.obj, aspectList);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
//#endregion
|
|
54
|
+
export { EggObjectAopHook };
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { CrosscutAdviceFactory } from "@eggjs/aop-decorator";
|
|
2
|
+
import { EggPrototype, EggPrototypeLifecycleContext, LifecycleHook } from "@eggjs/tegg-types";
|
|
3
|
+
|
|
4
|
+
//#region src/EggPrototypeCrossCutHook.d.ts
|
|
5
|
+
declare class EggPrototypeCrossCutHook implements LifecycleHook<EggPrototypeLifecycleContext, EggPrototype> {
|
|
6
|
+
private readonly crosscutAdviceFactory;
|
|
7
|
+
constructor(crosscutAdviceFactory: CrosscutAdviceFactory);
|
|
8
|
+
preCreate(ctx: EggPrototypeLifecycleContext): Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
//#endregion
|
|
11
|
+
export { EggPrototypeCrossCutHook };
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { CrosscutAdviceFactory, CrosscutInfoUtil } from "@eggjs/aop-decorator";
|
|
2
|
+
|
|
3
|
+
//#region src/EggPrototypeCrossCutHook.ts
|
|
4
|
+
var EggPrototypeCrossCutHook = class {
|
|
5
|
+
crosscutAdviceFactory;
|
|
6
|
+
constructor(crosscutAdviceFactory) {
|
|
7
|
+
this.crosscutAdviceFactory = crosscutAdviceFactory;
|
|
8
|
+
}
|
|
9
|
+
async preCreate(ctx) {
|
|
10
|
+
if (CrosscutInfoUtil.isCrosscutAdvice(ctx.clazz)) this.crosscutAdviceFactory.registerCrossAdviceClazz(ctx.clazz);
|
|
11
|
+
}
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
//#endregion
|
|
15
|
+
export { EggPrototypeCrossCutHook };
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { CrosscutAdviceFactory } from "@eggjs/aop-decorator";
|
|
2
|
+
import { LifecycleHook, LoadUnit, LoadUnitLifecycleContext } from "@eggjs/tegg-types";
|
|
3
|
+
|
|
4
|
+
//#region src/LoadUnitAopHook.d.ts
|
|
5
|
+
declare class LoadUnitAopHook implements LifecycleHook<LoadUnitLifecycleContext, LoadUnit> {
|
|
6
|
+
private readonly crosscutAdviceFactory;
|
|
7
|
+
constructor(crosscutAdviceFactory: CrosscutAdviceFactory);
|
|
8
|
+
postCreate(_: LoadUnitLifecycleContext, loadUnit: LoadUnit): Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
//#endregion
|
|
11
|
+
export { LoadUnitAopHook };
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { AspectInfoUtil, AspectMetaBuilder, CrosscutAdviceFactory } from "@eggjs/aop-decorator";
|
|
2
|
+
import { TeggError } from "@eggjs/tegg-metadata";
|
|
3
|
+
import { PrototypeUtil } from "@eggjs/core-decorator";
|
|
4
|
+
|
|
5
|
+
//#region src/LoadUnitAopHook.ts
|
|
6
|
+
var LoadUnitAopHook = class {
|
|
7
|
+
crosscutAdviceFactory;
|
|
8
|
+
constructor(crosscutAdviceFactory) {
|
|
9
|
+
this.crosscutAdviceFactory = crosscutAdviceFactory;
|
|
10
|
+
}
|
|
11
|
+
async postCreate(_, loadUnit) {
|
|
12
|
+
for (const proto of loadUnit.iterateEggPrototype()) {
|
|
13
|
+
const clazz = proto.clazz;
|
|
14
|
+
if (!clazz) continue;
|
|
15
|
+
const aspectList = new AspectMetaBuilder(clazz, { crosscutAdviceFactory: this.crosscutAdviceFactory }).build();
|
|
16
|
+
AspectInfoUtil.setAspectList(aspectList, clazz);
|
|
17
|
+
for (const aspect of aspectList) for (const advice of aspect.adviceList) {
|
|
18
|
+
const adviceProto = PrototypeUtil.getClazzProto(advice.clazz);
|
|
19
|
+
if (!adviceProto) throw TeggError.create(`Aop Advice(${advice.clazz.name}) not found in loadUnits`, "advice_not_found");
|
|
20
|
+
proto.injectObjects.push({
|
|
21
|
+
refName: advice.name,
|
|
22
|
+
objName: advice.name,
|
|
23
|
+
qualifiers: [],
|
|
24
|
+
proto: adviceProto
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
//#endregion
|
|
32
|
+
export { LoadUnitAopHook };
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { AspectMetaBuilder, PointcutAdviceInfoUtil } from "@eggjs/aop-decorator";
|
|
2
|
+
import "@eggjs/tegg-common-util";
|
|
3
|
+
import { ClassProtoDescriptor, GlobalGraph } from "@eggjs/tegg-metadata";
|
|
4
|
+
import assert from "node:assert";
|
|
5
|
+
import { PrototypeUtil, QualifierUtil } from "@eggjs/core-decorator";
|
|
6
|
+
|
|
7
|
+
//#region src/PointCutGraphHook.ts
|
|
8
|
+
function pointCutGraphHook(globalGraph) {
|
|
9
|
+
for (const moduleNode of globalGraph.moduleGraph.nodes.values()) for (const pointCuttedProtoNode of moduleNode.val.protos) {
|
|
10
|
+
const pointCutAdviceProtoList = findPointCutAdvice(globalGraph, pointCuttedProtoNode);
|
|
11
|
+
if (!pointCutAdviceProtoList) continue;
|
|
12
|
+
for (const pointCutAdviceProto of pointCutAdviceProtoList) globalGraph.addInject(moduleNode, pointCuttedProtoNode, pointCutAdviceProto, pointCutAdviceProto.val.proto.name);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
function findPointCutAdvice(globalGraph, protoNode) {
|
|
16
|
+
const proto = protoNode.val.proto;
|
|
17
|
+
if (!ClassProtoDescriptor.isClassProtoDescriptor(proto)) return;
|
|
18
|
+
const result = /* @__PURE__ */ new Set();
|
|
19
|
+
const allMethods = AspectMetaBuilder.getAllMethods(proto.clazz);
|
|
20
|
+
for (const method of allMethods) {
|
|
21
|
+
const adviceInfoList = PointcutAdviceInfoUtil.getPointcutAdviceInfoList(proto.clazz, method);
|
|
22
|
+
for (const { clazz } of adviceInfoList) {
|
|
23
|
+
const property = PrototypeUtil.getProperty(clazz);
|
|
24
|
+
assert(property, "not found property");
|
|
25
|
+
const injectProto = globalGraph.findDependencyProtoNode(protoNode.val.proto, {
|
|
26
|
+
objName: property.name,
|
|
27
|
+
refName: property.name,
|
|
28
|
+
qualifiers: QualifierUtil.mergeQualifiers(property?.qualifiers ?? [], QualifierUtil.getProtoQualifiers(clazz))
|
|
29
|
+
});
|
|
30
|
+
if (injectProto) result.add(injectProto);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
return Array.from(result);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
//#endregion
|
|
37
|
+
export { pointCutGraphHook };
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { AspectExecutor } from "./AspectExecutor.js";
|
|
2
|
+
import { crossCutGraphHook } from "./CrossCutGraphHook.js";
|
|
3
|
+
import { EggObjectAopHook } from "./EggObjectAopHook.js";
|
|
4
|
+
import { EggPrototypeCrossCutHook } from "./EggPrototypeCrossCutHook.js";
|
|
5
|
+
import { LoadUnitAopHook } from "./LoadUnitAopHook.js";
|
|
6
|
+
import { pointCutGraphHook } from "./PointCutGraphHook.js";
|
|
7
|
+
export { AspectExecutor, EggObjectAopHook, EggPrototypeCrossCutHook, LoadUnitAopHook, crossCutGraphHook, pointCutGraphHook };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { AspectExecutor } from "./AspectExecutor.js";
|
|
2
|
+
import { crossCutGraphHook } from "./CrossCutGraphHook.js";
|
|
3
|
+
import { EggObjectAopHook } from "./EggObjectAopHook.js";
|
|
4
|
+
import { EggPrototypeCrossCutHook } from "./EggPrototypeCrossCutHook.js";
|
|
5
|
+
import { LoadUnitAopHook } from "./LoadUnitAopHook.js";
|
|
6
|
+
import { pointCutGraphHook } from "./PointCutGraphHook.js";
|
|
7
|
+
|
|
8
|
+
export { AspectExecutor, EggObjectAopHook, EggPrototypeCrossCutHook, LoadUnitAopHook, crossCutGraphHook, pointCutGraphHook };
|
package/package.json
CHANGED
|
@@ -1,20 +1,17 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@eggjs/tegg-aop-runtime",
|
|
3
|
-
"version": "4.0.0-beta.
|
|
3
|
+
"version": "4.0.0-beta.6",
|
|
4
4
|
"description": "tegg aop",
|
|
5
5
|
"eggModule": {
|
|
6
6
|
"name": "teggAopRuntime"
|
|
7
7
|
},
|
|
8
8
|
"type": "module",
|
|
9
9
|
"exports": {
|
|
10
|
-
".":
|
|
11
|
-
|
|
12
|
-
"default": "./src/index.js"
|
|
13
|
-
}
|
|
10
|
+
".": "./dist/index.js",
|
|
11
|
+
"./package.json": "./package.json"
|
|
14
12
|
},
|
|
15
13
|
"files": [
|
|
16
|
-
"
|
|
17
|
-
"src/**/*.d.ts"
|
|
14
|
+
"dist"
|
|
18
15
|
],
|
|
19
16
|
"keywords": [
|
|
20
17
|
"egg",
|
|
@@ -23,15 +20,9 @@
|
|
|
23
20
|
"tegg",
|
|
24
21
|
"aop"
|
|
25
22
|
],
|
|
26
|
-
"scripts": {
|
|
27
|
-
"clean": "tsc -b --clean",
|
|
28
|
-
"tsc": "npm run clean && tsc -p ./tsconfig.json",
|
|
29
|
-
"tsc:pub": "npm run tsc",
|
|
30
|
-
"prepublishOnly": "npm run tsc"
|
|
31
|
-
},
|
|
32
23
|
"author": "killagu <killa123@126.com>",
|
|
33
24
|
"license": "MIT",
|
|
34
|
-
"homepage": "https://github.com/eggjs/tegg",
|
|
25
|
+
"homepage": "https://github.com/eggjs/tegg/tree/next/core/aop-runtime",
|
|
35
26
|
"bugs": {
|
|
36
27
|
"url": "https://github.com/eggjs/tegg/issues"
|
|
37
28
|
},
|
|
@@ -41,28 +32,35 @@
|
|
|
41
32
|
"directory": "core/aop-runtime"
|
|
42
33
|
},
|
|
43
34
|
"engines": {
|
|
44
|
-
"node": ">=
|
|
35
|
+
"node": ">=22.18.0"
|
|
45
36
|
},
|
|
46
37
|
"publishConfig": {
|
|
47
38
|
"access": "public"
|
|
48
39
|
},
|
|
49
40
|
"dependencies": {
|
|
50
|
-
"
|
|
51
|
-
"@eggjs/
|
|
52
|
-
"@eggjs/
|
|
53
|
-
"@eggjs/tegg-
|
|
54
|
-
"@eggjs/tegg-metadata": "
|
|
55
|
-
"@eggjs/tegg-runtime": "
|
|
56
|
-
"@eggjs/tegg-types": "
|
|
57
|
-
"koa-compose": "^4.1.0"
|
|
41
|
+
"koa-compose": "^4.1.0",
|
|
42
|
+
"@eggjs/aop-decorator": "4.0.0-beta.6",
|
|
43
|
+
"@eggjs/core-decorator": "4.0.0-beta.6",
|
|
44
|
+
"@eggjs/tegg-common-util": "4.0.0-beta.6",
|
|
45
|
+
"@eggjs/tegg-metadata": "4.0.0-beta.6",
|
|
46
|
+
"@eggjs/tegg-runtime": "4.0.0-beta.6",
|
|
47
|
+
"@eggjs/tegg-types": "4.0.0-beta.6"
|
|
58
48
|
},
|
|
59
49
|
"devDependencies": {
|
|
60
|
-
"@
|
|
61
|
-
"@
|
|
62
|
-
"
|
|
63
|
-
"
|
|
64
|
-
"
|
|
65
|
-
"
|
|
50
|
+
"@types/koa-compose": "^3.2.5",
|
|
51
|
+
"@types/node": "^22.10.5",
|
|
52
|
+
"typescript": "^5.9.3",
|
|
53
|
+
"tsdown": "^0.15.6",
|
|
54
|
+
"unplugin-unused": "^0.5.3",
|
|
55
|
+
"@eggjs/module-test-util": "4.0.0-beta.4",
|
|
56
|
+
"@eggjs/tegg-loader": "4.0.0-beta.6"
|
|
66
57
|
},
|
|
67
|
-
"
|
|
68
|
-
|
|
58
|
+
"main": "./dist/index.js",
|
|
59
|
+
"module": "./dist/index.js",
|
|
60
|
+
"types": "./dist/index.d.ts",
|
|
61
|
+
"scripts": {
|
|
62
|
+
"clean": "rimraf dist",
|
|
63
|
+
"build": "tsdown",
|
|
64
|
+
"typecheck": "tsc --noEmit"
|
|
65
|
+
}
|
|
66
|
+
}
|
package/src/AspectExecutor.d.ts
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import type { AdviceContext, AspectAdvice, IAdvice } from '@eggjs/tegg-types';
|
|
2
|
-
declare class InternalAdviceContext<T = Record<string, IAdvice>> {
|
|
3
|
-
private readonly state;
|
|
4
|
-
that: T;
|
|
5
|
-
method: PropertyKey;
|
|
6
|
-
args: any[];
|
|
7
|
-
constructor(that: T, method: PropertyKey, args: any[]);
|
|
8
|
-
get(key: PropertyKey): any;
|
|
9
|
-
set(key: PropertyKey, value: any): this;
|
|
10
|
-
createCallContext(adviceParams?: any): AdviceContext<T>;
|
|
11
|
-
}
|
|
12
|
-
export declare class AspectExecutor {
|
|
13
|
-
obj: object;
|
|
14
|
-
method: PropertyKey;
|
|
15
|
-
aspectAdviceList: readonly AspectAdvice[];
|
|
16
|
-
constructor(obj: object, method: PropertyKey, aspectAdviceList: readonly AspectAdvice[]);
|
|
17
|
-
execute(...args: any[]): Promise<void>;
|
|
18
|
-
beforeCall(ctx: InternalAdviceContext): Promise<void>;
|
|
19
|
-
afterReturn(ctx: InternalAdviceContext, result: any): Promise<void>;
|
|
20
|
-
afterThrow(ctx: InternalAdviceContext, error: Error): Promise<void>;
|
|
21
|
-
afterFinally(ctx: InternalAdviceContext): Promise<void>;
|
|
22
|
-
doExecute(ctx: InternalAdviceContext): Promise<void>;
|
|
23
|
-
}
|
|
24
|
-
export {};
|
package/src/AspectExecutor.js
DELETED
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
import compose from 'koa-compose';
|
|
2
|
-
class InternalAdviceContext {
|
|
3
|
-
state;
|
|
4
|
-
that;
|
|
5
|
-
method;
|
|
6
|
-
args;
|
|
7
|
-
constructor(that, method, args) {
|
|
8
|
-
this.state = new Map();
|
|
9
|
-
this.that = that;
|
|
10
|
-
this.method = method;
|
|
11
|
-
this.args = args;
|
|
12
|
-
}
|
|
13
|
-
get(key) {
|
|
14
|
-
return this.state.get(key);
|
|
15
|
-
}
|
|
16
|
-
set(key, value) {
|
|
17
|
-
this.state.set(key, value);
|
|
18
|
-
return this;
|
|
19
|
-
}
|
|
20
|
-
createCallContext(adviceParams) {
|
|
21
|
-
return Object.create(this, {
|
|
22
|
-
adviceParams: {
|
|
23
|
-
value: adviceParams,
|
|
24
|
-
},
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
export class AspectExecutor {
|
|
29
|
-
obj;
|
|
30
|
-
method;
|
|
31
|
-
aspectAdviceList;
|
|
32
|
-
constructor(obj, method, aspectAdviceList) {
|
|
33
|
-
this.obj = obj;
|
|
34
|
-
this.method = method;
|
|
35
|
-
this.aspectAdviceList = aspectAdviceList;
|
|
36
|
-
}
|
|
37
|
-
async execute(...args) {
|
|
38
|
-
const ctx = new InternalAdviceContext(this.obj, this.method, args);
|
|
39
|
-
await this.beforeCall(ctx);
|
|
40
|
-
try {
|
|
41
|
-
const result = await this.doExecute(ctx);
|
|
42
|
-
await this.afterReturn(ctx, result);
|
|
43
|
-
return result;
|
|
44
|
-
}
|
|
45
|
-
catch (e) {
|
|
46
|
-
await this.afterThrow(ctx, e);
|
|
47
|
-
throw e;
|
|
48
|
-
}
|
|
49
|
-
finally {
|
|
50
|
-
await this.afterFinally(ctx);
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
async beforeCall(ctx) {
|
|
54
|
-
for (const aspectAdvice of this.aspectAdviceList) {
|
|
55
|
-
const advice = ctx.that[aspectAdvice.name];
|
|
56
|
-
if (advice.beforeCall) {
|
|
57
|
-
/**
|
|
58
|
-
* 这里...写法使传入的参数变成了一个新的对象
|
|
59
|
-
* 因此beforeCall里面如果修改了ctx.args
|
|
60
|
-
* 最新的args是不会在方法里生效的
|
|
61
|
-
* 先保证args可以生效
|
|
62
|
-
* 不改动其余地方
|
|
63
|
-
*/
|
|
64
|
-
const fnCtx = ctx.createCallContext(aspectAdvice.adviceParams);
|
|
65
|
-
await advice.beforeCall(fnCtx);
|
|
66
|
-
ctx.args = fnCtx.args;
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
async afterReturn(ctx, result) {
|
|
71
|
-
for (const aspectAdvice of this.aspectAdviceList) {
|
|
72
|
-
const advice = ctx.that[aspectAdvice.name];
|
|
73
|
-
if (advice.afterReturn) {
|
|
74
|
-
const fnCtx = ctx.createCallContext(aspectAdvice.adviceParams);
|
|
75
|
-
await advice.afterReturn(fnCtx, result);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
async afterThrow(ctx, error) {
|
|
80
|
-
for (const aspectAdvice of this.aspectAdviceList) {
|
|
81
|
-
const advice = ctx.that[aspectAdvice.name];
|
|
82
|
-
if (advice.afterThrow) {
|
|
83
|
-
const fnCtx = ctx.createCallContext(aspectAdvice.adviceParams);
|
|
84
|
-
await advice.afterThrow(fnCtx, error);
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
async afterFinally(ctx) {
|
|
89
|
-
for (const aspectAdvice of this.aspectAdviceList) {
|
|
90
|
-
const advice = ctx.that[aspectAdvice.name];
|
|
91
|
-
if (advice.afterFinally) {
|
|
92
|
-
const fnCtx = ctx.createCallContext(aspectAdvice.adviceParams);
|
|
93
|
-
await advice.afterFinally(fnCtx);
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
async doExecute(ctx) {
|
|
98
|
-
const lastCall = () => {
|
|
99
|
-
const originMethod = Object.getPrototypeOf(this.obj)[this.method];
|
|
100
|
-
return Reflect.apply(originMethod, ctx.that, ctx.args);
|
|
101
|
-
};
|
|
102
|
-
const functions = [];
|
|
103
|
-
for (const aspectAdvice of this.aspectAdviceList) {
|
|
104
|
-
const advice = ctx.that[aspectAdvice.name];
|
|
105
|
-
const fn = advice.around;
|
|
106
|
-
if (fn) {
|
|
107
|
-
functions.push(async (ctx, next) => {
|
|
108
|
-
const fnCtx = ctx.createCallContext(aspectAdvice.adviceParams);
|
|
109
|
-
return await fn.call(advice, fnCtx, next);
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
functions.push(lastCall);
|
|
114
|
-
return compose(functions)(ctx);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXNwZWN0RXhlY3V0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJBc3BlY3RFeGVjdXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLE9BQU8sTUFBTSxhQUFhLENBQUM7QUFHbEMsTUFBTSxxQkFBcUI7SUFDUixLQUFLLENBQXdCO0lBQzlDLElBQUksQ0FBSTtJQUNSLE1BQU0sQ0FBYztJQUNwQixJQUFJLENBQVE7SUFFWixZQUNFLElBQU8sRUFDUCxNQUFtQixFQUNuQixJQUFXO1FBRVgsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFFRCxHQUFHLENBQUMsR0FBZ0I7UUFDbEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBRUQsR0FBRyxDQUFDLEdBQWdCLEVBQUUsS0FBVTtRQUM5QixJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDM0IsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsaUJBQWlCLENBQUMsWUFBa0I7UUFDbEMsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRTtZQUN6QixZQUFZLEVBQUU7Z0JBQ1osS0FBSyxFQUFFLFlBQVk7YUFDcEI7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sY0FBYztJQUN6QixHQUFHLENBQVM7SUFDWixNQUFNLENBQWM7SUFDcEIsZ0JBQWdCLENBQTBCO0lBRTFDLFlBQVksR0FBVyxFQUFFLE1BQW1CLEVBQUUsZ0JBQXlDO1FBQ3JGLElBQUksQ0FBQyxHQUFH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
|
package/src/CrossCutGraphHook.js
DELETED
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import { AspectMetaBuilder, CrosscutInfoUtil } from '@eggjs/aop-decorator';
|
|
2
|
-
import { ClassProtoDescriptor, } from '@eggjs/tegg-metadata';
|
|
3
|
-
export function crossCutGraphHook(globalGraph) {
|
|
4
|
-
for (const moduleNode of globalGraph.moduleGraph.nodes.values()) {
|
|
5
|
-
for (const crossCutProtoNode of moduleNode.val.protos) {
|
|
6
|
-
const protoNodes = findCrossCuttedClazz(globalGraph, crossCutProtoNode);
|
|
7
|
-
if (!protoNodes)
|
|
8
|
-
continue;
|
|
9
|
-
for (const crossCuttedProtoNode of protoNodes) {
|
|
10
|
-
const crossCuttedModuleNode = globalGraph.findModuleNode(crossCuttedProtoNode.val.proto.instanceModuleName);
|
|
11
|
-
if (!crossCuttedModuleNode)
|
|
12
|
-
continue;
|
|
13
|
-
globalGraph.addInject(crossCuttedModuleNode, crossCuttedProtoNode, crossCutProtoNode, crossCutProtoNode.val.proto.name);
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
function findCrossCuttedClazz(globalGraph, protoNode) {
|
|
19
|
-
const proto = protoNode.val.proto;
|
|
20
|
-
if (!ClassProtoDescriptor.isClassProtoDescriptor(proto)) {
|
|
21
|
-
return;
|
|
22
|
-
}
|
|
23
|
-
if (!CrosscutInfoUtil.isCrosscutAdvice(proto.clazz)) {
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
const crosscutInfoList = CrosscutInfoUtil.getCrosscutInfoList(proto.clazz);
|
|
27
|
-
const result = [];
|
|
28
|
-
// eslint-disable-next-line no-labels
|
|
29
|
-
crosscut: for (const crosscutInfo of crosscutInfoList) {
|
|
30
|
-
for (const protoNode of globalGraph.protoGraph.nodes.values()) {
|
|
31
|
-
if (checkClazzMatchCrossCut(protoNode, crosscutInfo)) {
|
|
32
|
-
result.push(protoNode);
|
|
33
|
-
// eslint-disable-next-line no-labels
|
|
34
|
-
break crosscut;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
return result;
|
|
39
|
-
}
|
|
40
|
-
function checkClazzMatchCrossCut(protoNode, crosscutInfo) {
|
|
41
|
-
const proto = protoNode.val.proto;
|
|
42
|
-
if (!ClassProtoDescriptor.isClassProtoDescriptor(proto)) {
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
const allMethods = AspectMetaBuilder.getAllMethods(proto.clazz);
|
|
46
|
-
for (const method of allMethods) {
|
|
47
|
-
if (crosscutInfo.pointcutInfo.match(proto.clazz, method)) {
|
|
48
|
-
return true;
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
return false;
|
|
52
|
-
}
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ3Jvc3NDdXRHcmFwaEhvb2suanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJDcm9zc0N1dEdyYXBoSG9vay50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQWdCLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFekYsT0FBTyxFQUNMLG9CQUFvQixHQUlyQixNQUFNLHNCQUFzQixDQUFDO0FBRTlCLE1BQU0sVUFBVSxpQkFBaUIsQ0FBQyxXQUF3QjtJQUN4RCxLQUFLLE1BQU0sVUFBVSxJQUFJLFdBQVcsQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUM7UUFDaEUsS0FBSyxNQUFNLGlCQUFpQixJQUFJLFVBQVUsQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDdEQsTUFBTSxVQUFVLEdBQUcsb0JBQW9CLENBQUMsV0FBVyxFQUFFLGlCQUFpQixDQUFDLENBQUM7WUFDeEUsSUFBSSxDQUFDLFVBQVU7Z0JBQUUsU0FBUztZQUMxQixLQUFLLE1BQU0sb0JBQW9CLElBQUksVUFBVSxFQUFFLENBQUM7Z0JBQzlDLE1BQU0scUJBQXFCLEdBQUcsV0FBVyxDQUFDLGNBQWMsQ0FBQyxvQkFBb0IsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLGtCQUFrQixDQUFDLENBQUM7Z0JBQzVHLElBQUksQ0FBQyxxQkFBcUI7b0JBQUUsU0FBUztnQkFDckMsV0FBVyxDQUFDLFNBQVMsQ0FDbkIscUJBQXFCLEVBQ3JCLG9CQUFvQixFQUNwQixpQkFBaUIsRUFDakIsaUJBQWlCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUN0QyxDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7QUFDSCxDQUFDO0FBRUQsU0FBUyxvQkFBb0IsQ0FBQyxXQUF3QixFQUFFLFNBQW9EO0lBQzFHLE1BQU0sS0FBSyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDO0lBQ2xDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxzQkFBc0IsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQ3hELE9BQU87SUFDVCxDQUFDO0lBQ0QsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQ3BELE9BQU87SUFDVCxDQUFDO0lBQ0QsTUFBTSxnQkFBZ0IsR0FBRyxnQkFBZ0IsQ0FBQyxtQkFBbUIsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0UsTUFBTSxNQUFNLEdBQWdELEVBQUUsQ0FBQztJQUMvRCxxQ0FBcUM7SUFDckMsUUFBUSxFQUFFLEtBQUssTUFBTSxZQUFZLElBQUksZ0JBQWdCLEVBQUUsQ0FBQztRQUN0RCxLQUFLLE1BQU0sU0FBUyxJQUFJLFdBQVcsQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUM7WUFDOUQsSUFBSSx1QkFBdUIsQ0FBQyxTQUFTLEVBQUUsWUFBWSxDQUFDLEVBQUUsQ0FBQztnQkFDckQsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztnQkFDdkIscUNBQXFDO2dCQUNyQyxNQUFNLFFBQVEsQ0FBQztZQUNqQixDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFDRCxPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQsU0FBUyx1QkFBdUIsQ0FBQyxTQUErQixFQUFFLFlBQTBCO0lBQzFGLE1BQU0sS0FBSyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDO0lBQ2xDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxzQkFBc0IsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQ3hELE9BQU87SUFDVCxDQUFDO0lBQ0QsTUFBTSxVQUFVLEdBQUcsaUJBQWlCLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoRSxLQUFLLE1BQU0sTUFBTSxJQUFJLFVBQVUsRUFBRSxDQUFDO1FBQ2hDLElBQUksWUFBWSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQ3pELE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztJQUNILENBQUM7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNmLENBQUMifQ==
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import type { EggObject, EggObjectLifeCycleContext, LifecycleHook } from '@eggjs/tegg-types';
|
|
2
|
-
export declare class EggObjectAopHook implements LifecycleHook<EggObjectLifeCycleContext, EggObject> {
|
|
3
|
-
private hijackMethods;
|
|
4
|
-
private injectAdvice;
|
|
5
|
-
postCreate(_: EggObjectLifeCycleContext, eggObject: EggObject): Promise<void>;
|
|
6
|
-
}
|
package/src/EggObjectAopHook.js
DELETED
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import assert from 'node:assert';
|
|
2
|
-
import { ASPECT_LIST, InjectType } from '@eggjs/tegg-types';
|
|
3
|
-
import { PrototypeUtil } from '@eggjs/core-decorator';
|
|
4
|
-
import { EggContainerFactory } from '@eggjs/tegg-runtime';
|
|
5
|
-
import { AspectExecutor } from './AspectExecutor.js';
|
|
6
|
-
export class EggObjectAopHook {
|
|
7
|
-
hijackMethods(obj, aspectList) {
|
|
8
|
-
for (const aspect of aspectList) {
|
|
9
|
-
const newExecutor = new AspectExecutor(obj, aspect.method, aspect.adviceList);
|
|
10
|
-
obj[aspect.method] = newExecutor.execute.bind(newExecutor);
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
// constructor inject only paas obj to constructor
|
|
14
|
-
// should manually define obj to property
|
|
15
|
-
injectAdvice(eggObject, obj, aspectList) {
|
|
16
|
-
if (eggObject.proto.getMetaData(PrototypeUtil.INJECT_TYPE) !== InjectType.CONSTRUCTOR) {
|
|
17
|
-
return;
|
|
18
|
-
}
|
|
19
|
-
for (const aspect of aspectList) {
|
|
20
|
-
for (const advice of aspect.adviceList) {
|
|
21
|
-
const injectObject = eggObject.proto.injectObjects.find(t => t.objName === advice.name);
|
|
22
|
-
assert(injectObject, `not found inject advice ${advice.name}`);
|
|
23
|
-
const adviceObj = EggContainerFactory.getEggObject(injectObject.proto, advice.name);
|
|
24
|
-
Object.defineProperty(obj, advice.name, {
|
|
25
|
-
value: adviceObj.obj,
|
|
26
|
-
enumerable: false,
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
async postCreate(_, eggObject) {
|
|
32
|
-
const aspectList = eggObject.proto.getMetaData(ASPECT_LIST);
|
|
33
|
-
if (!aspectList || !aspectList.length)
|
|
34
|
-
return;
|
|
35
|
-
const propertyDesc = eggObject.constructor && Reflect.getOwnPropertyDescriptor(eggObject.constructor.prototype, 'obj');
|
|
36
|
-
// process the lazy getter
|
|
37
|
-
if (propertyDesc?.get) {
|
|
38
|
-
let obj;
|
|
39
|
-
// eslint-disable-next-line
|
|
40
|
-
const self = this;
|
|
41
|
-
Object.defineProperty(eggObject, 'obj', {
|
|
42
|
-
...propertyDesc,
|
|
43
|
-
get() {
|
|
44
|
-
if (!obj) {
|
|
45
|
-
obj = Reflect.apply(propertyDesc.get, eggObject, []);
|
|
46
|
-
self.hijackMethods(obj, aspectList);
|
|
47
|
-
self.injectAdvice(eggObject, obj, aspectList);
|
|
48
|
-
}
|
|
49
|
-
return obj;
|
|
50
|
-
},
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
else {
|
|
54
|
-
this.hijackMethods(eggObject.obj, aspectList);
|
|
55
|
-
this.injectAdvice(eggObject, eggObject.obj, aspectList);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRWdnT2JqZWN0QW9wSG9vay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIkVnZ09iamVjdEFvcEhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxNQUFNLE1BQU0sYUFBYSxDQUFDO0FBQ2pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsVUFBVSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFHNUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzFELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUVyRCxNQUFNLE9BQU8sZ0JBQWdCO0lBQ25CLGFBQWEsQ0FBQyxHQUFRLEVBQUUsVUFBeUI7UUFDdkQsS0FBSyxNQUFNLE1BQU0sSUFBSSxVQUFVLEVBQUUsQ0FBQztZQUNoQyxNQUFNLFdBQVcsR0FBRyxJQUFJLGNBQWMsQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDOUUsR0FBRyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxXQUFXLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUM3RCxDQUFDO0lBQ0gsQ0FBQztJQUVELGtEQUFrRDtJQUNsRCx5Q0FBeUM7SUFDakMsWUFBWSxDQUFDLFNBQW9CLEVBQUUsR0FBUSxFQUFFLFVBQXlCO1FBQzVFLElBQUksU0FBUyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLFdBQVcsQ0FBQyxLQUFLLFVBQVUsQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUN0RixPQUFPO1FBQ1QsQ0FBQztRQUNELEtBQUssTUFBTSxNQUFNLElBQUksVUFBVSxFQUFFLENBQUM7WUFDaEMsS0FBSyxNQUFNLE1BQU0sSUFBSSxNQUFNLENBQUMsVUFBVSxFQUFFLENBQUM7Z0JBQ3ZDLE1BQU0sWUFBWSxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLEtBQUssTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUN4RixNQUFNLENBQUMsWUFBWSxFQUFFLDJCQUEyQixNQUFNLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztnQkFDL0QsTUFBTSxTQUFTLEdBQUcsbUJBQW1CLENBQUMsWUFBWSxDQUFDLFlBQWEsQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUNyRixNQUFNLENBQUMsY0FBYyxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQUMsSUFBSSxFQUFFO29CQUN0QyxLQUFLLEVBQUUsU0FBUyxDQUFDLEdBQUc7b0JBQ3BCLFVBQVUsRUFBRSxLQUFLO2lCQUNsQixDQUFDLENBQUM7WUFDTCxDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFFRCxLQUFLLENBQUMsVUFBVSxDQUFDLENBQTRCLEVBQUUsU0FBb0I7UUFDakUsTUFBTSxVQUFVLEdBQThCLFNBQVMsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ3ZGLElBQUksQ0FBQyxVQUFVLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTTtZQUFFLE9BQU87UUFDOUMsTUFBTSxZQUFZLEdBQUcsU0FBUyxDQUFDLFdBQVcsSUFBSSxPQUFPLENBQUMsd0JBQXdCLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFFLENBQUM7UUFDeEgsMEJBQTBCO1FBQzFCLElBQUksWUFBWSxFQUFFLEdBQUcsRUFBRSxDQUFDO1lBQ3RCLElBQUksR0FBWSxDQUFDO1lBQ2pCLDJCQUEyQjtZQUMzQixNQUFNLElBQUksR0FBRyxJQUFJLENBQUM7WUFDbEIsTUFBTSxDQUFDLGNBQWMsQ0FBQyxTQUFTLEVBQUUsS0FBSyxFQUFFO2dCQUN0QyxHQUFHLFlBQVk7Z0JBQ2YsR0FBRztvQkFDRCxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7d0JBQ1QsR0FBRyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLEdBQUksRUFBRSxTQUFTLEVBQUUsRUFBRSxDQUFDLENBQUM7d0JBQ3RELElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxFQUFFLFVBQVUsQ0FBQyxDQUFDO3dCQUNwQyxJQUFJLENBQUMsWUFBWSxDQUFDLFNBQVMsRUFBRSxHQUFHLEVBQUUsVUFBVSxDQUFDLENBQUM7b0JBQ2hELENBQUM7b0JBQ0QsT0FBTyxHQUFHLENBQUM7Z0JBQ2IsQ0FBQzthQUNGLENBQUMsQ0FBQztRQUNMLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1lBQzlDLElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxHQUFHLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFDMUQsQ0FBQztJQUNILENBQUM7Q0FDRiJ9
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import type { EggPrototype, EggPrototypeLifecycleContext, LifecycleHook } from '@eggjs/tegg-types';
|
|
2
|
-
import { CrosscutAdviceFactory } from '@eggjs/aop-decorator';
|
|
3
|
-
export declare class EggPrototypeCrossCutHook implements LifecycleHook<EggPrototypeLifecycleContext, EggPrototype> {
|
|
4
|
-
private readonly crosscutAdviceFactory;
|
|
5
|
-
constructor(crosscutAdviceFactory: CrosscutAdviceFactory);
|
|
6
|
-
preCreate(ctx: EggPrototypeLifecycleContext): Promise<void>;
|
|
7
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { CrosscutInfoUtil } from '@eggjs/aop-decorator';
|
|
2
|
-
export class EggPrototypeCrossCutHook {
|
|
3
|
-
crosscutAdviceFactory;
|
|
4
|
-
constructor(crosscutAdviceFactory) {
|
|
5
|
-
this.crosscutAdviceFactory = crosscutAdviceFactory;
|
|
6
|
-
}
|
|
7
|
-
async preCreate(ctx) {
|
|
8
|
-
if (CrosscutInfoUtil.isCrosscutAdvice(ctx.clazz)) {
|
|
9
|
-
this.crosscutAdviceFactory.registerCrossAdviceClazz(ctx.clazz);
|
|
10
|
-
}
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRWdnUHJvdG90eXBlQ3Jvc3NDdXRIb29rLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiRWdnUHJvdG90eXBlQ3Jvc3NDdXRIb29rLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBeUIsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUUvRSxNQUFNLE9BQU8sd0JBQXdCO0lBQ2xCLHFCQUFxQixDQUF3QjtJQUU5RCxZQUFZLHFCQUE0QztRQUN0RCxJQUFJLENBQUMscUJBQXFCLEdBQUcscUJBQXFCLENBQUM7SUFDckQsQ0FBQztJQUVELEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBaUM7UUFDL0MsSUFBSSxnQkFBZ0IsQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUNqRCxJQUFJLENBQUMscUJBQXFCLENBQUMsd0JBQXdCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2pFLENBQUM7SUFDSCxDQUFDO0NBQ0YifQ==
|
package/src/LoadUnitAopHook.d.ts
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { CrosscutAdviceFactory } from '@eggjs/aop-decorator';
|
|
2
|
-
import type { LifecycleHook, LoadUnit, LoadUnitLifecycleContext } from '@eggjs/tegg-types';
|
|
3
|
-
export declare class LoadUnitAopHook implements LifecycleHook<LoadUnitLifecycleContext, LoadUnit> {
|
|
4
|
-
private readonly crosscutAdviceFactory;
|
|
5
|
-
constructor(crosscutAdviceFactory: CrosscutAdviceFactory);
|
|
6
|
-
postCreate(_: LoadUnitLifecycleContext, loadUnit: LoadUnit): Promise<void>;
|
|
7
|
-
}
|
package/src/LoadUnitAopHook.js
DELETED
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { AspectInfoUtil, AspectMetaBuilder } from '@eggjs/aop-decorator';
|
|
2
|
-
import { PrototypeUtil } from '@eggjs/core-decorator';
|
|
3
|
-
import { TeggError } from '@eggjs/tegg-metadata';
|
|
4
|
-
export class LoadUnitAopHook {
|
|
5
|
-
crosscutAdviceFactory;
|
|
6
|
-
constructor(crosscutAdviceFactory) {
|
|
7
|
-
this.crosscutAdviceFactory = crosscutAdviceFactory;
|
|
8
|
-
}
|
|
9
|
-
async postCreate(_, loadUnit) {
|
|
10
|
-
for (const proto of loadUnit.iterateEggPrototype()) {
|
|
11
|
-
const protoWithClazz = proto;
|
|
12
|
-
const clazz = protoWithClazz.clazz;
|
|
13
|
-
if (!clazz)
|
|
14
|
-
continue;
|
|
15
|
-
const builder = new AspectMetaBuilder(clazz, {
|
|
16
|
-
crosscutAdviceFactory: this.crosscutAdviceFactory,
|
|
17
|
-
});
|
|
18
|
-
const aspectList = builder.build();
|
|
19
|
-
AspectInfoUtil.setAspectList(aspectList, clazz);
|
|
20
|
-
for (const aspect of aspectList) {
|
|
21
|
-
for (const advice of aspect.adviceList) {
|
|
22
|
-
const adviceProto = PrototypeUtil.getClazzProto(advice.clazz);
|
|
23
|
-
if (!adviceProto) {
|
|
24
|
-
throw TeggError.create(`Aop Advice(${advice.clazz.name}) not found in loadUnits`, 'advice_not_found');
|
|
25
|
-
}
|
|
26
|
-
proto.injectObjects.push({
|
|
27
|
-
refName: advice.name,
|
|
28
|
-
objName: advice.name,
|
|
29
|
-
qualifiers: [],
|
|
30
|
-
proto: adviceProto,
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTG9hZFVuaXRBb3BIb29rLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiTG9hZFVuaXRBb3BIb29rLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsaUJBQWlCLEVBQXlCLE1BQU0sc0JBQXNCLENBQUM7QUFDaEcsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQVNqRCxNQUFNLE9BQU8sZUFBZTtJQUNULHFCQUFxQixDQUF3QjtJQUU5RCxZQUFZLHFCQUE0QztRQUN0RCxJQUFJLENBQUMscUJBQXFCLEdBQUcscUJBQXFCLENBQUM7SUFDckQsQ0FBQztJQUVELEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBMkIsRUFBRSxRQUFrQjtRQUM5RCxLQUFLLE1BQU0sS0FBSyxJQUFJLFFBQVEsQ0FBQyxtQkFBbUIsRUFBRSxFQUFFLENBQUM7WUFDbkQsTUFBTSxjQUFjLEdBQUcsS0FBOEIsQ0FBQztZQUN0RCxNQUFNLEtBQUssR0FBRyxjQUFjLENBQUMsS0FBSyxDQUFDO1lBQ25DLElBQUksQ0FBQyxLQUFLO2dCQUFFLFNBQVM7WUFFckIsTUFBTSxPQUFPLEdBQUcsSUFBSSxpQkFBaUIsQ0FBQyxLQUFLLEVBQUU7Z0JBQzNDLHFCQUFxQixFQUFFLElBQUksQ0FBQyxxQkFBcUI7YUFDbEQsQ0FBQyxDQUFDO1lBQ0gsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ25DLGNBQWMsQ0FBQyxhQUFhLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQ2hELEtBQUssTUFBTSxNQUFNLElBQUksVUFBVSxFQUFFLENBQUM7Z0JBQ2hDLEtBQUssTUFBTSxNQUFNLElBQUksTUFBTSxDQUFDLFVBQVUsRUFBRSxDQUFDO29CQUN2QyxNQUFNLFdBQVcsR0FBRyxhQUFhLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztvQkFDOUQsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO3dCQUNqQixNQUFNLFNBQVMsQ0FBQyxNQUFNLENBQUMsY0FBYyxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksMEJBQTBCLEVBQUUsa0JBQWtCLENBQUMsQ0FBQztvQkFDeEcsQ0FBQztvQkFFRCxLQUFLLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQzt3QkFDdkIsT0FBTyxFQUFFLE1BQU0sQ0FBQyxJQUFJO3dCQUNwQixPQUFPLEVBQUUsTUFBTSxDQUFDLElBQUk7d0JBQ3BCLFVBQVUsRUFBRSxFQUFFO3dCQUNkLEtBQUssRUFBRSxXQUEyQjtxQkFDbkMsQ0FBQyxDQUFDO2dCQUNMLENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7Q0FDRiJ9
|
package/src/PointCutGraphHook.js
DELETED
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import assert from 'node:assert';
|
|
2
|
-
import { AspectMetaBuilder, PointcutAdviceInfoUtil } from '@eggjs/aop-decorator';
|
|
3
|
-
import { PrototypeUtil, QualifierUtil } from '@eggjs/core-decorator';
|
|
4
|
-
import { ClassProtoDescriptor, } from '@eggjs/tegg-metadata';
|
|
5
|
-
export function pointCutGraphHook(globalGraph) {
|
|
6
|
-
for (const moduleNode of globalGraph.moduleGraph.nodes.values()) {
|
|
7
|
-
for (const pointCuttedProtoNode of moduleNode.val.protos) {
|
|
8
|
-
const pointCutAdviceProtoList = findPointCutAdvice(globalGraph, pointCuttedProtoNode);
|
|
9
|
-
if (!pointCutAdviceProtoList)
|
|
10
|
-
continue;
|
|
11
|
-
for (const pointCutAdviceProto of pointCutAdviceProtoList) {
|
|
12
|
-
globalGraph.addInject(moduleNode, pointCuttedProtoNode, pointCutAdviceProto, pointCutAdviceProto.val.proto.name);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
function findPointCutAdvice(globalGraph, protoNode) {
|
|
18
|
-
const proto = protoNode.val.proto;
|
|
19
|
-
if (!ClassProtoDescriptor.isClassProtoDescriptor(proto)) {
|
|
20
|
-
return;
|
|
21
|
-
}
|
|
22
|
-
const result = new Set();
|
|
23
|
-
const allMethods = AspectMetaBuilder.getAllMethods(proto.clazz);
|
|
24
|
-
for (const method of allMethods) {
|
|
25
|
-
const adviceInfoList = PointcutAdviceInfoUtil.getPointcutAdviceInfoList(proto.clazz, method);
|
|
26
|
-
for (const { clazz } of adviceInfoList) {
|
|
27
|
-
const property = PrototypeUtil.getProperty(clazz);
|
|
28
|
-
assert(property, 'not found property');
|
|
29
|
-
const injectProto = globalGraph.findDependencyProtoNode(protoNode.val.proto, {
|
|
30
|
-
objName: property.name,
|
|
31
|
-
refName: property.name,
|
|
32
|
-
qualifiers: QualifierUtil.mergeQualifiers(property?.qualifiers ?? [], QualifierUtil.getProtoQualifiers(clazz)),
|
|
33
|
-
});
|
|
34
|
-
if (injectProto) {
|
|
35
|
-
result.add(injectProto);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
return Array.from(result);
|
|
40
|
-
}
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUG9pbnRDdXRHcmFwaEhvb2suanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJQb2ludEN1dEdyYXBoSG9vay50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU0sTUFBTSxhQUFhLENBQUM7QUFDakMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLHNCQUFzQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDakYsT0FBTyxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUVyRSxPQUFPLEVBQ0wsb0JBQW9CLEdBSXJCLE1BQU0sc0JBQXNCLENBQUM7QUFFOUIsTUFBTSxVQUFVLGlCQUFpQixDQUFDLFdBQXdCO0lBQ3hELEtBQUssTUFBTSxVQUFVLElBQUksV0FBVyxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQztRQUNoRSxLQUFLLE1BQU0sb0JBQW9CLElBQUksVUFBVSxDQUFDLEdBQUcsQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUN6RCxNQUFNLHVCQUF1QixHQUFHLGtCQUFrQixDQUFDLFdBQVcsRUFBRSxvQkFBb0IsQ0FBQyxDQUFDO1lBQ3RGLElBQUksQ0FBQyx1QkFBdUI7Z0JBQUUsU0FBUztZQUN2QyxLQUFLLE1BQU0sbUJBQW1CLElBQUksdUJBQXVCLEVBQUUsQ0FBQztnQkFDMUQsV0FBVyxDQUFDLFNBQVMsQ0FDbkIsVUFBVSxFQUNWLG9CQUFvQixFQUNwQixtQkFBbUIsRUFDbkIsbUJBQW1CLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUN4QyxDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7QUFDSCxDQUFDO0FBRUQsU0FBUyxrQkFBa0IsQ0FBQyxXQUF3QixFQUFFLFNBQW9EO0lBQ3hHLE1BQU0sS0FBSyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDO0lBQ2xDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxzQkFBc0IsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQ3hELE9BQU87SUFDVCxDQUFDO0lBQ0QsTUFBTSxNQUFNLEdBQW1ELElBQUksR0FBRyxFQUFFLENBQUM7SUFDekUsTUFBTSxVQUFVLEdBQUcsaUJBQWlCLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoRSxLQUFLLE1BQU0sTUFBTSxJQUFJLFVBQVUsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sY0FBYyxHQUFHLHNCQUFzQixDQUFDLHlCQUF5QixDQUFDLEtBQUssQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDN0YsS0FBSyxNQUFNLEVBQUUsS0FBSyxFQUFFLElBQUksY0FBYyxFQUFFLENBQUM7WUFDdkMsTUFBTSxRQUFRLEdBQUcsYUFBYSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNsRCxNQUFNLENBQUMsUUFBUSxFQUFFLG9CQUFvQixDQUFDLENBQUM7WUFDdkMsTUFBTSxXQUFXLEdBQUcsV0FBVyxDQUFDLHVCQUF1QixDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFO2dCQUMzRSxPQUFPLEVBQUUsUUFBUSxDQUFDLElBQUk7Z0JBQ3RCLE9BQU8sRUFBRSxRQUFRLENBQUMsSUFBSTtnQkFDdEIsVUFBVSxFQUFFLGFBQWEsQ0FBQyxlQUFlLENBQ3ZDLFFBQVEsRUFBRSxVQUFVLElBQUksRUFBRSxFQUMxQixhQUFhLENBQUMsa0JBQWtCLENBQUMsS0FBSyxDQUFDLENBQ3hDO2FBQ0YsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxXQUFXLEVBQUUsQ0FBQztnQkFDaEIsTUFBTSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUMxQixDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFDRCxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7QUFDNUIsQ0FBQyJ9
|
package/src/index.d.ts
DELETED
package/src/index.js
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
export * from './AspectExecutor.js';
|
|
2
|
-
export * from './CrossCutGraphHook.js';
|
|
3
|
-
export * from './EggObjectAopHook.js';
|
|
4
|
-
export * from './EggPrototypeCrossCutHook.js';
|
|
5
|
-
export * from './LoadUnitAopHook.js';
|
|
6
|
-
export * from './PointCutGraphHook.js';
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyx3QkFBd0IsQ0FBQyJ9
|