@eggjs/tegg-plugin 4.0.0-beta.9 → 4.0.2-beta.0

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.
Files changed (49) hide show
  1. package/dist/app/extend/application.d.ts +28 -49
  2. package/dist/app/extend/application.js +69 -79
  3. package/dist/app/extend/application.unittest.d.ts +9 -21
  4. package/dist/app/extend/application.unittest.js +39 -53
  5. package/dist/app/extend/context.d.ts +12 -19
  6. package/dist/app/extend/context.js +27 -34
  7. package/dist/app/middleware/tegg_ctx_lifecycle_middleware.d.ts +6 -3
  8. package/dist/app/middleware/tegg_ctx_lifecycle_middleware.js +7 -3
  9. package/dist/app.d.ts +20 -16
  10. package/dist/app.js +50 -56
  11. package/dist/index.d.ts +3 -3
  12. package/dist/index.js +4 -3
  13. package/dist/lib/AppLoadUnit.d.ts +23 -18
  14. package/dist/lib/AppLoadUnit.js +77 -89
  15. package/dist/lib/AppLoadUnitInstance.d.ts +23 -19
  16. package/dist/lib/AppLoadUnitInstance.js +69 -81
  17. package/dist/lib/CompatibleUtil.d.ts +22 -13
  18. package/dist/lib/CompatibleUtil.js +99 -95
  19. package/dist/lib/ConfigSourceLoadUnitHook.d.ts +13 -8
  20. package/dist/lib/ConfigSourceLoadUnitHook.js +20 -20
  21. package/dist/lib/EggAppLoader.d.ts +19 -15
  22. package/dist/lib/EggAppLoader.js +104 -127
  23. package/dist/lib/EggCompatibleObject.d.ts +19 -17
  24. package/dist/lib/EggCompatibleObject.js +34 -40
  25. package/dist/lib/EggCompatibleProtoImpl.d.ts +25 -20
  26. package/dist/lib/EggCompatibleProtoImpl.js +49 -52
  27. package/dist/lib/EggContextCompatibleHook.d.ts +13 -9
  28. package/dist/lib/EggContextCompatibleHook.js +32 -44
  29. package/dist/lib/EggContextHandler.d.ts +12 -8
  30. package/dist/lib/EggContextHandler.js +28 -26
  31. package/dist/lib/EggContextImpl.d.ts +9 -5
  32. package/dist/lib/EggContextImpl.js +18 -15
  33. package/dist/lib/EggModuleLoader.d.ts +16 -10
  34. package/dist/lib/EggModuleLoader.js +53 -53
  35. package/dist/lib/EggQualifierProtoHook.d.ts +13 -9
  36. package/dist/lib/EggQualifierProtoHook.js +46 -62
  37. package/dist/lib/ModuleConfigLoader.d.ts +11 -7
  38. package/dist/lib/ModuleConfigLoader.js +81 -80
  39. package/dist/lib/ModuleHandler.d.ts +17 -12
  40. package/dist/lib/ModuleHandler.js +47 -52
  41. package/dist/lib/Utils.d.ts +4 -1
  42. package/dist/lib/Utils.js +30 -33
  43. package/dist/lib/ctx_lifecycle_middleware.d.ts +6 -2
  44. package/dist/lib/ctx_lifecycle_middleware.js +36 -31
  45. package/dist/lib/run_in_background.d.ts +7 -3
  46. package/dist/lib/run_in_background.js +46 -54
  47. package/dist/types.d.ts +54 -8
  48. package/dist/types.js +3 -5
  49. package/package.json +49 -54
@@ -1,50 +1,29 @@
1
- import { EggPrototypeCreatorFactory, EggPrototypeFactory, EggPrototypeLifecycleUtil, LoadUnitFactory, LoadUnitLifecycleUtil } from '@eggjs/tegg-metadata';
2
- import { AbstractEggContext, EggContainerFactory, EggObjectFactory, LoadUnitInstanceFactory, EggContextLifecycleUtil, EggObjectLifecycleUtil, LoadUnitInstanceLifecycleUtil, type EggContext as TEggContext } from '@eggjs/tegg-runtime';
3
- import { LoaderFactory } from '@eggjs/tegg-loader';
4
- import { type EggProtoImplClass, IdenticalUtil, type RuntimeConfig, type QualifierInfo } from '@eggjs/tegg';
5
- import { Application } from 'egg';
6
- import { ModuleHandler } from '../../lib/ModuleHandler.ts';
7
- import { EggContextHandler } from '../../lib/EggContextHandler.ts';
8
- export default class TEggPluginApplication extends Application {
9
- get eggPrototypeCreatorFactory(): typeof EggPrototypeCreatorFactory;
10
- get eggPrototypeFactory(): EggPrototypeFactory;
11
- get loadUnitLifecycleUtil(): import("@eggjs/tegg").LifecycleUtil<import("@eggjs/tegg-metadata").LoadUnitLifecycleContext, import("@eggjs/tegg-metadata").LoadUnit>;
12
- get loadUnitFactory(): typeof LoadUnitFactory;
13
- get eggObjectFactory(): typeof EggObjectFactory;
14
- get loadUnitInstanceFactory(): typeof LoadUnitInstanceFactory;
15
- get loadUnitInstanceLifecycleUtil(): import("@eggjs/tegg").LifecycleUtil<import("@eggjs/tegg-runtime").LoadUnitInstanceLifecycleContext, import("@eggjs/tegg-runtime").LoadUnitInstance>;
16
- get eggContainerFactory(): typeof EggContainerFactory;
17
- get loaderFactory(): typeof LoaderFactory;
18
- get eggPrototypeLifecycleUtil(): import("@eggjs/tegg").LifecycleUtil<import("@eggjs/tegg-metadata").EggPrototypeLifecycleContext, import("@eggjs/tegg-metadata").EggPrototype>;
19
- get eggContextLifecycleUtil(): import("@eggjs/tegg").LifecycleUtil<import("@eggjs/tegg-runtime").EggContextLifecycleContext, TEggContext>;
20
- get eggObjectLifecycleUtil(): import("@eggjs/tegg").LifecycleUtil<import("@eggjs/tegg-runtime").EggObjectLifeCycleContext, import("@eggjs/tegg-runtime").EggObject>;
21
- get abstractEggContext(): typeof AbstractEggContext;
22
- get identicalUtil(): typeof IdenticalUtil;
23
- get runtimeConfig(): RuntimeConfig;
24
- getEggObject<T>(clazz: EggProtoImplClass<T>, name?: string, qualifiers?: QualifierInfo | QualifierInfo[]): Promise<T>;
25
- getEggObjectFromName<T extends object>(name: string, qualifiers?: QualifierInfo | QualifierInfo[]): Promise<T>;
26
- }
27
- declare module 'egg' {
28
- interface Application {
29
- eggPrototypeCreatorFactory: typeof EggPrototypeCreatorFactory;
30
- eggPrototypeFactory: EggPrototypeFactory;
31
- eggContainerFactory: typeof EggContainerFactory;
32
- loadUnitFactory: typeof LoadUnitFactory;
33
- eggObjectFactory: typeof EggObjectFactory;
34
- loadUnitInstanceFactory: typeof LoadUnitInstanceFactory;
35
- abstractEggContext: typeof AbstractEggContext;
36
- identicalUtil: typeof IdenticalUtil;
37
- loaderFactory: typeof LoaderFactory;
38
- loadUnitLifecycleUtil: typeof LoadUnitLifecycleUtil;
39
- loadUnitInstanceLifecycleUtil: typeof LoadUnitInstanceLifecycleUtil;
40
- eggPrototypeLifecycleUtil: typeof EggPrototypeLifecycleUtil;
41
- eggContextLifecycleUtil: typeof EggContextLifecycleUtil;
42
- eggObjectLifecycleUtil: typeof EggObjectLifecycleUtil;
43
- teggContext: TEggContext;
44
- moduleHandler: ModuleHandler;
45
- eggContextHandler: EggContextHandler;
46
- getEggObject<T>(clazz: new (...args: any[]) => T, name?: string, qualifiers?: QualifierInfo | QualifierInfo[]): Promise<T>;
47
- getEggObjectFromName<T extends object>(name: string, qualifiers?: QualifierInfo | QualifierInfo[]): Promise<T>;
48
- module: EggModule;
49
- }
1
+ import { EggProtoImplClass, QualifierInfo } from "@eggjs/core-decorator";
2
+ import { IdenticalUtil } from "@eggjs/lifecycle";
3
+ import { EggPrototypeCreatorFactory, EggPrototypeFactory, EggPrototypeLifecycleUtil, LoadUnitFactory, LoadUnitLifecycleUtil } from "@eggjs/metadata";
4
+ import { AbstractEggContext, EggContainerFactory, EggContextLifecycleUtil, EggObjectFactory, EggObjectLifecycleUtil, LoadUnitInstanceFactory, LoadUnitInstanceLifecycleUtil } from "@eggjs/tegg-runtime";
5
+ import { LoaderFactory } from "@eggjs/tegg-loader";
6
+ import { RuntimeConfig } from "@eggjs/tegg-types";
7
+
8
+ //#region src/app/extend/application.d.ts
9
+ declare class TEggPluginApplication {
10
+ get eggPrototypeCreatorFactory(): typeof EggPrototypeCreatorFactory;
11
+ get eggPrototypeFactory(): EggPrototypeFactory;
12
+ get loadUnitLifecycleUtil(): typeof LoadUnitLifecycleUtil;
13
+ get loadUnitFactory(): typeof LoadUnitFactory;
14
+ get eggObjectFactory(): typeof EggObjectFactory;
15
+ get loadUnitInstanceFactory(): typeof LoadUnitInstanceFactory;
16
+ get loadUnitInstanceLifecycleUtil(): typeof LoadUnitInstanceLifecycleUtil;
17
+ get eggContainerFactory(): typeof EggContainerFactory;
18
+ get loaderFactory(): typeof LoaderFactory;
19
+ get eggPrototypeLifecycleUtil(): typeof EggPrototypeLifecycleUtil;
20
+ get eggContextLifecycleUtil(): typeof EggContextLifecycleUtil;
21
+ get eggObjectLifecycleUtil(): typeof EggObjectLifecycleUtil;
22
+ get abstractEggContext(): typeof AbstractEggContext;
23
+ get identicalUtil(): typeof IdenticalUtil;
24
+ get runtimeConfig(): RuntimeConfig;
25
+ getEggObject<T>(clazz: EggProtoImplClass<T>, name?: string, qualifiers?: QualifierInfo | QualifierInfo[]): Promise<T>;
26
+ getEggObjectFromName<T extends object>(name: string, qualifiers?: QualifierInfo | QualifierInfo[]): Promise<T>;
50
27
  }
28
+ //#endregion
29
+ export { TEggPluginApplication as default };
@@ -1,79 +1,69 @@
1
- import { EggPrototypeCreatorFactory, EggPrototypeFactory, EggPrototypeLifecycleUtil, LoadUnitFactory, LoadUnitLifecycleUtil, } from '@eggjs/tegg-metadata';
2
- import { AbstractEggContext, EggContainerFactory, EggObjectFactory, LoadUnitInstanceFactory, EggContextLifecycleUtil, EggObjectLifecycleUtil, LoadUnitInstanceLifecycleUtil, } from '@eggjs/tegg-runtime';
3
- import { LoaderFactory } from '@eggjs/tegg-loader';
4
- import { IdenticalUtil } from '@eggjs/tegg';
5
- import { Application } from 'egg';
6
- import { ModuleHandler } from "../../lib/ModuleHandler.js";
7
- import { EggContextHandler } from "../../lib/EggContextHandler.js";
8
- export default class TEggPluginApplication extends Application {
9
- // @eggjs/tegg-metadata should not depend by other egg plugins.
10
- // May make multi singleton instances.
11
- // So tegg-compatible should delegate the metadata factories
12
- // TODO delegate all the singleton
13
- get eggPrototypeCreatorFactory() {
14
- return EggPrototypeCreatorFactory;
15
- }
16
- get eggPrototypeFactory() {
17
- return EggPrototypeFactory.instance;
18
- }
19
- get loadUnitLifecycleUtil() {
20
- return LoadUnitLifecycleUtil;
21
- }
22
- get loadUnitFactory() {
23
- return LoadUnitFactory;
24
- }
25
- get eggObjectFactory() {
26
- return EggObjectFactory;
27
- }
28
- get loadUnitInstanceFactory() {
29
- return LoadUnitInstanceFactory;
30
- }
31
- get loadUnitInstanceLifecycleUtil() {
32
- return LoadUnitInstanceLifecycleUtil;
33
- }
34
- get eggContainerFactory() {
35
- return EggContainerFactory;
36
- }
37
- get loaderFactory() {
38
- return LoaderFactory;
39
- }
40
- get eggPrototypeLifecycleUtil() {
41
- return EggPrototypeLifecycleUtil;
42
- }
43
- get eggContextLifecycleUtil() {
44
- return EggContextLifecycleUtil;
45
- }
46
- get eggObjectLifecycleUtil() {
47
- return EggObjectLifecycleUtil;
48
- }
49
- get abstractEggContext() {
50
- return AbstractEggContext;
51
- }
52
- get identicalUtil() {
53
- return IdenticalUtil;
54
- }
55
- get runtimeConfig() {
56
- const config = this.config;
57
- return {
58
- baseDir: config.baseDir,
59
- env: config.env,
60
- name: config.name,
61
- };
62
- }
63
- async getEggObject(clazz, name, qualifiers) {
64
- if (qualifiers) {
65
- qualifiers = Array.isArray(qualifiers) ? qualifiers : [qualifiers];
66
- }
67
- const eggObject = await EggContainerFactory.getOrCreateEggObjectFromClazz(clazz, name, qualifiers);
68
- return eggObject.obj;
69
- }
70
- async getEggObjectFromName(name, qualifiers) {
71
- if (qualifiers) {
72
- qualifiers = Array.isArray(qualifiers) ? qualifiers : [qualifiers];
73
- }
74
- const eggObject = await EggContainerFactory.getOrCreateEggObjectFromName(name, qualifiers);
75
- return eggObject.obj;
76
- }
77
- }
78
- ;
79
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBwL2V4dGVuZC9hcHBsaWNhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsMEJBQTBCLEVBQzFCLG1CQUFtQixFQUNuQix5QkFBeUIsRUFDekIsZUFBZSxFQUNmLHFCQUFxQixHQUN0QixNQUFNLHNCQUFzQixDQUFDO0FBQzlCLE9BQU8sRUFDTCxrQkFBa0IsRUFDbEIsbUJBQW1CLEVBQ25CLGdCQUFnQixFQUNoQix1QkFBdUIsRUFDdkIsdUJBQXVCLEVBQ3ZCLHNCQUFzQixFQUN0Qiw2QkFBNkIsR0FFOUIsTUFBTSxxQkFBcUIsQ0FBQztBQUM3QixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbkQsT0FBTyxFQUEwQixhQUFhLEVBQTBDLE1BQU0sYUFBYSxDQUFDO0FBQzVHLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxLQUFLLENBQUM7QUFFbEMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzNELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRW5FLE1BQU0sQ0FBQyxPQUFPLE9BQU8scUJBQXNCLFNBQVEsV0FBVztJQUM1RCwrREFBK0Q7SUFDL0Qsc0NBQXNDO0lBQ3RDLDREQUE0RDtJQUM1RCxrQ0FBa0M7SUFDbEMsSUFBSSwwQkFBMEI7UUFDNUIsT0FBTywwQkFBMEIsQ0FBQztJQUNwQyxDQUFDO0lBRUQsSUFBSSxtQkFBbUI7UUFDckIsT0FBTyxtQkFBbUIsQ0FBQyxRQUFRLENBQUM7SUFDdEMsQ0FBQztJQUVELElBQUkscUJBQXFCO1FBQ3ZCLE9BQU8scUJBQXFCLENBQUM7SUFDL0IsQ0FBQztJQUVELElBQUksZUFBZTtRQUNqQixPQUFPLGVBQWUsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBSSxnQkFBZ0I7UUFDbEIsT0FBTyxnQkFBZ0IsQ0FBQztJQUMxQixDQUFDO0lBRUQsSUFBSSx1QkFBdUI7UUFDekIsT0FBTyx1QkFBdUIsQ0FBQztJQUNqQyxDQUFDO0lBRUQsSUFBSSw2QkFBNkI7UUFDL0IsT0FBTyw2QkFBNkIsQ0FBQztJQUN2QyxDQUFDO0lBRUQsSUFBSSxtQkFBbUI7UUFDckIsT0FBTyxtQkFBbUIsQ0FBQztJQUM3QixDQUFDO0lBRUQsSUFBSSxhQUFhO1FBQ2YsT0FBTyxhQUFhLENBQUM7SUFDdkIsQ0FBQztJQUVELElBQUkseUJBQXlCO1FBQzNCLE9BQU8seUJBQXlCLENBQUM7SUFDbkMsQ0FBQztJQUVELElBQUksdUJBQXVCO1FBQ3pCLE9BQU8sdUJBQXVCLENBQUM7SUFDakMsQ0FBQztJQUVELElBQUksc0JBQXNCO1FBQ3hCLE9BQU8sc0JBQXNCLENBQUM7SUFDaEMsQ0FBQztJQUVELElBQUksa0JBQWtCO1FBQ3BCLE9BQU8sa0JBQWtCLENBQUM7SUFDNUIsQ0FBQztJQUVELElBQUksYUFBYTtRQUNmLE9BQU8sYUFBYSxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxJQUFJLGFBQWE7UUFDZixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQzNCLE9BQU87WUFDTCxPQUFPLEVBQUUsTUFBTSxDQUFDLE9BQU87WUFDdkIsR0FBRyxFQUFFLE1BQU0sQ0FBQyxHQUFHO1lBQ2YsSUFBSSxFQUFFLE1BQU0sQ0FBQyxJQUFJO1NBQ2xCLENBQUM7SUFDSixDQUFDO0lBRUQsS0FBSyxDQUFDLFlBQVksQ0FBSSxLQUEyQixFQUFFLElBQWEsRUFBRSxVQUE0QztRQUM1RyxJQUFJLFVBQVUsRUFBRSxDQUFDO1lBQ2YsVUFBVSxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBRSxVQUFVLENBQUUsQ0FBQztRQUN2RSxDQUFDO1FBQ0QsTUFBTSxTQUFTLEdBQUcsTUFBTSxtQkFBbUIsQ0FBQyw2QkFBNkIsQ0FBQyxLQUEwQixFQUFFLElBQUksRUFBRSxVQUE2QixDQUFDLENBQUM7UUFDM0ksT0FBTyxTQUFTLENBQUMsR0FBUSxDQUFDO0lBQzVCLENBQUM7SUFFRCxLQUFLLENBQUMsb0JBQW9CLENBQW1CLElBQVksRUFBRSxVQUE0QztRQUNyRyxJQUFJLFVBQVUsRUFBRSxDQUFDO1lBQ2YsVUFBVSxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBRSxVQUFVLENBQUUsQ0FBQztRQUN2RSxDQUFDO1FBQ0QsTUFBTSxTQUFTLEdBQUcsTUFBTSxtQkFBbUIsQ0FBQyw0QkFBNEIsQ0FBQyxJQUFJLEVBQUUsVUFBNkIsQ0FBQyxDQUFDO1FBQzlHLE9BQU8sU0FBUyxDQUFDLEdBQVEsQ0FBQztJQUM1QixDQUFDO0NBQ0Y7QUFBQSxDQUFDIn0=
1
+ import { IdenticalUtil } from "@eggjs/lifecycle";
2
+ import { EggPrototypeCreatorFactory, EggPrototypeFactory, EggPrototypeLifecycleUtil, LoadUnitFactory, LoadUnitLifecycleUtil } from "@eggjs/metadata";
3
+ import { AbstractEggContext, EggContainerFactory, EggContextLifecycleUtil, EggObjectFactory, EggObjectLifecycleUtil, LoadUnitInstanceFactory, LoadUnitInstanceLifecycleUtil } from "@eggjs/tegg-runtime";
4
+ import { LoaderFactory } from "@eggjs/tegg-loader";
5
+
6
+ //#region src/app/extend/application.ts
7
+ var TEggPluginApplication = class {
8
+ get eggPrototypeCreatorFactory() {
9
+ return EggPrototypeCreatorFactory;
10
+ }
11
+ get eggPrototypeFactory() {
12
+ return EggPrototypeFactory.instance;
13
+ }
14
+ get loadUnitLifecycleUtil() {
15
+ return LoadUnitLifecycleUtil;
16
+ }
17
+ get loadUnitFactory() {
18
+ return LoadUnitFactory;
19
+ }
20
+ get eggObjectFactory() {
21
+ return EggObjectFactory;
22
+ }
23
+ get loadUnitInstanceFactory() {
24
+ return LoadUnitInstanceFactory;
25
+ }
26
+ get loadUnitInstanceLifecycleUtil() {
27
+ return LoadUnitInstanceLifecycleUtil;
28
+ }
29
+ get eggContainerFactory() {
30
+ return EggContainerFactory;
31
+ }
32
+ get loaderFactory() {
33
+ return LoaderFactory;
34
+ }
35
+ get eggPrototypeLifecycleUtil() {
36
+ return EggPrototypeLifecycleUtil;
37
+ }
38
+ get eggContextLifecycleUtil() {
39
+ return EggContextLifecycleUtil;
40
+ }
41
+ get eggObjectLifecycleUtil() {
42
+ return EggObjectLifecycleUtil;
43
+ }
44
+ get abstractEggContext() {
45
+ return AbstractEggContext;
46
+ }
47
+ get identicalUtil() {
48
+ return IdenticalUtil;
49
+ }
50
+ get runtimeConfig() {
51
+ const config = this.config;
52
+ return {
53
+ baseDir: config.baseDir,
54
+ env: config.env,
55
+ name: config.name
56
+ };
57
+ }
58
+ async getEggObject(clazz, name, qualifiers) {
59
+ if (qualifiers) qualifiers = Array.isArray(qualifiers) ? qualifiers : [qualifiers];
60
+ return (await EggContainerFactory.getOrCreateEggObjectFromClazz(clazz, name, qualifiers)).obj;
61
+ }
62
+ async getEggObjectFromName(name, qualifiers) {
63
+ if (qualifiers) qualifiers = Array.isArray(qualifiers) ? qualifiers : [qualifiers];
64
+ return (await EggContainerFactory.getOrCreateEggObjectFromName(name, qualifiers)).obj;
65
+ }
66
+ };
67
+
68
+ //#endregion
69
+ export { TEggPluginApplication as default };
@@ -1,22 +1,10 @@
1
- import { type Context, Application } from 'egg';
2
- export default class TEggPluginApplicationUnittest extends Application {
3
- mockModuleContext(data?: any): Promise<Context>;
4
- destroyModuleContext(ctx: Context): Promise<void>;
5
- mockModuleContextScope<R = any>(fn: (ctx: Context) => Promise<R>, data?: any): Promise<R>;
6
- }
7
- declare module 'egg' {
8
- interface Application {
9
- /**
10
- * Mock the module context, only for unittest
11
- */
12
- mockModuleContext(data?: any): Promise<Context>;
13
- /**
14
- * Mock the module context scope, only for unittest
15
- */
16
- mockModuleContextScope<R = any>(fn: (ctx: Context) => Promise<R>, data?: any): Promise<R>;
17
- /**
18
- * Destroy the module context, only for unittest
19
- */
20
- destroyModuleContext(context: Context): Promise<void>;
21
- }
1
+ import { Application, Context } from "egg";
2
+
3
+ //#region src/app/extend/application.unittest.d.ts
4
+ declare class TEggPluginApplicationUnittest {
5
+ mockModuleContext(this: Application, data?: any): Promise<Context>;
6
+ destroyModuleContext(this: Application, ctx: Context): Promise<void>;
7
+ mockModuleContextScope<R = any>(fn: (ctx: Context) => Promise<R>, data?: any): Promise<R>;
22
8
  }
9
+ //#endregion
10
+ export { TEggPluginApplicationUnittest as default };
@@ -1,55 +1,41 @@
1
- import { Application } from 'egg';
2
- import {} from '@eggjs/tegg-runtime';
3
1
  import { EggContextImpl } from "../../lib/EggContextImpl.js";
4
- const TEGG_LIFECYCLE_CACHE = new Map();
2
+
3
+ //#region src/app/extend/application.unittest.ts
4
+ const TEGG_LIFECYCLE_CACHE = /* @__PURE__ */ new Map();
5
5
  let hasMockModuleContext = false;
6
- export default class TEggPluginApplicationUnittest extends Application {
7
- async mockModuleContext(data) {
8
- this.deprecate('app.mockModuleContext is deprecated, use mockModuleContextScope.');
9
- if (hasMockModuleContext) {
10
- throw new Error('should not call mockModuleContext twice.');
11
- }
12
- // @ts-expect-error mockContext is not typed
13
- const ctx = this.mockContext(data);
14
- const teggCtx = new EggContextImpl(ctx);
15
- const lifecycle = {};
16
- TEGG_LIFECYCLE_CACHE.set(teggCtx, lifecycle);
17
- if (teggCtx.init) {
18
- await teggCtx.init(lifecycle);
19
- }
20
- hasMockModuleContext = true;
21
- return ctx;
22
- }
23
- async destroyModuleContext(ctx) {
24
- hasMockModuleContext = false;
25
- const teggCtx = ctx.teggContext;
26
- if (!teggCtx) {
27
- return;
28
- }
29
- const lifecycle = TEGG_LIFECYCLE_CACHE.get(teggCtx);
30
- if (teggCtx.destroy && lifecycle) {
31
- await teggCtx.destroy(lifecycle);
32
- }
33
- }
34
- async mockModuleContextScope(fn, data) {
35
- if (hasMockModuleContext) {
36
- throw new Error('mockModuleContextScope can not use with mockModuleContext, should use mockModuleContextScope only.');
37
- }
38
- // @ts-expect-error mockContextScope only exists in MockApplication
39
- return this.mockContextScope(async (ctx) => {
40
- const teggCtx = new EggContextImpl(ctx);
41
- const lifecycle = {};
42
- if (teggCtx.init) {
43
- await teggCtx.init(lifecycle);
44
- }
45
- try {
46
- return await fn(ctx);
47
- }
48
- finally {
49
- await teggCtx.destroy(lifecycle);
50
- }
51
- }, data);
52
- }
53
- }
54
- ;
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24udW5pdHRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBwL2V4dGVuZC9hcHBsaWNhdGlvbi51bml0dGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWdCLFdBQVcsRUFBRSxNQUFNLEtBQUssQ0FBQztBQUVoRCxPQUFPLEVBQW9ELE1BQU0scUJBQXFCLENBQUM7QUFFdkYsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBRTdELE1BQU0sb0JBQW9CLEdBQWdELElBQUksR0FBRyxFQUFFLENBQUM7QUFFcEYsSUFBSSxvQkFBb0IsR0FBRyxLQUFLLENBQUM7QUFFakMsTUFBTSxDQUFDLE9BQU8sT0FBTyw2QkFBOEIsU0FBUSxXQUFXO0lBQ3BFLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxJQUFVO1FBQ2hDLElBQUksQ0FBQyxTQUFTLENBQUMsa0VBQWtFLENBQUMsQ0FBQztRQUNuRixJQUFJLG9CQUFvQixFQUFFLENBQUM7WUFDekIsTUFBTSxJQUFJLEtBQUssQ0FBQywwQ0FBMEMsQ0FBQyxDQUFDO1FBQzlELENBQUM7UUFDRCw0Q0FBNEM7UUFDNUMsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQVksQ0FBQztRQUM5QyxNQUFNLE9BQU8sR0FBRyxJQUFJLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN4QyxNQUFNLFNBQVMsR0FBRyxFQUFFLENBQUM7UUFDckIsb0JBQW9CLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxTQUFTLENBQUMsQ0FBQztRQUM3QyxJQUFJLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNqQixNQUFNLE9BQU8sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDaEMsQ0FBQztRQUNELG9CQUFvQixHQUFHLElBQUksQ0FBQztRQUM1QixPQUFPLEdBQUcsQ0FBQztJQUNiLENBQUM7SUFFRCxLQUFLLENBQUMsb0JBQW9CLENBQUMsR0FBWTtRQUNyQyxvQkFBb0IsR0FBRyxLQUFLLENBQUM7UUFFN0IsTUFBTSxPQUFPLEdBQUcsR0FBRyxDQUFDLFdBQVcsQ0FBQztRQUNoQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDYixPQUFPO1FBQ1QsQ0FBQztRQUNELE1BQU0sU0FBUyxHQUFHLG9CQUFvQixDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNwRCxJQUFJLE9BQU8sQ0FBQyxPQUFPLElBQUksU0FBUyxFQUFFLENBQUM7WUFDakMsTUFBTSxPQUFPLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ25DLENBQUM7SUFDSCxDQUFDO0lBRUQsS0FBSyxDQUFDLHNCQUFzQixDQUFRLEVBQWdDLEVBQUUsSUFBVTtRQUM5RSxJQUFJLG9CQUFvQixFQUFFLENBQUM7WUFDekIsTUFBTSxJQUFJLEtBQUssQ0FBQyxvR0FBb0csQ0FBQyxDQUFDO1FBQ3hILENBQUM7UUFDRCxtRUFBbUU7UUFDbkUsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLEdBQVksRUFBRSxFQUFFO1lBQ2xELE1BQU0sT0FBTyxHQUFHLElBQUksY0FBYyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ3hDLE1BQU0sU0FBUyxHQUFHLEVBQUUsQ0FBQztZQUNyQixJQUFJLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztnQkFDakIsTUFBTSxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ2hDLENBQUM7WUFDRCxJQUFJLENBQUM7Z0JBQ0gsT0FBTyxNQUFNLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUN2QixDQUFDO29CQUFTLENBQUM7Z0JBQ1QsTUFBTSxPQUFPLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ25DLENBQUM7UUFDSCxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDWCxDQUFDO0NBQ0Y7QUFBQSxDQUFDIn0=
6
+ var TEggPluginApplicationUnittest = class {
7
+ async mockModuleContext(data) {
8
+ this.deprecate("app.mockModuleContext is deprecated, use mockModuleContextScope.");
9
+ if (hasMockModuleContext) throw new Error("should not call mockModuleContext twice.");
10
+ const ctx = this.mockContext(data);
11
+ const teggCtx = new EggContextImpl(ctx);
12
+ const lifecycle = {};
13
+ TEGG_LIFECYCLE_CACHE.set(teggCtx, lifecycle);
14
+ if (teggCtx.init) await teggCtx.init(lifecycle);
15
+ hasMockModuleContext = true;
16
+ return ctx;
17
+ }
18
+ async destroyModuleContext(ctx) {
19
+ hasMockModuleContext = false;
20
+ const teggCtx = ctx.teggContext;
21
+ if (!teggCtx) return;
22
+ const lifecycle = TEGG_LIFECYCLE_CACHE.get(teggCtx);
23
+ if (teggCtx.destroy && lifecycle) await teggCtx.destroy(lifecycle);
24
+ }
25
+ async mockModuleContextScope(fn, data) {
26
+ if (hasMockModuleContext) throw new Error("mockModuleContextScope can not use with mockModuleContext, should use mockModuleContextScope only.");
27
+ return this.mockContextScope(async (ctx) => {
28
+ const teggCtx = new EggContextImpl(ctx);
29
+ const lifecycle = {};
30
+ if (teggCtx.init) await teggCtx.init(lifecycle);
31
+ try {
32
+ return await fn(ctx);
33
+ } finally {
34
+ await teggCtx.destroy(lifecycle);
35
+ }
36
+ }, data);
37
+ }
38
+ };
39
+
40
+ //#endregion
41
+ export { TEggPluginApplicationUnittest as default };
@@ -1,20 +1,13 @@
1
- import { Context } from 'egg';
2
- import type { EggContext as TEggContext } from '@eggjs/tegg-runtime';
3
- import { TEGG_CONTEXT } from '@eggjs/egg-module-common';
4
- import { type EggProtoImplClass, type QualifierInfo } from '@eggjs/tegg';
5
- export default class TEggPluginContext extends Context {
6
- [TEGG_CONTEXT]: TEggContext | undefined;
7
- beginModuleScope(func: () => Promise<void>): Promise<void>;
8
- get teggContext(): TEggContext;
9
- getEggObject<T>(clazz: EggProtoImplClass<T>, name?: string): Promise<T>;
10
- getEggObjectFromName<T>(name: string, qualifiers?: QualifierInfo | QualifierInfo[]): Promise<T>;
11
- }
12
- declare module 'egg' {
13
- interface Context {
14
- beginModuleScope(func: () => Promise<void>): Promise<void>;
15
- getEggObject<T>(clazz: new (...args: any[]) => T, name?: string, qualifiers?: QualifierInfo | QualifierInfo[]): Promise<T>;
16
- getEggObjectFromName<T>(name: string, qualifiers?: QualifierInfo | QualifierInfo[]): Promise<T>;
17
- teggContext: TEggContext;
18
- module: EggModule;
19
- }
1
+ import { EggProtoImplClass, QualifierInfo } from "@eggjs/core-decorator";
2
+ import { EggContext } from "@eggjs/tegg-runtime";
3
+ import { Context } from "egg";
4
+
5
+ //#region src/app/extend/context.d.ts
6
+ declare class TEggPluginContext {
7
+ beginModuleScope(this: Context, func: () => Promise<void>): Promise<void>;
8
+ get teggContext(): EggContext;
9
+ getEggObject<T>(this: Context, clazz: EggProtoImplClass<T>, name?: string): Promise<T>;
10
+ getEggObjectFromName<T>(this: Context, name: string, qualifiers?: QualifierInfo | QualifierInfo[]): Promise<T>;
20
11
  }
12
+ //#endregion
13
+ export { TEggPluginContext as default };
@@ -1,35 +1,28 @@
1
- import { Context } from 'egg';
2
- import { TEGG_CONTEXT } from '@eggjs/egg-module-common';
3
- import { PrototypeUtil } from '@eggjs/tegg';
4
- import {} from '@eggjs/tegg-metadata';
5
1
  import { ctxLifecycleMiddleware } from "../../lib/ctx_lifecycle_middleware.js";
6
- export default class TEggPluginContext extends Context {
7
- [TEGG_CONTEXT];
8
- async beginModuleScope(func) {
9
- await ctxLifecycleMiddleware(this, func);
10
- }
11
- get teggContext() {
12
- if (!this[TEGG_CONTEXT]) {
13
- throw new Error('tegg context have not ready, should call after teggCtxLifecycleMiddleware');
14
- }
15
- return this[TEGG_CONTEXT];
16
- }
17
- async getEggObject(clazz, name) {
18
- const protoObj = PrototypeUtil.getClazzProto(clazz);
19
- if (!protoObj) {
20
- throw new Error(`can not get proto for clazz ${clazz.name}`);
21
- }
22
- const proto = protoObj;
23
- const eggObject = await this.app.eggContainerFactory.getOrCreateEggObject(proto, name ?? proto.name);
24
- return eggObject.obj;
25
- }
26
- async getEggObjectFromName(name, qualifiers) {
27
- if (qualifiers) {
28
- qualifiers = Array.isArray(qualifiers) ? qualifiers : [qualifiers];
29
- }
30
- const eggObject = await this.app.eggContainerFactory.getOrCreateEggObjectFromName(name, qualifiers);
31
- return eggObject.obj;
32
- }
33
- }
34
- ;
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcHAvZXh0ZW5kL2NvbnRleHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLEtBQUssQ0FBQztBQUU5QixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDeEQsT0FBTyxFQUEwQixhQUFhLEVBQXNCLE1BQU0sYUFBYSxDQUFDO0FBQ3hGLE9BQU8sRUFBcUIsTUFBTSxzQkFBc0IsQ0FBQztBQUV6RCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUUvRSxNQUFNLENBQUMsT0FBTyxPQUFPLGlCQUFrQixTQUFRLE9BQU87SUFDcEQsQ0FBQyxZQUFZLENBQUMsQ0FBMEI7SUFFeEMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLElBQXlCO1FBQzlDLE1BQU0sc0JBQXNCLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzNDLENBQUM7SUFFRCxJQUFJLFdBQVc7UUFDYixJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxFQUFFLENBQUM7WUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FBQywyRUFBMkUsQ0FBQyxDQUFDO1FBQy9GLENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM1QixDQUFDO0lBRUQsS0FBSyxDQUFDLFlBQVksQ0FBSSxLQUEyQixFQUFFLElBQWE7UUFDOUQsTUFBTSxRQUFRLEdBQUcsYUFBYSxDQUFDLGFBQWEsQ0FBQyxLQUEwQixDQUFDLENBQUM7UUFDekUsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ2QsTUFBTSxJQUFJLEtBQUssQ0FBQywrQkFBK0IsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUM7UUFDL0QsQ0FBQztRQUNELE1BQU0sS0FBSyxHQUFHLFFBQXdCLENBQUM7UUFDdkMsTUFBTSxTQUFTLEdBQUcsTUFBTSxJQUFJLENBQUMsR0FBRyxDQUFDLG1CQUFtQixDQUFDLG9CQUFvQixDQUFDLEtBQUssRUFBRSxJQUFJLElBQUksS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JHLE9BQU8sU0FBUyxDQUFDLEdBQVEsQ0FBQztJQUM1QixDQUFDO0lBRUQsS0FBSyxDQUFDLG9CQUFvQixDQUFJLElBQVksRUFBRSxVQUE0QztRQUN0RixJQUFJLFVBQVUsRUFBRSxDQUFDO1lBQ2YsVUFBVSxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBRSxVQUFVLENBQUUsQ0FBQztRQUN2RSxDQUFDO1FBQ0QsTUFBTSxTQUFTLEdBQUcsTUFBTSxJQUFJLENBQUMsR0FBRyxDQUFDLG1CQUFtQixDQUFDLDRCQUE0QixDQUFDLElBQUksRUFBRSxVQUE2QixDQUFDLENBQUM7UUFDdkgsT0FBTyxTQUFTLENBQUMsR0FBUSxDQUFDO0lBQzVCLENBQUM7Q0FDRjtBQUFBLENBQUMifQ==
2
+ import { PrototypeUtil } from "@eggjs/core-decorator";
3
+ import { TEGG_CONTEXT } from "@eggjs/module-common";
4
+
5
+ //#region src/app/extend/context.ts
6
+ var TEggPluginContext = class {
7
+ async beginModuleScope(func) {
8
+ await ctxLifecycleMiddleware(this, func);
9
+ }
10
+ get teggContext() {
11
+ const ctx = this;
12
+ if (!ctx[TEGG_CONTEXT]) throw new Error("tegg context have not ready, should call after teggCtxLifecycleMiddleware");
13
+ return ctx[TEGG_CONTEXT];
14
+ }
15
+ async getEggObject(clazz, name) {
16
+ const protoObj = PrototypeUtil.getClazzProto(clazz);
17
+ if (!protoObj) throw new Error(`can not get proto for clazz ${clazz.name}`);
18
+ const proto = protoObj;
19
+ return (await this.app.eggContainerFactory.getOrCreateEggObject(proto, name ?? proto.name)).obj;
20
+ }
21
+ async getEggObjectFromName(name, qualifiers) {
22
+ if (qualifiers) qualifiers = Array.isArray(qualifiers) ? qualifiers : [qualifiers];
23
+ return (await this.app.eggContainerFactory.getOrCreateEggObjectFromName(name, qualifiers)).obj;
24
+ }
25
+ };
26
+
27
+ //#endregion
28
+ export { TEggPluginContext as default };
@@ -1,3 +1,6 @@
1
- import { ctxLifecycleMiddleware } from '../../lib/ctx_lifecycle_middleware.ts';
2
- declare const _default: () => typeof ctxLifecycleMiddleware;
3
- export default _default;
1
+ import { MiddlewareFunc } from "egg";
2
+
3
+ //#region src/app/middleware/tegg_ctx_lifecycle_middleware.d.ts
4
+ declare const _default: () => MiddlewareFunc;
5
+ //#endregion
6
+ export { _default as default };
@@ -1,5 +1,9 @@
1
1
  import { ctxLifecycleMiddleware } from "../../lib/ctx_lifecycle_middleware.js";
2
- export default () => {
3
- return ctxLifecycleMiddleware;
2
+
3
+ //#region src/app/middleware/tegg_ctx_lifecycle_middleware.ts
4
+ var tegg_ctx_lifecycle_middleware_default = () => {
5
+ return ctxLifecycleMiddleware;
4
6
  };
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVnZ19jdHhfbGlmZWN5Y2xlX21pZGRsZXdhcmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBwL21pZGRsZXdhcmUvdGVnZ19jdHhfbGlmZWN5Y2xlX21pZGRsZXdhcmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFFL0UsZUFBZSxHQUFHLEVBQUU7SUFDbEIsT0FBTyxzQkFBc0IsQ0FBQztBQUNoQyxDQUFDLENBQUMifQ==
7
+
8
+ //#endregion
9
+ export { tegg_ctx_lifecycle_middleware_default as default };
package/dist/app.d.ts CHANGED
@@ -1,17 +1,21 @@
1
- import './lib/AppLoadUnit.ts';
2
- import './lib/AppLoadUnitInstance.ts';
3
- import './lib/EggCompatibleObject.ts';
4
- import type { Application, ILifecycleBoot } from 'egg';
5
- export default class App implements ILifecycleBoot {
6
- private readonly app;
7
- private compatibleHook?;
8
- private eggContextHandler;
9
- private eggQualifierProtoHook;
10
- private loadUnitMultiInstanceProtoHook;
11
- private configSourceEggPrototypeHook;
12
- constructor(app: Application);
13
- configWillLoad(): void;
14
- configDidLoad(): void;
15
- didLoad(): Promise<void>;
16
- beforeClose(): Promise<void>;
1
+ import "./lib/AppLoadUnit.js";
2
+ import "./lib/AppLoadUnitInstance.js";
3
+ import "./lib/EggCompatibleObject.js";
4
+ import { Application, ILifecycleBoot } from "egg";
5
+
6
+ //#region src/app.d.ts
7
+ declare class TeggAppBoot implements ILifecycleBoot {
8
+ private readonly app;
9
+ private compatibleHook?;
10
+ private eggContextHandler;
11
+ private eggQualifierProtoHook;
12
+ private loadUnitMultiInstanceProtoHook;
13
+ private configSourceEggPrototypeHook;
14
+ constructor(app: Application);
15
+ configWillLoad(): void;
16
+ configDidLoad(): void;
17
+ didLoad(): Promise<void>;
18
+ beforeClose(): Promise<void>;
17
19
  }
20
+ //#endregion
21
+ export { TeggAppBoot as default };