egg 3.29.0 → 4.0.0-beta.10

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