egg 4.1.0-beta.20 → 4.1.0-beta.22

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 (123) hide show
  1. package/dist/agent.d.ts +3 -17
  2. package/dist/agent.js +7 -11
  3. package/dist/app/extend/context.d.ts +180 -12
  4. package/dist/app/extend/context.js +259 -3
  5. package/dist/app/extend/helper.d.ts +37 -12
  6. package/dist/app/extend/helper.js +43 -5
  7. package/dist/app/extend/request.d.ts +132 -12
  8. package/dist/app/extend/request.js +265 -4
  9. package/dist/app/extend/response.d.ts +25 -2
  10. package/dist/app/extend/response.js +34 -3
  11. package/dist/app/middleware/body_parser.d.ts +2 -2
  12. package/dist/app/middleware/body_parser.js +3 -7
  13. package/dist/app/middleware/meta.d.ts +10 -12
  14. package/dist/app/middleware/meta.js +19 -13
  15. package/dist/app/middleware/notfound.d.ts +7 -12
  16. package/dist/app/middleware/notfound.js +28 -25
  17. package/dist/app/middleware/override_method.d.ts +2 -2
  18. package/dist/app/middleware/override_method.js +3 -7
  19. package/dist/app/middleware/site_file.d.ts +9 -12
  20. package/dist/app/middleware/site_file.js +52 -37
  21. package/dist/config/config.default.d.ts +2 -16
  22. package/dist/config/config.default.js +375 -282
  23. package/dist/config/config.local.d.ts +5 -7
  24. package/dist/config/config.local.js +9 -6
  25. package/dist/config/config.unittest.d.ts +5 -7
  26. package/dist/config/config.unittest.js +8 -9
  27. package/dist/config/plugin.d.ts +120 -122
  28. package/dist/config/plugin.js +121 -53
  29. package/dist/index.d.ts +66 -13
  30. package/dist/index.js +70 -30
  31. package/dist/lib/agent.d.ts +19 -12
  32. package/dist/lib/agent.js +48 -22
  33. package/dist/lib/application.d.ts +56 -12
  34. package/dist/lib/application.js +261 -23
  35. package/dist/lib/core/base_context_class.d.ts +18 -12
  36. package/dist/lib/core/base_context_class.js +17 -4
  37. package/dist/lib/core/base_context_logger.d.ts +36 -12
  38. package/dist/lib/core/base_context_logger.js +60 -3
  39. package/dist/lib/core/base_hook_class.d.ts +11 -12
  40. package/dist/lib/core/base_hook_class.js +22 -3
  41. package/dist/lib/core/context_httpclient.d.ts +17 -12
  42. package/dist/lib/core/context_httpclient.js +26 -3
  43. package/dist/lib/core/httpclient.d.ts +14 -12
  44. package/dist/lib/core/httpclient.js +39 -3
  45. package/dist/lib/core/logger.d.ts +3 -17
  46. package/dist/lib/core/logger.js +37 -3
  47. package/dist/lib/core/messenger/IMessenger.d.ts +50 -2
  48. package/dist/lib/core/messenger/IMessenger.js +2 -1
  49. package/dist/lib/core/messenger/base.d.ts +8 -13
  50. package/dist/lib/core/messenger/base.js +28 -17
  51. package/dist/lib/core/messenger/index.d.ts +7 -12
  52. package/dist/lib/core/messenger/index.js +10 -17
  53. package/dist/lib/core/messenger/ipc.d.ts +55 -68
  54. package/dist/lib/core/messenger/ipc.js +151 -17
  55. package/dist/lib/core/messenger/local.d.ts +56 -69
  56. package/dist/lib/core/messenger/local.js +128 -17
  57. package/dist/lib/core/utils.d.ts +2 -5
  58. package/dist/lib/core/utils.js +70 -3
  59. package/dist/lib/egg.d.ts +285 -12
  60. package/dist/lib/egg.js +581 -17
  61. package/dist/lib/error/CookieLimitExceedError.d.ts +5 -2
  62. package/dist/lib/error/CookieLimitExceedError.js +12 -3
  63. package/dist/lib/error/MessageUnhandledRejectionError.d.ts +5 -2
  64. package/dist/lib/error/MessageUnhandledRejectionError.js +12 -3
  65. package/dist/lib/error/index.d.ts +2 -4
  66. package/dist/lib/error/index.js +3 -5
  67. package/dist/lib/loader/AgentWorkerLoader.d.ts +12 -3
  68. package/dist/lib/loader/AgentWorkerLoader.js +20 -4
  69. package/dist/lib/loader/AppWorkerLoader.d.ts +17 -3
  70. package/dist/lib/loader/AppWorkerLoader.js +39 -4
  71. package/dist/lib/loader/EggApplicationLoader.d.ts +4 -2
  72. package/dist/lib/loader/EggApplicationLoader.js +4 -3
  73. package/dist/lib/loader/index.d.ts +3 -5
  74. package/dist/lib/loader/index.js +4 -6
  75. package/dist/lib/start.d.ts +24 -12
  76. package/dist/lib/start.js +46 -27
  77. package/dist/lib/types.d.ts +281 -12
  78. package/dist/lib/types.js +31 -4
  79. package/dist/lib/types.plugin.d.ts +12 -1
  80. package/dist/lib/types.plugin.js +14 -3
  81. package/dist/lib/utils.d.ts +2 -5
  82. package/dist/lib/utils.js +14 -3
  83. package/dist/urllib.d.ts +1 -1
  84. package/dist/urllib.js +2 -3
  85. package/package.json +23 -23
  86. package/dist/AgentWorkerLoader-DG_hAClt.d.ts +0 -17
  87. package/dist/AgentWorkerLoader-D_hceBRW.js +0 -24
  88. package/dist/AppWorkerLoader-CAtxJvGl.js +0 -37
  89. package/dist/AppWorkerLoader-CT875rYM.d.ts +0 -22
  90. package/dist/CookieLimitExceedError-CAW0HYJw.d.ts +0 -8
  91. package/dist/CookieLimitExceedError-DLGakbeu.js +0 -15
  92. package/dist/EggApplicationLoader-CMe1VQt1.js +0 -7
  93. package/dist/EggApplicationLoader-PnIvd5oV.d.ts +0 -8
  94. package/dist/IMessenger-C9g6ypSI.d.ts +0 -54
  95. package/dist/MessageUnhandledRejectionError-Lq5fWw24.d.ts +0 -8
  96. package/dist/MessageUnhandledRejectionError-oD_E1Ewl.js +0 -15
  97. package/dist/agent-BfFWeJj4.js +0 -55
  98. package/dist/application-DVwFQSa9.js +0 -208
  99. package/dist/base-KLVtlzUD.d.ts +0 -12
  100. package/dist/base_context_class-Xc1OZql9.js +0 -19
  101. package/dist/base_context_logger-CZU59PGA.js +0 -58
  102. package/dist/base_hook_class-D0Gu2p8r.js +0 -26
  103. package/dist/base_hook_class-R8A8gm1s.d.ts +0 -1109
  104. package/dist/context-D1Wg7CXs.js +0 -244
  105. package/dist/context_httpclient-BpRMdJhf.js +0 -29
  106. package/dist/egg-DVo5e_lr.js +0 -800
  107. package/dist/error-BYo_LRnd.js +0 -1
  108. package/dist/helper-B3PKMPXq.js +0 -47
  109. package/dist/httpclient-C1QPc_R7.js +0 -36
  110. package/dist/index-CUPkUUOR.d.ts +0 -1
  111. package/dist/index-CkgLZdB4.d.ts +0 -1
  112. package/dist/loader-3myZ-rpm.js +0 -1
  113. package/dist/logger-C4tIcO3S.js +0 -31
  114. package/dist/request-Cy_1DlaX.js +0 -225
  115. package/dist/response-CDeQ9Sx2.js +0 -36
  116. package/dist/response-DlNYDj00.d.ts +0 -29
  117. package/dist/src-BuOjXSrB.js +0 -3
  118. package/dist/start-4E84z796.js +0 -35
  119. package/dist/types-dKSyDnVp.js +0 -32
  120. package/dist/types.plugin-B2v0K0I8.js +0 -14
  121. package/dist/types.plugin-C3D5I7VD.d.ts +0 -12
  122. package/dist/utils-B1Rjsoi9.js +0 -48
  123. package/dist/utils-BDoYg6z6.js +0 -14
package/dist/lib/egg.js CHANGED
@@ -1,17 +1,581 @@
1
- import "../base_hook_class-D0Gu2p8r.js";
2
- import "../base_context_logger-CZU59PGA.js";
3
- import "../base_context_class-Xc1OZql9.js";
4
- import { Context } from "../context-D1Wg7CXs.js";
5
- import { Response } from "../response-CDeQ9Sx2.js";
6
- import { Request } from "../request-Cy_1DlaX.js";
7
- import "../CookieLimitExceedError-DLGakbeu.js";
8
- import "../MessageUnhandledRejectionError-oD_E1Ewl.js";
9
- import "../error-BYo_LRnd.js";
10
- import { EggApplicationCore, Router } from "../egg-DVo5e_lr.js";
11
- import "../context_httpclient-BpRMdJhf.js";
12
- import "../httpclient-C1QPc_R7.js";
13
- import "../logger-C4tIcO3S.js";
14
- import "../utils-B1Rjsoi9.js";
15
- import "../utils-BDoYg6z6.js";
16
-
17
- export { Context, EggApplicationCore, Request, Response, Router };
1
+ import { performance } from 'node:perf_hooks';
2
+ import path from 'node:path';
3
+ import fs from 'node:fs';
4
+ import http, {} from 'node:http';
5
+ import inspector from 'node:inspector';
6
+ import { EggCore, Router } from '@eggjs/core';
7
+ import { utils as eggUtils } from '@eggjs/core';
8
+ // @ts-expect-error no types for 'cluster-client'
9
+ import createClusterClient from 'cluster-client';
10
+ // @ts-expect-error no types for 'cluster-client'
11
+ import { close as closeClusterClient } from 'cluster-client';
12
+ import { extend } from '@eggjs/extend2';
13
+ import { EggContextLogger as ContextLogger, EggLoggers, EggLogger } from 'egg-logger';
14
+ import { Cookies as ContextCookies } from '@eggjs/cookies';
15
+ // @ts-expect-error no types for circular-json-for-egg
16
+ import CircularJSON from 'circular-json-for-egg';
17
+ import Context from "../app/extend/context.js";
18
+ import Request from "../app/extend/request.js";
19
+ import Response from "../app/extend/response.js";
20
+ import { create as createMessenger } from "./core/messenger/index.js";
21
+ import { ContextHttpClient } from "./core/context_httpclient.js";
22
+ import { HttpClient, } from "./core/httpclient.js";
23
+ import { createLoggers } from "./core/logger.js";
24
+ import { convertObject } from "./core/utils.js";
25
+ import { BaseContextClass } from "./core/base_context_class.js";
26
+ import { BaseHookClass } from "./core/base_hook_class.js";
27
+ import { getSourceDirname } from "./utils.js";
28
+ const EGG_PATH = Symbol.for('egg#eggPath');
29
+ export { Request, Response };
30
+ // export egg classes
31
+ export { Context, Router };
32
+ /**
33
+ * Based on koa's Application
34
+ * @see https://github.com/eggjs/egg-core
35
+ * @see https://github.com/eggjs/koa/blob/master/src/application.ts
36
+ * @augments EggCore
37
+ */
38
+ export class EggApplicationCore extends EggCore {
39
+ /**
40
+ * Get the current request context from AsyncLocalStorage.
41
+ * This provides access to the context object for the current request lifecycle.
42
+ * @returns {Context | undefined} The current request context, or undefined if not in a request scope.
43
+ */
44
+ get currentContext() {
45
+ return this.ctxStorage.getStore();
46
+ }
47
+ // export context base classes, let framework can impl sub class and over context extend easily.
48
+ ContextCookies = ContextCookies;
49
+ ContextLogger = ContextLogger;
50
+ ContextHttpClient = ContextHttpClient;
51
+ HttpClient = HttpClient;
52
+ // keep compatible with egg version 3.x
53
+ HttpClientNext = HttpClient;
54
+ /**
55
+ * Retrieve base context class
56
+ * @member {BaseContextClass} BaseContextClass
57
+ * @since 1.0.0
58
+ */
59
+ BaseContextClass = BaseContextClass;
60
+ /**
61
+ * Retrieve base controller
62
+ * @member {Controller} Controller
63
+ * @since 1.0.0
64
+ */
65
+ Controller = BaseContextClass;
66
+ /**
67
+ * Retrieve base service
68
+ * @member {Service} Service
69
+ * @since 1.0.0
70
+ */
71
+ Service = BaseContextClass;
72
+ /**
73
+ * Retrieve base subscription
74
+ * @member {Subscription} Subscription
75
+ * @since 2.12.0
76
+ */
77
+ Subscription = BaseContextClass;
78
+ /**
79
+ * Retrieve base context class
80
+ * @member {BaseHookClass} BaseHookClass
81
+ */
82
+ BaseHookClass = BaseHookClass;
83
+ /**
84
+ * Retrieve base boot
85
+ * @member {Boot}
86
+ * @alias BaseHookClass
87
+ */
88
+ Boot = BaseHookClass;
89
+ #httpClient;
90
+ #loggers;
91
+ #clusterClients = [];
92
+ messenger;
93
+ agent;
94
+ application;
95
+ /**
96
+ * @class
97
+ * @param {Object} options
98
+ * - {Object} [type] - type of instance, Agent and Application both extend koa, type can determine what it is.
99
+ * - {String} [baseDir] - app root dir, default is `process.cwd()`
100
+ * - {Object} [plugins] - custom plugin config, use it in unittest
101
+ * - {String} [mode] - process mode, can be cluster / single, default is `cluster`
102
+ */
103
+ constructor(options) {
104
+ options = {
105
+ mode: 'cluster',
106
+ type: 'application',
107
+ baseDir: process.cwd(),
108
+ ...options,
109
+ };
110
+ super(options);
111
+ /**
112
+ * messenger instance
113
+ * @member {Messenger}
114
+ * @since 1.0.0
115
+ */
116
+ this.messenger = createMessenger(this);
117
+ // trigger `serverDidReady` hook when all the app workers
118
+ // and agent worker are ready
119
+ this.messenger.once('egg-ready', () => {
120
+ this.lifecycle.triggerServerDidReady();
121
+ });
122
+ this.lifecycle.registerBeforeStart(async () => {
123
+ await this.load();
124
+ }, 'load files');
125
+ }
126
+ /**
127
+ * @deprecated please use `options` property instead
128
+ */
129
+ get _options() {
130
+ return this.options;
131
+ }
132
+ async loadConfig() {
133
+ await this.loader.loadConfig();
134
+ }
135
+ async load() {
136
+ await this.loadConfig();
137
+ // dump config after ready, ensure all the modifications during start will be recorded
138
+ // make sure dumpConfig is the last ready callback
139
+ this.ready(() => process.nextTick(() => {
140
+ const dumpStartTime = Date.now();
141
+ this.dumpConfig();
142
+ this.dumpTiming();
143
+ this.coreLogger.info('[egg] dump config after ready, %sms', Date.now() - dumpStartTime);
144
+ }));
145
+ this.#setupTimeoutTimer();
146
+ this.console.info('[egg] App root: %s', this.baseDir);
147
+ this.console.info('[egg] All *.log files save on %j', this.config.logger.dir);
148
+ this.console.info('[egg] Loaded enabled plugin %j', this.loader.orderPlugins);
149
+ // Listen the error that promise had not catch, then log it in common-error
150
+ this._unhandledRejectionHandler = this._unhandledRejectionHandler.bind(this);
151
+ process.on('unhandledRejection', this._unhandledRejectionHandler);
152
+ // register close function
153
+ this.lifecycle.registerBeforeClose(async () => {
154
+ // close all cluster clients
155
+ for (const clusterClient of this.#clusterClients) {
156
+ await closeClusterClient(clusterClient);
157
+ }
158
+ this.#clusterClients = [];
159
+ // single process mode will close agent before app close
160
+ if (this.type === 'application' && this.options.mode === 'single') {
161
+ await this.agent.close();
162
+ }
163
+ for (const logger of this.loggers.values()) {
164
+ logger.close();
165
+ }
166
+ this.messenger.close();
167
+ process.removeListener('unhandledRejection', this._unhandledRejectionHandler);
168
+ });
169
+ await this.loader.load();
170
+ }
171
+ /**
172
+ * Usage: new ApiClient({ cluster: app.cluster })
173
+ */
174
+ get cluster() {
175
+ return this.clusterWrapper.bind(this);
176
+ }
177
+ /**
178
+ * Wrap the Client with Leader/Follower Pattern
179
+ *
180
+ * @description almost the same as Agent.cluster API, the only different is that this method create Follower.
181
+ *
182
+ * @see https://github.com/node-modules/cluster-client
183
+ * @param {Function} clientClass - client class function
184
+ * @param {Object} [options]
185
+ * - {Boolean} [autoGenerate] - whether generate delegate rule automatically, default is true
186
+ * - {Function} [formatKey] - a method to transform the subscription info into a string,default is JSON.stringify
187
+ * - {Object} [transcode|JSON.stringify/parse]
188
+ * - {Function} encode - custom serialize method
189
+ * - {Function} decode - custom deserialize method
190
+ * - {Boolean} [isBroadcast] - whether broadcast subscription result to all followers or just one, default is true
191
+ * - {Number} [responseTimeout] - response timeout, default is 3 seconds
192
+ * - {Number} [maxWaitTime|30000] - leader startup max time, default is 30 seconds
193
+ * @return {ClientWrapper} wrapper
194
+ */
195
+ clusterWrapper(clientClass, options) {
196
+ const clientClassOptions = {
197
+ ...this.config.clusterClient,
198
+ ...options,
199
+ singleMode: this.options.mode === 'single',
200
+ // cluster need a port that can't conflict on the environment
201
+ port: this.options.clusterPort,
202
+ // agent worker is leader, app workers are follower
203
+ isLeader: this.type === 'agent',
204
+ logger: this.coreLogger,
205
+ // debug mode does not check heartbeat
206
+ isCheckHeartbeat: this.config.env === 'prod' ? true : inspector.url() === undefined,
207
+ };
208
+ const client = createClusterClient(clientClass, clientClassOptions);
209
+ this.#patchClusterClient(client);
210
+ return client;
211
+ }
212
+ /**
213
+ * print the information when console.log(app)
214
+ * @return {Object} inspected app.
215
+ * @since 1.0.0
216
+ * @example
217
+ * ```js
218
+ * console.log(app);
219
+ * =>
220
+ * {
221
+ * name: 'mock-app',
222
+ * env: 'test',
223
+ * subdomainOffset: 2,
224
+ * config: '<egg config>',
225
+ * controller: '<egg controller>',
226
+ * service: '<egg service>',
227
+ * middlewares: '<egg middlewares>',
228
+ * urllib: '<egg urllib>',
229
+ * loggers: '<egg loggers>'
230
+ * }
231
+ * ```
232
+ */
233
+ inspect() {
234
+ const res = {
235
+ env: this.config.env,
236
+ };
237
+ function delegate(res, app, keys) {
238
+ for (const key of keys) {
239
+ if (app[key]) {
240
+ res[key] = app[key];
241
+ }
242
+ }
243
+ }
244
+ function abbr(res, app, keys) {
245
+ for (const key of keys) {
246
+ if (app[key]) {
247
+ res[key] = `<egg ${key}>`;
248
+ }
249
+ }
250
+ }
251
+ delegate(res, this, ['name', 'baseDir', 'subdomainOffset']);
252
+ abbr(res, this, ['config', 'controller', 'httpclient', 'loggers', 'middlewares', 'router', 'serviceClasses']);
253
+ return res;
254
+ }
255
+ toJSON() {
256
+ return this.inspect();
257
+ }
258
+ /**
259
+ * http request helper base on {@link httpclient}, it will auto save httpclient log.
260
+ * Keep the same api with `httpclient.request(url, args)`.
261
+ *
262
+ * See https://github.com/node-modules/urllib#api-doc for more details.
263
+ *
264
+ * @param {String} url request url address.
265
+ * @param {Object} options
266
+ * - method {String} - Request method, defaults to GET. Could be GET, POST, DELETE or PUT. Alias 'type'.
267
+ * - data {Object} - Data to be sent. Will be stringify automatically.
268
+ * - dataType {String} - String - Type of response data. Could be `text` or `json`.
269
+ * If it's `text`, the callback data would be a String.
270
+ * If it's `json`, the data of callback would be a parsed JSON Object.
271
+ * Default callback data would be a Buffer.
272
+ * - headers {Object} - Request headers.
273
+ * - timeout {Number} - Request timeout in milliseconds. Defaults to exports.TIMEOUT.
274
+ * Include remote server connecting timeout and response timeout.
275
+ * When timeout happen, will return ConnectionTimeout or ResponseTimeout.
276
+ * - auth {String} - `username:password` used in HTTP Basic Authorization.
277
+ * - followRedirect {Boolean} - follow HTTP 3xx responses as redirects. defaults to false.
278
+ * - gzip {Boolean} - let you get the res object when request connected, default false. alias customResponse
279
+ * - nestedQuerystring {Boolean} - urllib default use querystring to stringify form data which don't
280
+ * support nested object, will use qs instead of querystring to support nested object by set this option to true.
281
+ * - more options see https://github.com/node-modules/urllib
282
+ * @return {Object}
283
+ * - status {Number} - HTTP response status
284
+ * - headers {Object} - HTTP response headers
285
+ * - res {Object} - HTTP response meta
286
+ * - data {Object} - HTTP response body
287
+ *
288
+ * @example
289
+ * ```js
290
+ * const result = await app.curl('http://example.com/foo.json', {
291
+ * method: 'GET',
292
+ * dataType: 'json',
293
+ * });
294
+ * console.log(result.status, result.headers, result.data);
295
+ * ```
296
+ */
297
+ async curl(url, options) {
298
+ return await this.httpClient.request(url, options);
299
+ }
300
+ /**
301
+ * Create a new HttpClient instance with custom options
302
+ * @param {Object} [options] HttpClient init options
303
+ */
304
+ createHttpClient(options) {
305
+ return new this.HttpClient(this, options);
306
+ }
307
+ /**
308
+ * HttpClient instance
309
+ * @see https://github.com/node-modules/urllib
310
+ * @member {HttpClient}
311
+ */
312
+ get httpClient() {
313
+ if (!this.#httpClient) {
314
+ this.#httpClient = this.createHttpClient();
315
+ }
316
+ return this.#httpClient;
317
+ }
318
+ /**
319
+ * @deprecated please use httpClient instead
320
+ * @alias httpClient
321
+ * @member {HttpClient}
322
+ */
323
+ get httpclient() {
324
+ return this.httpClient;
325
+ }
326
+ /**
327
+ * All loggers contain logger, coreLogger and customLogger
328
+ * @member {Object}
329
+ * @since 1.0.0
330
+ */
331
+ get loggers() {
332
+ if (!this.#loggers) {
333
+ this.#loggers = createLoggers(this);
334
+ }
335
+ return this.#loggers;
336
+ }
337
+ /**
338
+ * Get logger by name, it's equal to app.loggers['name'],
339
+ * but you can extend it with your own logical.
340
+ * @param {String} name - logger name
341
+ * @return {Logger} logger
342
+ */
343
+ getLogger(name) {
344
+ return this.loggers[name] || null;
345
+ }
346
+ /**
347
+ * application logger, log file is `$HOME/logs/{appname}/{appname}-web`
348
+ * @member {Logger}
349
+ * @since 1.0.0
350
+ */
351
+ get logger() {
352
+ return this.getLogger('logger');
353
+ }
354
+ /**
355
+ * core logger for framework and plugins, log file is `$HOME/logs/{appname}/egg-web`
356
+ * @member {Logger}
357
+ * @since 1.0.0
358
+ */
359
+ get coreLogger() {
360
+ return this.getLogger('coreLogger');
361
+ }
362
+ _unhandledRejectionHandler(err) {
363
+ this.coreLogger.error('[egg:unhandledRejection] %s', (err && err.message) || err);
364
+ if (!(err instanceof Error)) {
365
+ const newError = new Error(String(err));
366
+ // err maybe an object, try to copy the name, message and stack to the new error instance
367
+ if (err) {
368
+ if (err.name)
369
+ newError.name = err.name;
370
+ if (err.message)
371
+ newError.message = err.message;
372
+ if (err.stack)
373
+ newError.stack = err.stack;
374
+ }
375
+ err = newError;
376
+ }
377
+ if (err.name === 'Error') {
378
+ err.name = 'unhandledRejectionError';
379
+ }
380
+ this.coreLogger.error(err);
381
+ }
382
+ /**
383
+ * dump out the config and meta object
384
+ * @private
385
+ */
386
+ dumpConfigToObject() {
387
+ let ignoreList;
388
+ try {
389
+ // support array and set
390
+ ignoreList = Array.from(this.config.dump.ignore);
391
+ }
392
+ catch {
393
+ ignoreList = [];
394
+ }
395
+ const config = extend(true, {}, {
396
+ config: this.config,
397
+ plugins: this.loader.allPlugins,
398
+ appInfo: this.loader.appInfo,
399
+ });
400
+ convertObject(config, ignoreList);
401
+ return {
402
+ config,
403
+ meta: this.loader.configMeta,
404
+ };
405
+ }
406
+ /**
407
+ * save app.config to `run/${type}_config.json`
408
+ * @private
409
+ */
410
+ dumpConfig() {
411
+ const rundir = this.config.rundir;
412
+ try {
413
+ if (!fs.existsSync(rundir)) {
414
+ fs.mkdirSync(rundir);
415
+ }
416
+ // get dumped object
417
+ const { config, meta } = this.dumpConfigToObject();
418
+ // dump config
419
+ const dumpFile = path.join(rundir, `${this.type}_config.json`);
420
+ fs.writeFileSync(dumpFile, CircularJSON.stringify(config, null, 2));
421
+ // dump config meta
422
+ const dumpMetaFile = path.join(rundir, `${this.type}_config_meta.json`);
423
+ fs.writeFileSync(dumpMetaFile, CircularJSON.stringify(meta, null, 2));
424
+ }
425
+ catch (err) {
426
+ this.coreLogger.warn(`[egg] dumpConfig error: ${err.message}`);
427
+ }
428
+ }
429
+ dumpTiming() {
430
+ try {
431
+ const items = this.timing.toJSON();
432
+ const rundir = this.config.rundir;
433
+ const dumpFile = path.join(rundir, `${this.type}_timing_${process.pid}.json`);
434
+ fs.writeFileSync(dumpFile, CircularJSON.stringify(items, null, 2));
435
+ this.coreLogger.info(this.timing.toString());
436
+ // only disable, not clear bootstrap timing data.
437
+ this.timing.disable();
438
+ // show duration >= ${slowBootActionMinDuration}ms action to warning log
439
+ for (const item of items) {
440
+ // ignore #0 name: Process Start
441
+ if (item.index > 0 && item.duration && item.duration >= this.config.dump.timing.slowBootActionMinDuration) {
442
+ this.coreLogger.warn('[egg][dumpTiming][slow-boot-action] #%d %dms, name: %s', item.index, item.duration, item.name);
443
+ }
444
+ }
445
+ }
446
+ catch (err) {
447
+ this.coreLogger.warn(`[egg] dumpTiming error: ${err.message}`);
448
+ }
449
+ }
450
+ get [EGG_PATH]() {
451
+ return getSourceDirname();
452
+ }
453
+ #setupTimeoutTimer() {
454
+ const startTimeoutTimer = setTimeout(() => {
455
+ this.coreLogger.error(this.timing.toString());
456
+ this.coreLogger.error(`${this.type} still doesn't ready after ${this.config.workerStartTimeout} ms.`);
457
+ // log unfinished
458
+ const items = this.timing.toJSON();
459
+ for (const item of items) {
460
+ if (item.end)
461
+ continue;
462
+ this.coreLogger.error(`unfinished timing item: ${CircularJSON.stringify(item)}`);
463
+ }
464
+ this.coreLogger.error('[egg][setupTimeoutTimer] check run/%s_timing_%s.json for more details.', this.type, process.pid);
465
+ this.emit('startTimeout');
466
+ this.dumpConfig();
467
+ this.dumpTiming();
468
+ }, this.config.workerStartTimeout);
469
+ this.ready(() => clearTimeout(startTimeoutTimer));
470
+ }
471
+ get config() {
472
+ return super.config;
473
+ }
474
+ /**
475
+ * app.env delegate app.config.env
476
+ * @deprecated
477
+ */
478
+ get env() {
479
+ this.deprecate('please use app.config.env instead');
480
+ return this.config.env;
481
+ }
482
+ /* eslint no-empty-function: off */
483
+ set env(_) { }
484
+ /**
485
+ * app.proxy delegate app.config.proxy
486
+ * @deprecated
487
+ */
488
+ get proxy() {
489
+ // this.deprecate('please use app.config.proxy instead');
490
+ return this.config.proxy;
491
+ }
492
+ /* eslint no-empty-function: off */
493
+ set proxy(_) { }
494
+ #patchClusterClient(client) {
495
+ const rawCreate = client.create;
496
+ client.create = (...args) => {
497
+ const realClient = rawCreate.apply(client, args);
498
+ this.#clusterClients.push(realClient);
499
+ return realClient;
500
+ };
501
+ }
502
+ /**
503
+ * Create an anonymous context, the context isn't request level, so the request is mocked.
504
+ * then you can use context level API like `ctx.service`
505
+ * @member {String} EggApplication#createAnonymousContext
506
+ * @param {Request} [req] - if you want to mock request like querystring, you can pass an object to this function.
507
+ * @return {Context} context
508
+ */
509
+ createAnonymousContext(req) {
510
+ const request = {
511
+ headers: {
512
+ host: '127.0.0.1',
513
+ 'x-forwarded-for': '127.0.0.1',
514
+ },
515
+ query: {},
516
+ querystring: '',
517
+ host: '127.0.0.1',
518
+ hostname: '127.0.0.1',
519
+ protocol: 'http',
520
+ secure: 'false',
521
+ method: 'GET',
522
+ url: '/',
523
+ path: '/',
524
+ socket: {
525
+ remoteAddress: '127.0.0.1',
526
+ remotePort: 7001,
527
+ },
528
+ };
529
+ if (req) {
530
+ for (const key in req) {
531
+ if (key === 'headers' || key === 'query' || key === 'socket') {
532
+ Object.assign(request[key], req[key]);
533
+ }
534
+ else {
535
+ request[key] = req[key];
536
+ }
537
+ }
538
+ }
539
+ const response = new http.ServerResponse(request);
540
+ return this.createContext(request, response);
541
+ }
542
+ /**
543
+ * Run async function in the anonymous context scope
544
+ * @see Context#runInAnonymousContextScope
545
+ * @param {Function} scope - the first args is an anonymous ctx, scope should be async function
546
+ * @param {Request} [req] - if you want to mock request like querystring, you can pass an object to this function.
547
+ */
548
+ async runInAnonymousContextScope(scope, req) {
549
+ const ctx = this.createAnonymousContext(req);
550
+ if (!scope.name) {
551
+ Reflect.set(scope, '_name', eggUtils.getCalleeFromStack(true));
552
+ }
553
+ return await this.ctxStorage.run(ctx, async () => {
554
+ return await scope(ctx);
555
+ });
556
+ }
557
+ /**
558
+ * Create egg context
559
+ * @function EggApplication#createContext
560
+ * @param {Req} req - node native Request object
561
+ * @param {Res} res - node native Response object
562
+ * @return {Context} context object
563
+ */
564
+ createContext(req, res) {
565
+ const context = Object.create(this.context);
566
+ const request = (context.request = Object.create(this.request));
567
+ const response = (context.response = Object.create(this.response));
568
+ context.app = request.app = response.app = this;
569
+ context.req = request.req = response.req = req;
570
+ context.res = request.res = response.res = res;
571
+ request.ctx = response.ctx = context;
572
+ request.response = response;
573
+ response.request = request;
574
+ context.onerror = context.onerror.bind(context);
575
+ context.originalUrl = request.originalUrl = req.url;
576
+ context.starttime = Date.now();
577
+ context.performanceStarttime = performance.now();
578
+ return context;
579
+ }
580
+ }
581
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWdnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi9lZ2cudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzlDLE9BQU8sSUFBSSxNQUFNLFdBQVcsQ0FBQztBQUM3QixPQUFPLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDekIsT0FBTyxJQUFJLEVBQUUsRUFBNkMsTUFBTSxXQUFXLENBQUM7QUFDNUUsT0FBTyxTQUFTLE1BQU0sZ0JBQWdCLENBQUM7QUFHdkMsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFOUMsT0FBTyxFQUFFLEtBQUssSUFBSSxRQUFRLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDaEQsaURBQWlEO0FBQ2pELE9BQU8sbUJBQW1CLE1BQU0sZ0JBQWdCLENBQUM7QUFDakQsaURBQWlEO0FBQ2pELE9BQU8sRUFBRSxLQUFLLElBQUksa0JBQWtCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3RCxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEMsT0FBTyxFQUFFLGdCQUFnQixJQUFJLGFBQWEsRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxPQUFPLElBQUksY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0Qsc0RBQXNEO0FBQ3RELE9BQU8sWUFBWSxNQUFNLHVCQUF1QixDQUFDO0FBSWpELE9BQU8sT0FBTyxNQUFNLDBCQUEwQixDQUFDO0FBQy9DLE9BQU8sT0FBTyxNQUFNLDBCQUEwQixDQUFDO0FBQy9DLE9BQU8sUUFBUSxNQUFNLDJCQUEyQixDQUFDO0FBRWpELE9BQU8sRUFBRSxNQUFNLElBQUksZUFBZSxFQUFtQixNQUFNLDJCQUEyQixDQUFDO0FBQ3ZGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFN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
@@ -1,2 +1,5 @@
1
- import { CookieLimitExceedError } from "../../CookieLimitExceedError-CAW0HYJw.js";
2
- export { CookieLimitExceedError };
1
+ export declare class CookieLimitExceedError extends Error {
2
+ key: string;
3
+ cookie: string;
4
+ constructor(key: string, cookie: string);
5
+ }
@@ -1,3 +1,12 @@
1
- import { CookieLimitExceedError } from "../../CookieLimitExceedError-DLGakbeu.js";
2
-
3
- export { CookieLimitExceedError };
1
+ export class CookieLimitExceedError extends Error {
2
+ key;
3
+ cookie;
4
+ constructor(key, cookie) {
5
+ super(`cookie ${key}'s length(${cookie.length}) exceed the limit(4093)`);
6
+ this.name = this.constructor.name;
7
+ this.key = key;
8
+ this.cookie = cookie;
9
+ Error.captureStackTrace(this, this.constructor);
10
+ }
11
+ }
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29va2llTGltaXRFeGNlZWRFcnJvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvZXJyb3IvQ29va2llTGltaXRFeGNlZWRFcnJvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sc0JBQXVCLFNBQVEsS0FBSztJQUMvQyxHQUFHLENBQVM7SUFDWixNQUFNLENBQVM7SUFFZixZQUFZLEdBQVcsRUFBRSxNQUFjO1FBQ3JDLEtBQUssQ0FBQyxVQUFVLEdBQUcsYUFBYSxNQUFNLENBQUMsTUFBTSwwQkFBMEIsQ0FBQyxDQUFDO1FBQ3pFLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUM7UUFDbEMsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7UUFDZixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixLQUFLLENBQUMsaUJBQWlCLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNsRCxDQUFDO0NBQ0YifQ==
@@ -1,2 +1,5 @@
1
- import { MessageUnhandledRejectionError } from "../../MessageUnhandledRejectionError-Lq5fWw24.js";
2
- export { MessageUnhandledRejectionError };
1
+ export declare class MessageUnhandledRejectionError extends Error {
2
+ event: string | symbol;
3
+ args: any[];
4
+ constructor(err: Error, event: string | symbol, ...args: any[]);
5
+ }