egg 4.1.0-beta.3 → 4.1.0-beta.31
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/agent.d.ts +3 -7
- package/dist/agent.js +6 -10
- package/dist/ajv.d.ts +1 -0
- package/dist/ajv.js +2 -0
- package/dist/aop.d.ts +1 -0
- package/dist/aop.js +2 -0
- package/dist/app/extend/context.d.ts +166 -193
- package/dist/app/extend/context.js +259 -244
- package/dist/app/extend/helper.d.ts +31 -36
- package/dist/app/extend/helper.js +41 -45
- package/dist/app/extend/request.d.ts +127 -140
- package/dist/app/extend/request.js +258 -219
- package/dist/app/extend/response.d.ts +22 -32
- package/dist/app/extend/response.js +34 -36
- package/dist/app/middleware/body_parser.d.ts +2 -2
- package/dist/app/middleware/body_parser.js +3 -7
- package/dist/app/middleware/meta.d.ts +9 -10
- package/dist/app/middleware/meta.js +19 -13
- package/dist/app/middleware/notfound.d.ts +6 -10
- package/dist/app/middleware/notfound.js +28 -25
- package/dist/app/middleware/override_method.d.ts +2 -2
- package/dist/app/middleware/override_method.js +3 -7
- package/dist/app/middleware/site_file.d.ts +8 -12
- package/dist/app/middleware/site_file.js +52 -37
- package/dist/config/config.default.d.ts +3 -8
- package/dist/config/config.default.js +377 -256
- package/dist/config/config.local.d.ts +3 -10
- package/dist/config/config.local.js +9 -7
- package/dist/config/config.unittest.d.ts +3 -9
- package/dist/config/config.unittest.js +9 -10
- package/dist/config/favicon.png +0 -0
- package/dist/config/plugin.d.ts +3 -124
- package/dist/config/plugin.js +154 -53
- package/dist/dal.d.ts +1 -0
- package/dist/dal.js +2 -0
- package/dist/helper.d.ts +1 -0
- package/dist/helper.js +2 -0
- package/dist/index.d.ts +106 -19
- package/dist/index.js +89 -19
- package/dist/lib/agent.d.ts +12 -17
- package/dist/lib/agent.js +45 -54
- package/dist/lib/application.d.ts +47 -62
- package/dist/lib/application.js +249 -197
- package/dist/lib/core/base_context_class.d.ts +13 -17
- package/dist/lib/core/base_context_class.js +15 -17
- package/dist/lib/core/base_context_logger.d.ts +35 -39
- package/dist/lib/core/base_context_logger.js +60 -58
- package/dist/lib/core/base_hook_class.d.ts +11 -17
- package/dist/lib/core/base_hook_class.js +22 -26
- package/dist/lib/core/context_httpclient.d.ts +16 -20
- package/dist/lib/core/context_httpclient.js +26 -29
- package/dist/lib/core/httpclient.d.ts +12 -15
- package/dist/lib/core/httpclient.js +37 -34
- package/dist/lib/core/logger.d.ts +3 -7
- package/dist/lib/core/logger.js +36 -30
- package/dist/lib/core/messenger/IMessenger.d.ts +49 -53
- package/dist/lib/core/messenger/IMessenger.js +2 -1
- package/dist/lib/core/messenger/base.d.ts +7 -11
- package/dist/lib/core/messenger/base.js +29 -29
- package/dist/lib/core/messenger/index.d.ts +4 -8
- package/dist/lib/core/messenger/index.js +8 -11
- package/dist/lib/core/messenger/ipc.d.ts +55 -59
- package/dist/lib/core/messenger/ipc.js +138 -120
- package/dist/lib/core/messenger/local.d.ts +56 -61
- package/dist/lib/core/messenger/local.js +131 -124
- package/dist/lib/core/utils.d.ts +2 -5
- package/dist/lib/core/utils.js +66 -44
- package/dist/lib/define.d.ts +76 -0
- package/dist/lib/define.js +59 -0
- package/dist/lib/egg.d.ts +272 -294
- package/dist/lib/egg.js +574 -507
- package/dist/lib/error/CookieLimitExceedError.d.ts +4 -7
- package/dist/lib/error/CookieLimitExceedError.js +12 -15
- package/dist/lib/error/MessageUnhandledRejectionError.d.ts +4 -7
- package/dist/lib/error/MessageUnhandledRejectionError.js +12 -15
- package/dist/lib/error/index.d.ts +2 -3
- package/dist/lib/error/index.js +3 -4
- package/dist/lib/loader/AgentWorkerLoader.d.ts +7 -12
- package/dist/lib/loader/AgentWorkerLoader.js +18 -22
- package/dist/lib/loader/AppWorkerLoader.d.ts +12 -17
- package/dist/lib/loader/AppWorkerLoader.js +37 -35
- package/dist/lib/loader/EggApplicationLoader.d.ts +3 -7
- package/dist/lib/loader/EggApplicationLoader.js +4 -7
- package/dist/lib/loader/index.d.ts +3 -4
- package/dist/lib/loader/index.js +4 -5
- package/dist/lib/start.d.ts +18 -22
- package/dist/lib/start.js +42 -32
- package/dist/lib/types.d.ts +277 -230
- package/dist/lib/types.js +3 -14
- package/dist/lib/types.plugin.d.ts +20 -0
- package/dist/lib/types.plugin.js +24 -0
- package/dist/orm.d.ts +1 -0
- package/dist/orm.js +2 -0
- package/dist/schedule.d.ts +2 -0
- package/dist/schedule.js +5 -0
- package/dist/transaction.d.ts +1 -0
- package/dist/transaction.js +2 -0
- package/dist/urllib.d.ts +1 -1
- package/dist/urllib.js +2 -3
- package/package.json +49 -32
- package/dist/lib/utils.d.ts +0 -5
- package/dist/lib/utils.js +0 -14
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import "../../
|
|
3
|
-
import {
|
|
4
|
-
|
|
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
|
-
|
|
1
|
+
import { EventEmitter, captureRejectionSymbol } from 'node:events';
|
|
2
|
+
import { MessageUnhandledRejectionError } from "../../error/index.js";
|
|
3
|
+
import { EggApplicationCore } from "../../egg.js";
|
|
4
|
+
export class BaseMessenger extends EventEmitter {
|
|
5
|
+
egg;
|
|
6
|
+
constructor(egg) {
|
|
7
|
+
super({ captureRejections: true });
|
|
8
|
+
this.egg = egg;
|
|
9
|
+
this[captureRejectionSymbol] = this.onRejection.bind(this);
|
|
10
|
+
}
|
|
11
|
+
onRejection(err, event, ...args) {
|
|
12
|
+
this.egg.coreLogger.error(new MessageUnhandledRejectionError(err, event, args));
|
|
13
|
+
}
|
|
14
|
+
emit(eventName, ...args) {
|
|
15
|
+
const hasListeners = this.listenerCount(eventName) > 0;
|
|
16
|
+
try {
|
|
17
|
+
return super.emit(eventName, ...args);
|
|
18
|
+
}
|
|
19
|
+
catch (e) {
|
|
20
|
+
let err = e;
|
|
21
|
+
if (!(err instanceof Error)) {
|
|
22
|
+
err = new Error(String(err));
|
|
23
|
+
}
|
|
24
|
+
this.egg.coreLogger.error(new MessageUnhandledRejectionError(err, eventName, args));
|
|
25
|
+
return hasListeners;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9tZXNzZW5nZXIvYmFzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLHNCQUFzQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRW5FLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3RFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUVsRCxNQUFNLE9BQU8sYUFBYyxTQUFRLFlBQVk7SUFDMUIsR0FBRyxDQUFxQjtJQUUzQyxZQUFZLEdBQXVCO1FBQ2pDLEtBQUssQ0FBQyxFQUFFLGlCQUFpQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7UUFDbkMsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7UUFFZixJQUFJLENBQUMsc0JBQXNCLENBQUMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBRU8sV0FBVyxDQUFDLEdBQVUsRUFBRSxLQUFzQixFQUFFLEdBQUcsSUFBVztRQUNwRSxJQUFJLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsSUFBSSw4QkFBOEIsQ0FBQyxHQUFHLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDbEYsQ0FBQztJQUVELElBQUksQ0FBQyxTQUEwQixFQUFFLEdBQUcsSUFBVztRQUM3QyxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN2RCxJQUFJLENBQUM7WUFDSCxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUM7UUFDeEMsQ0FBQztRQUFDLE9BQU8sQ0FBVSxFQUFFLENBQUM7WUFDcEIsSUFBSSxHQUFHLEdBQUcsQ0FBVSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxDQUFDLEdBQUcsWUFBWSxLQUFLLENBQUMsRUFBRSxDQUFDO2dCQUM1QixHQUFHLEdBQUcsSUFBSSxLQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7WUFDL0IsQ0FBQztZQUNELElBQUksQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxJQUFJLDhCQUE4QixDQUFDLEdBQUcsRUFBRSxTQUFTLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztZQUNwRixPQUFPLFlBQVksQ0FBQztRQUN0QixDQUFDO0lBQ0gsQ0FBQztDQUNGIn0=
|
|
@@ -1,11 +1,7 @@
|
|
|
1
|
-
import { IMessenger } from
|
|
2
|
-
import { EggApplicationCore } from
|
|
3
|
-
|
|
4
|
-
//#region src/lib/core/messenger/index.d.ts
|
|
5
|
-
|
|
1
|
+
import type { IMessenger } from './IMessenger.ts';
|
|
2
|
+
import type { EggApplicationCore } from '../../egg.ts';
|
|
3
|
+
export type { IMessenger } from './IMessenger.ts';
|
|
6
4
|
/**
|
|
7
5
|
* @class Messenger
|
|
8
6
|
*/
|
|
9
|
-
declare function create(egg: EggApplicationCore): IMessenger;
|
|
10
|
-
//#endregion
|
|
11
|
-
export { type IMessenger, create };
|
|
7
|
+
export declare function create(egg: EggApplicationCore): IMessenger;
|
|
@@ -1,13 +1,10 @@
|
|
|
1
|
-
import { Messenger } from "./local.js";
|
|
2
|
-
import { Messenger as
|
|
3
|
-
|
|
4
|
-
//#region src/lib/core/messenger/index.ts
|
|
1
|
+
import { Messenger as LocalMessenger } from "./local.js";
|
|
2
|
+
import { Messenger as IPCMessenger } from "./ipc.js";
|
|
5
3
|
/**
|
|
6
|
-
* @class Messenger
|
|
7
|
-
*/
|
|
8
|
-
function create(egg) {
|
|
9
|
-
|
|
4
|
+
* @class Messenger
|
|
5
|
+
*/
|
|
6
|
+
export function create(egg) {
|
|
7
|
+
const messenger = egg.options.mode === 'single' ? new LocalMessenger(egg) : new IPCMessenger(egg);
|
|
8
|
+
return messenger;
|
|
10
9
|
}
|
|
11
|
-
|
|
12
|
-
//#endregion
|
|
13
|
-
export { create };
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvbWVzc2VuZ2VyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLElBQUksY0FBYyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxTQUFTLElBQUksWUFBWSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBTXJEOztHQUVHO0FBQ0gsTUFBTSxVQUFVLE1BQU0sQ0FBQyxHQUF1QjtJQUM1QyxNQUFNLFNBQVMsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksY0FBYyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsRyxPQUFPLFNBQVMsQ0FBQztBQUNuQixDQUFDIn0=
|
|
@@ -1,63 +1,59 @@
|
|
|
1
|
-
import { IMessenger } from
|
|
2
|
-
import { EggApplicationCore } from
|
|
3
|
-
import { BaseMessenger } from
|
|
4
|
-
|
|
5
|
-
//#region src/lib/core/messenger/ipc.d.ts
|
|
6
|
-
|
|
1
|
+
import type { IMessenger } from './IMessenger.ts';
|
|
2
|
+
import type { EggApplicationCore } from '../../egg.ts';
|
|
3
|
+
import { BaseMessenger } from './base.ts';
|
|
7
4
|
/**
|
|
8
5
|
* Communication between app worker and agent worker by IPC channel
|
|
9
6
|
*/
|
|
10
|
-
declare class Messenger extends BaseMessenger implements IMessenger {
|
|
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
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
7
|
+
export declare class Messenger extends BaseMessenger implements IMessenger {
|
|
8
|
+
#private;
|
|
9
|
+
readonly pid: string;
|
|
10
|
+
opids: string[];
|
|
11
|
+
constructor(egg: EggApplicationCore);
|
|
12
|
+
/**
|
|
13
|
+
* Send message to all agent and app
|
|
14
|
+
* @param {String} action - message key
|
|
15
|
+
* @param {Object} data - message value
|
|
16
|
+
* @return {Messenger} this
|
|
17
|
+
*/
|
|
18
|
+
broadcast(action: string, data?: unknown): Messenger;
|
|
19
|
+
/**
|
|
20
|
+
* send message to the specified process
|
|
21
|
+
* @param {String} workerId - the workerId of the receiver
|
|
22
|
+
* @param {String} action - message key
|
|
23
|
+
* @param {Object} data - message value
|
|
24
|
+
* @return {Messenger} this
|
|
25
|
+
*/
|
|
26
|
+
sendTo(workerId: string, action: string, data?: unknown): Messenger;
|
|
27
|
+
/**
|
|
28
|
+
* send message to one app worker by random
|
|
29
|
+
* - if it's running in agent, it will send to one of app workers
|
|
30
|
+
* - if it's running in app, it will send to agent
|
|
31
|
+
* @param {String} action - message key
|
|
32
|
+
* @param {Object} data - message value
|
|
33
|
+
* @return {Messenger} this
|
|
34
|
+
*/
|
|
35
|
+
sendRandom(action: string, data?: unknown): Messenger;
|
|
36
|
+
/**
|
|
37
|
+
* send message to app
|
|
38
|
+
* @param {String} action - message key
|
|
39
|
+
* @param {Object} data - message value
|
|
40
|
+
* @return {Messenger} this
|
|
41
|
+
*/
|
|
42
|
+
sendToApp(action: string, data?: unknown): Messenger;
|
|
43
|
+
/**
|
|
44
|
+
* send message to agent
|
|
45
|
+
* @param {String} action - message key
|
|
46
|
+
* @param {Object} data - message value
|
|
47
|
+
* @return {Messenger} this
|
|
48
|
+
*/
|
|
49
|
+
sendToAgent(action: string, data?: unknown): Messenger;
|
|
50
|
+
/**
|
|
51
|
+
* @param {String} action - message key
|
|
52
|
+
* @param {Object} data - message value
|
|
53
|
+
* @param {String} to - let master know how to send message
|
|
54
|
+
* @return {Messenger} this
|
|
55
|
+
*/
|
|
56
|
+
send(action: string, data: unknown | undefined, to?: string): Messenger;
|
|
57
|
+
onMessage(message: any): void;
|
|
58
|
+
close(): void;
|
|
61
59
|
}
|
|
62
|
-
//#endregion
|
|
63
|
-
export { Messenger };
|
|
@@ -1,122 +1,140 @@
|
|
|
1
|
+
import { debuglog } from 'node:util';
|
|
2
|
+
import workerThreads from 'node:worker_threads';
|
|
3
|
+
import { sendmessage } from 'sendmessage';
|
|
1
4
|
import { BaseMessenger } from "./base.js";
|
|
2
|
-
|
|
3
|
-
import workerThreads from "node:worker_threads";
|
|
4
|
-
import { sendmessage } from "sendmessage";
|
|
5
|
-
|
|
6
|
-
//#region src/lib/core/messenger/ipc.ts
|
|
7
|
-
const debug = debuglog("egg/lib/core/messenger/ipc");
|
|
5
|
+
const debug = debuglog('egg/lib/core/messenger/ipc');
|
|
8
6
|
/**
|
|
9
|
-
* Communication between app worker and agent worker by IPC channel
|
|
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
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
7
|
+
* Communication between app worker and agent worker by IPC channel
|
|
8
|
+
*/
|
|
9
|
+
export class Messenger extends BaseMessenger {
|
|
10
|
+
pid;
|
|
11
|
+
opids = [];
|
|
12
|
+
constructor(egg) {
|
|
13
|
+
super(egg);
|
|
14
|
+
this.pid = String(process.pid);
|
|
15
|
+
// pids of agent or app managed by master
|
|
16
|
+
// - retrieve app worker pids when it's an agent worker
|
|
17
|
+
// - retrieve agent worker pids when it's an app worker
|
|
18
|
+
this.on('egg-pids', (workerIds) => {
|
|
19
|
+
debug('[%s:%s] got egg-pids %j', this.egg.type, this.pid, workerIds);
|
|
20
|
+
this.opids = workerIds.map((workerId) => String(workerId));
|
|
21
|
+
});
|
|
22
|
+
this.onMessage = this.onMessage.bind(this);
|
|
23
|
+
process.on('message', this.onMessage);
|
|
24
|
+
if (!workerThreads.isMainThread) {
|
|
25
|
+
workerThreads.parentPort.on('message', this.onMessage);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Send message to all agent and app
|
|
30
|
+
* @param {String} action - message key
|
|
31
|
+
* @param {Object} data - message value
|
|
32
|
+
* @return {Messenger} this
|
|
33
|
+
*/
|
|
34
|
+
broadcast(action, data) {
|
|
35
|
+
debug('[%s:%s] broadcast %s with %j', this.egg.type, this.pid, action, data);
|
|
36
|
+
this.send(action, data, 'app');
|
|
37
|
+
this.send(action, data, 'agent');
|
|
38
|
+
return this;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* send message to the specified process
|
|
42
|
+
* @param {String} workerId - the workerId of the receiver
|
|
43
|
+
* @param {String} action - message key
|
|
44
|
+
* @param {Object} data - message value
|
|
45
|
+
* @return {Messenger} this
|
|
46
|
+
*/
|
|
47
|
+
sendTo(workerId, action, data) {
|
|
48
|
+
debug('[%s:%s] send %s with %j to workerId:%s', this.egg.type, this.pid, action, data, workerId);
|
|
49
|
+
const message = {
|
|
50
|
+
action,
|
|
51
|
+
data,
|
|
52
|
+
/**
|
|
53
|
+
* @deprecated Keep compatible, please use receiverWorkerId instead
|
|
54
|
+
*/
|
|
55
|
+
receiverPid: String(workerId),
|
|
56
|
+
receiverWorkerId: String(workerId),
|
|
57
|
+
};
|
|
58
|
+
this.#sendMessage(message);
|
|
59
|
+
return this;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* send message to one app worker by random
|
|
63
|
+
* - if it's running in agent, it will send to one of app workers
|
|
64
|
+
* - if it's running in app, it will send to agent
|
|
65
|
+
* @param {String} action - message key
|
|
66
|
+
* @param {Object} data - message value
|
|
67
|
+
* @return {Messenger} this
|
|
68
|
+
*/
|
|
69
|
+
sendRandom(action, data) {
|
|
70
|
+
if (this.opids.length === 0) {
|
|
71
|
+
debug('[%s:%s] no pids, ignore sendRandom %s with %j', this.egg.type, this.pid, action, data);
|
|
72
|
+
return this;
|
|
73
|
+
}
|
|
74
|
+
const index = Math.floor(Math.random() * this.opids.length);
|
|
75
|
+
const workerId = this.opids[index];
|
|
76
|
+
this.sendTo(workerId, action, data);
|
|
77
|
+
return this;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* send message to app
|
|
81
|
+
* @param {String} action - message key
|
|
82
|
+
* @param {Object} data - message value
|
|
83
|
+
* @return {Messenger} this
|
|
84
|
+
*/
|
|
85
|
+
sendToApp(action, data) {
|
|
86
|
+
debug('[%s:%s] send %s with %j to all app', this.egg.type, this.pid, action, data);
|
|
87
|
+
this.send(action, data, 'app');
|
|
88
|
+
return this;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* send message to agent
|
|
92
|
+
* @param {String} action - message key
|
|
93
|
+
* @param {Object} data - message value
|
|
94
|
+
* @return {Messenger} this
|
|
95
|
+
*/
|
|
96
|
+
sendToAgent(action, data) {
|
|
97
|
+
debug('[%s:%s] send %s with %j to all agent', this.egg.type, this.pid, action, data);
|
|
98
|
+
this.send(action, data, 'agent');
|
|
99
|
+
return this;
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* @param {String} action - message key
|
|
103
|
+
* @param {Object} data - message value
|
|
104
|
+
* @param {String} to - let master know how to send message
|
|
105
|
+
* @return {Messenger} this
|
|
106
|
+
*/
|
|
107
|
+
send(action, data, to) {
|
|
108
|
+
debug('send message %s with %j to %s', action, data, to);
|
|
109
|
+
this.#sendMessage({
|
|
110
|
+
action,
|
|
111
|
+
data,
|
|
112
|
+
to,
|
|
113
|
+
});
|
|
114
|
+
return this;
|
|
115
|
+
}
|
|
116
|
+
#sendMessage(message) {
|
|
117
|
+
debug('[%s:%s] send message %j, mode: %s', this.egg.type, this.pid, message, this.egg.options.mode);
|
|
118
|
+
sendmessage(process, message);
|
|
119
|
+
}
|
|
120
|
+
onMessage(message) {
|
|
121
|
+
if (typeof message?.action === 'string') {
|
|
122
|
+
debug('[%s:%s] got message %s with %j, receiverWorkerId: %s', this.egg.type, this.pid, message.action, message.data, message.receiverWorkerId ?? message.receiverPid);
|
|
123
|
+
this.emit(message.action, message.data);
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
if (message?.type === 'Buffer') {
|
|
127
|
+
// {"type":"Buffer","data":[255,153,....]
|
|
128
|
+
debug('[%s:%s] got an invalid message: %s', this.egg.type, this.pid, Buffer.from(message.data));
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
debug('[%s:%s] got an invalid message %j', this.egg.type, this.pid, message);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
close() {
|
|
136
|
+
process.removeListener('message', this.onMessage);
|
|
137
|
+
this.removeAllListeners();
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXBjLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL21lc3Nlbmdlci9pcGMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUNyQyxPQUFPLGFBQWEsTUFBTSxxQkFBcUIsQ0FBQztBQUVoRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBSTFDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFFMUMsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLDRCQUE0QixDQUFDLENBQUM7QUFFckQ7O0dBRUc7QUFDSCxNQUFNLE9BQU8sU0FBVSxTQUFRLGFBQWE7SUFDakMsR0FBRyxDQUFTO0lBQ3JCLEtBQUssR0FBYSxFQUFFLENBQUM7SUFFckIsWUFBWSxHQUF1QjtRQUNqQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDWCxJQUFJLENBQUMsR0FBRyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDL0IseUNBQXlDO1FBQ3pDLHVEQUF1RDtRQUN2RCx1REFBdUQ7UUFDdkQsSUFBSSxDQUFDLEVBQUUsQ0FBQyxVQUFVLEVBQUUsQ0FBQyxTQUFTLEVBQUUsRUFBRTtZQUNoQyxLQUFLLENBQUMseUJBQXlCLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLEdBQUcsRUFBRSxTQUFTLENBQUMsQ0FBQztZQUNyRSxJQUFJLENBQUMsS0FBSyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFnQixFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztRQUNyRSxDQUFDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7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
|
|
@@ -1,65 +1,60 @@
|
|
|
1
|
-
import { IMessenger } from
|
|
2
|
-
import { EggApplicationCore } from
|
|
3
|
-
import { BaseMessenger } from
|
|
4
|
-
|
|
5
|
-
//#region src/lib/core/messenger/local.d.ts
|
|
6
|
-
|
|
1
|
+
import type { IMessenger } from './IMessenger.ts';
|
|
2
|
+
import type { EggApplicationCore } from '../../egg.ts';
|
|
3
|
+
import { BaseMessenger } from './base.ts';
|
|
7
4
|
/**
|
|
8
5
|
* Communication between app worker and agent worker with EventEmitter
|
|
9
6
|
*/
|
|
10
|
-
declare class Messenger extends BaseMessenger implements IMessenger {
|
|
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
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
7
|
+
export declare class Messenger extends BaseMessenger implements IMessenger {
|
|
8
|
+
readonly pid: string;
|
|
9
|
+
constructor(egg: EggApplicationCore);
|
|
10
|
+
/**
|
|
11
|
+
* Send message to all agent and app
|
|
12
|
+
* @param {String} action - message key
|
|
13
|
+
* @param {Object} data - message value
|
|
14
|
+
* @return {Messenger} this
|
|
15
|
+
*/
|
|
16
|
+
broadcast(action: string, data?: unknown): Messenger;
|
|
17
|
+
/**
|
|
18
|
+
* send message to the specified process
|
|
19
|
+
* Notice: in single process mode, it only can send to self process,
|
|
20
|
+
* and it will send to both agent and app's messengers.
|
|
21
|
+
* @param {String} workerId - the workerId of the receiver
|
|
22
|
+
* @param {String} action - message key
|
|
23
|
+
* @param {Object} data - message value
|
|
24
|
+
* @return {Messenger} this
|
|
25
|
+
*/
|
|
26
|
+
sendTo(workerId: string, action: string, data?: unknown): Messenger;
|
|
27
|
+
/**
|
|
28
|
+
* send message to one worker by random
|
|
29
|
+
* Notice: in single process mode, we only start one agent worker and one app worker
|
|
30
|
+
* - if it's running in agent, it will send to one of app workers
|
|
31
|
+
* - if it's running in app, it will send to agent
|
|
32
|
+
* @param {String} action - message key
|
|
33
|
+
* @param {Object} data - message value
|
|
34
|
+
* @return {Messenger} this
|
|
35
|
+
*/
|
|
36
|
+
sendRandom(action: string, data?: unknown): Messenger;
|
|
37
|
+
/**
|
|
38
|
+
* send message to app
|
|
39
|
+
* @param {String} action - message key
|
|
40
|
+
* @param {Object} data - message value
|
|
41
|
+
* @return {Messenger} this
|
|
42
|
+
*/
|
|
43
|
+
sendToApp(action: string, data?: unknown): Messenger;
|
|
44
|
+
/**
|
|
45
|
+
* send message to agent
|
|
46
|
+
* @param {String} action - message key
|
|
47
|
+
* @param {Object} data - message value
|
|
48
|
+
* @return {Messenger} this
|
|
49
|
+
*/
|
|
50
|
+
sendToAgent(action: string, data?: unknown): Messenger;
|
|
51
|
+
/**
|
|
52
|
+
* @param {String} action - message key
|
|
53
|
+
* @param {Object} data - message value
|
|
54
|
+
* @param {String} to - let master know how to send message
|
|
55
|
+
* @return {Messenger} this
|
|
56
|
+
*/
|
|
57
|
+
send(action: string, data: unknown, to?: string): Messenger;
|
|
58
|
+
onMessage(message: any): void;
|
|
59
|
+
close(): void;
|
|
63
60
|
}
|
|
64
|
-
//#endregion
|
|
65
|
-
export { Messenger };
|