cdk-ecr-deployment 3.1.6 → 3.1.8

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 (30) hide show
  1. package/.jsii +2 -2
  2. package/lib/index.js +3 -3
  3. package/node_modules/@types/cacheable-request/node_modules/@types/node/README.md +1 -1
  4. package/node_modules/@types/cacheable-request/node_modules/@types/node/dgram.d.ts +7 -6
  5. package/node_modules/@types/cacheable-request/node_modules/@types/node/fs.d.ts +45 -98
  6. package/node_modules/@types/cacheable-request/node_modules/@types/node/globals.d.ts +0 -57
  7. package/node_modules/@types/cacheable-request/node_modules/@types/node/module.d.ts +445 -233
  8. package/node_modules/@types/cacheable-request/node_modules/@types/node/net.d.ts +6 -5
  9. package/node_modules/@types/cacheable-request/node_modules/@types/node/package.json +2 -2
  10. package/node_modules/@types/cacheable-request/node_modules/@types/node/sqlite.d.ts +115 -0
  11. package/node_modules/@types/cacheable-request/node_modules/@types/node/util.d.ts +34 -8
  12. package/node_modules/@types/keyv/node_modules/@types/node/README.md +1 -1
  13. package/node_modules/@types/keyv/node_modules/@types/node/dgram.d.ts +7 -6
  14. package/node_modules/@types/keyv/node_modules/@types/node/fs.d.ts +45 -98
  15. package/node_modules/@types/keyv/node_modules/@types/node/globals.d.ts +0 -57
  16. package/node_modules/@types/keyv/node_modules/@types/node/module.d.ts +445 -233
  17. package/node_modules/@types/keyv/node_modules/@types/node/net.d.ts +6 -5
  18. package/node_modules/@types/keyv/node_modules/@types/node/package.json +2 -2
  19. package/node_modules/@types/keyv/node_modules/@types/node/sqlite.d.ts +115 -0
  20. package/node_modules/@types/keyv/node_modules/@types/node/util.d.ts +34 -8
  21. package/node_modules/@types/responselike/node_modules/@types/node/README.md +1 -1
  22. package/node_modules/@types/responselike/node_modules/@types/node/dgram.d.ts +7 -6
  23. package/node_modules/@types/responselike/node_modules/@types/node/fs.d.ts +45 -98
  24. package/node_modules/@types/responselike/node_modules/@types/node/globals.d.ts +0 -57
  25. package/node_modules/@types/responselike/node_modules/@types/node/module.d.ts +445 -233
  26. package/node_modules/@types/responselike/node_modules/@types/node/net.d.ts +6 -5
  27. package/node_modules/@types/responselike/node_modules/@types/node/package.json +2 -2
  28. package/node_modules/@types/responselike/node_modules/@types/node/sqlite.d.ts +115 -0
  29. package/node_modules/@types/responselike/node_modules/@types/node/util.d.ts +34 -8
  30. package/package.json +1 -1
package/.jsii CHANGED
@@ -4040,6 +4040,6 @@
4040
4040
  "symbolId": "src/index:S3ArchiveName"
4041
4041
  }
4042
4042
  },
4043
- "version": "3.1.6",
4044
- "fingerprint": "pmIwXWhpuQndxDRnZox9o9dNJy652u0z6oxR+xQt82I="
4043
+ "version": "3.1.8",
4044
+ "fingerprint": "QeOs8BV4Wew1Zi20xKg/cG1U1elbudb5nF6X52JXzhU="
4045
4045
  }
package/lib/index.js CHANGED
@@ -38,7 +38,7 @@ class DockerImageName {
38
38
  }
39
39
  exports.DockerImageName = DockerImageName;
40
40
  _a = JSII_RTTI_SYMBOL_1;
41
- DockerImageName[_a] = { fqn: "cdk-ecr-deployment.DockerImageName", version: "3.1.6" };
41
+ DockerImageName[_a] = { fqn: "cdk-ecr-deployment.DockerImageName", version: "3.1.8" };
42
42
  class S3ArchiveName {
43
43
  constructor(p, ref, creds) {
44
44
  this.creds = creds;
@@ -51,7 +51,7 @@ class S3ArchiveName {
51
51
  }
52
52
  exports.S3ArchiveName = S3ArchiveName;
53
53
  _b = JSII_RTTI_SYMBOL_1;
54
- S3ArchiveName[_b] = { fqn: "cdk-ecr-deployment.S3ArchiveName", version: "3.1.6" };
54
+ S3ArchiveName[_b] = { fqn: "cdk-ecr-deployment.S3ArchiveName", version: "3.1.8" };
55
55
  class ECRDeployment extends constructs_1.Construct {
56
56
  constructor(scope, id, props) {
57
57
  super(scope, id);
@@ -141,5 +141,5 @@ class ECRDeployment extends constructs_1.Construct {
141
141
  }
142
142
  exports.ECRDeployment = ECRDeployment;
143
143
  _c = JSII_RTTI_SYMBOL_1;
144
- ECRDeployment[_c] = { fqn: "cdk-ecr-deployment.ECRDeployment", version: "3.1.6" };
144
+ ECRDeployment[_c] = { fqn: "cdk-ecr-deployment.ECRDeployment", version: "3.1.8" };
145
145
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n\n\nimport * as child_process from 'child_process';\nimport * as path from 'path';\nimport { aws_ec2 as ec2, aws_iam as iam, aws_lambda as lambda, Duration, CustomResource, Token } from 'aws-cdk-lib';\nimport { PolicyStatement, AddToPrincipalPolicyResult } from 'aws-cdk-lib/aws-iam';\nimport { RuntimeFamily } from 'aws-cdk-lib/aws-lambda';\nimport { Construct } from 'constructs';\nimport { shouldUsePrebuiltLambda } from './config';\n\nexport interface ECRDeploymentProps {\n\n  /**\n   * Image to use to build Golang lambda for custom resource, if download fails or is not wanted.\n   *\n   * Might be needed for local build if all images need to come from own registry.\n   *\n   * Note that image should use yum as a package manager and have golang available.\n   *\n   * @default - public.ecr.aws/sam/build-go1.x:latest\n   */\n  readonly buildImage?: string;\n  /**\n   * The source of the docker image.\n   */\n  readonly src: IImageName;\n\n  /**\n   * The destination of the docker image.\n   */\n  readonly dest: IImageName;\n\n  /**\n   * The image architecture to be copied.\n   *\n   * The 'amd64' architecture will be copied by default. Specify the\n   * architecture or architectures to copy here.\n   *\n   * It is currently not possible to copy more than one architecture\n   * at a time: the array you specify must contain exactly one string.\n   *\n   * @default ['amd64']\n   */\n  readonly imageArch?: string[];\n\n  /**\n   * The amount of memory (in MiB) to allocate to the AWS Lambda function which\n   * replicates the files from the CDK bucket to the destination bucket.\n   *\n   * If you are deploying large files, you will need to increase this number\n   * accordingly.\n   *\n   * @default - 512\n   */\n  readonly memoryLimit?: number;\n\n  /**\n   * Execution role associated with this function\n   *\n   * @default - A role is automatically created\n   */\n  readonly role?: iam.IRole;\n\n  /**\n   * The VPC network to place the deployment lambda handler in.\n   *\n   * @default - None\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Where in the VPC to place the deployment lambda handler.\n   * Only used if 'vpc' is supplied.\n   *\n   * @default - the Vpc default strategy if not specified\n   */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n  /**\n   * The list of security groups to associate with the Lambda's network interfaces.\n   *\n   * Only used if 'vpc' is supplied.\n   *\n   * @default - If the function is placed within a VPC and a security group is\n   * not specified, either by this or securityGroup prop, a dedicated security\n   * group will be created for this function.\n   */\n  readonly securityGroups?: ec2.SecurityGroup[];\n\n  /**\n   * The lambda function runtime environment.\n   *\n   * @default - lambda.Runtime.PROVIDED_AL2023\n   */\n  readonly lambdaRuntime?: lambda.Runtime;\n\n  /**\n   * The name of the lambda handler.\n   *\n   * @default - bootstrap\n   */\n  readonly lambdaHandler?: string;\n\n  /**\n   * The environment variable to set\n   */\n  readonly environment?: { [key: string]: string };\n}\n\nexport interface IImageName {\n  /**\n   *  The uri of the docker image.\n   *\n   *  The uri spec follows https://github.com/containers/skopeo\n   */\n  readonly uri: string;\n\n  /**\n   * The credentials of the docker image. Format `user:password` or `AWS Secrets Manager secret arn` or `AWS Secrets Manager secret name`\n   */\n  creds?: string;\n}\n\nfunction getCode(buildImage: string): lambda.AssetCode {\n  if (shouldUsePrebuiltLambda()) {\n    try {\n      const installScript = path.join(__dirname, '../lambda/install.js');\n      const prebuiltPath = path.join(__dirname, '../lambda/out');\n      child_process.execFileSync(process.argv0, [installScript, prebuiltPath]);\n\n      return lambda.Code.fromAsset(prebuiltPath);\n    } catch (err) {\n      console.warn(`Can not get prebuilt lambda: ${err}`);\n    }\n  }\n\n  return lambda.Code.fromDockerBuild(path.join(__dirname, '../lambda'), {\n    buildArgs: {\n      buildImage,\n    },\n  });\n}\n\nexport class DockerImageName implements IImageName {\n  public constructor(private name: string, public creds?: string) { }\n  public get uri(): string { return `docker://${this.name}`; }\n}\n\nexport class S3ArchiveName implements IImageName {\n  private name: string;\n  public constructor(p: string, ref?: string, public creds?: string) {\n    this.name = p;\n    if (ref) {\n      this.name += ':' + ref;\n    }\n  }\n  public get uri(): string { return `s3://${this.name}`; }\n}\n\nexport class ECRDeployment extends Construct {\n  private handler: lambda.SingletonFunction;\n\n  constructor(scope: Construct, id: string, props: ECRDeploymentProps) {\n    super(scope, id);\n    const memoryLimit = props.memoryLimit ?? 512;\n    this.handler = new lambda.SingletonFunction(this, 'CustomResourceHandler', {\n      uuid: this.renderSingletonUuid(memoryLimit),\n      code: getCode(props.buildImage ?? 'public.ecr.aws/docker/library/golang:1'),\n      runtime: props.lambdaRuntime ?? new lambda.Runtime('provided.al2023', RuntimeFamily.OTHER), // not using Runtime.PROVIDED_AL2023 to support older CDK versions (< 2.105.0)\n      handler: props.lambdaHandler ?? 'bootstrap',\n      environment: props.environment,\n      lambdaPurpose: 'Custom::CDKECRDeployment',\n      timeout: Duration.minutes(15),\n      role: props.role,\n      memorySize: memoryLimit,\n      vpc: props.vpc,\n      vpcSubnets: props.vpcSubnets,\n      securityGroups: props.securityGroups,\n    });\n\n    const handlerRole = this.handler.role;\n    if (!handlerRole) { throw new Error('lambda.SingletonFunction should have created a Role'); }\n\n    handlerRole.addToPrincipalPolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        actions: [\n          'ecr:GetAuthorizationToken',\n          'ecr:BatchCheckLayerAvailability',\n          'ecr:GetDownloadUrlForLayer',\n          'ecr:GetRepositoryPolicy',\n          'ecr:DescribeRepositories',\n          'ecr:ListImages',\n          'ecr:DescribeImages',\n          'ecr:BatchGetImage',\n          'ecr:ListTagsForResource',\n          'ecr:DescribeImageScanFindings',\n          'ecr:InitiateLayerUpload',\n          'ecr:UploadLayerPart',\n          'ecr:CompleteLayerUpload',\n          'ecr:PutImage',\n        ],\n        resources: ['*'],\n      }));\n    handlerRole.addToPrincipalPolicy(new iam.PolicyStatement({\n      effect: iam.Effect.ALLOW,\n      actions: [\n        's3:GetObject',\n      ],\n      resources: ['*'],\n    }));\n\n    if (props.imageArch && props.imageArch.length !== 1) {\n      throw new Error(`imageArch must contain exactly 1 element, got ${JSON.stringify(props.imageArch)}`);\n    }\n    const imageArch = props.imageArch ? props.imageArch[0] : '';\n\n    new CustomResource(this, 'CustomResource', {\n      serviceToken: this.handler.functionArn,\n      // This has been copy/pasted and is a pure lie, but changing it is going to change people's infra!! X(\n      resourceType: 'Custom::CDKBucketDeployment',\n      properties: {\n        SrcImage: props.src.uri,\n        SrcCreds: props.src.creds,\n        DestImage: props.dest.uri,\n        DestCreds: props.dest.creds,\n        ...imageArch ? { ImageArch: imageArch } : {},\n      },\n    });\n  }\n\n  public addToPrincipalPolicy(statement: PolicyStatement): AddToPrincipalPolicyResult {\n    const handlerRole = this.handler.role;\n    if (!handlerRole) { throw new Error('lambda.SingletonFunction should have created a Role'); }\n\n    return handlerRole.addToPrincipalPolicy(statement);\n  }\n\n  private renderSingletonUuid(memoryLimit?: number) {\n    let uuid = 'bd07c930-edb9-4112-a20f-03f096f53666';\n\n    // if user specify a custom memory limit, define another singleton handler\n    // with this configuration. otherwise, it won't be possible to use multiple\n    // configurations since we have a singleton.\n    if (memoryLimit) {\n      if (Token.isUnresolved(memoryLimit)) {\n        throw new Error('Can\\'t use tokens when specifying \"memoryLimit\" since we use it to identify the singleton custom resource handler');\n      }\n\n      uuid += `-${memoryLimit.toString()}MiB`;\n    }\n\n    return uuid;\n  }\n}\n"]}
@@ -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, 16 Jan 2025 00:46:49 GMT
11
+ * Last updated: Tue, 28 Jan 2025 02:01:18 GMT
12
12
  * Dependencies: [undici-types](https://npmjs.com/package/undici-types)
13
13
 
14
14
  # Credits
@@ -45,6 +45,7 @@ declare module "dgram" {
45
45
  interface SocketOptions extends Abortable {
46
46
  type: SocketType;
47
47
  reuseAddr?: boolean | undefined;
48
+ reusePort?: boolean | undefined;
48
49
  /**
49
50
  * @default false
50
51
  */
@@ -352,22 +353,22 @@ declare module "dgram" {
352
353
  * @param callback Called when the message has been sent.
353
354
  */
354
355
  send(
355
- msg: string | Uint8Array | readonly any[],
356
+ msg: string | NodeJS.ArrayBufferView | readonly any[],
356
357
  port?: number,
357
358
  address?: string,
358
359
  callback?: (error: Error | null, bytes: number) => void,
359
360
  ): void;
360
361
  send(
361
- msg: string | Uint8Array | readonly any[],
362
+ msg: string | NodeJS.ArrayBufferView | readonly any[],
362
363
  port?: number,
363
364
  callback?: (error: Error | null, bytes: number) => void,
364
365
  ): void;
365
366
  send(
366
- msg: string | Uint8Array | readonly any[],
367
+ msg: string | NodeJS.ArrayBufferView | readonly any[],
367
368
  callback?: (error: Error | null, bytes: number) => void,
368
369
  ): void;
369
370
  send(
370
- msg: string | Uint8Array,
371
+ msg: string | NodeJS.ArrayBufferView,
371
372
  offset: number,
372
373
  length: number,
373
374
  port?: number,
@@ -375,14 +376,14 @@ declare module "dgram" {
375
376
  callback?: (error: Error | null, bytes: number) => void,
376
377
  ): void;
377
378
  send(
378
- msg: string | Uint8Array,
379
+ msg: string | NodeJS.ArrayBufferView,
379
380
  offset: number,
380
381
  length: number,
381
382
  port?: number,
382
383
  callback?: (error: Error | null, bytes: number) => void,
383
384
  ): void;
384
385
  send(
385
- msg: string | Uint8Array,
386
+ msg: string | NodeJS.ArrayBufferView,
386
387
  offset: number,
387
388
  length: number,
388
389
  callback?: (error: Error | null, bytes: number) => void,
@@ -438,57 +438,47 @@ declare module "fs" {
438
438
  * 2. close
439
439
  * 3. ready
440
440
  */
441
- addListener(event: "close", listener: () => void): this;
442
- addListener(event: "data", listener: (chunk: Buffer | string) => void): this;
443
- addListener(event: "end", listener: () => void): this;
444
- addListener(event: "error", listener: (err: Error) => void): this;
445
- addListener(event: "open", listener: (fd: number) => void): this;
446
- addListener(event: "pause", listener: () => void): this;
447
- addListener(event: "readable", listener: () => void): this;
448
- addListener(event: "ready", listener: () => void): this;
449
- addListener(event: "resume", listener: () => void): this;
450
- addListener(event: string | symbol, listener: (...args: any[]) => void): this;
451
- on(event: "close", listener: () => void): this;
452
- on(event: "data", listener: (chunk: Buffer | string) => void): this;
453
- on(event: "end", listener: () => void): this;
454
- on(event: "error", listener: (err: Error) => void): this;
455
- on(event: "open", listener: (fd: number) => void): this;
456
- on(event: "pause", listener: () => void): this;
457
- on(event: "readable", listener: () => void): this;
458
- on(event: "ready", listener: () => void): this;
459
- on(event: "resume", listener: () => void): this;
460
- on(event: string | symbol, listener: (...args: any[]) => void): this;
461
- once(event: "close", listener: () => void): this;
462
- once(event: "data", listener: (chunk: Buffer | string) => void): this;
463
- once(event: "end", listener: () => void): this;
464
- once(event: "error", listener: (err: Error) => void): this;
465
- once(event: "open", listener: (fd: number) => void): this;
466
- once(event: "pause", listener: () => void): this;
467
- once(event: "readable", listener: () => void): this;
468
- once(event: "ready", listener: () => void): this;
469
- once(event: "resume", listener: () => void): this;
470
- once(event: string | symbol, listener: (...args: any[]) => void): this;
471
- prependListener(event: "close", listener: () => void): this;
472
- prependListener(event: "data", listener: (chunk: Buffer | string) => void): this;
473
- prependListener(event: "end", listener: () => void): this;
474
- prependListener(event: "error", listener: (err: Error) => void): this;
475
- prependListener(event: "open", listener: (fd: number) => void): this;
476
- prependListener(event: "pause", listener: () => void): this;
477
- prependListener(event: "readable", listener: () => void): this;
478
- prependListener(event: "ready", listener: () => void): this;
479
- prependListener(event: "resume", listener: () => void): this;
480
- prependListener(event: string | symbol, listener: (...args: any[]) => void): this;
481
- prependOnceListener(event: "close", listener: () => void): this;
482
- prependOnceListener(event: "data", listener: (chunk: Buffer | string) => void): this;
483
- prependOnceListener(event: "end", listener: () => void): this;
484
- prependOnceListener(event: "error", listener: (err: Error) => void): this;
485
- prependOnceListener(event: "open", listener: (fd: number) => void): this;
486
- prependOnceListener(event: "pause", listener: () => void): this;
487
- prependOnceListener(event: "readable", listener: () => void): this;
488
- prependOnceListener(event: "ready", listener: () => void): this;
489
- prependOnceListener(event: "resume", listener: () => void): this;
490
- prependOnceListener(event: string | symbol, listener: (...args: any[]) => void): this;
441
+ addListener<K extends keyof ReadStreamEvents>(event: K, listener: ReadStreamEvents[K]): this;
442
+ on<K extends keyof ReadStreamEvents>(event: K, listener: ReadStreamEvents[K]): this;
443
+ once<K extends keyof ReadStreamEvents>(event: K, listener: ReadStreamEvents[K]): this;
444
+ prependListener<K extends keyof ReadStreamEvents>(event: K, listener: ReadStreamEvents[K]): this;
445
+ prependOnceListener<K extends keyof ReadStreamEvents>(event: K, listener: ReadStreamEvents[K]): this;
491
446
  }
447
+
448
+ /**
449
+ * The Keys are events of the ReadStream and the values are the functions that are called when the event is emitted.
450
+ */
451
+ type ReadStreamEvents = {
452
+ close: () => void;
453
+ data: (chunk: Buffer | string) => void;
454
+ end: () => void;
455
+ error: (err: Error) => void;
456
+ open: (fd: number) => void;
457
+ pause: () => void;
458
+ readable: () => void;
459
+ ready: () => void;
460
+ resume: () => void;
461
+ } & CustomEvents;
462
+
463
+ /**
464
+ * string & {} allows to allow any kind of strings for the event
465
+ * but still allows to have auto completion for the normal events.
466
+ */
467
+ type CustomEvents = { [Key in string & {} | symbol]: (...args: any[]) => void };
468
+
469
+ /**
470
+ * The Keys are events of the WriteStream and the values are the functions that are called when the event is emitted.
471
+ */
472
+ type WriteStreamEvents = {
473
+ close: () => void;
474
+ drain: () => void;
475
+ error: (err: Error) => void;
476
+ finish: () => void;
477
+ open: (fd: number) => void;
478
+ pipe: (src: stream.Readable) => void;
479
+ ready: () => void;
480
+ unpipe: (src: stream.Readable) => void;
481
+ } & CustomEvents;
492
482
  /**
493
483
  * * Extends `stream.Writable`
494
484
  *
@@ -527,51 +517,11 @@ declare module "fs" {
527
517
  * 2. close
528
518
  * 3. ready
529
519
  */
530
- addListener(event: "close", listener: () => void): this;
531
- addListener(event: "drain", listener: () => void): this;
532
- addListener(event: "error", listener: (err: Error) => void): this;
533
- addListener(event: "finish", listener: () => void): this;
534
- addListener(event: "open", listener: (fd: number) => void): this;
535
- addListener(event: "pipe", listener: (src: stream.Readable) => void): this;
536
- addListener(event: "ready", listener: () => void): this;
537
- addListener(event: "unpipe", listener: (src: stream.Readable) => void): this;
538
- addListener(event: string | symbol, listener: (...args: any[]) => void): this;
539
- on(event: "close", listener: () => void): this;
540
- on(event: "drain", listener: () => void): this;
541
- on(event: "error", listener: (err: Error) => void): this;
542
- on(event: "finish", listener: () => void): this;
543
- on(event: "open", listener: (fd: number) => void): this;
544
- on(event: "pipe", listener: (src: stream.Readable) => void): this;
545
- on(event: "ready", listener: () => void): this;
546
- on(event: "unpipe", listener: (src: stream.Readable) => void): this;
547
- on(event: string | symbol, listener: (...args: any[]) => void): this;
548
- once(event: "close", listener: () => void): this;
549
- once(event: "drain", listener: () => void): this;
550
- once(event: "error", listener: (err: Error) => void): this;
551
- once(event: "finish", listener: () => void): this;
552
- once(event: "open", listener: (fd: number) => void): this;
553
- once(event: "pipe", listener: (src: stream.Readable) => void): this;
554
- once(event: "ready", listener: () => void): this;
555
- once(event: "unpipe", listener: (src: stream.Readable) => void): this;
556
- once(event: string | symbol, listener: (...args: any[]) => void): this;
557
- prependListener(event: "close", listener: () => void): this;
558
- prependListener(event: "drain", listener: () => void): this;
559
- prependListener(event: "error", listener: (err: Error) => void): this;
560
- prependListener(event: "finish", listener: () => void): this;
561
- prependListener(event: "open", listener: (fd: number) => void): this;
562
- prependListener(event: "pipe", listener: (src: stream.Readable) => void): this;
563
- prependListener(event: "ready", listener: () => void): this;
564
- prependListener(event: "unpipe", listener: (src: stream.Readable) => void): this;
565
- prependListener(event: string | symbol, listener: (...args: any[]) => void): this;
566
- prependOnceListener(event: "close", listener: () => void): this;
567
- prependOnceListener(event: "drain", listener: () => void): this;
568
- prependOnceListener(event: "error", listener: (err: Error) => void): this;
569
- prependOnceListener(event: "finish", listener: () => void): this;
570
- prependOnceListener(event: "open", listener: (fd: number) => void): this;
571
- prependOnceListener(event: "pipe", listener: (src: stream.Readable) => void): this;
572
- prependOnceListener(event: "ready", listener: () => void): this;
573
- prependOnceListener(event: "unpipe", listener: (src: stream.Readable) => void): this;
574
- prependOnceListener(event: string | symbol, listener: (...args: any[]) => void): this;
520
+ addListener<K extends keyof WriteStreamEvents>(event: K, listener: WriteStreamEvents[K]): this;
521
+ on<K extends keyof WriteStreamEvents>(event: K, listener: WriteStreamEvents[K]): this;
522
+ once<K extends keyof WriteStreamEvents>(event: K, listener: WriteStreamEvents[K]): this;
523
+ prependListener<K extends keyof WriteStreamEvents>(event: K, listener: WriteStreamEvents[K]): this;
524
+ prependOnceListener<K extends keyof WriteStreamEvents>(event: K, listener: WriteStreamEvents[K]): this;
575
525
  }
576
526
  /**
577
527
  * Asynchronously rename file at `oldPath` to the pathname provided
@@ -3845,9 +3795,6 @@ declare module "fs" {
3845
3795
  flush?: boolean | undefined;
3846
3796
  }
3847
3797
  /**
3848
- * Unlike the 16 KiB default `highWaterMark` for a `stream.Readable`, the stream
3849
- * returned by this method has a default `highWaterMark` of 64 KiB.
3850
- *
3851
3798
  * `options` can include `start` and `end` values to read a range of bytes from
3852
3799
  * the file instead of the entire file. Both `start` and `end` are inclusive and
3853
3800
  * start counting at 0, allowed values are in the
@@ -151,25 +151,11 @@ declare global {
151
151
  * *
152
152
  ------------------------------------------------*/
153
153
 
154
- // For backwards compability
155
- interface NodeRequire extends NodeJS.Require {}
156
- interface RequireResolve extends NodeJS.RequireResolve {}
157
- interface NodeModule extends NodeJS.Module {}
158
-
159
154
  var global: typeof globalThis;
160
155
 
161
156
  var process: NodeJS.Process;
162
157
  var console: Console;
163
158
 
164
- var __filename: string;
165
- var __dirname: string;
166
-
167
- var require: NodeRequire;
168
- var module: NodeModule;
169
-
170
- // Same as module.exports
171
- var exports: any;
172
-
173
159
  interface GCFunction {
174
160
  (options: {
175
161
  execution?: "sync";
@@ -440,49 +426,6 @@ declare global {
440
426
  unref(): this;
441
427
  }
442
428
 
443
- interface Require {
444
- (id: string): any;
445
- resolve: RequireResolve;
446
- cache: Dict<NodeModule>;
447
- /**
448
- * @deprecated
449
- */
450
- extensions: RequireExtensions;
451
- main: Module | undefined;
452
- }
453
-
454
- interface RequireResolve {
455
- (id: string, options?: { paths?: string[] | undefined }): string;
456
- paths(request: string): string[] | null;
457
- }
458
-
459
- interface RequireExtensions extends Dict<(m: Module, filename: string) => any> {
460
- ".js": (m: Module, filename: string) => any;
461
- ".json": (m: Module, filename: string) => any;
462
- ".node": (m: Module, filename: string) => any;
463
- }
464
- interface Module {
465
- /**
466
- * `true` if the module is running during the Node.js preload
467
- */
468
- isPreloading: boolean;
469
- exports: any;
470
- require: Require;
471
- id: string;
472
- filename: string;
473
- loaded: boolean;
474
- /** @deprecated since v14.6.0 Please use `require.main` and `module.children` instead. */
475
- parent: Module | null | undefined;
476
- children: Module[];
477
- /**
478
- * @since v11.14.0
479
- *
480
- * The directory name of the module. This is usually the same as the path.dirname() of the module.id.
481
- */
482
- path: string;
483
- paths: string[];
484
- }
485
-
486
429
  interface Dict<T> {
487
430
  [key: string]: T | undefined;
488
431
  }