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.
Files changed (102) hide show
  1. package/dist/agent.d.ts +3 -7
  2. package/dist/agent.js +6 -10
  3. package/dist/ajv.d.ts +1 -0
  4. package/dist/ajv.js +2 -0
  5. package/dist/aop.d.ts +1 -0
  6. package/dist/aop.js +2 -0
  7. package/dist/app/extend/context.d.ts +166 -193
  8. package/dist/app/extend/context.js +259 -244
  9. package/dist/app/extend/helper.d.ts +31 -36
  10. package/dist/app/extend/helper.js +41 -45
  11. package/dist/app/extend/request.d.ts +127 -140
  12. package/dist/app/extend/request.js +258 -219
  13. package/dist/app/extend/response.d.ts +22 -32
  14. package/dist/app/extend/response.js +34 -36
  15. package/dist/app/middleware/body_parser.d.ts +2 -2
  16. package/dist/app/middleware/body_parser.js +3 -7
  17. package/dist/app/middleware/meta.d.ts +9 -10
  18. package/dist/app/middleware/meta.js +19 -13
  19. package/dist/app/middleware/notfound.d.ts +6 -10
  20. package/dist/app/middleware/notfound.js +28 -25
  21. package/dist/app/middleware/override_method.d.ts +2 -2
  22. package/dist/app/middleware/override_method.js +3 -7
  23. package/dist/app/middleware/site_file.d.ts +8 -12
  24. package/dist/app/middleware/site_file.js +52 -37
  25. package/dist/config/config.default.d.ts +3 -8
  26. package/dist/config/config.default.js +377 -256
  27. package/dist/config/config.local.d.ts +3 -10
  28. package/dist/config/config.local.js +9 -7
  29. package/dist/config/config.unittest.d.ts +3 -9
  30. package/dist/config/config.unittest.js +9 -10
  31. package/dist/config/favicon.png +0 -0
  32. package/dist/config/plugin.d.ts +3 -124
  33. package/dist/config/plugin.js +154 -53
  34. package/dist/dal.d.ts +1 -0
  35. package/dist/dal.js +2 -0
  36. package/dist/helper.d.ts +1 -0
  37. package/dist/helper.js +2 -0
  38. package/dist/index.d.ts +106 -19
  39. package/dist/index.js +89 -19
  40. package/dist/lib/agent.d.ts +12 -17
  41. package/dist/lib/agent.js +45 -54
  42. package/dist/lib/application.d.ts +47 -62
  43. package/dist/lib/application.js +249 -197
  44. package/dist/lib/core/base_context_class.d.ts +13 -17
  45. package/dist/lib/core/base_context_class.js +15 -17
  46. package/dist/lib/core/base_context_logger.d.ts +35 -39
  47. package/dist/lib/core/base_context_logger.js +60 -58
  48. package/dist/lib/core/base_hook_class.d.ts +11 -17
  49. package/dist/lib/core/base_hook_class.js +22 -26
  50. package/dist/lib/core/context_httpclient.d.ts +16 -20
  51. package/dist/lib/core/context_httpclient.js +26 -29
  52. package/dist/lib/core/httpclient.d.ts +12 -15
  53. package/dist/lib/core/httpclient.js +37 -34
  54. package/dist/lib/core/logger.d.ts +3 -7
  55. package/dist/lib/core/logger.js +36 -30
  56. package/dist/lib/core/messenger/IMessenger.d.ts +49 -53
  57. package/dist/lib/core/messenger/IMessenger.js +2 -1
  58. package/dist/lib/core/messenger/base.d.ts +7 -11
  59. package/dist/lib/core/messenger/base.js +29 -29
  60. package/dist/lib/core/messenger/index.d.ts +4 -8
  61. package/dist/lib/core/messenger/index.js +8 -11
  62. package/dist/lib/core/messenger/ipc.d.ts +55 -59
  63. package/dist/lib/core/messenger/ipc.js +138 -120
  64. package/dist/lib/core/messenger/local.d.ts +56 -61
  65. package/dist/lib/core/messenger/local.js +131 -124
  66. package/dist/lib/core/utils.d.ts +2 -5
  67. package/dist/lib/core/utils.js +66 -44
  68. package/dist/lib/define.d.ts +76 -0
  69. package/dist/lib/define.js +59 -0
  70. package/dist/lib/egg.d.ts +272 -294
  71. package/dist/lib/egg.js +574 -507
  72. package/dist/lib/error/CookieLimitExceedError.d.ts +4 -7
  73. package/dist/lib/error/CookieLimitExceedError.js +12 -15
  74. package/dist/lib/error/MessageUnhandledRejectionError.d.ts +4 -7
  75. package/dist/lib/error/MessageUnhandledRejectionError.js +12 -15
  76. package/dist/lib/error/index.d.ts +2 -3
  77. package/dist/lib/error/index.js +3 -4
  78. package/dist/lib/loader/AgentWorkerLoader.d.ts +7 -12
  79. package/dist/lib/loader/AgentWorkerLoader.js +18 -22
  80. package/dist/lib/loader/AppWorkerLoader.d.ts +12 -17
  81. package/dist/lib/loader/AppWorkerLoader.js +37 -35
  82. package/dist/lib/loader/EggApplicationLoader.d.ts +3 -7
  83. package/dist/lib/loader/EggApplicationLoader.js +4 -7
  84. package/dist/lib/loader/index.d.ts +3 -4
  85. package/dist/lib/loader/index.js +4 -5
  86. package/dist/lib/start.d.ts +18 -22
  87. package/dist/lib/start.js +42 -32
  88. package/dist/lib/types.d.ts +277 -230
  89. package/dist/lib/types.js +3 -14
  90. package/dist/lib/types.plugin.d.ts +20 -0
  91. package/dist/lib/types.plugin.js +24 -0
  92. package/dist/orm.d.ts +1 -0
  93. package/dist/orm.js +2 -0
  94. package/dist/schedule.d.ts +2 -0
  95. package/dist/schedule.js +5 -0
  96. package/dist/transaction.d.ts +1 -0
  97. package/dist/transaction.js +2 -0
  98. package/dist/urllib.d.ts +1 -1
  99. package/dist/urllib.js +2 -3
  100. package/package.json +49 -32
  101. package/dist/lib/utils.d.ts +0 -5
  102. package/dist/lib/utils.js +0 -14
@@ -1,126 +1,133 @@
1
+ import { debuglog } from 'node:util';
1
2
  import { BaseMessenger } from "./base.js";
2
- import { debuglog } from "node:util";
3
-
4
- //#region src/lib/core/messenger/local.ts
5
- const debug = debuglog("egg/lib/core/messenger/local");
3
+ const debug = debuglog('egg/lib/core/messenger/local');
6
4
  /**
7
- * Communication between app worker and agent worker with EventEmitter
8
- */
9
- var Messenger = class extends BaseMessenger {
10
- pid;
11
- constructor(egg) {
12
- super(egg);
13
- this.pid = String(process.pid);
14
- }
15
- /**
16
- * Send message to all agent and app
17
- * @param {String} action - message key
18
- * @param {Object} data - message value
19
- * @return {Messenger} this
20
- */
21
- broadcast(action, data) {
22
- debug("[%s:%s] broadcast %s with %j", this.egg.type, this.pid, action, data);
23
- this.send(action, data, "both");
24
- return this;
25
- }
26
- /**
27
- * send message to the specified process
28
- * Notice: in single process mode, it only can send to self process,
29
- * and it will send to both agent and app's messengers.
30
- * @param {String} workerId - the workerId of the receiver
31
- * @param {String} action - message key
32
- * @param {Object} data - message value
33
- * @return {Messenger} this
34
- */
35
- sendTo(workerId, action, data) {
36
- debug("[%s:%s] send %s with %j to %s", this.egg.type, this.pid, action, data, workerId);
37
- if (String(workerId) !== this.pid) return this;
38
- this.send(action, data, "both");
39
- return this;
40
- }
41
- /**
42
- * send message to one worker by random
43
- * Notice: in single process mode, we only start one agent worker and one app worker
44
- * - if it's running in agent, it will send to one of app workers
45
- * - if it's running in app, it will send to agent
46
- * @param {String} action - message key
47
- * @param {Object} data - message value
48
- * @return {Messenger} this
49
- */
50
- sendRandom(action, data) {
51
- debug("[%s:%s] send %s with %j to opposite", this.egg.type, this.pid, action, data);
52
- this.send(action, data, "opposite");
53
- return this;
54
- }
55
- /**
56
- * send message to app
57
- * @param {String} action - message key
58
- * @param {Object} data - message value
59
- * @return {Messenger} this
60
- */
61
- sendToApp(action, data) {
62
- debug("[%s:%s] send %s with %j to all app", this.egg.type, this.pid, action, data);
63
- this.send(action, data, "application");
64
- return this;
65
- }
66
- /**
67
- * send message to agent
68
- * @param {String} action - message key
69
- * @param {Object} data - message value
70
- * @return {Messenger} this
71
- */
72
- sendToAgent(action, data) {
73
- debug("[%s:%s] send %s with %j to all agent", this.egg.type, this.pid, action, data);
74
- this.send(action, data, "agent");
75
- return this;
76
- }
77
- /**
78
- * @param {String} action - message key
79
- * @param {Object} data - message value
80
- * @param {String} to - let master know how to send message
81
- * @return {Messenger} this
82
- */
83
- send(action, data, to) {
84
- process.nextTick(() => {
85
- const { egg } = this;
86
- let application;
87
- let agent;
88
- let opposite;
89
- if (egg.type === "application") {
90
- application = egg;
91
- agent = egg.agent;
92
- opposite = agent;
93
- } else {
94
- agent = egg;
95
- application = egg.application;
96
- opposite = application;
97
- }
98
- if (!to) to = egg.type === "application" ? "agent" : "application";
99
- if (application && application.messenger && (to === "application" || to === "both")) application.messenger.onMessage({
100
- action,
101
- data
102
- });
103
- if (agent && agent.messenger && (to === "agent" || to === "both")) agent.messenger.onMessage({
104
- action,
105
- data
106
- });
107
- if (opposite && opposite.messenger && to === "opposite") opposite.messenger.onMessage({
108
- action,
109
- data
110
- });
111
- });
112
- return this;
113
- }
114
- onMessage(message) {
115
- if (typeof message?.action === "string") {
116
- debug("[%s:%s] got message %s with %j", this.egg.type, this.pid, message.action, message.data);
117
- this.emit(message.action, message.data);
118
- } else debug("[%s:%s] got an invalid message %j", this.egg.type, this.pid, message);
119
- }
120
- close() {
121
- this.removeAllListeners();
122
- }
123
- };
124
-
125
- //#endregion
126
- export { Messenger };
5
+ * Communication between app worker and agent worker with EventEmitter
6
+ */
7
+ export class Messenger extends BaseMessenger {
8
+ pid;
9
+ constructor(egg) {
10
+ super(egg);
11
+ this.pid = String(process.pid);
12
+ }
13
+ /**
14
+ * Send message to all agent and app
15
+ * @param {String} action - message key
16
+ * @param {Object} data - message value
17
+ * @return {Messenger} this
18
+ */
19
+ broadcast(action, data) {
20
+ debug('[%s:%s] broadcast %s with %j', this.egg.type, this.pid, action, data);
21
+ this.send(action, data, 'both');
22
+ return this;
23
+ }
24
+ /**
25
+ * send message to the specified process
26
+ * Notice: in single process mode, it only can send to self process,
27
+ * and it will send to both agent and app's messengers.
28
+ * @param {String} workerId - the workerId of the receiver
29
+ * @param {String} action - message key
30
+ * @param {Object} data - message value
31
+ * @return {Messenger} this
32
+ */
33
+ sendTo(workerId, action, data) {
34
+ debug('[%s:%s] send %s with %j to %s', this.egg.type, this.pid, action, data, workerId);
35
+ if (String(workerId) !== this.pid) {
36
+ return this;
37
+ }
38
+ this.send(action, data, 'both');
39
+ return this;
40
+ }
41
+ /**
42
+ * send message to one worker by random
43
+ * Notice: in single process mode, we only start one agent worker and one app worker
44
+ * - if it's running in agent, it will send to one of app workers
45
+ * - if it's running in app, it will send to agent
46
+ * @param {String} action - message key
47
+ * @param {Object} data - message value
48
+ * @return {Messenger} this
49
+ */
50
+ sendRandom(action, data) {
51
+ debug('[%s:%s] send %s with %o to opposite', this.egg.type, this.pid, action, data);
52
+ this.send(action, data, 'opposite');
53
+ return this;
54
+ }
55
+ /**
56
+ * send message to app
57
+ * @param {String} action - message key
58
+ * @param {Object} data - message value
59
+ * @return {Messenger} this
60
+ */
61
+ sendToApp(action, data) {
62
+ debug('[%s:%s] send %s with %o to all app', this.egg.type, this.pid, action, data);
63
+ this.send(action, data, 'application');
64
+ return this;
65
+ }
66
+ /**
67
+ * send message to agent
68
+ * @param {String} action - message key
69
+ * @param {Object} data - message value
70
+ * @return {Messenger} this
71
+ */
72
+ sendToAgent(action, data) {
73
+ debug('[%s:%s] send %s with %o to all agent', this.egg.type, this.pid, action, data);
74
+ this.send(action, data, 'agent');
75
+ return this;
76
+ }
77
+ /**
78
+ * @param {String} action - message key
79
+ * @param {Object} data - message value
80
+ * @param {String} to - let master know how to send message
81
+ * @return {Messenger} this
82
+ */
83
+ send(action, data, to) {
84
+ if (to === 'app') {
85
+ // alias app to application
86
+ to = 'application';
87
+ }
88
+ // use nextTick to keep it async as IPC messenger
89
+ process.nextTick(() => {
90
+ const { egg } = this;
91
+ let application;
92
+ let agent;
93
+ let opposite;
94
+ if (egg.type === 'application') {
95
+ application = egg;
96
+ agent = egg.agent;
97
+ opposite = agent;
98
+ }
99
+ else {
100
+ agent = egg;
101
+ application = egg.application;
102
+ opposite = application;
103
+ }
104
+ if (!to) {
105
+ to = egg.type === 'application' ? 'agent' : 'application';
106
+ }
107
+ debug('[%s:%s] send action:%s with %o to %s', this.egg.type, this.pid, action, data, to);
108
+ if (application && application.messenger && (to === 'application' || to === 'both')) {
109
+ application.messenger.onMessage({ action, data });
110
+ }
111
+ if (agent && agent.messenger && (to === 'agent' || to === 'both')) {
112
+ agent.messenger.onMessage({ action, data });
113
+ }
114
+ if (opposite && opposite.messenger && to === 'opposite') {
115
+ opposite.messenger.onMessage({ action, data });
116
+ }
117
+ });
118
+ return this;
119
+ }
120
+ onMessage(message) {
121
+ if (typeof message?.action === 'string') {
122
+ debug('[%s:%s] got message %s with %j', this.egg.type, this.pid, message.action, message.data);
123
+ this.emit(message.action, message.data);
124
+ }
125
+ else {
126
+ debug('[%s:%s] got an invalid message %j', this.egg.type, this.pid, message);
127
+ }
128
+ }
129
+ close() {
130
+ this.removeAllListeners();
131
+ }
132
+ }
133
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvbWVzc2VuZ2VyL2xvY2FsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFJckMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUUxQyxNQUFNLEtBQUssR0FBRyxRQUFRLENBQUMsOEJBQThCLENBQUMsQ0FBQztBQUV2RDs7R0FFRztBQUNILE1BQU0sT0FBTyxTQUFVLFNBQVEsYUFBYTtJQUNqQyxHQUFHLENBQVM7SUFFckIsWUFBWSxHQUF1QjtRQUNqQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDWCxJQUFJLENBQUMsR0FBRyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsU0FBUyxDQUFDLE1BQWMsRUFBRSxJQUFjO1FBQ3RDLEtBQUssQ0FBQyw4QkFBOEIsRUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUM3RSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDaEMsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7Ozs7Ozs7O09BUUc7SUFDSCxNQUFNLENBQUMsUUFBZ0IsRUFBRSxNQUFjLEVBQUUsSUFBYztRQUNyRCxLQUFLLENBQUMsK0JBQStCLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLEdBQUcsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQ3hGLElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQyxLQUFLLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUNsQyxPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFDRCxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDaEMsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7Ozs7Ozs7O09BUUc7SUFDSCxVQUFVLENBQUMsTUFBYyxFQUFFLElBQWM7UUFDdkMsS0FBSyxDQUFDLHFDQUFxQyxFQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxHQUFHLEVBQUUsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ3BGLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLElBQUksRUFBRSxVQUFVLENBQUMsQ0FBQztRQUNwQyxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILFNBQVMsQ0FBQyxNQUFjLEVBQUUsSUFBYztRQUN0QyxLQUFLLENBQUMsb0NBQW9DLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLEdBQUcsRUFBRSxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDbkYsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLGFBQWEsQ0FBQyxDQUFDO1FBQ3ZDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsV0FBVyxDQUFDLE1BQWMsRUFBRSxJQUFjO1FBQ3hDLEtBQUssQ0FBQyxzQ0FBc0MsRUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNyRixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDakMsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxJQUFJLENBQUMsTUFBYyxFQUFFLElBQWEsRUFBRSxFQUFXO1FBQzdDLElBQUksRUFBRSxLQUFLLEtBQUssRUFBRSxDQUFDO1lBQ2pCLDJCQUEyQjtZQUMzQixFQUFFLEdBQUcsYUFBYSxDQUFDO1FBQ3JCLENBQUM7UUFDRCxpREFBaUQ7UUFDakQsT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDcEIsTUFBTSxFQUFFLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQztZQUNyQixJQUFJLFdBQVcsQ0FBQztZQUNoQixJQUFJLEtBQUssQ0FBQztZQUNWLElBQUksUUFBUSxDQUFDO1lBRWIsSUFBSSxHQUFHLENBQUMsSUFBSSxLQUFLLGFBQWEsRUFBRSxDQUFDO2dCQUMvQixXQUFXLEdBQUcsR0FBRyxDQUFDO2dCQUNsQixLQUFLLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQztnQkFDbEIsUUFBUSxHQUFHLEtBQUssQ0FBQztZQUNuQixDQUFDO2lCQUFNLENBQUM7Z0JBQ04sS0FBSyxHQUFHLEdBQUcsQ0FBQztnQkFDWixXQUFXLEdBQUcsR0FBRyxDQUFDLFdBQVcsQ0FBQztnQkFDOUIsUUFBUSxHQUFHLFdBQVcsQ0FBQztZQUN6QixDQUFDO1lBQ0QsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDO2dCQUNSLEVBQUUsR0FBRyxHQUFHLENBQUMsSUFBSSxLQUFLLGFBQWEsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUM7WUFDNUQsQ0FBQztZQUNELEtBQUssQ0FBQyxzQ0FBc0MsRUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFFekYsSUFBSSxXQUFXLElBQUksV0FBVyxDQUFDLFNBQVMsSUFBSSxDQUFDLEVBQUUsS0FBSyxhQUFhLElBQUksRUFBRSxLQUFLLE1BQU0sQ0FBQyxFQUFFLENBQUM7Z0JBQ3BGLFdBQVcsQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7WUFDcEQsQ0FBQztZQUNELElBQUksS0FBSyxJQUFJLEtBQUssQ0FBQyxTQUFTLElBQUksQ0FBQyxFQUFFLEtBQUssT0FBTyxJQUFJLEVBQUUsS0FBSyxNQUFNLENBQUMsRUFBRSxDQUFDO2dCQUNsRSxLQUFLLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1lBQzlDLENBQUM7WUFDRCxJQUFJLFFBQVEsSUFBSSxRQUFRLENBQUMsU0FBUyxJQUFJLEVBQUUsS0FBSyxVQUFVLEVBQUUsQ0FBQztnQkFDeEQsUUFBUSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztZQUNqRCxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxTQUFTLENBQUMsT0FBWTtRQUNwQixJQUFJLE9BQU8sT0FBTyxFQUFFLE1BQU0sS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUN4QyxLQUFLLENBQUMsZ0NBQWdDLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLEdBQUcsRUFBRSxPQUFPLENBQUMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUMvRixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFDLENBQUM7YUFBTSxDQUFDO1lBQ04sS0FBSyxDQUFDLG1DQUFtQyxFQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDL0UsQ0FBQztJQUNILENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUM7SUFDNUIsQ0FBQztDQU9GIn0=
@@ -1,5 +1,2 @@
1
- //#region src/lib/core/utils.d.ts
2
- declare function convertObject(obj: any, ignore?: string | RegExp | (string | RegExp)[]): any;
3
- declare function safeParseURL(url: string): URL | null;
4
- //#endregion
5
- export { convertObject, safeParseURL };
1
+ export declare function convertObject(obj: any, ignore?: string | RegExp | (string | RegExp)[]): any;
2
+ export declare function safeParseURL(url: string): URL | null;
@@ -1,48 +1,70 @@
1
- import util from "node:util";
2
- import { isAsyncFunction, isClass, isFunction, isGeneratorFunction, isPrimitive, isRegExp, isSymbol } from "is-type-of";
3
-
4
- //#region src/lib/core/utils.ts
5
- function convertObject(obj, ignore = []) {
6
- if (!Array.isArray(ignore)) ignore = [ignore];
7
- for (const key of Object.keys(obj)) obj[key] = convertValue(key, obj[key], ignore);
8
- return obj;
1
+ import util from 'node:util';
2
+ import { isSymbol, isRegExp, isPrimitive, isClass, isFunction, isGeneratorFunction, isAsyncFunction } from 'is-type-of';
3
+ export function convertObject(obj, ignore = []) {
4
+ if (!Array.isArray(ignore)) {
5
+ ignore = [ignore];
6
+ }
7
+ for (const key of Object.keys(obj)) {
8
+ obj[key] = convertValue(key, obj[key], ignore);
9
+ }
10
+ return obj;
9
11
  }
10
12
  function convertValue(key, value, ignore) {
11
- if (value === null || value === void 0) return value;
12
- let hit = false;
13
- for (const matchKey of ignore) if (typeof matchKey === "string" && matchKey === key) {
14
- hit = true;
15
- break;
16
- } else if (isRegExp(matchKey) && matchKey.test(key)) {
17
- hit = true;
18
- break;
19
- }
20
- if (!hit) {
21
- if (isSymbol(value) || isRegExp(value) || value instanceof URL) return value.toString();
22
- if (isPrimitive(value) || Array.isArray(value)) return value;
23
- }
24
- if (Object.getPrototypeOf(value) === Object.prototype) return convertObject(value, ignore);
25
- const name = value.name || "anonymous";
26
- if (isClass(value)) return `<Class ${name}>`;
27
- if (isFunction(value)) {
28
- if (isGeneratorFunction(value)) return `<GeneratorFunction ${name}>`;
29
- if (isAsyncFunction(value)) return `<AsyncFunction ${name}>`;
30
- return `<Function ${name}>`;
31
- }
32
- const typeName = value.constructor.name;
33
- if (typeName) {
34
- if (Buffer.isBuffer(value) || typeof value === "string") return `<${typeName} len: ${value.length}>`;
35
- return `<${typeName}>`;
36
- }
37
- return util.format(value);
13
+ if (value === null || value === undefined) {
14
+ return value;
15
+ }
16
+ let hit = false;
17
+ for (const matchKey of ignore) {
18
+ if (typeof matchKey === 'string' && matchKey === key) {
19
+ hit = true;
20
+ break;
21
+ }
22
+ else if (isRegExp(matchKey) && matchKey.test(key)) {
23
+ hit = true;
24
+ break;
25
+ }
26
+ }
27
+ if (!hit) {
28
+ if (isSymbol(value) || isRegExp(value) || value instanceof URL) {
29
+ return value.toString();
30
+ }
31
+ if (isPrimitive(value) || Array.isArray(value)) {
32
+ return value;
33
+ }
34
+ }
35
+ // only convert recursively when it's a plain object,
36
+ // o = {}
37
+ if (Object.getPrototypeOf(value) === Object.prototype) {
38
+ return convertObject(value, ignore);
39
+ }
40
+ // support class
41
+ const name = value.name || 'anonymous';
42
+ if (isClass(value)) {
43
+ return `<Class ${name}>`;
44
+ }
45
+ // support generator function
46
+ if (isFunction(value)) {
47
+ if (isGeneratorFunction(value))
48
+ return `<GeneratorFunction ${name}>`;
49
+ if (isAsyncFunction(value))
50
+ return `<AsyncFunction ${name}>`;
51
+ return `<Function ${name}>`;
52
+ }
53
+ const typeName = value.constructor.name;
54
+ if (typeName) {
55
+ if (Buffer.isBuffer(value) || typeof value === 'string') {
56
+ return `<${typeName} len: ${value.length}>`;
57
+ }
58
+ return `<${typeName}>`;
59
+ }
60
+ return util.format(value);
38
61
  }
39
- function safeParseURL(url) {
40
- try {
41
- return new URL(url);
42
- } catch {
43
- return null;
44
- }
62
+ export function safeParseURL(url) {
63
+ try {
64
+ return new URL(url);
65
+ }
66
+ catch {
67
+ return null;
68
+ }
45
69
  }
46
-
47
- //#endregion
48
- export { convertObject, safeParseURL };
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2NvcmUvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxJQUFJLE1BQU0sV0FBVyxDQUFDO0FBQzdCLE9BQU8sRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLFdBQVcsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLG1CQUFtQixFQUFFLGVBQWUsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUV4SCxNQUFNLFVBQVUsYUFBYSxDQUFDLEdBQVEsRUFBRSxTQUFnRCxFQUFFO0lBQ3hGLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDM0IsTUFBTSxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDcEIsQ0FBQztJQUNELEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ25DLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxZQUFZLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBQ0QsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBRUQsU0FBUyxZQUFZLENBQUMsR0FBVyxFQUFFLEtBQVUsRUFBRSxNQUEyQjtJQUN4RSxJQUFJLEtBQUssS0FBSyxJQUFJLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRSxDQUFDO1FBQzFDLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVELElBQUksR0FBRyxHQUFHLEtBQUssQ0FBQztJQUNoQixLQUFLLE1BQU0sUUFBUSxJQUFJLE1BQU0sRUFBRSxDQUFDO1FBQzlCLElBQUksT0FBTyxRQUFRLEtBQUssUUFBUSxJQUFJLFFBQVEsS0FBSyxHQUFHLEVBQUUsQ0FBQztZQUNyRCxHQUFHLEdBQUcsSUFBSSxDQUFDO1lBQ1gsTUFBTTtRQUNSLENBQUM7YUFBTSxJQUFJLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxRQUFRLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDcEQsR0FBRyxHQUFHLElBQUksQ0FBQztZQUNYLE1BQU07UUFDUixDQUFDO0lBQ0gsQ0FBQztJQUNELElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUNULElBQUksUUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLLFlBQVksR0FBRyxFQUFFLENBQUM7WUFDL0QsT0FBTyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDMUIsQ0FBQztRQUNELElBQUksV0FBVyxDQUFDLEtBQUssQ0FBQyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUMvQyxPQUFPLEtBQUssQ0FBQztRQUNmLENBQUM7SUFDSCxDQUFDO0lBRUQscURBQXFEO0lBQ3JELFNBQVM7SUFDVCxJQUFJLE1BQU0sQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLEtBQUssTUFBTSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQ3RELE9BQU8sYUFBYSxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBRUQsZ0JBQWdCO0lBQ2hCLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLElBQUksV0FBVyxDQUFDO0lBQ3ZDLElBQUksT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDbkIsT0FBTyxVQUFVLElBQUksR0FBRyxDQUFDO0lBQzNCLENBQUM7SUFFRCw2QkFBNkI7SUFDN0IsSUFBSSxVQUFVLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUN0QixJQUFJLG1CQUFtQixDQUFDLEtBQUssQ0FBQztZQUFFLE9BQU8sc0JBQXNCLElBQUksR0FBRyxDQUFDO1FBQ3JFLElBQUksZUFBZSxDQUFDLEtBQUssQ0FBQztZQUFFLE9BQU8sa0JBQWtCLElBQUksR0FBRyxDQUFDO1FBQzdELE9BQU8sYUFBYSxJQUFJLEdBQUcsQ0FBQztJQUM5QixDQUFDO0lBRUQsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUM7SUFDeEMsSUFBSSxRQUFRLEVBQUUsQ0FBQztRQUNiLElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUN4RCxPQUFPLElBQUksUUFBUSxTQUFTLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQztRQUM5QyxDQUFDO1FBQ0QsT0FBTyxJQUFJLFFBQVEsR0FBRyxDQUFDO0lBQ3pCLENBQUM7SUFFRCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7QUFDNUIsQ0FBQztBQUVELE1BQU0sVUFBVSxZQUFZLENBQUMsR0FBVztJQUN0QyxJQUFJLENBQUM7UUFDSCxPQUFPLElBQUksR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3RCLENBQUM7SUFBQyxNQUFNLENBQUM7UUFDUCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7QUFDSCxDQUFDIn0=
@@ -0,0 +1,76 @@
1
+ import type { PartialDeep } from 'type-fest';
2
+ import type { EggAppConfig, EggAppInfo, EggEnvType } from './types.ts';
3
+ /**
4
+ * Partial EggAppConfig
5
+ */
6
+ export type PartialEggConfig = PartialDeep<EggAppConfig>;
7
+ /**
8
+ * Configuration factory function return type
9
+ */
10
+ export type EggConfigFactory = (appInfo: EggAppInfo) => PartialEggConfig;
11
+ /**
12
+ * Define configuration with type safety
13
+ * @example
14
+ * ```ts
15
+ * import { defineConfig } from 'egg';
16
+ *
17
+ * export default defineConfig({
18
+ * keys: 'my-keys',
19
+ * middleware: []
20
+ * });
21
+ * ```
22
+ */
23
+ export declare function defineConfig(config: PartialEggConfig): PartialEggConfig;
24
+ /**
25
+ * Define configuration factory function with type safety
26
+ * @example
27
+ * ```ts
28
+ * export default defineConfigFactory((appInfo): PartialEggConfig => ({
29
+ * keys: appInfo.name + '_keys',
30
+ * middleware: []
31
+ * }));
32
+ * ```
33
+ */
34
+ export declare function defineConfigFactory(configFactory: EggConfigFactory): EggConfigFactory;
35
+ /**
36
+ * Define plugin meta with type safety
37
+ */
38
+ export interface EggPluginMeta {
39
+ /** the plugin name, it can be used in `dep` */
40
+ name: string;
41
+ /** whether enabled */
42
+ enable: boolean;
43
+ /** the directory of the plugin package */
44
+ path: string;
45
+ /** the dependent plugins, you can use the plugin name */
46
+ dependencies?: string[];
47
+ /** the optional dependent plugins. */
48
+ optionalDependencies?: string[];
49
+ /** specify the serverEnv that only enable the plugin in it, default to all envs */
50
+ env?: EggEnvType[];
51
+ }
52
+ /**
53
+ * Egg plugin options, user can't provide name, it will be generated by the plugin factory.
54
+ */
55
+ export type EggPluginOptions = PartialDeep<Omit<EggPluginMeta, 'name'>>;
56
+ /**
57
+ * Egg plugin factory type, the return value is a record of plugin name and plugin meta.
58
+ */
59
+ export type EggPluginFactory = (options?: EggPluginOptions) => Record<string, EggPluginMeta>;
60
+ /**
61
+ * Define plugin factory with type safety
62
+ * @example
63
+ * ```ts
64
+ * import { definePluginFactory } from 'egg';
65
+ *
66
+ * export default definePluginFactory({
67
+ * name: 'my-plugin',
68
+ * enable: true,
69
+ * path: 'path/to/my-plugin',
70
+ * dependencies: ['watcher'],
71
+ * optionalDependencies: ['view'],
72
+ * env: ['local', 'unittest'],
73
+ * });
74
+ * ```
75
+ */
76
+ export declare function definePluginFactory(pluginMeta: EggPluginMeta): EggPluginFactory;
@@ -0,0 +1,59 @@
1
+ import assert from 'node:assert/strict';
2
+ /**
3
+ * Define configuration with type safety
4
+ * @example
5
+ * ```ts
6
+ * import { defineConfig } from 'egg';
7
+ *
8
+ * export default defineConfig({
9
+ * keys: 'my-keys',
10
+ * middleware: []
11
+ * });
12
+ * ```
13
+ */
14
+ export function defineConfig(config) {
15
+ return config;
16
+ }
17
+ /**
18
+ * Define configuration factory function with type safety
19
+ * @example
20
+ * ```ts
21
+ * export default defineConfigFactory((appInfo): PartialEggConfig => ({
22
+ * keys: appInfo.name + '_keys',
23
+ * middleware: []
24
+ * }));
25
+ * ```
26
+ */
27
+ export function defineConfigFactory(configFactory) {
28
+ return configFactory;
29
+ }
30
+ /**
31
+ * Define plugin factory with type safety
32
+ * @example
33
+ * ```ts
34
+ * import { definePluginFactory } from 'egg';
35
+ *
36
+ * export default definePluginFactory({
37
+ * name: 'my-plugin',
38
+ * enable: true,
39
+ * path: 'path/to/my-plugin',
40
+ * dependencies: ['watcher'],
41
+ * optionalDependencies: ['view'],
42
+ * env: ['local', 'unittest'],
43
+ * });
44
+ * ```
45
+ */
46
+ export function definePluginFactory(pluginMeta) {
47
+ assert(pluginMeta.name, 'plugin name is required');
48
+ assert(pluginMeta.path, 'plugin path is required');
49
+ return (options) => ({
50
+ [pluginMeta.name]: {
51
+ ...pluginMeta,
52
+ ...options,
53
+ name: pluginMeta.name,
54
+ // skip merge `eggPlugin` field from package.json
55
+ skipMerge: true,
56
+ },
57
+ });
58
+ }
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmaW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi9kZWZpbmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxNQUFNLE1BQU0sb0JBQW9CLENBQUM7QUFnQnhDOzs7Ozs7Ozs7OztHQVdHO0FBQ0gsTUFBTSxVQUFVLFlBQVksQ0FBQyxNQUF3QjtJQUNuRCxPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQ7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxVQUFVLG1CQUFtQixDQUFDLGFBQStCO0lBQ2pFLE9BQU8sYUFBYSxDQUFDO0FBQ3ZCLENBQUM7QUE4QkQ7Ozs7Ozs7Ozs7Ozs7OztHQWVHO0FBQ0gsTUFBTSxVQUFVLG1CQUFtQixDQUFDLFVBQXlCO0lBQzNELE1BQU0sQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLHlCQUF5QixDQUFDLENBQUM7SUFDbkQsTUFBTSxDQUFDLFVBQVUsQ0FBQyxJQUFJLEVBQUUseUJBQXlCLENBQUMsQ0FBQztJQUNuRCxPQUFPLENBQUMsT0FBMEIsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUN0QyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUNqQixHQUFHLFVBQVU7WUFDYixHQUFHLE9BQU87WUFDVixJQUFJLEVBQUUsVUFBVSxDQUFDLElBQUk7WUFDckIsaURBQWlEO1lBQ2pELFNBQVMsRUFBRSxJQUFJO1NBQ2hCO0tBQ0YsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyJ9