@alanszp/express 12.0.2 → 13.0.0

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 (180) hide show
  1. package/dist/helpers/getRequestBaseLog.d.ts +2 -0
  2. package/dist/helpers/getRequestBaseLog.js +9 -0
  3. package/dist/helpers/getRequestBaseLog.js.map +1 -0
  4. package/dist/helpers/renderErrorJson.d.ts +1 -0
  5. package/dist/helpers/renderErrorJson.js +10 -1
  6. package/dist/helpers/renderErrorJson.js.map +1 -1
  7. package/dist/index.d.ts +3 -1
  8. package/dist/index.js +3 -1
  9. package/dist/index.js.map +1 -1
  10. package/dist/middlewares/errorRequestHandlerMiddleware.d.ts +4 -0
  11. package/dist/middlewares/errorRequestHandlerMiddleware.js +68 -0
  12. package/dist/middlewares/errorRequestHandlerMiddleware.js.map +1 -0
  13. package/dist/middlewares/hasPermissions.d.ts +20 -0
  14. package/dist/middlewares/hasPermissions.js +90 -0
  15. package/dist/middlewares/hasPermissions.js.map +1 -0
  16. package/dist/middlewares/hasRoles.js +4 -4
  17. package/dist/middlewares/hasRoles.js.map +1 -1
  18. package/package.json +9 -10
  19. package/.gitignore +0 -3
  20. package/.npmignore +0 -3
  21. package/dist/middlewares/returnInternalServerError.d.ts +0 -4
  22. package/dist/middlewares/returnInternalServerError.js +0 -10
  23. package/dist/middlewares/returnInternalServerError.js.map +0 -1
  24. package/node_modules/@jest/expect-utils/LICENSE +0 -21
  25. package/node_modules/@jest/expect-utils/README.md +0 -5
  26. package/node_modules/@jest/expect-utils/build/index.d.ts +0 -93
  27. package/node_modules/@jest/expect-utils/build/index.js +0 -37
  28. package/node_modules/@jest/expect-utils/build/jasmineUtils.js +0 -282
  29. package/node_modules/@jest/expect-utils/build/types.js +0 -1
  30. package/node_modules/@jest/expect-utils/build/utils.js +0 -457
  31. package/node_modules/@jest/expect-utils/package.json +0 -33
  32. package/node_modules/@jest/types/LICENSE +0 -21
  33. package/node_modules/@jest/types/README.md +0 -30
  34. package/node_modules/@jest/types/build/Circus.js +0 -1
  35. package/node_modules/@jest/types/build/Config.js +0 -1
  36. package/node_modules/@jest/types/build/Global.js +0 -1
  37. package/node_modules/@jest/types/build/TestResult.js +0 -1
  38. package/node_modules/@jest/types/build/Transform.js +0 -1
  39. package/node_modules/@jest/types/build/index.d.ts +0 -1166
  40. package/node_modules/@jest/types/build/index.js +0 -1
  41. package/node_modules/@jest/types/package.json +0 -38
  42. package/node_modules/@types/jest/LICENSE +0 -21
  43. package/node_modules/@types/jest/README.md +0 -17
  44. package/node_modules/@types/jest/index.d.ts +0 -1608
  45. package/node_modules/@types/jest/package.json +0 -159
  46. package/node_modules/@types/node/LICENSE +0 -21
  47. package/node_modules/@types/node/README.md +0 -15
  48. package/node_modules/@types/node/assert/strict.d.ts +0 -8
  49. package/node_modules/@types/node/assert.d.ts +0 -996
  50. package/node_modules/@types/node/async_hooks.d.ts +0 -539
  51. package/node_modules/@types/node/buffer.d.ts +0 -2362
  52. package/node_modules/@types/node/child_process.d.ts +0 -1540
  53. package/node_modules/@types/node/cluster.d.ts +0 -432
  54. package/node_modules/@types/node/console.d.ts +0 -415
  55. package/node_modules/@types/node/constants.d.ts +0 -19
  56. package/node_modules/@types/node/crypto.d.ts +0 -4487
  57. package/node_modules/@types/node/dgram.d.ts +0 -596
  58. package/node_modules/@types/node/diagnostics_channel.d.ts +0 -545
  59. package/node_modules/@types/node/dns/promises.d.ts +0 -425
  60. package/node_modules/@types/node/dns.d.ts +0 -809
  61. package/node_modules/@types/node/dom-events.d.ts +0 -122
  62. package/node_modules/@types/node/domain.d.ts +0 -170
  63. package/node_modules/@types/node/events.d.ts +0 -879
  64. package/node_modules/@types/node/fs/promises.d.ts +0 -1239
  65. package/node_modules/@types/node/fs.d.ts +0 -4311
  66. package/node_modules/@types/node/globals.d.ts +0 -411
  67. package/node_modules/@types/node/globals.global.d.ts +0 -1
  68. package/node_modules/@types/node/http.d.ts +0 -1887
  69. package/node_modules/@types/node/http2.d.ts +0 -2382
  70. package/node_modules/@types/node/https.d.ts +0 -550
  71. package/node_modules/@types/node/index.d.ts +0 -88
  72. package/node_modules/@types/node/inspector.d.ts +0 -2747
  73. package/node_modules/@types/node/module.d.ts +0 -315
  74. package/node_modules/@types/node/net.d.ts +0 -949
  75. package/node_modules/@types/node/os.d.ts +0 -478
  76. package/node_modules/@types/node/package.json +0 -229
  77. package/node_modules/@types/node/path.d.ts +0 -191
  78. package/node_modules/@types/node/perf_hooks.d.ts +0 -645
  79. package/node_modules/@types/node/process.d.ts +0 -1561
  80. package/node_modules/@types/node/punycode.d.ts +0 -117
  81. package/node_modules/@types/node/querystring.d.ts +0 -141
  82. package/node_modules/@types/node/readline/promises.d.ts +0 -150
  83. package/node_modules/@types/node/readline.d.ts +0 -539
  84. package/node_modules/@types/node/repl.d.ts +0 -430
  85. package/node_modules/@types/node/stream/consumers.d.ts +0 -12
  86. package/node_modules/@types/node/stream/promises.d.ts +0 -83
  87. package/node_modules/@types/node/stream/web.d.ts +0 -366
  88. package/node_modules/@types/node/stream.d.ts +0 -1701
  89. package/node_modules/@types/node/string_decoder.d.ts +0 -67
  90. package/node_modules/@types/node/test.d.ts +0 -1465
  91. package/node_modules/@types/node/timers/promises.d.ts +0 -93
  92. package/node_modules/@types/node/timers.d.ts +0 -240
  93. package/node_modules/@types/node/tls.d.ts +0 -1210
  94. package/node_modules/@types/node/trace_events.d.ts +0 -182
  95. package/node_modules/@types/node/ts4.8/assert/strict.d.ts +0 -8
  96. package/node_modules/@types/node/ts4.8/assert.d.ts +0 -996
  97. package/node_modules/@types/node/ts4.8/async_hooks.d.ts +0 -539
  98. package/node_modules/@types/node/ts4.8/buffer.d.ts +0 -2362
  99. package/node_modules/@types/node/ts4.8/child_process.d.ts +0 -1540
  100. package/node_modules/@types/node/ts4.8/cluster.d.ts +0 -432
  101. package/node_modules/@types/node/ts4.8/console.d.ts +0 -415
  102. package/node_modules/@types/node/ts4.8/constants.d.ts +0 -19
  103. package/node_modules/@types/node/ts4.8/crypto.d.ts +0 -4487
  104. package/node_modules/@types/node/ts4.8/dgram.d.ts +0 -596
  105. package/node_modules/@types/node/ts4.8/diagnostics_channel.d.ts +0 -545
  106. package/node_modules/@types/node/ts4.8/dns/promises.d.ts +0 -425
  107. package/node_modules/@types/node/ts4.8/dns.d.ts +0 -809
  108. package/node_modules/@types/node/ts4.8/dom-events.d.ts +0 -122
  109. package/node_modules/@types/node/ts4.8/domain.d.ts +0 -170
  110. package/node_modules/@types/node/ts4.8/events.d.ts +0 -879
  111. package/node_modules/@types/node/ts4.8/fs/promises.d.ts +0 -1239
  112. package/node_modules/@types/node/ts4.8/fs.d.ts +0 -4311
  113. package/node_modules/@types/node/ts4.8/globals.d.ts +0 -411
  114. package/node_modules/@types/node/ts4.8/globals.global.d.ts +0 -1
  115. package/node_modules/@types/node/ts4.8/http.d.ts +0 -1887
  116. package/node_modules/@types/node/ts4.8/http2.d.ts +0 -2382
  117. package/node_modules/@types/node/ts4.8/https.d.ts +0 -550
  118. package/node_modules/@types/node/ts4.8/index.d.ts +0 -88
  119. package/node_modules/@types/node/ts4.8/inspector.d.ts +0 -2747
  120. package/node_modules/@types/node/ts4.8/module.d.ts +0 -315
  121. package/node_modules/@types/node/ts4.8/net.d.ts +0 -949
  122. package/node_modules/@types/node/ts4.8/os.d.ts +0 -478
  123. package/node_modules/@types/node/ts4.8/path.d.ts +0 -191
  124. package/node_modules/@types/node/ts4.8/perf_hooks.d.ts +0 -645
  125. package/node_modules/@types/node/ts4.8/process.d.ts +0 -1561
  126. package/node_modules/@types/node/ts4.8/punycode.d.ts +0 -117
  127. package/node_modules/@types/node/ts4.8/querystring.d.ts +0 -141
  128. package/node_modules/@types/node/ts4.8/readline/promises.d.ts +0 -150
  129. package/node_modules/@types/node/ts4.8/readline.d.ts +0 -539
  130. package/node_modules/@types/node/ts4.8/repl.d.ts +0 -430
  131. package/node_modules/@types/node/ts4.8/stream/consumers.d.ts +0 -12
  132. package/node_modules/@types/node/ts4.8/stream/promises.d.ts +0 -83
  133. package/node_modules/@types/node/ts4.8/stream/web.d.ts +0 -366
  134. package/node_modules/@types/node/ts4.8/stream.d.ts +0 -1701
  135. package/node_modules/@types/node/ts4.8/string_decoder.d.ts +0 -67
  136. package/node_modules/@types/node/ts4.8/test.d.ts +0 -1465
  137. package/node_modules/@types/node/ts4.8/timers/promises.d.ts +0 -93
  138. package/node_modules/@types/node/ts4.8/timers.d.ts +0 -240
  139. package/node_modules/@types/node/ts4.8/tls.d.ts +0 -1210
  140. package/node_modules/@types/node/ts4.8/trace_events.d.ts +0 -182
  141. package/node_modules/@types/node/ts4.8/tty.d.ts +0 -208
  142. package/node_modules/@types/node/ts4.8/url.d.ts +0 -927
  143. package/node_modules/@types/node/ts4.8/util.d.ts +0 -2183
  144. package/node_modules/@types/node/ts4.8/v8.d.ts +0 -764
  145. package/node_modules/@types/node/ts4.8/vm.d.ts +0 -903
  146. package/node_modules/@types/node/ts4.8/wasi.d.ts +0 -179
  147. package/node_modules/@types/node/ts4.8/worker_threads.d.ts +0 -691
  148. package/node_modules/@types/node/ts4.8/zlib.d.ts +0 -517
  149. package/node_modules/@types/node/tty.d.ts +0 -208
  150. package/node_modules/@types/node/url.d.ts +0 -927
  151. package/node_modules/@types/node/util.d.ts +0 -2183
  152. package/node_modules/@types/node/v8.d.ts +0 -764
  153. package/node_modules/@types/node/vm.d.ts +0 -903
  154. package/node_modules/@types/node/wasi.d.ts +0 -179
  155. package/node_modules/@types/node/worker_threads.d.ts +0 -691
  156. package/node_modules/@types/node/zlib.d.ts +0 -517
  157. package/src/helpers/getIp.ts +0 -5
  158. package/src/helpers/getRequestLogger.ts +0 -6
  159. package/src/helpers/now.ts +0 -3
  160. package/src/helpers/renderErrorJson.ts +0 -29
  161. package/src/index.ts +0 -10
  162. package/src/middlewares/accessLogger.ts +0 -34
  163. package/src/middlewares/auditLog.ts +0 -52
  164. package/src/middlewares/authedForOrg.ts +0 -50
  165. package/src/middlewares/authenticateUser.test.ts +0 -403
  166. package/src/middlewares/authenticateUser.ts +0 -171
  167. package/src/middlewares/createContext.test.ts +0 -85
  168. package/src/middlewares/createContext.ts +0 -49
  169. package/src/middlewares/hasRoles.ts +0 -24
  170. package/src/middlewares/jsonBodyParser.ts +0 -22
  171. package/src/middlewares/returnInternalServerError.ts +0 -15
  172. package/src/middlewares/returnNotFound.ts +0 -11
  173. package/src/test/mocks/authOptionsMocks.ts +0 -35
  174. package/src/test/mocks/expressMocks.ts +0 -33
  175. package/src/test/mocks/jwtUserMocks.ts +0 -19
  176. package/src/test/setup.test.ts +0 -15
  177. package/src/test/setup.ts +0 -3
  178. package/src/types/AuthMethod.ts +0 -27
  179. package/src/types/GenericRequest.ts +0 -3
  180. package/src/types/custom.d.ts +0 -20
@@ -1,432 +0,0 @@
1
- /**
2
- * Clusters of Node.js processes can be used to run multiple instances of Node.js
3
- * that can distribute workloads among their application threads. When process
4
- * isolation is not needed, use the `worker_threads` module instead, which
5
- * allows running multiple application threads within a single Node.js instance.
6
- *
7
- * The cluster module allows easy creation of child processes that all share
8
- * server ports.
9
- *
10
- * ```js
11
- * import cluster from 'node:cluster';
12
- * import http from 'node:http';
13
- * import { availableParallelism } from 'node:os';
14
- * import process from 'node:process';
15
- *
16
- * const numCPUs = availableParallelism();
17
- *
18
- * if (cluster.isPrimary) {
19
- * console.log(`Primary ${process.pid} is running`);
20
- *
21
- * // Fork workers.
22
- * for (let i = 0; i < numCPUs; i++) {
23
- * cluster.fork();
24
- * }
25
- *
26
- * cluster.on('exit', (worker, code, signal) => {
27
- * console.log(`worker ${worker.process.pid} died`);
28
- * });
29
- * } else {
30
- * // Workers can share any TCP connection
31
- * // In this case it is an HTTP server
32
- * http.createServer((req, res) => {
33
- * res.writeHead(200);
34
- * res.end('hello world\n');
35
- * }).listen(8000);
36
- *
37
- * console.log(`Worker ${process.pid} started`);
38
- * }
39
- * ```
40
- *
41
- * Running Node.js will now share port 8000 between the workers:
42
- *
43
- * ```console
44
- * $ node server.js
45
- * Primary 3596 is running
46
- * Worker 4324 started
47
- * Worker 4520 started
48
- * Worker 6056 started
49
- * Worker 5644 started
50
- * ```
51
- *
52
- * On Windows, it is not yet possible to set up a named pipe server in a worker.
53
- * @see [source](https://github.com/nodejs/node/blob/v20.2.0/lib/cluster.js)
54
- */
55
- declare module "cluster" {
56
- import * as child from "node:child_process";
57
- import EventEmitter = require("node:events");
58
- import * as net from "node:net";
59
- type SerializationType = "json" | "advanced";
60
- export interface ClusterSettings {
61
- execArgv?: string[] | undefined; // default: process.execArgv
62
- exec?: string | undefined;
63
- args?: string[] | undefined;
64
- silent?: boolean | undefined;
65
- stdio?: any[] | undefined;
66
- uid?: number | undefined;
67
- gid?: number | undefined;
68
- inspectPort?: number | (() => number) | undefined;
69
- serialization?: SerializationType | undefined;
70
- cwd?: string | undefined;
71
- windowsHide?: boolean | undefined;
72
- }
73
- export interface Address {
74
- address: string;
75
- port: number;
76
- addressType: number | "udp4" | "udp6"; // 4, 6, -1, "udp4", "udp6"
77
- }
78
- /**
79
- * A `Worker` object contains all public information and method about a worker.
80
- * In the primary it can be obtained using `cluster.workers`. In a worker
81
- * it can be obtained using `cluster.worker`.
82
- * @since v0.7.0
83
- */
84
- export class Worker extends EventEmitter {
85
- /**
86
- * Each new worker is given its own unique id, this id is stored in the`id`.
87
- *
88
- * While a worker is alive, this is the key that indexes it in`cluster.workers`.
89
- * @since v0.8.0
90
- */
91
- id: number;
92
- /**
93
- * All workers are created using `child_process.fork()`, the returned object
94
- * from this function is stored as `.process`. In a worker, the global `process`is stored.
95
- *
96
- * See: `Child Process module`.
97
- *
98
- * Workers will call `process.exit(0)` if the `'disconnect'` event occurs
99
- * on `process` and `.exitedAfterDisconnect` is not `true`. This protects against
100
- * accidental disconnection.
101
- * @since v0.7.0
102
- */
103
- process: child.ChildProcess;
104
- /**
105
- * Send a message to a worker or primary, optionally with a handle.
106
- *
107
- * In the primary, this sends a message to a specific worker. It is identical to `ChildProcess.send()`.
108
- *
109
- * In a worker, this sends a message to the primary. It is identical to`process.send()`.
110
- *
111
- * This example will echo back all messages from the primary:
112
- *
113
- * ```js
114
- * if (cluster.isPrimary) {
115
- * const worker = cluster.fork();
116
- * worker.send('hi there');
117
- *
118
- * } else if (cluster.isWorker) {
119
- * process.on('message', (msg) => {
120
- * process.send(msg);
121
- * });
122
- * }
123
- * ```
124
- * @since v0.7.0
125
- * @param options The `options` argument, if present, is an object used to parameterize the sending of certain types of handles. `options` supports the following properties:
126
- */
127
- send(message: child.Serializable, callback?: (error: Error | null) => void): boolean;
128
- send(
129
- message: child.Serializable,
130
- sendHandle: child.SendHandle,
131
- callback?: (error: Error | null) => void,
132
- ): boolean;
133
- send(
134
- message: child.Serializable,
135
- sendHandle: child.SendHandle,
136
- options?: child.MessageOptions,
137
- callback?: (error: Error | null) => void,
138
- ): boolean;
139
- /**
140
- * This function will kill the worker. In the primary worker, it does this by
141
- * disconnecting the `worker.process`, and once disconnected, killing with`signal`. In the worker, it does it by killing the process with `signal`.
142
- *
143
- * The `kill()` function kills the worker process without waiting for a graceful
144
- * disconnect, it has the same behavior as `worker.process.kill()`.
145
- *
146
- * This method is aliased as `worker.destroy()` for backwards compatibility.
147
- *
148
- * In a worker, `process.kill()` exists, but it is not this function;
149
- * it is `kill()`.
150
- * @since v0.9.12
151
- * @param [signal='SIGTERM'] Name of the kill signal to send to the worker process.
152
- */
153
- kill(signal?: string): void;
154
- destroy(signal?: string): void;
155
- /**
156
- * In a worker, this function will close all servers, wait for the `'close'` event
157
- * on those servers, and then disconnect the IPC channel.
158
- *
159
- * In the primary, an internal message is sent to the worker causing it to call`.disconnect()` on itself.
160
- *
161
- * Causes `.exitedAfterDisconnect` to be set.
162
- *
163
- * After a server is closed, it will no longer accept new connections,
164
- * but connections may be accepted by any other listening worker. Existing
165
- * connections will be allowed to close as usual. When no more connections exist,
166
- * see `server.close()`, the IPC channel to the worker will close allowing it
167
- * to die gracefully.
168
- *
169
- * The above applies _only_ to server connections, client connections are not
170
- * automatically closed by workers, and disconnect does not wait for them to close
171
- * before exiting.
172
- *
173
- * In a worker, `process.disconnect` exists, but it is not this function;
174
- * it is `disconnect()`.
175
- *
176
- * Because long living server connections may block workers from disconnecting, it
177
- * may be useful to send a message, so application specific actions may be taken to
178
- * close them. It also may be useful to implement a timeout, killing a worker if
179
- * the `'disconnect'` event has not been emitted after some time.
180
- *
181
- * ```js
182
- * if (cluster.isPrimary) {
183
- * const worker = cluster.fork();
184
- * let timeout;
185
- *
186
- * worker.on('listening', (address) => {
187
- * worker.send('shutdown');
188
- * worker.disconnect();
189
- * timeout = setTimeout(() => {
190
- * worker.kill();
191
- * }, 2000);
192
- * });
193
- *
194
- * worker.on('disconnect', () => {
195
- * clearTimeout(timeout);
196
- * });
197
- *
198
- * } else if (cluster.isWorker) {
199
- * const net = require('node:net');
200
- * const server = net.createServer((socket) => {
201
- * // Connections never end
202
- * });
203
- *
204
- * server.listen(8000);
205
- *
206
- * process.on('message', (msg) => {
207
- * if (msg === 'shutdown') {
208
- * // Initiate graceful close of any connections to server
209
- * }
210
- * });
211
- * }
212
- * ```
213
- * @since v0.7.7
214
- * @return A reference to `worker`.
215
- */
216
- disconnect(): void;
217
- /**
218
- * This function returns `true` if the worker is connected to its primary via its
219
- * IPC channel, `false` otherwise. A worker is connected to its primary after it
220
- * has been created. It is disconnected after the `'disconnect'` event is emitted.
221
- * @since v0.11.14
222
- */
223
- isConnected(): boolean;
224
- /**
225
- * This function returns `true` if the worker's process has terminated (either
226
- * because of exiting or being signaled). Otherwise, it returns `false`.
227
- *
228
- * ```js
229
- * import cluster from 'node:cluster';
230
- * import http from 'node:http';
231
- * import { availableParallelism } from 'node:os';
232
- * import process from 'node:process';
233
- *
234
- * const numCPUs = availableParallelism();
235
- *
236
- * if (cluster.isPrimary) {
237
- * console.log(`Primary ${process.pid} is running`);
238
- *
239
- * // Fork workers.
240
- * for (let i = 0; i < numCPUs; i++) {
241
- * cluster.fork();
242
- * }
243
- *
244
- * cluster.on('fork', (worker) => {
245
- * console.log('worker is dead:', worker.isDead());
246
- * });
247
- *
248
- * cluster.on('exit', (worker, code, signal) => {
249
- * console.log('worker is dead:', worker.isDead());
250
- * });
251
- * } else {
252
- * // Workers can share any TCP connection. In this case, it is an HTTP server.
253
- * http.createServer((req, res) => {
254
- * res.writeHead(200);
255
- * res.end(`Current process\n ${process.pid}`);
256
- * process.kill(process.pid);
257
- * }).listen(8000);
258
- * }
259
- * ```
260
- * @since v0.11.14
261
- */
262
- isDead(): boolean;
263
- /**
264
- * This property is `true` if the worker exited due to `.disconnect()`.
265
- * If the worker exited any other way, it is `false`. If the
266
- * worker has not exited, it is `undefined`.
267
- *
268
- * The boolean `worker.exitedAfterDisconnect` allows distinguishing between
269
- * voluntary and accidental exit, the primary may choose not to respawn a worker
270
- * based on this value.
271
- *
272
- * ```js
273
- * cluster.on('exit', (worker, code, signal) => {
274
- * if (worker.exitedAfterDisconnect === true) {
275
- * console.log('Oh, it was just voluntary – no need to worry');
276
- * }
277
- * });
278
- *
279
- * // kill worker
280
- * worker.kill();
281
- * ```
282
- * @since v6.0.0
283
- */
284
- exitedAfterDisconnect: boolean;
285
- /**
286
- * events.EventEmitter
287
- * 1. disconnect
288
- * 2. error
289
- * 3. exit
290
- * 4. listening
291
- * 5. message
292
- * 6. online
293
- */
294
- addListener(event: string, listener: (...args: any[]) => void): this;
295
- addListener(event: "disconnect", listener: () => void): this;
296
- addListener(event: "error", listener: (error: Error) => void): this;
297
- addListener(event: "exit", listener: (code: number, signal: string) => void): this;
298
- addListener(event: "listening", listener: (address: Address) => void): this;
299
- addListener(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
300
- addListener(event: "online", listener: () => void): this;
301
- emit(event: string | symbol, ...args: any[]): boolean;
302
- emit(event: "disconnect"): boolean;
303
- emit(event: "error", error: Error): boolean;
304
- emit(event: "exit", code: number, signal: string): boolean;
305
- emit(event: "listening", address: Address): boolean;
306
- emit(event: "message", message: any, handle: net.Socket | net.Server): boolean;
307
- emit(event: "online"): boolean;
308
- on(event: string, listener: (...args: any[]) => void): this;
309
- on(event: "disconnect", listener: () => void): this;
310
- on(event: "error", listener: (error: Error) => void): this;
311
- on(event: "exit", listener: (code: number, signal: string) => void): this;
312
- on(event: "listening", listener: (address: Address) => void): this;
313
- on(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
314
- on(event: "online", listener: () => void): this;
315
- once(event: string, listener: (...args: any[]) => void): this;
316
- once(event: "disconnect", listener: () => void): this;
317
- once(event: "error", listener: (error: Error) => void): this;
318
- once(event: "exit", listener: (code: number, signal: string) => void): this;
319
- once(event: "listening", listener: (address: Address) => void): this;
320
- once(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
321
- once(event: "online", listener: () => void): this;
322
- prependListener(event: string, listener: (...args: any[]) => void): this;
323
- prependListener(event: "disconnect", listener: () => void): this;
324
- prependListener(event: "error", listener: (error: Error) => void): this;
325
- prependListener(event: "exit", listener: (code: number, signal: string) => void): this;
326
- prependListener(event: "listening", listener: (address: Address) => void): this;
327
- prependListener(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
328
- prependListener(event: "online", listener: () => void): this;
329
- prependOnceListener(event: string, listener: (...args: any[]) => void): this;
330
- prependOnceListener(event: "disconnect", listener: () => void): this;
331
- prependOnceListener(event: "error", listener: (error: Error) => void): this;
332
- prependOnceListener(event: "exit", listener: (code: number, signal: string) => void): this;
333
- prependOnceListener(event: "listening", listener: (address: Address) => void): this;
334
- prependOnceListener(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
335
- prependOnceListener(event: "online", listener: () => void): this;
336
- }
337
- export interface Cluster extends EventEmitter {
338
- disconnect(callback?: () => void): void;
339
- fork(env?: any): Worker;
340
- /** @deprecated since v16.0.0 - use isPrimary. */
341
- readonly isMaster: boolean;
342
- readonly isPrimary: boolean;
343
- readonly isWorker: boolean;
344
- schedulingPolicy: number;
345
- readonly settings: ClusterSettings;
346
- /** @deprecated since v16.0.0 - use setupPrimary. */
347
- setupMaster(settings?: ClusterSettings): void;
348
- /**
349
- * `setupPrimary` is used to change the default 'fork' behavior. Once called, the settings will be present in cluster.settings.
350
- */
351
- setupPrimary(settings?: ClusterSettings): void;
352
- readonly worker?: Worker | undefined;
353
- readonly workers?: NodeJS.Dict<Worker> | undefined;
354
- readonly SCHED_NONE: number;
355
- readonly SCHED_RR: number;
356
- /**
357
- * events.EventEmitter
358
- * 1. disconnect
359
- * 2. exit
360
- * 3. fork
361
- * 4. listening
362
- * 5. message
363
- * 6. online
364
- * 7. setup
365
- */
366
- addListener(event: string, listener: (...args: any[]) => void): this;
367
- addListener(event: "disconnect", listener: (worker: Worker) => void): this;
368
- addListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this;
369
- addListener(event: "fork", listener: (worker: Worker) => void): this;
370
- addListener(event: "listening", listener: (worker: Worker, address: Address) => void): this;
371
- addListener(
372
- event: "message",
373
- listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void,
374
- ): this; // the handle is a net.Socket or net.Server object, or undefined.
375
- addListener(event: "online", listener: (worker: Worker) => void): this;
376
- addListener(event: "setup", listener: (settings: ClusterSettings) => void): this;
377
- emit(event: string | symbol, ...args: any[]): boolean;
378
- emit(event: "disconnect", worker: Worker): boolean;
379
- emit(event: "exit", worker: Worker, code: number, signal: string): boolean;
380
- emit(event: "fork", worker: Worker): boolean;
381
- emit(event: "listening", worker: Worker, address: Address): boolean;
382
- emit(event: "message", worker: Worker, message: any, handle: net.Socket | net.Server): boolean;
383
- emit(event: "online", worker: Worker): boolean;
384
- emit(event: "setup", settings: ClusterSettings): boolean;
385
- on(event: string, listener: (...args: any[]) => void): this;
386
- on(event: "disconnect", listener: (worker: Worker) => void): this;
387
- on(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this;
388
- on(event: "fork", listener: (worker: Worker) => void): this;
389
- on(event: "listening", listener: (worker: Worker, address: Address) => void): this;
390
- on(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
391
- on(event: "online", listener: (worker: Worker) => void): this;
392
- on(event: "setup", listener: (settings: ClusterSettings) => void): this;
393
- once(event: string, listener: (...args: any[]) => void): this;
394
- once(event: "disconnect", listener: (worker: Worker) => void): this;
395
- once(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this;
396
- once(event: "fork", listener: (worker: Worker) => void): this;
397
- once(event: "listening", listener: (worker: Worker, address: Address) => void): this;
398
- once(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
399
- once(event: "online", listener: (worker: Worker) => void): this;
400
- once(event: "setup", listener: (settings: ClusterSettings) => void): this;
401
- prependListener(event: string, listener: (...args: any[]) => void): this;
402
- prependListener(event: "disconnect", listener: (worker: Worker) => void): this;
403
- prependListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this;
404
- prependListener(event: "fork", listener: (worker: Worker) => void): this;
405
- prependListener(event: "listening", listener: (worker: Worker, address: Address) => void): this;
406
- // the handle is a net.Socket or net.Server object, or undefined.
407
- prependListener(
408
- event: "message",
409
- listener: (worker: Worker, message: any, handle?: net.Socket | net.Server) => void,
410
- ): this;
411
- prependListener(event: "online", listener: (worker: Worker) => void): this;
412
- prependListener(event: "setup", listener: (settings: ClusterSettings) => void): this;
413
- prependOnceListener(event: string, listener: (...args: any[]) => void): this;
414
- prependOnceListener(event: "disconnect", listener: (worker: Worker) => void): this;
415
- prependOnceListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this;
416
- prependOnceListener(event: "fork", listener: (worker: Worker) => void): this;
417
- prependOnceListener(event: "listening", listener: (worker: Worker, address: Address) => void): this;
418
- // the handle is a net.Socket or net.Server object, or undefined.
419
- prependOnceListener(
420
- event: "message",
421
- listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void,
422
- ): this;
423
- prependOnceListener(event: "online", listener: (worker: Worker) => void): this;
424
- prependOnceListener(event: "setup", listener: (settings: ClusterSettings) => void): this;
425
- }
426
- const cluster: Cluster;
427
- export default cluster;
428
- }
429
- declare module "node:cluster" {
430
- export * from "cluster";
431
- export { default as default } from "cluster";
432
- }