cdk-common 2.0.1302 → 2.0.1304

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 (48) hide show
  1. package/.jsii +14 -2
  2. package/API.md +12 -0
  3. package/lib/main.js +1 -1
  4. package/lib/managed-policies.d.ts +3 -1
  5. package/lib/managed-policies.js +3 -1
  6. package/node_modules/@types/concat-stream/node_modules/@types/node/README.md +1 -1
  7. package/node_modules/@types/concat-stream/node_modules/@types/node/assert.d.ts +1 -1
  8. package/node_modules/@types/concat-stream/node_modules/@types/node/child_process.d.ts +15 -9
  9. package/node_modules/@types/concat-stream/node_modules/@types/node/cluster.d.ts +3 -4
  10. package/node_modules/@types/concat-stream/node_modules/@types/node/crypto.d.ts +35 -35
  11. package/node_modules/@types/concat-stream/node_modules/@types/node/dns.d.ts +1 -1
  12. package/node_modules/@types/concat-stream/node_modules/@types/node/events.d.ts +1 -1
  13. package/node_modules/@types/concat-stream/node_modules/@types/node/fs.d.ts +11 -11
  14. package/node_modules/@types/concat-stream/node_modules/@types/node/http.d.ts +3 -4
  15. package/node_modules/@types/concat-stream/node_modules/@types/node/http2.d.ts +4 -3
  16. package/node_modules/@types/concat-stream/node_modules/@types/node/https.d.ts +9 -12
  17. package/node_modules/@types/concat-stream/node_modules/@types/node/net.d.ts +5 -5
  18. package/node_modules/@types/concat-stream/node_modules/@types/node/os.d.ts +13 -3
  19. package/node_modules/@types/concat-stream/node_modules/@types/node/package.json +2 -2
  20. package/node_modules/@types/concat-stream/node_modules/@types/node/perf_hooks.d.ts +6 -8
  21. package/node_modules/@types/concat-stream/node_modules/@types/node/process.d.ts +7 -19
  22. package/node_modules/@types/concat-stream/node_modules/@types/node/readline/promises.d.ts +1 -1
  23. package/node_modules/@types/concat-stream/node_modules/@types/node/stream.d.ts +29 -22
  24. package/node_modules/@types/concat-stream/node_modules/@types/node/tls.d.ts +2 -2
  25. package/node_modules/@types/concat-stream/node_modules/@types/node/v8.d.ts +2 -2
  26. package/node_modules/@types/concat-stream/node_modules/@types/node/vm.d.ts +18 -48
  27. package/node_modules/@types/form-data/node_modules/@types/node/README.md +1 -1
  28. package/node_modules/@types/form-data/node_modules/@types/node/assert.d.ts +1 -1
  29. package/node_modules/@types/form-data/node_modules/@types/node/child_process.d.ts +15 -9
  30. package/node_modules/@types/form-data/node_modules/@types/node/cluster.d.ts +3 -4
  31. package/node_modules/@types/form-data/node_modules/@types/node/crypto.d.ts +35 -35
  32. package/node_modules/@types/form-data/node_modules/@types/node/dns.d.ts +1 -1
  33. package/node_modules/@types/form-data/node_modules/@types/node/events.d.ts +1 -1
  34. package/node_modules/@types/form-data/node_modules/@types/node/fs.d.ts +11 -11
  35. package/node_modules/@types/form-data/node_modules/@types/node/http.d.ts +3 -4
  36. package/node_modules/@types/form-data/node_modules/@types/node/http2.d.ts +4 -3
  37. package/node_modules/@types/form-data/node_modules/@types/node/https.d.ts +9 -12
  38. package/node_modules/@types/form-data/node_modules/@types/node/net.d.ts +5 -5
  39. package/node_modules/@types/form-data/node_modules/@types/node/os.d.ts +13 -3
  40. package/node_modules/@types/form-data/node_modules/@types/node/package.json +2 -2
  41. package/node_modules/@types/form-data/node_modules/@types/node/perf_hooks.d.ts +6 -8
  42. package/node_modules/@types/form-data/node_modules/@types/node/process.d.ts +7 -19
  43. package/node_modules/@types/form-data/node_modules/@types/node/readline/promises.d.ts +1 -1
  44. package/node_modules/@types/form-data/node_modules/@types/node/stream.d.ts +29 -22
  45. package/node_modules/@types/form-data/node_modules/@types/node/tls.d.ts +2 -2
  46. package/node_modules/@types/form-data/node_modules/@types/node/v8.d.ts +2 -2
  47. package/node_modules/@types/form-data/node_modules/@types/node/vm.d.ts +18 -48
  48. package/package.json +2 -2
@@ -8,7 +8,7 @@ This package contains type definitions for node (https://nodejs.org/).
8
8
  Files were exported from https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node.
9
9
 
10
10
  ### Additional Details
11
- * Last updated: Thu, 09 Oct 2025 17:35:09 GMT
11
+ * Last updated: Sat, 11 Oct 2025 14:02:18 GMT
12
12
  * Dependencies: [undici-types](https://npmjs.com/package/undici-types)
13
13
 
14
14
  # Credits
@@ -88,7 +88,7 @@ declare module "assert" {
88
88
  * @since v24.6.0
89
89
  */
90
90
  new(
91
- options?: AssertOptions & { strict?: true },
91
+ options?: AssertOptions & { strict?: true | undefined },
92
92
  ): AssertStrict;
93
93
  new(
94
94
  options: AssertOptions,
@@ -69,7 +69,7 @@ declare module "child_process" {
69
69
  import { Abortable, EventEmitter } from "node:events";
70
70
  import * as dgram from "node:dgram";
71
71
  import * as net from "node:net";
72
- import { Pipe, Readable, Stream, Writable } from "node:stream";
72
+ import { Readable, Stream, Writable } from "node:stream";
73
73
  import { URL } from "node:url";
74
74
  type Serializable = string | object | number | boolean | bigint;
75
75
  type SendHandle = net.Socket | net.Server | dgram.Socket | undefined;
@@ -139,7 +139,7 @@ declare module "child_process" {
139
139
  * no IPC channel exists, this property is `undefined`.
140
140
  * @since v7.1.0
141
141
  */
142
- readonly channel?: Pipe | null | undefined;
142
+ readonly channel?: Control | null;
143
143
  /**
144
144
  * A sparse array of pipes to the child process, corresponding with positions in
145
145
  * the `stdio` option passed to {@link spawn} that have been set
@@ -612,6 +612,10 @@ declare module "child_process" {
612
612
  Readable | Writable | null | undefined, // extra, no modification
613
613
  ];
614
614
  }
615
+ interface Control extends EventEmitter {
616
+ ref(): void;
617
+ unref(): void;
618
+ }
615
619
  interface MessageOptions {
616
620
  keepOpen?: boolean | undefined;
617
621
  }
@@ -894,11 +898,12 @@ declare module "child_process" {
894
898
  interface ExecOptionsWithBufferEncoding extends ExecOptions {
895
899
  encoding: "buffer" | null; // specify `null`.
896
900
  }
901
+ // TODO: Just Plain Wrong™ (see also nodejs/node#57392)
897
902
  interface ExecException extends Error {
898
- cmd?: string | undefined;
899
- killed?: boolean | undefined;
900
- code?: number | undefined;
901
- signal?: NodeJS.Signals | undefined;
903
+ cmd?: string;
904
+ killed?: boolean;
905
+ code?: number;
906
+ signal?: NodeJS.Signals;
902
907
  stdout?: string;
903
908
  stderr?: string;
904
909
  }
@@ -1056,10 +1061,11 @@ declare module "child_process" {
1056
1061
  }
1057
1062
  /** @deprecated Use `ExecFileOptions` instead. */
1058
1063
  interface ExecFileOptionsWithOtherEncoding extends ExecFileOptions {}
1064
+ // TODO: execFile exceptions can take many forms... this accurately describes none of them
1059
1065
  type ExecFileException =
1060
1066
  & Omit<ExecException, "code">
1061
1067
  & Omit<NodeJS.ErrnoException, "code">
1062
- & { code?: string | number | undefined | null };
1068
+ & { code?: string | number | null };
1063
1069
  /**
1064
1070
  * The `child_process.execFile()` function is similar to {@link exec} except that it does not spawn a shell by default. Rather, the specified
1065
1071
  * executable `file` is spawned directly as a new process making it slightly more
@@ -1320,7 +1326,7 @@ declare module "child_process" {
1320
1326
  stderr: T;
1321
1327
  status: number | null;
1322
1328
  signal: NodeJS.Signals | null;
1323
- error?: Error | undefined;
1329
+ error?: Error;
1324
1330
  }
1325
1331
  /**
1326
1332
  * The `child_process.spawnSync()` method is generally identical to {@link spawn} with the exception that the function will not return
@@ -1409,7 +1415,7 @@ declare module "child_process" {
1409
1415
  encoding: BufferEncoding;
1410
1416
  }
1411
1417
  interface ExecFileSyncOptionsWithBufferEncoding extends ExecFileSyncOptions {
1412
- encoding?: "buffer" | null; // specify `null`.
1418
+ encoding?: "buffer" | null | undefined; // specify `null`.
1413
1419
  }
1414
1420
  /**
1415
1421
  * The `child_process.execFileSync()` method is generally identical to {@link execFile} with the exception that the method will not
@@ -481,7 +481,7 @@ declare module "cluster" {
481
481
  * ```
482
482
  * @since v0.7.0
483
483
  */
484
- readonly worker?: Worker | undefined;
484
+ readonly worker?: Worker;
485
485
  /**
486
486
  * A hash that stores the active worker objects, keyed by `id` field. This makes it easy to loop through all the workers. It is only available in the primary process.
487
487
  *
@@ -497,7 +497,7 @@ declare module "cluster" {
497
497
  * ```
498
498
  * @since v0.7.0
499
499
  */
500
- readonly workers?: NodeJS.Dict<Worker> | undefined;
500
+ readonly workers?: NodeJS.Dict<Worker>;
501
501
  readonly SCHED_NONE: number;
502
502
  readonly SCHED_RR: number;
503
503
  /**
@@ -550,10 +550,9 @@ declare module "cluster" {
550
550
  prependListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this;
551
551
  prependListener(event: "fork", listener: (worker: Worker) => void): this;
552
552
  prependListener(event: "listening", listener: (worker: Worker, address: Address) => void): this;
553
- // the handle is a net.Socket or net.Server object, or undefined.
554
553
  prependListener(
555
554
  event: "message",
556
- listener: (worker: Worker, message: any, handle?: net.Socket | net.Server) => void,
555
+ listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void,
557
556
  ): this;
558
557
  prependListener(event: "online", listener: (worker: Worker) => void): this;
559
558
  prependListener(event: "setup", listener: (settings: ClusterSettings) => void): this;
@@ -510,50 +510,50 @@ declare module "crypto" {
510
510
  format: "jwk";
511
511
  }
512
512
  interface JsonWebKey {
513
- crv?: string | undefined;
514
- d?: string | undefined;
515
- dp?: string | undefined;
516
- dq?: string | undefined;
517
- e?: string | undefined;
518
- k?: string | undefined;
519
- kty?: string | undefined;
520
- n?: string | undefined;
521
- p?: string | undefined;
522
- q?: string | undefined;
523
- qi?: string | undefined;
524
- x?: string | undefined;
525
- y?: string | undefined;
513
+ crv?: string;
514
+ d?: string;
515
+ dp?: string;
516
+ dq?: string;
517
+ e?: string;
518
+ k?: string;
519
+ kty?: string;
520
+ n?: string;
521
+ p?: string;
522
+ q?: string;
523
+ qi?: string;
524
+ x?: string;
525
+ y?: string;
526
526
  [key: string]: unknown;
527
527
  }
528
528
  interface AsymmetricKeyDetails {
529
529
  /**
530
530
  * Key size in bits (RSA, DSA).
531
531
  */
532
- modulusLength?: number | undefined;
532
+ modulusLength?: number;
533
533
  /**
534
534
  * Public exponent (RSA).
535
535
  */
536
- publicExponent?: bigint | undefined;
536
+ publicExponent?: bigint;
537
537
  /**
538
538
  * Name of the message digest (RSA-PSS).
539
539
  */
540
- hashAlgorithm?: string | undefined;
540
+ hashAlgorithm?: string;
541
541
  /**
542
542
  * Name of the message digest used by MGF1 (RSA-PSS).
543
543
  */
544
- mgf1HashAlgorithm?: string | undefined;
544
+ mgf1HashAlgorithm?: string;
545
545
  /**
546
546
  * Minimal salt length in bytes (RSA-PSS).
547
547
  */
548
- saltLength?: number | undefined;
548
+ saltLength?: number;
549
549
  /**
550
550
  * Size of q in bits (DSA).
551
551
  */
552
- divisorLength?: number | undefined;
552
+ divisorLength?: number;
553
553
  /**
554
554
  * Name of the curve (EC).
555
555
  */
556
- namedCurve?: string | undefined;
556
+ namedCurve?: string;
557
557
  }
558
558
  /**
559
559
  * Node.js uses a `KeyObject` class to represent a symmetric or asymmetric key,
@@ -598,7 +598,7 @@ declare module "crypto" {
598
598
  * keys.
599
599
  * @since v11.6.0
600
600
  */
601
- asymmetricKeyType?: KeyType | undefined;
601
+ asymmetricKeyType?: KeyType;
602
602
  /**
603
603
  * This property exists only on asymmetric keys. Depending on the type of the key,
604
604
  * this object contains information about the key. None of the information obtained
@@ -612,7 +612,7 @@ declare module "crypto" {
612
612
  * Other key details might be exposed via this API using additional attributes.
613
613
  * @since v15.7.0
614
614
  */
615
- asymmetricKeyDetails?: AsymmetricKeyDetails | undefined;
615
+ asymmetricKeyDetails?: AsymmetricKeyDetails;
616
616
  /**
617
617
  * For symmetric keys, the following encoding options can be used:
618
618
  *
@@ -651,7 +651,7 @@ declare module "crypto" {
651
651
  * property is `undefined` for asymmetric keys.
652
652
  * @since v11.6.0
653
653
  */
654
- symmetricKeySize?: number | undefined;
654
+ symmetricKeySize?: number;
655
655
  /**
656
656
  * Converts a `KeyObject` instance to a `CryptoKey`.
657
657
  * @since 22.10.0
@@ -2512,15 +2512,15 @@ declare module "crypto" {
2512
2512
  /**
2513
2513
  * Name of the message digest
2514
2514
  */
2515
- hashAlgorithm?: string;
2515
+ hashAlgorithm?: string | undefined;
2516
2516
  /**
2517
2517
  * Name of the message digest used by MGF1
2518
2518
  */
2519
- mgf1HashAlgorithm?: string;
2519
+ mgf1HashAlgorithm?: string | undefined;
2520
2520
  /**
2521
2521
  * Minimal salt length in bytes
2522
2522
  */
2523
- saltLength?: string;
2523
+ saltLength?: string | undefined;
2524
2524
  }
2525
2525
  interface DSAKeyPairKeyObjectOptions {
2526
2526
  /**
@@ -2563,15 +2563,15 @@ declare module "crypto" {
2563
2563
  /**
2564
2564
  * Name of the message digest
2565
2565
  */
2566
- hashAlgorithm?: string;
2566
+ hashAlgorithm?: string | undefined;
2567
2567
  /**
2568
2568
  * Name of the message digest used by MGF1
2569
2569
  */
2570
- mgf1HashAlgorithm?: string;
2570
+ mgf1HashAlgorithm?: string | undefined;
2571
2571
  /**
2572
2572
  * Minimal salt length in bytes
2573
2573
  */
2574
- saltLength?: string;
2574
+ saltLength?: string | undefined;
2575
2575
  publicKeyEncoding: {
2576
2576
  type: "spki";
2577
2577
  format: PubF;
@@ -3835,23 +3835,23 @@ declare module "crypto" {
3835
3835
  /**
3836
3836
  * @default 'always'
3837
3837
  */
3838
- subject?: "always" | "default" | "never";
3838
+ subject?: "always" | "default" | "never" | undefined;
3839
3839
  /**
3840
3840
  * @default true
3841
3841
  */
3842
- wildcards?: boolean;
3842
+ wildcards?: boolean | undefined;
3843
3843
  /**
3844
3844
  * @default true
3845
3845
  */
3846
- partialWildcards?: boolean;
3846
+ partialWildcards?: boolean | undefined;
3847
3847
  /**
3848
3848
  * @default false
3849
3849
  */
3850
- multiLabelWildcards?: boolean;
3850
+ multiLabelWildcards?: boolean | undefined;
3851
3851
  /**
3852
3852
  * @default false
3853
3853
  */
3854
- singleLabelSubdomains?: boolean;
3854
+ singleLabelSubdomains?: boolean | undefined;
3855
3855
  }
3856
3856
  /**
3857
3857
  * Encapsulates an X509 certificate and provides read-only access to
@@ -3953,7 +3953,7 @@ declare module "crypto" {
3953
3953
  * available.
3954
3954
  * @since v15.9.0
3955
3955
  */
3956
- readonly issuerCertificate?: X509Certificate | undefined;
3956
+ readonly issuerCertificate: X509Certificate | undefined;
3957
3957
  /**
3958
3958
  * The public key `KeyObject` for this certificate.
3959
3959
  * @since v15.6.0
@@ -829,7 +829,7 @@ declare module "dns" {
829
829
  * The number of tries the resolver will try contacting each name server before giving up.
830
830
  * @default 4
831
831
  */
832
- tries?: number;
832
+ tries?: number | undefined;
833
833
  /**
834
834
  * The max retry timeout, in milliseconds.
835
835
  * @default 0
@@ -484,7 +484,7 @@ declare module "events" {
484
484
  * directly rather than as a child class.
485
485
  * @default new.target.name if instantiated as a child class.
486
486
  */
487
- name?: string;
487
+ name?: string | undefined;
488
488
  }
489
489
 
490
490
  /**
@@ -2634,7 +2634,7 @@ declare module "fs" {
2634
2634
  /**
2635
2635
  * @default null
2636
2636
  */
2637
- position?: number | undefined | null;
2637
+ position?: number | null | undefined;
2638
2638
  }
2639
2639
  /**
2640
2640
  * Write `buffer` to the file specified by `fd`.
@@ -4463,7 +4463,7 @@ declare module "fs" {
4463
4463
  /**
4464
4464
  * @default false
4465
4465
  */
4466
- recursive?: boolean;
4466
+ recursive?: boolean | undefined;
4467
4467
  }
4468
4468
  /**
4469
4469
  * Synchronously open a directory. See [`opendir(3)`](http://man7.org/linux/man-pages/man3/opendir.3.html).
@@ -4516,54 +4516,54 @@ declare module "fs" {
4516
4516
  * Dereference symlinks
4517
4517
  * @default false
4518
4518
  */
4519
- dereference?: boolean;
4519
+ dereference?: boolean | undefined;
4520
4520
  /**
4521
4521
  * When `force` is `false`, and the destination
4522
4522
  * exists, throw an error.
4523
4523
  * @default false
4524
4524
  */
4525
- errorOnExist?: boolean;
4525
+ errorOnExist?: boolean | undefined;
4526
4526
  /**
4527
4527
  * Overwrite existing file or directory. _The copy
4528
4528
  * operation will ignore errors if you set this to false and the destination
4529
4529
  * exists. Use the `errorOnExist` option to change this behavior.
4530
4530
  * @default true
4531
4531
  */
4532
- force?: boolean;
4532
+ force?: boolean | undefined;
4533
4533
  /**
4534
4534
  * Modifiers for copy operation. See `mode` flag of {@link copyFileSync()}
4535
4535
  */
4536
- mode?: number;
4536
+ mode?: number | undefined;
4537
4537
  /**
4538
4538
  * When `true` timestamps from `src` will
4539
4539
  * be preserved.
4540
4540
  * @default false
4541
4541
  */
4542
- preserveTimestamps?: boolean;
4542
+ preserveTimestamps?: boolean | undefined;
4543
4543
  /**
4544
4544
  * Copy directories recursively.
4545
4545
  * @default false
4546
4546
  */
4547
- recursive?: boolean;
4547
+ recursive?: boolean | undefined;
4548
4548
  /**
4549
4549
  * When true, path resolution for symlinks will be skipped
4550
4550
  * @default false
4551
4551
  */
4552
- verbatimSymlinks?: boolean;
4552
+ verbatimSymlinks?: boolean | undefined;
4553
4553
  }
4554
4554
  export interface CopyOptions extends CopyOptionsBase {
4555
4555
  /**
4556
4556
  * Function to filter copied files/directories. Return
4557
4557
  * `true` to copy the item, `false` to ignore it.
4558
4558
  */
4559
- filter?(source: string, destination: string): boolean | Promise<boolean>;
4559
+ filter?: ((source: string, destination: string) => boolean | Promise<boolean>) | undefined;
4560
4560
  }
4561
4561
  export interface CopySyncOptions extends CopyOptionsBase {
4562
4562
  /**
4563
4563
  * Function to filter copied files/directories. Return
4564
4564
  * `true` to copy the item, `false` to ignore it.
4565
4565
  */
4566
- filter?(source: string, destination: string): boolean;
4566
+ filter?: ((source: string, destination: string) => boolean) | undefined;
4567
4567
  }
4568
4568
  /**
4569
4569
  * Asynchronously copies the entire directory structure from `src` to `dest`,
@@ -200,7 +200,7 @@ declare module "http" {
200
200
  "x-frame-options"?: string | undefined;
201
201
  "x-xss-protection"?: string | undefined;
202
202
  }
203
- interface ClientRequestArgs {
203
+ interface ClientRequestArgs extends Pick<LookupOptions, "hints"> {
204
204
  _defaultAgent?: Agent | undefined;
205
205
  agent?: Agent | boolean | undefined;
206
206
  auth?: string | null | undefined;
@@ -213,7 +213,6 @@ declare module "http" {
213
213
  defaultPort?: number | string | undefined;
214
214
  family?: number | undefined;
215
215
  headers?: OutgoingHttpHeaders | readonly string[] | undefined;
216
- hints?: LookupOptions["hints"];
217
216
  host?: string | null | undefined;
218
217
  hostname?: string | null | undefined;
219
218
  insecureHTTPParser?: boolean | undefined;
@@ -234,7 +233,7 @@ declare module "http" {
234
233
  socketPath?: string | undefined;
235
234
  timeout?: number | undefined;
236
235
  uniqueHeaders?: Array<string | string[]> | undefined;
237
- joinDuplicateHeaders?: boolean;
236
+ joinDuplicateHeaders?: boolean | undefined;
238
237
  }
239
238
  interface ServerOptions<
240
239
  Request extends typeof IncomingMessage = typeof IncomingMessage,
@@ -260,7 +259,7 @@ declare module "http" {
260
259
  * @default false
261
260
  * @since v18.14.0
262
261
  */
263
- joinDuplicateHeaders?: boolean;
262
+ joinDuplicateHeaders?: boolean | undefined;
264
263
  /**
265
264
  * The number of milliseconds of inactivity a server needs to wait for additional incoming data,
266
265
  * after it has finished writing the last response, before a socket will be destroyed.
@@ -51,14 +51,15 @@ declare module "http2" {
51
51
  length: number;
52
52
  }
53
53
  export interface ServerStreamFileResponseOptions {
54
- // eslint-disable-next-line @typescript-eslint/no-invalid-void-type
55
- statCheck?(stats: fs.Stats, headers: OutgoingHttpHeaders, statOptions: StatOptions): void | boolean;
54
+ statCheck?:
55
+ | ((stats: fs.Stats, headers: OutgoingHttpHeaders, statOptions: StatOptions) => void)
56
+ | undefined;
56
57
  waitForTrailers?: boolean | undefined;
57
58
  offset?: number | undefined;
58
59
  length?: number | undefined;
59
60
  }
60
61
  export interface ServerStreamFileResponseOptionsWithError extends ServerStreamFileResponseOptions {
61
- onError?(err: NodeJS.ErrnoException): void;
62
+ onError?: ((err: NodeJS.ErrnoException) => void) | undefined;
62
63
  }
63
64
  export interface Http2Stream extends stream.Duplex {
64
65
  /**
@@ -8,20 +8,17 @@ declare module "https" {
8
8
  import * as tls from "node:tls";
9
9
  import * as http from "node:http";
10
10
  import { URL } from "node:url";
11
- type ServerOptions<
11
+ interface ServerOptions<
12
12
  Request extends typeof http.IncomingMessage = typeof http.IncomingMessage,
13
13
  Response extends typeof http.ServerResponse<InstanceType<Request>> = typeof http.ServerResponse,
14
- > = tls.SecureContextOptions & tls.TlsOptions & http.ServerOptions<Request, Response>;
15
- type RequestOptions =
16
- & http.RequestOptions
17
- & tls.SecureContextOptions
18
- & {
19
- checkServerIdentity?:
20
- | ((hostname: string, cert: tls.DetailedPeerCertificate) => Error | undefined)
21
- | undefined;
22
- rejectUnauthorized?: boolean | undefined; // Defaults to true
23
- servername?: string | undefined; // SNI TLS Extension
24
- };
14
+ > extends http.ServerOptions<Request, Response>, tls.TlsOptions {}
15
+ interface RequestOptions extends http.RequestOptions, tls.SecureContextOptions {
16
+ checkServerIdentity?:
17
+ | ((hostname: string, cert: tls.DetailedPeerCertificate) => Error | undefined)
18
+ | undefined;
19
+ rejectUnauthorized?: boolean | undefined; // Defaults to true
20
+ servername?: string | undefined; // SNI TLS Extension
21
+ }
25
22
  interface AgentOptions extends http.AgentOptions, tls.ConnectionOptions {
26
23
  maxCachedSessions?: number | undefined;
27
24
  }
@@ -32,7 +32,7 @@ declare module "net" {
32
32
  onread?: OnReadOpts | undefined;
33
33
  readable?: boolean | undefined;
34
34
  writable?: boolean | undefined;
35
- signal?: AbortSignal;
35
+ signal?: AbortSignal | undefined;
36
36
  }
37
37
  interface OnReadOpts {
38
38
  buffer: Uint8Array | (() => Uint8Array);
@@ -321,25 +321,25 @@ declare module "net" {
321
321
  * the socket is destroyed (for example, if the client disconnected).
322
322
  * @since v0.5.10
323
323
  */
324
- readonly remoteAddress?: string | undefined;
324
+ readonly remoteAddress: string | undefined;
325
325
  /**
326
326
  * The string representation of the remote IP family. `'IPv4'` or `'IPv6'`. Value may be `undefined` if
327
327
  * the socket is destroyed (for example, if the client disconnected).
328
328
  * @since v0.11.14
329
329
  */
330
- readonly remoteFamily?: string | undefined;
330
+ readonly remoteFamily: string | undefined;
331
331
  /**
332
332
  * The numeric representation of the remote port. For example, `80` or `21`. Value may be `undefined` if
333
333
  * the socket is destroyed (for example, if the client disconnected).
334
334
  * @since v0.5.10
335
335
  */
336
- readonly remotePort?: number | undefined;
336
+ readonly remotePort: number | undefined;
337
337
  /**
338
338
  * The socket timeout in milliseconds as set by `socket.setTimeout()`.
339
339
  * It is `undefined` if a timeout has not been set.
340
340
  * @since v10.7.0
341
341
  */
342
- readonly timeout?: number | undefined;
342
+ readonly timeout?: number;
343
343
  /**
344
344
  * Half-closes the socket. i.e., it sends a FIN packet. It is possible the
345
345
  * server will still send some data.
@@ -30,10 +30,10 @@ declare module "os" {
30
30
  mac: string;
31
31
  internal: boolean;
32
32
  cidr: string | null;
33
+ scopeid?: number;
33
34
  }
34
35
  interface NetworkInterfaceInfoIPv4 extends NetworkInterfaceBase {
35
36
  family: "IPv4";
36
- scopeid?: undefined;
37
37
  }
38
38
  interface NetworkInterfaceInfoIPv6 extends NetworkInterfaceBase {
39
39
  family: "IPv6";
@@ -231,6 +231,15 @@ declare module "os" {
231
231
  * @since v2.3.0
232
232
  */
233
233
  function homedir(): string;
234
+ interface UserInfoOptions {
235
+ encoding?: BufferEncoding | "buffer" | undefined;
236
+ }
237
+ interface UserInfoOptionsWithBufferEncoding extends UserInfoOptions {
238
+ encoding: "buffer";
239
+ }
240
+ interface UserInfoOptionsWithStringEncoding extends UserInfoOptions {
241
+ encoding?: BufferEncoding | undefined;
242
+ }
234
243
  /**
235
244
  * Returns information about the currently effective user. On POSIX platforms,
236
245
  * this is typically a subset of the password file. The returned object includes
@@ -244,8 +253,9 @@ declare module "os" {
244
253
  * Throws a [`SystemError`](https://nodejs.org/docs/latest-v24.x/api/errors.html#class-systemerror) if a user has no `username` or `homedir`.
245
254
  * @since v6.0.0
246
255
  */
247
- function userInfo(options: { encoding: "buffer" }): UserInfo<Buffer>;
248
- function userInfo(options?: { encoding: BufferEncoding }): UserInfo<string>;
256
+ function userInfo(options: UserInfoOptionsWithBufferEncoding): UserInfo<Buffer>;
257
+ function userInfo(options?: UserInfoOptionsWithStringEncoding): UserInfo<string>;
258
+ function userInfo(options: UserInfoOptions): UserInfo<string | Buffer>;
249
259
  type SignalConstants = {
250
260
  [key in NodeJS.Signals]: number;
251
261
  };
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@types/node",
3
- "version": "24.7.1",
3
+ "version": "24.7.2",
4
4
  "description": "TypeScript definitions for node",
5
5
  "homepage": "https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node",
6
6
  "license": "MIT",
@@ -150,6 +150,6 @@
150
150
  "undici-types": "~7.14.0"
151
151
  },
152
152
  "peerDependencies": {},
153
- "typesPublisherContentHash": "3707c233ea107d992d9f52fba949c67a272356911b6089143bd81b83b0ebb9c3",
153
+ "typesPublisherContentHash": "4bf36d2d52de2aa8898ee24d026198a784567fa5a42adcae5e37b826951ff66d",
154
154
  "typeScriptVersion": "5.2"
155
155
  }
@@ -48,13 +48,13 @@ declare module "perf_hooks" {
48
48
  * the type of garbage collection operation that occurred.
49
49
  * See perf_hooks.constants for valid values.
50
50
  */
51
- readonly kind?: number | undefined;
51
+ readonly kind: number;
52
52
  /**
53
53
  * When `performanceEntry.entryType` is equal to 'gc', the `performance.flags`
54
54
  * property contains additional information about garbage collection operation.
55
55
  * See perf_hooks.constants for valid values.
56
56
  */
57
- readonly flags?: number | undefined;
57
+ readonly flags: number;
58
58
  }
59
59
  /**
60
60
  * The constructor of this class is not exposed to users directly.
@@ -92,11 +92,6 @@ declare module "perf_hooks" {
92
92
  * @since v8.5.0
93
93
  */
94
94
  readonly entryType: EntryType;
95
- /**
96
- * Additional detail specific to the `entryType`.
97
- * @since v16.0.0
98
- */
99
- readonly detail?: NodeGCPerformanceDetail | unknown | undefined; // TODO: Narrow this based on entry type.
100
95
  toJSON(): any;
101
96
  }
102
97
  /**
@@ -104,6 +99,7 @@ declare module "perf_hooks" {
104
99
  * @since v18.2.0, v16.17.0
105
100
  */
106
101
  class PerformanceMark extends PerformanceEntry {
102
+ readonly detail: any;
107
103
  readonly duration: 0;
108
104
  readonly entryType: "mark";
109
105
  }
@@ -114,6 +110,7 @@ declare module "perf_hooks" {
114
110
  * @since v18.2.0, v16.17.0
115
111
  */
116
112
  class PerformanceMeasure extends PerformanceEntry {
113
+ readonly detail: any;
117
114
  readonly entryType: "measure";
118
115
  }
119
116
  interface UVMetrics {
@@ -130,6 +127,7 @@ declare module "perf_hooks" {
130
127
  */
131
128
  readonly eventsWaiting: number;
132
129
  }
130
+ // TODO: PerformanceNodeEntry is missing
133
131
  /**
134
132
  * _This property is an extension by Node.js. It is not available in Web browsers._
135
133
  *
@@ -225,7 +223,7 @@ declare module "perf_hooks" {
225
223
  /**
226
224
  * Additional optional detail to include with the mark.
227
225
  */
228
- detail?: unknown | undefined;
226
+ detail?: unknown;
229
227
  /**
230
228
  * Duration between start and end times.
231
229
  */