egg 3.29.0 → 4.0.0-beta.2

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 (202) hide show
  1. package/README.md +2 -1
  2. package/README.zh-CN.md +7 -5
  3. package/dist/commonjs/agent.d.ts +4 -0
  4. package/dist/commonjs/agent.js +10 -0
  5. package/dist/commonjs/app/extend/context.d.ts +2 -0
  6. package/dist/commonjs/app/extend/context.js +263 -0
  7. package/dist/commonjs/app/middleware/body_parser.d.ts +2 -0
  8. package/dist/commonjs/app/middleware/body_parser.js +8 -0
  9. package/dist/commonjs/app/middleware/meta.d.ts +11 -0
  10. package/dist/commonjs/app/middleware/meta.js +22 -0
  11. package/dist/commonjs/app/middleware/notfound.d.ts +8 -0
  12. package/dist/commonjs/app/middleware/notfound.js +31 -0
  13. package/dist/commonjs/app/middleware/override_method.d.ts +2 -0
  14. package/dist/commonjs/app/middleware/override_method.js +8 -0
  15. package/dist/commonjs/app/middleware/site_file.d.ts +7 -0
  16. package/dist/commonjs/app/middleware/site_file.js +59 -0
  17. package/dist/commonjs/config/config.default.d.ts +9 -0
  18. package/dist/commonjs/config/config.default.js +378 -0
  19. package/dist/commonjs/config/config.local.d.ts +8 -0
  20. package/dist/commonjs/config/config.local.js +12 -0
  21. package/dist/commonjs/config/config.unittest.d.ts +7 -0
  22. package/dist/commonjs/config/config.unittest.js +11 -0
  23. package/dist/commonjs/config/plugin.d.ts +122 -0
  24. package/dist/commonjs/config/plugin.js +125 -0
  25. package/dist/commonjs/index.d.ts +61 -0
  26. package/dist/commonjs/index.js +89 -0
  27. package/dist/commonjs/lib/agent.d.ts +19 -0
  28. package/dist/commonjs/lib/agent.js +58 -0
  29. package/dist/commonjs/lib/application.d.ts +66 -0
  30. package/dist/commonjs/lib/application.js +281 -0
  31. package/dist/commonjs/lib/core/base_context_class.d.ts +14 -0
  32. package/dist/commonjs/lib/core/base_context_class.js +22 -0
  33. package/dist/commonjs/lib/core/base_context_logger.d.ts +36 -0
  34. package/dist/commonjs/lib/core/base_context_logger.js +64 -0
  35. package/dist/commonjs/lib/core/base_hook_class.d.ts +11 -0
  36. package/dist/commonjs/lib/core/base_hook_class.js +30 -0
  37. package/dist/commonjs/lib/core/context_httpclient.d.ts +16 -0
  38. package/dist/commonjs/lib/core/context_httpclient.js +30 -0
  39. package/dist/commonjs/lib/core/httpclient.d.ts +14 -0
  40. package/dist/commonjs/lib/core/httpclient.js +40 -0
  41. package/dist/commonjs/lib/core/logger.d.ts +3 -0
  42. package/dist/commonjs/lib/core/logger.js +40 -0
  43. package/dist/commonjs/lib/core/messenger/IMessenger.d.ts +50 -0
  44. package/dist/commonjs/lib/core/messenger/IMessenger.js +3 -0
  45. package/dist/commonjs/lib/core/messenger/index.d.ts +7 -0
  46. package/dist/commonjs/lib/core/messenger/index.js +14 -0
  47. package/dist/commonjs/lib/core/messenger/ipc.d.ts +57 -0
  48. package/dist/commonjs/lib/core/messenger/ipc.js +126 -0
  49. package/dist/commonjs/lib/core/messenger/local.d.ts +61 -0
  50. package/dist/commonjs/lib/core/messenger/local.js +134 -0
  51. package/dist/commonjs/lib/core/singleton.d.ts +23 -0
  52. package/dist/commonjs/lib/core/singleton.js +120 -0
  53. package/dist/commonjs/lib/core/utils.d.ts +2 -0
  54. package/dist/commonjs/lib/core/utils.js +77 -0
  55. package/dist/commonjs/lib/egg.d.ts +271 -0
  56. package/dist/commonjs/lib/egg.js +613 -0
  57. package/dist/commonjs/lib/loader/AgentWorkerLoader.d.ts +12 -0
  58. package/dist/commonjs/lib/loader/AgentWorkerLoader.js +24 -0
  59. package/dist/commonjs/lib/loader/AppWorkerLoader.d.ts +17 -0
  60. package/dist/commonjs/lib/loader/AppWorkerLoader.js +43 -0
  61. package/dist/commonjs/lib/loader/EggApplicationLoader.d.ts +4 -0
  62. package/dist/commonjs/lib/loader/EggApplicationLoader.js +8 -0
  63. package/dist/commonjs/lib/loader/index.d.ts +3 -0
  64. package/dist/commonjs/lib/loader/index.js +22 -0
  65. package/dist/commonjs/lib/start.d.ts +15 -0
  66. package/dist/commonjs/lib/start.js +49 -0
  67. package/dist/commonjs/lib/type.d.ts +296 -0
  68. package/dist/commonjs/lib/type.js +3 -0
  69. package/dist/commonjs/package.json +3 -0
  70. package/dist/esm/agent.d.ts +4 -0
  71. package/dist/esm/agent.js +7 -0
  72. package/dist/esm/app/extend/context.d.ts +2 -0
  73. package/dist/esm/app/extend/context.js +258 -0
  74. package/dist/esm/app/middleware/body_parser.d.ts +2 -0
  75. package/dist/esm/app/middleware/body_parser.js +3 -0
  76. package/dist/esm/app/middleware/meta.d.ts +11 -0
  77. package/dist/esm/app/middleware/meta.js +20 -0
  78. package/dist/esm/app/middleware/notfound.d.ts +8 -0
  79. package/dist/esm/app/middleware/notfound.js +29 -0
  80. package/dist/esm/app/middleware/override_method.d.ts +2 -0
  81. package/dist/esm/app/middleware/override_method.js +3 -0
  82. package/dist/esm/app/middleware/site_file.d.ts +7 -0
  83. package/dist/esm/app/middleware/site_file.js +54 -0
  84. package/dist/esm/config/config.default.d.ts +9 -0
  85. package/dist/esm/config/config.default.js +373 -0
  86. package/dist/esm/config/config.local.d.ts +8 -0
  87. package/dist/esm/config/config.local.js +10 -0
  88. package/dist/esm/config/config.unittest.d.ts +7 -0
  89. package/dist/esm/config/config.unittest.js +9 -0
  90. package/dist/esm/config/favicon.png +0 -0
  91. package/dist/esm/config/plugin.d.ts +122 -0
  92. package/dist/esm/config/plugin.js +123 -0
  93. package/dist/esm/index.d.ts +61 -0
  94. package/dist/esm/index.js +65 -0
  95. package/dist/esm/lib/agent.d.ts +19 -0
  96. package/dist/esm/lib/agent.js +54 -0
  97. package/dist/esm/lib/application.d.ts +66 -0
  98. package/dist/esm/lib/application.js +274 -0
  99. package/dist/esm/lib/core/base_context_class.d.ts +14 -0
  100. package/dist/esm/lib/core/base_context_class.js +18 -0
  101. package/dist/esm/lib/core/base_context_logger.d.ts +36 -0
  102. package/dist/esm/lib/core/base_context_logger.js +60 -0
  103. package/dist/esm/lib/core/base_hook_class.d.ts +11 -0
  104. package/dist/esm/lib/core/base_hook_class.js +23 -0
  105. package/dist/esm/lib/core/context_httpclient.d.ts +16 -0
  106. package/dist/esm/lib/core/context_httpclient.js +26 -0
  107. package/dist/esm/lib/core/httpclient.d.ts +14 -0
  108. package/dist/esm/lib/core/httpclient.js +33 -0
  109. package/dist/esm/lib/core/logger.d.ts +3 -0
  110. package/dist/esm/lib/core/logger.js +37 -0
  111. package/dist/esm/lib/core/messenger/IMessenger.d.ts +50 -0
  112. package/dist/esm/lib/core/messenger/IMessenger.js +2 -0
  113. package/dist/esm/lib/core/messenger/index.d.ts +7 -0
  114. package/dist/esm/lib/core/messenger/index.js +11 -0
  115. package/dist/esm/lib/core/messenger/ipc.d.ts +57 -0
  116. package/dist/esm/lib/core/messenger/ipc.js +119 -0
  117. package/dist/esm/lib/core/messenger/local.d.ts +61 -0
  118. package/dist/esm/lib/core/messenger/local.js +127 -0
  119. package/dist/esm/lib/core/singleton.d.ts +23 -0
  120. package/dist/esm/lib/core/singleton.js +113 -0
  121. package/dist/esm/lib/core/utils.d.ts +2 -0
  122. package/dist/esm/lib/core/utils.js +70 -0
  123. package/dist/esm/lib/egg.d.ts +271 -0
  124. package/dist/esm/lib/egg.js +573 -0
  125. package/dist/esm/lib/loader/AgentWorkerLoader.d.ts +12 -0
  126. package/dist/esm/lib/loader/AgentWorkerLoader.js +20 -0
  127. package/dist/esm/lib/loader/AppWorkerLoader.d.ts +17 -0
  128. package/dist/esm/lib/loader/AppWorkerLoader.js +39 -0
  129. package/dist/esm/lib/loader/EggApplicationLoader.d.ts +4 -0
  130. package/dist/esm/lib/loader/EggApplicationLoader.js +4 -0
  131. package/dist/esm/lib/loader/index.d.ts +3 -0
  132. package/dist/esm/lib/loader/index.js +4 -0
  133. package/dist/esm/lib/start.d.ts +15 -0
  134. package/dist/esm/lib/start.js +43 -0
  135. package/dist/esm/lib/type.d.ts +296 -0
  136. package/dist/esm/lib/type.js +2 -0
  137. package/dist/esm/package.json +3 -0
  138. package/dist/package.json +4 -0
  139. package/package.json +87 -72
  140. package/src/agent.ts +7 -0
  141. package/{app/extend/context.js → src/app/extend/context.ts} +19 -23
  142. package/src/app/middleware/body_parser.ts +3 -0
  143. package/{app/middleware/meta.js → src/app/middleware/meta.ts} +12 -4
  144. package/{app/middleware/notfound.js → src/app/middleware/notfound.ts} +9 -3
  145. package/src/app/middleware/override_method.ts +3 -0
  146. package/src/app/middleware/site_file.ts +70 -0
  147. package/{config/config.default.js → src/config/config.default.ts} +24 -45
  148. package/src/config/config.local.ts +11 -0
  149. package/src/config/config.unittest.ts +10 -0
  150. package/src/config/favicon.png +0 -0
  151. package/{config/plugin.js → src/config/plugin.ts} +1 -3
  152. package/src/index.ts +78 -0
  153. package/src/lib/agent.ts +66 -0
  154. package/{lib/application.js → src/lib/application.ts} +79 -120
  155. package/src/lib/core/base_context_class.ts +21 -0
  156. package/src/lib/core/base_context_logger.ts +67 -0
  157. package/src/lib/core/base_hook_class.ts +30 -0
  158. package/src/lib/core/context_httpclient.ts +33 -0
  159. package/src/lib/core/httpclient.ts +52 -0
  160. package/src/lib/core/logger.ts +42 -0
  161. package/src/lib/core/messenger/IMessenger.ts +58 -0
  162. package/src/lib/core/messenger/index.ts +15 -0
  163. package/{lib/core/messenger/ipc.js → src/lib/core/messenger/ipc.ts} +24 -29
  164. package/{lib/core/messenger/local.js → src/lib/core/messenger/local.ts} +27 -21
  165. package/{lib/core/singleton.js → src/lib/core/singleton.ts} +56 -33
  166. package/src/lib/core/utils.ts +77 -0
  167. package/{lib/egg.js → src/lib/egg.ts} +262 -219
  168. package/src/lib/loader/AgentWorkerLoader.ts +21 -0
  169. package/src/lib/loader/AppWorkerLoader.ts +42 -0
  170. package/src/lib/loader/EggApplicationLoader.ts +5 -0
  171. package/src/lib/loader/index.ts +3 -0
  172. package/src/lib/start.ts +56 -0
  173. package/src/lib/type.ts +336 -0
  174. package/CHANGELOG.md +0 -2395
  175. package/History.md +0 -52
  176. package/agent.js +0 -11
  177. package/app/middleware/body_parser.js +0 -3
  178. package/app/middleware/override_method.js +0 -3
  179. package/app/middleware/site_file.js +0 -31
  180. package/config/config.local.js +0 -7
  181. package/config/config.unittest.js +0 -8
  182. package/index.d.ts +0 -1288
  183. package/index.js +0 -68
  184. package/lib/agent.js +0 -95
  185. package/lib/core/base_context_class.js +0 -20
  186. package/lib/core/base_context_logger.js +0 -64
  187. package/lib/core/base_hook_class.js +0 -31
  188. package/lib/core/context_httpclient.js +0 -26
  189. package/lib/core/dnscache_httpclient.js +0 -93
  190. package/lib/core/httpclient.js +0 -119
  191. package/lib/core/httpclient_next.js +0 -80
  192. package/lib/core/logger.js +0 -35
  193. package/lib/core/messenger/index.js +0 -14
  194. package/lib/core/utils.js +0 -73
  195. package/lib/loader/agent_worker_loader.js +0 -27
  196. package/lib/loader/app_worker_loader.js +0 -48
  197. package/lib/loader/index.js +0 -5
  198. package/lib/start.js +0 -39
  199. /package/{config → dist/commonjs/config}/favicon.png +0 -0
  200. /package/{app → src/app}/extend/helper.js +0 -0
  201. /package/{app → src/app}/extend/request.js +0 -0
  202. /package/{app → src/app}/extend/response.js +0 -0
@@ -0,0 +1,127 @@
1
+ import { debuglog } from 'node:util';
2
+ import EventEmitter from 'node:events';
3
+ const debug = debuglog('egg:lib:core:messenger:local');
4
+ /**
5
+ * Communication between app worker and agent worker with EventEmitter
6
+ */
7
+ export class Messenger extends EventEmitter {
8
+ pid;
9
+ egg;
10
+ constructor(egg) {
11
+ super();
12
+ this.egg = 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] broadcast %s with %j', 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} pid - the process id of the receiver
31
+ * @param {String} action - message key
32
+ * @param {Object} data - message value
33
+ * @return {Messenger} this
34
+ */
35
+ sendTo(pid, action, data) {
36
+ debug('[%s] send %s with %j to %s', this.pid, action, data, pid);
37
+ if (String(pid) !== this.pid) {
38
+ return this;
39
+ }
40
+ this.send(action, data, 'both');
41
+ return this;
42
+ }
43
+ /**
44
+ * send message to one worker by random
45
+ * Notice: in single process mode, we only start one agent worker and one app worker
46
+ * - if it's running in agent, it will send to one of app workers
47
+ * - if it's running in app, it will send to agent
48
+ * @param {String} action - message key
49
+ * @param {Object} data - message value
50
+ * @return {Messenger} this
51
+ */
52
+ sendRandom(action, data) {
53
+ debug('[%s] send %s with %j to opposite', this.pid, action, data);
54
+ this.send(action, data, 'opposite');
55
+ return this;
56
+ }
57
+ /**
58
+ * send message to app
59
+ * @param {String} action - message key
60
+ * @param {Object} data - message value
61
+ * @return {Messenger} this
62
+ */
63
+ sendToApp(action, data) {
64
+ debug('[%s] send %s with %j to all app', this.pid, action, data);
65
+ this.send(action, data, 'application');
66
+ return this;
67
+ }
68
+ /**
69
+ * send message to agent
70
+ * @param {String} action - message key
71
+ * @param {Object} data - message value
72
+ * @return {Messenger} this
73
+ */
74
+ sendToAgent(action, data) {
75
+ debug('[%s] send %s with %j to all agent', this.pid, action, data);
76
+ this.send(action, data, 'agent');
77
+ return this;
78
+ }
79
+ /**
80
+ * @param {String} action - message key
81
+ * @param {Object} data - message value
82
+ * @param {String} to - let master know how to send message
83
+ * @return {Messenger} this
84
+ */
85
+ send(action, data, to) {
86
+ // use nextTick to keep it async as IPC messenger
87
+ process.nextTick(() => {
88
+ const { egg } = this;
89
+ let application;
90
+ let agent;
91
+ let opposite;
92
+ if (egg.type === 'application') {
93
+ application = egg;
94
+ agent = egg.agent;
95
+ opposite = agent;
96
+ }
97
+ else {
98
+ agent = egg;
99
+ application = egg.application;
100
+ opposite = application;
101
+ }
102
+ if (!to) {
103
+ to = egg.type === 'application' ? 'agent' : 'application';
104
+ }
105
+ if (application && application.messenger && (to === 'application' || to === 'both')) {
106
+ application.messenger.onMessage({ action, data });
107
+ }
108
+ if (agent && agent.messenger && (to === 'agent' || to === 'both')) {
109
+ agent.messenger.onMessage({ action, data });
110
+ }
111
+ if (opposite && opposite.messenger && to === 'opposite') {
112
+ opposite.messenger.onMessage({ action, data });
113
+ }
114
+ });
115
+ return this;
116
+ }
117
+ onMessage(message) {
118
+ if (typeof message?.action === 'string') {
119
+ debug('[%s] got message %s with %j', this.pid, message.action, message.data);
120
+ this.emit(message.action, message.data);
121
+ }
122
+ }
123
+ close() {
124
+ this.removeAllListeners();
125
+ }
126
+ }
127
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvbWVzc2VuZ2VyL2xvY2FsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDckMsT0FBTyxZQUFZLE1BQU0sYUFBYSxDQUFDO0FBSXZDLE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyw4QkFBOEIsQ0FBQyxDQUFDO0FBRXZEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLFNBQVUsU0FBUSxZQUFZO0lBQ2hDLEdBQUcsQ0FBUztJQUNaLEdBQUcsQ0FBcUI7SUFFakMsWUFBWSxHQUF1QjtRQUNqQyxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1FBQ2YsSUFBSSxDQUFDLEdBQUcsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILFNBQVMsQ0FBQyxNQUFjLEVBQUUsSUFBYztRQUN0QyxLQUFLLENBQUMsMkJBQTJCLEVBQUUsSUFBSSxDQUFDLEdBQUcsRUFBRSxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDM0QsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ2hDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7Ozs7OztPQVFHO0lBQ0gsTUFBTSxDQUFDLEdBQVcsRUFBRSxNQUFjLEVBQUUsSUFBYztRQUNoRCxLQUFLLENBQUMsNEJBQTRCLEVBQUUsSUFBSSxDQUFDLEdBQUcsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQ2pFLElBQUksTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFLLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUM3QixPQUFPLElBQUksQ0FBQztR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
@@ -0,0 +1,23 @@
1
+ import type { EggApplicationCore } from '../egg.js';
2
+ export type SingletonCreateMethod = (config: Record<string, any>, app: EggApplicationCore, clientName: string) => unknown | Promise<unknown>;
3
+ export interface SingletonOptions {
4
+ name: string;
5
+ app: EggApplicationCore;
6
+ create: SingletonCreateMethod;
7
+ }
8
+ export declare class Singleton {
9
+ #private;
10
+ readonly clients: Map<string, any>;
11
+ readonly app: EggApplicationCore;
12
+ readonly create: SingletonCreateMethod;
13
+ readonly name: string;
14
+ readonly options: Record<string, any>;
15
+ constructor(options: SingletonOptions);
16
+ init(): void | Promise<void>;
17
+ initSync(): void;
18
+ initAsync(): Promise<void>;
19
+ get(id: string): any;
20
+ getSingletonInstance(id: string): any;
21
+ createInstance(config: Record<string, any>, clientName: string): unknown;
22
+ createInstanceAsync(config: Record<string, any>, clientName: string): Promise<unknown>;
23
+ }
@@ -0,0 +1,113 @@
1
+ import assert from 'node:assert';
2
+ import { isAsyncFunction } from 'is-type-of';
3
+ export class Singleton {
4
+ clients = new Map();
5
+ app;
6
+ create;
7
+ name;
8
+ options;
9
+ constructor(options) {
10
+ assert(options.name, '[egg:singleton] Singleton#constructor options.name is required');
11
+ assert(options.app, '[egg:singleton] Singleton#constructor options.app is required');
12
+ assert(options.create, '[egg:singleton] Singleton#constructor options.create is required');
13
+ assert(!(options.name in options.app), `[egg:singleton] ${options.name} is already exists in app`);
14
+ this.app = options.app;
15
+ this.name = options.name;
16
+ this.create = options.create;
17
+ this.options = options.app.config[this.name] ?? {};
18
+ }
19
+ init() {
20
+ return isAsyncFunction(this.create) ? this.initAsync() : this.initSync();
21
+ }
22
+ initSync() {
23
+ const options = this.options;
24
+ assert(!(options.client && options.clients), `[egg:singleton] ${this.name} can not set options.client and options.clients both`);
25
+ // alias app[name] as client, but still support createInstance method
26
+ if (options.client) {
27
+ const client = this.createInstance(options.client, options.name);
28
+ this.#setClientToApp(client);
29
+ this.#extendDynamicMethods(client);
30
+ return;
31
+ }
32
+ // multi client, use app[name].getInstance(id)
33
+ if (options.clients) {
34
+ Object.keys(options.clients).forEach(id => {
35
+ const client = this.createInstance(options.clients[id], id);
36
+ this.clients.set(id, client);
37
+ });
38
+ this.#setClientToApp(this);
39
+ return;
40
+ }
41
+ // no config.clients and config.client
42
+ this.#setClientToApp(this);
43
+ }
44
+ async initAsync() {
45
+ const options = this.options;
46
+ assert(!(options.client && options.clients), `[egg:singleton] ${this.name} can not set options.client and options.clients both`);
47
+ // alias app[name] as client, but still support createInstance method
48
+ if (options.client) {
49
+ const client = await this.createInstanceAsync(options.client, options.name);
50
+ this.#setClientToApp(client);
51
+ this.#extendDynamicMethods(client);
52
+ return;
53
+ }
54
+ // multi client, use app[name].getInstance(id)
55
+ if (options.clients) {
56
+ await Promise.all(Object.keys(options.clients).map((id) => {
57
+ return this.createInstanceAsync(options.clients[id], id)
58
+ .then(client => this.clients.set(id, client));
59
+ }));
60
+ this.#setClientToApp(this);
61
+ return;
62
+ }
63
+ // no config.clients and config.client
64
+ this.#setClientToApp(this);
65
+ }
66
+ #setClientToApp(client) {
67
+ Reflect.set(this.app, this.name, client);
68
+ }
69
+ get(id) {
70
+ return this.clients.get(id);
71
+ }
72
+ // alias to `get(id)`
73
+ getSingletonInstance(id) {
74
+ return this.clients.get(id);
75
+ }
76
+ createInstance(config, clientName) {
77
+ // async creator only support createInstanceAsync
78
+ assert(!isAsyncFunction(this.create), `egg:singleton ${this.name} only support create asynchronous, please use createInstanceAsync`);
79
+ // options.default will be merge in to options.clients[id]
80
+ config = {
81
+ ...this.options.default,
82
+ ...config,
83
+ };
84
+ return this.create(config, this.app, clientName);
85
+ }
86
+ async createInstanceAsync(config, clientName) {
87
+ // options.default will be merge in to options.clients[id]
88
+ config = {
89
+ ...this.options.default,
90
+ ...config,
91
+ };
92
+ return await this.create(config, this.app, clientName);
93
+ }
94
+ #extendDynamicMethods(client) {
95
+ assert(!client.createInstance, 'singleton instance should not have createInstance method');
96
+ assert(!client.createInstanceAsync, 'singleton instance should not have createInstanceAsync method');
97
+ try {
98
+ let extendable = client;
99
+ // Object.preventExtensions() or Object.freeze()
100
+ if (!Object.isExtensible(client) || Object.isFrozen(client)) {
101
+ // eslint-disable-next-line no-proto
102
+ extendable = client.__proto__ || client;
103
+ }
104
+ extendable.createInstance = this.createInstance.bind(this);
105
+ extendable.createInstanceAsync = this.createInstanceAsync.bind(this);
106
+ }
107
+ catch (err) {
108
+ this.app.coreLogger.warn('[egg:singleton] %s dynamic create is disabled because of client is un-extendable', this.name);
109
+ this.app.coreLogger.warn(err);
110
+ }
111
+ }
112
+ }
113
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xldG9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NpbmdsZXRvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU0sTUFBTSxhQUFhLENBQUM7QUFDakMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFlBQVksQ0FBQztBQVk3QyxNQUFNLE9BQU8sU0FBUztJQUNYLE9BQU8sR0FBRyxJQUFJLEdBQUcsRUFBZSxDQUFDO0lBQ2pDLEdBQUcsQ0FBcUI7SUFDeEIsTUFBTSxDQUF3QjtJQUM5QixJQUFJLENBQVM7SUFDYixPQUFPLENBQXNCO0lBRXRDLFlBQVksT0FBeUI7UUFDbkMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsZ0VBQWdFLENBQUMsQ0FBQztRQUN2RixNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSwrREFBK0QsQ0FBQyxDQUFDO1FBQ3JGLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLGtFQUFrRSxDQUFDLENBQUM7UUFDM0YsTUFBTSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxtQkFBbUIsT0FBTyxDQUFDLElBQUksMkJBQTJCLENBQUMsQ0FBQztRQUNuRyxJQUFJLENBQUMsR0FBRyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUM7UUFDdkIsSUFBSSxDQUFDLElBQUksR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQztRQUM3QixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDckQsQ0FBQztJQUVELElBQUk7UUFDRixPQUFPLGVBQWUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMs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
@@ -0,0 +1,2 @@
1
+ export declare function convertObject(obj: any, ignore: string | RegExp | (string | RegExp)[]): any;
2
+ export declare function safeParseURL(url: string): URL | null;
@@ -0,0 +1,70 @@
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;
11
+ }
12
+ function convertValue(key, value, ignore) {
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)) {
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);
61
+ }
62
+ export function safeParseURL(url) {
63
+ try {
64
+ return new URL(url);
65
+ }
66
+ catch {
67
+ return null;
68
+ }
69
+ }
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxJQUFJLE1BQU0sV0FBVyxDQUFDO0FBQzdCLE9BQU8sRUFDTCxRQUFRLEVBQUUsUUFBUSxFQUFFLFdBQVcsRUFDL0IsT0FBTyxFQUFFLFVBQVUsRUFBRSxtQkFBbUIsRUFBRSxlQUFlLEdBQzFELE1BQU0sWUFBWSxDQUFDO0FBRXBCLE1BQU0sVUFBVSxhQUFhLENBQUMsR0FBUSxFQUFFLE1BQTZDO0lBQ25GLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDM0IsTUFBTSxHQUFHLENBQUUsTUFBTSxDQUFFLENBQUM7SUFDdEIsQ0FBQztJQUNELEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ25DLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxZQUFZLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBQ0QsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBRUQsU0FBUyxZQUFZLENBQUMsR0FBVyxFQUFFLEtBQVUsRUFBRSxNQUEyQjtJQUN4RSxJQUFJLEtBQUssS0FBSyxJQUFJLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRSxDQUFDO1FBQzFDLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVELElBQUksR0FBRyxHQUFHLEtBQUssQ0FBQztJQUNoQixLQUFLLE1BQU0sUUFBUSxJQUFJLE1BQU0sRUFBRSxDQUFDO1FBQzlCLElBQUksT0FBTyxRQUFRLEtBQUssUUFBUSxJQUFJLFFBQVEsS0FBSyxHQUFHLEVBQUUsQ0FBQztZQUNyRCxHQUFHLEdBQUcsSUFBSSxDQUFDO1lBQ1gsTUFBTTtRQUNSLENBQUM7YUFBTSxJQUFJLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxRQUFRLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDcEQsR0FBRyxHQUFHLElBQUksQ0FBQztZQUNYLE1BQU07UUFDUixDQUFDO0lBQ0gsQ0FBQztJQUNELElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUNULElBQUksUUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLFFBQVEsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQ3ZDLE9BQU8sS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQzFCLENBQUM7UUFDRCxJQUFJLFdBQVcsQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDL0MsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDO0lBQ0gsQ0FBQztJQUVELHFEQUFxRDtJQUNyRCxTQUFTO0lBQ1QsSUFBSSxNQUFNLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxLQUFLLE1BQU0sQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUN0RCxPQUFPLGFBQWEsQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVELGdCQUFnQjtJQUNoQixNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxJQUFJLFdBQVcsQ0FBQztJQUN2QyxJQUFJLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQ25CLE9BQU8sVUFBVSxJQUFJLEdBQUcsQ0FBQztJQUMzQixDQUFDO0lBRUQsNkJBQTZCO0lBQzdCLElBQUksVUFBVSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDdEIsSUFBSSxtQkFBbUIsQ0FBQyxLQUFLLENBQUM7WUFBRSxPQUFPLHNCQUFzQixJQUFJLEdBQUcsQ0FBQztRQUNyRSxJQUFJLGVBQWUsQ0FBQyxLQUFLLENBQUM7WUFBRSxPQUFPLGtCQUFrQixJQUFJLEdBQUcsQ0FBQztRQUM3RCxPQUFPLGFBQWEsSUFBSSxHQUFHLENBQUM7SUFDOUIsQ0FBQztJQUVELE1BQU0sUUFBUSxHQUFHLEtBQUssQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDO0lBQ3hDLElBQUksUUFBUSxFQUFFLENBQUM7UUFDYixJQUFJLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDeEQsT0FBTyxJQUFJLFFBQVEsU0FBUyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUM7UUFDOUMsQ0FBQztRQUNELE9BQU8sSUFBSSxRQUFRLEdBQUcsQ0FBQztJQUN6QixDQUFDO0lBRUQsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0FBQzVCLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLEdBQVc7SUFDdEMsSUFBSSxDQUFDO1FBQ0gsT0FBTyxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN0QixDQUFDO0lBQUMsTUFBTSxDQUFDO1FBQ1AsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0FBQ0gsQ0FBQyJ9
@@ -0,0 +1,271 @@
1
+ import { type IncomingMessage, type ServerResponse } from 'node:http';
2
+ import { EggCore, type EggCoreContext, type EggCoreOptions } from '@eggjs/core';
3
+ import { EggContextLogger as ContextLogger, EggLoggers, EggLogger } from 'egg-logger';
4
+ import { Cookies as ContextCookies } from '@eggjs/cookies';
5
+ import type { Agent } from './agent.js';
6
+ import type { Application } from './application.js';
7
+ import type { EggAppConfig } from './type.js';
8
+ import { IMessenger } from './core/messenger/index.js';
9
+ import { ContextHttpClient } from './core/context_httpclient.js';
10
+ import { HttpClient, type HttpClientRequestOptions, type HttpClientRequestURL, type HttpClientResponse } from './core/httpclient.js';
11
+ import { type SingletonCreateMethod } from './core/singleton.js';
12
+ import { BaseContextClass } from './core/base_context_class.js';
13
+ import { BaseHookClass } from './core/base_hook_class.js';
14
+ import type { EggApplicationLoader } from './loader/index.js';
15
+ declare const EGG_PATH: unique symbol;
16
+ export interface EggApplicationCoreOptions extends Omit<EggCoreOptions, 'baseDir'> {
17
+ mode?: 'cluster' | 'single';
18
+ clusterPort?: number;
19
+ baseDir?: string;
20
+ }
21
+ export interface EggContext extends EggCoreContext {
22
+ app: EggApplicationCore;
23
+ /**
24
+ * Request start time
25
+ * @member {Number} Context#starttime
26
+ */
27
+ starttime: number;
28
+ /**
29
+ * Request start timer using `performance.now()`
30
+ * @member {Number} Context#performanceStarttime
31
+ */
32
+ performanceStarttime: number;
33
+ }
34
+ /**
35
+ * Based on koa's Application
36
+ * @see https://github.com/eggjs/egg-core
37
+ * @see https://github.com/eggjs/koa/blob/master/src/application.ts
38
+ * @augments EggCore
39
+ */
40
+ export declare class EggApplicationCore extends EggCore {
41
+ #private;
42
+ ContextCookies: typeof ContextCookies;
43
+ ContextLogger: typeof ContextLogger;
44
+ ContextHttpClient: typeof ContextHttpClient;
45
+ HttpClient: typeof HttpClient;
46
+ /**
47
+ * Retrieve base context class
48
+ * @member {BaseContextClass} BaseContextClass
49
+ * @since 1.0.0
50
+ */
51
+ BaseContextClass: typeof BaseContextClass;
52
+ /**
53
+ * Retrieve base controller
54
+ * @member {Controller} Controller
55
+ * @since 1.0.0
56
+ */
57
+ Controller: typeof BaseContextClass;
58
+ /**
59
+ * Retrieve base service
60
+ * @member {Service} Service
61
+ * @since 1.0.0
62
+ */
63
+ Service: typeof BaseContextClass;
64
+ /**
65
+ * Retrieve base subscription
66
+ * @member {Subscription} Subscription
67
+ * @since 2.12.0
68
+ */
69
+ Subscription: typeof BaseContextClass;
70
+ /**
71
+ * Retrieve base context class
72
+ * @member {BaseHookClass} BaseHookClass
73
+ */
74
+ BaseHookClass: typeof BaseHookClass;
75
+ /**
76
+ * Retrieve base boot
77
+ * @member {Boot}
78
+ */
79
+ Boot: typeof BaseHookClass;
80
+ options: Required<EggApplicationCoreOptions>;
81
+ readonly messenger: IMessenger;
82
+ agent?: Agent;
83
+ application?: Application;
84
+ loader: EggApplicationLoader;
85
+ /**
86
+ * @class
87
+ * @param {Object} options
88
+ * - {Object} [type] - type of instance, Agent and Application both extend koa, type can determine what it is.
89
+ * - {String} [baseDir] - app root dir, default is `process.cwd()`
90
+ * - {Object} [plugins] - custom plugin config, use it in unittest
91
+ * - {String} [mode] - process mode, can be cluster / single, default is `cluster`
92
+ */
93
+ constructor(options?: EggApplicationCoreOptions);
94
+ /**
95
+ * @deprecated please use `options` property instead
96
+ */
97
+ get _options(): Required<EggApplicationCoreOptions>;
98
+ protected loadConfig(): Promise<void>;
99
+ protected load(): Promise<void>;
100
+ /**
101
+ * Wrap the Client with Leader/Follower Pattern
102
+ *
103
+ * @description almost the same as Agent.cluster API, the only different is that this method create Follower.
104
+ *
105
+ * @see https://github.com/node-modules/cluster-client
106
+ * @param {Function} clientClass - client class function
107
+ * @param {Object} [options]
108
+ * - {Boolean} [autoGenerate] - whether generate delegate rule automatically, default is true
109
+ * - {Function} [formatKey] - a method to transform the subscription info into a string,default is JSON.stringify
110
+ * - {Object} [transcode|JSON.stringify/parse]
111
+ * - {Function} encode - custom serialize method
112
+ * - {Function} decode - custom deserialize method
113
+ * - {Boolean} [isBroadcast] - whether broadcast subscription result to all followers or just one, default is true
114
+ * - {Number} [responseTimeout] - response timeout, default is 3 seconds
115
+ * - {Number} [maxWaitTime|30000] - leader startup max time, default is 30 seconds
116
+ * @return {ClientWrapper} wrapper
117
+ */
118
+ cluster(clientClass: unknown, options: object): any;
119
+ /**
120
+ * print the information when console.log(app)
121
+ * @return {Object} inspected app.
122
+ * @since 1.0.0
123
+ * @example
124
+ * ```js
125
+ * console.log(app);
126
+ * =>
127
+ * {
128
+ * name: 'mock-app',
129
+ * env: 'test',
130
+ * subdomainOffset: 2,
131
+ * config: '<egg config>',
132
+ * controller: '<egg controller>',
133
+ * service: '<egg service>',
134
+ * middlewares: '<egg middlewares>',
135
+ * urllib: '<egg urllib>',
136
+ * loggers: '<egg loggers>'
137
+ * }
138
+ * ```
139
+ */
140
+ inspect(): any;
141
+ toJSON(): any;
142
+ /**
143
+ * http request helper base on {@link httpclient}, it will auto save httpclient log.
144
+ * Keep the same api with `httpclient.request(url, args)`.
145
+ *
146
+ * See https://github.com/node-modules/urllib#api-doc for more details.
147
+ *
148
+ * @param {String} url request url address.
149
+ * @param {Object} options
150
+ * - method {String} - Request method, defaults to GET. Could be GET, POST, DELETE or PUT. Alias 'type'.
151
+ * - data {Object} - Data to be sent. Will be stringify automatically.
152
+ * - dataType {String} - String - Type of response data. Could be `text` or `json`.
153
+ * If it's `text`, the callback data would be a String.
154
+ * If it's `json`, the data of callback would be a parsed JSON Object.
155
+ * Default callback data would be a Buffer.
156
+ * - headers {Object} - Request headers.
157
+ * - timeout {Number} - Request timeout in milliseconds. Defaults to exports.TIMEOUT.
158
+ * Include remote server connecting timeout and response timeout.
159
+ * When timeout happen, will return ConnectionTimeout or ResponseTimeout.
160
+ * - auth {String} - `username:password` used in HTTP Basic Authorization.
161
+ * - followRedirect {Boolean} - follow HTTP 3xx responses as redirects. defaults to false.
162
+ * - gzip {Boolean} - let you get the res object when request connected, default false. alias customResponse
163
+ * - nestedQuerystring {Boolean} - urllib default use querystring to stringify form data which don't
164
+ * support nested object, will use qs instead of querystring to support nested object by set this option to true.
165
+ * - more options see https://github.com/node-modules/urllib
166
+ * @return {Object}
167
+ * - status {Number} - HTTP response status
168
+ * - headers {Object} - HTTP response headers
169
+ * - res {Object} - HTTP response meta
170
+ * - data {Object} - HTTP response body
171
+ *
172
+ * @example
173
+ * ```js
174
+ * const result = await app.curl('http://example.com/foo.json', {
175
+ * method: 'GET',
176
+ * dataType: 'json',
177
+ * });
178
+ * console.log(result.status, result.headers, result.data);
179
+ * ```
180
+ */
181
+ curl<T = any>(url: HttpClientRequestURL, options?: HttpClientRequestOptions): Promise<HttpClientResponse<T>>;
182
+ /**
183
+ * HttpClient instance
184
+ * @see https://github.com/node-modules/urllib
185
+ * @member {HttpClient}
186
+ */
187
+ get httpClient(): HttpClient;
188
+ /**
189
+ * @deprecated please use httpClient instead
190
+ * @alias httpClient
191
+ * @member {HttpClient}
192
+ */
193
+ get httpclient(): HttpClient;
194
+ /**
195
+ * All loggers contain logger, coreLogger and customLogger
196
+ * @member {Object}
197
+ * @since 1.0.0
198
+ */
199
+ get loggers(): EggLoggers;
200
+ /**
201
+ * Get logger by name, it's equal to app.loggers['name'],
202
+ * but you can extend it with your own logical.
203
+ * @param {String} name - logger name
204
+ * @return {Logger} logger
205
+ */
206
+ getLogger(name: string): EggLogger;
207
+ /**
208
+ * application logger, log file is `$HOME/logs/{appname}/{appname}-web`
209
+ * @member {Logger}
210
+ * @since 1.0.0
211
+ */
212
+ get logger(): EggLogger;
213
+ /**
214
+ * core logger for framework and plugins, log file is `$HOME/logs/{appname}/egg-web`
215
+ * @member {Logger}
216
+ * @since 1.0.0
217
+ */
218
+ get coreLogger(): EggLogger;
219
+ _unhandledRejectionHandler(err: any): void;
220
+ /**
221
+ * dump out the config and meta object
222
+ * @private
223
+ */
224
+ dumpConfigToObject(): {
225
+ config: Record<string, any>;
226
+ meta: Record<string, any>;
227
+ };
228
+ /**
229
+ * save app.config to `run/${type}_config.json`
230
+ * @private
231
+ */
232
+ dumpConfig(): void;
233
+ dumpTiming(): void;
234
+ get [EGG_PATH](): string;
235
+ get config(): EggAppConfig;
236
+ /**
237
+ * app.env delegate app.config.env
238
+ * @deprecated
239
+ */
240
+ get env(): string;
241
+ set env(_: string);
242
+ /**
243
+ * app.proxy delegate app.config.proxy
244
+ * @deprecated
245
+ */
246
+ get proxy(): boolean;
247
+ set proxy(_: boolean);
248
+ /**
249
+ * create a singleton instance
250
+ * @param {String} name - unique name for singleton
251
+ * @param {Function|AsyncFunction} create - method will be invoked when singleton instance create
252
+ */
253
+ addSingleton(name: string, create: SingletonCreateMethod): void;
254
+ /**
255
+ * Create an anonymous context, the context isn't request level, so the request is mocked.
256
+ * then you can use context level API like `ctx.service`
257
+ * @member {String} EggApplication#createAnonymousContext
258
+ * @param {Request} [req] - if you want to mock request like querystring, you can pass an object to this function.
259
+ * @return {Context} context
260
+ */
261
+ createAnonymousContext(req?: any): EggCoreContext;
262
+ /**
263
+ * Create egg context
264
+ * @function EggApplication#createContext
265
+ * @param {Req} req - node native Request object
266
+ * @param {Res} res - node native Response object
267
+ * @return {Context} context object
268
+ */
269
+ createContext(req: IncomingMessage, res: ServerResponse): EggContext;
270
+ }
271
+ export {};