cdk-ecr-deployment
Advanced tools
Comparing version 3.0.132 to 3.0.133
@@ -41,3 +41,3 @@ "use strict"; | ||
_a = JSII_RTTI_SYMBOL_1; | ||
DockerImageName[_a] = { fqn: "cdk-ecr-deployment.DockerImageName", version: "3.0.132" }; | ||
DockerImageName[_a] = { fqn: "cdk-ecr-deployment.DockerImageName", version: "3.0.133" }; | ||
class S3ArchiveName { | ||
@@ -55,3 +55,3 @@ constructor(p, ref, creds) { | ||
_b = JSII_RTTI_SYMBOL_1; | ||
S3ArchiveName[_b] = { fqn: "cdk-ecr-deployment.S3ArchiveName", version: "3.0.132" }; | ||
S3ArchiveName[_b] = { fqn: "cdk-ecr-deployment.S3ArchiveName", version: "3.0.133" }; | ||
class ECRDeployment extends constructs_1.Construct { | ||
@@ -140,3 +140,3 @@ constructor(scope, id, props) { | ||
_c = JSII_RTTI_SYMBOL_1; | ||
ECRDeployment[_c] = { fqn: "cdk-ecr-deployment.ECRDeployment", version: "3.0.132" }; | ||
ECRDeployment[_c] = { fqn: "cdk-ecr-deployment.ECRDeployment", version: "3.0.133" }; | ||
//# 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 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    new CustomResource(this, 'CustomResource', {\n      serviceToken: this.handler.functionArn,\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      },\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"]} |
{ | ||
"name": "@types/node", | ||
"version": "22.8.6", | ||
"version": "22.8.7", | ||
"description": "TypeScript definitions for node", | ||
@@ -223,4 +223,4 @@ "homepage": "https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node", | ||
"peerDependencies": {}, | ||
"typesPublisherContentHash": "b5e95f7873a1811a61b3409c809ee30655d0268d76d767dbe9efc27cb421459f", | ||
"typesPublisherContentHash": "eb4a12d3db7d5c2f973b35f0ccc659d77637fdcdc340900124be3f5602cc29bc", | ||
"typeScriptVersion": "4.8" | ||
} |
@@ -317,25 +317,74 @@ /** | ||
export interface ReadLineOptions { | ||
/** | ||
* The [`Readable`](https://nodejs.org/docs/latest-v22.x/api/stream.html#readable-streams) stream to listen to | ||
*/ | ||
input: NodeJS.ReadableStream; | ||
/** | ||
* The [`Writable`](https://nodejs.org/docs/latest-v22.x/api/stream.html#writable-streams) stream to write readline data to. | ||
*/ | ||
output?: NodeJS.WritableStream | undefined; | ||
/** | ||
* An optional function used for Tab autocompletion. | ||
*/ | ||
completer?: Completer | AsyncCompleter | undefined; | ||
/** | ||
* `true` if the `input` and `output` streams should be treated like a TTY, | ||
* and have ANSI/VT100 escape codes written to it. | ||
* Default: checking `isTTY` on the `output` stream upon instantiation. | ||
*/ | ||
terminal?: boolean | undefined; | ||
/** | ||
* Initial list of history lines. This option makes sense | ||
* only if `terminal` is set to `true` by the user or by an internal `output` | ||
* check, otherwise the history caching mechanism is not initialized at all. | ||
* Initial list of history lines. | ||
* This option makes sense only if `terminal` is set to `true` by the user or by an internal `output` check, | ||
* otherwise the history caching mechanism is not initialized at all. | ||
* @default [] | ||
*/ | ||
history?: string[] | undefined; | ||
/** | ||
* Maximum number of history lines retained. | ||
* To disable the history set this value to `0`. | ||
* This option makes sense only if `terminal` is set to `true` by the user or by an internal `output` check, | ||
* otherwise the history caching mechanism is not initialized at all. | ||
* @default 30 | ||
*/ | ||
historySize?: number | undefined; | ||
/** | ||
* If `true`, when a new input line added to the history list duplicates an older one, | ||
* this removes the older line from the list. | ||
* @default false | ||
*/ | ||
removeHistoryDuplicates?: boolean | undefined; | ||
/** | ||
* The prompt string to use. | ||
* @default "> " | ||
*/ | ||
prompt?: string | undefined; | ||
/** | ||
* If the delay between `\r` and `\n` exceeds `crlfDelay` milliseconds, | ||
* both `\r` and `\n` will be treated as separate end-of-line input. | ||
* `crlfDelay` will be coerced to a number no less than `100`. | ||
* It can be set to `Infinity`, in which case | ||
* `\r` followed by `\n` will always be considered a single newline | ||
* (which may be reasonable for [reading files](https://nodejs.org/docs/latest-v22.x/api/readline.html#example-read-file-stream-line-by-line) with `\r\n` line delimiter). | ||
* @default 100 | ||
*/ | ||
crlfDelay?: number | undefined; | ||
/** | ||
* If `true`, when a new input line added | ||
* to the history list duplicates an older one, this removes the older line | ||
* from the list. | ||
* @default false | ||
* The duration `readline` will wait for a character | ||
* (when reading an ambiguous key sequence in milliseconds | ||
* one that can both form a complete key sequence using the input read so far | ||
* and can take additional input to complete a longer key sequence). | ||
* @default 500 | ||
*/ | ||
removeHistoryDuplicates?: boolean | undefined; | ||
escapeCodeTimeout?: number | undefined; | ||
/** | ||
* The number of spaces a tab is equal to (minimum 1). | ||
* @default 8 | ||
*/ | ||
tabSize?: number | undefined; | ||
/** | ||
* Allows closing the interface using an AbortSignal. | ||
* Aborting the signal will internally call `close` on the interface. | ||
*/ | ||
signal?: AbortSignal | undefined; | ||
} | ||
@@ -342,0 +391,0 @@ /** |
@@ -6,4 +6,9 @@ /** | ||
declare module "readline/promises" { | ||
import { AsyncCompleter, Completer, Direction, Interface as _Interface, ReadLineOptions } from "node:readline"; | ||
import { Abortable } from "node:events"; | ||
import { | ||
CompleterResult, | ||
Direction, | ||
Interface as _Interface, | ||
ReadLineOptions as _ReadLineOptions, | ||
} from "node:readline"; | ||
/** | ||
@@ -115,2 +120,9 @@ * Instances of the `readlinePromises.Interface` class are constructed using the `readlinePromises.createInterface()` method. Every instance is associated with a | ||
} | ||
type Completer = (line: string) => CompleterResult | Promise<CompleterResult>; | ||
interface ReadLineOptions extends Omit<_ReadLineOptions, "completer"> { | ||
/** | ||
* An optional function used for Tab autocompletion. | ||
*/ | ||
completer?: Completer | undefined; | ||
} | ||
/** | ||
@@ -145,3 +157,3 @@ * The `readlinePromises.createInterface()` method creates a new `readlinePromises.Interface` instance. | ||
output?: NodeJS.WritableStream, | ||
completer?: Completer | AsyncCompleter, | ||
completer?: Completer, | ||
terminal?: boolean, | ||
@@ -148,0 +160,0 @@ ): Interface; |
@@ -11,3 +11,3 @@ # Installation | ||
### Additional Details | ||
* Last updated: Thu, 31 Oct 2024 18:02:52 GMT | ||
* Last updated: Sun, 03 Nov 2024 04:02:17 GMT | ||
* Dependencies: [undici-types](https://npmjs.com/package/undici-types) | ||
@@ -14,0 +14,0 @@ |
{ | ||
"name": "@types/node", | ||
"version": "22.8.6", | ||
"version": "22.8.7", | ||
"description": "TypeScript definitions for node", | ||
@@ -223,4 +223,4 @@ "homepage": "https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node", | ||
"peerDependencies": {}, | ||
"typesPublisherContentHash": "b5e95f7873a1811a61b3409c809ee30655d0268d76d767dbe9efc27cb421459f", | ||
"typesPublisherContentHash": "eb4a12d3db7d5c2f973b35f0ccc659d77637fdcdc340900124be3f5602cc29bc", | ||
"typeScriptVersion": "4.8" | ||
} |
@@ -317,25 +317,74 @@ /** | ||
export interface ReadLineOptions { | ||
/** | ||
* The [`Readable`](https://nodejs.org/docs/latest-v22.x/api/stream.html#readable-streams) stream to listen to | ||
*/ | ||
input: NodeJS.ReadableStream; | ||
/** | ||
* The [`Writable`](https://nodejs.org/docs/latest-v22.x/api/stream.html#writable-streams) stream to write readline data to. | ||
*/ | ||
output?: NodeJS.WritableStream | undefined; | ||
/** | ||
* An optional function used for Tab autocompletion. | ||
*/ | ||
completer?: Completer | AsyncCompleter | undefined; | ||
/** | ||
* `true` if the `input` and `output` streams should be treated like a TTY, | ||
* and have ANSI/VT100 escape codes written to it. | ||
* Default: checking `isTTY` on the `output` stream upon instantiation. | ||
*/ | ||
terminal?: boolean | undefined; | ||
/** | ||
* Initial list of history lines. This option makes sense | ||
* only if `terminal` is set to `true` by the user or by an internal `output` | ||
* check, otherwise the history caching mechanism is not initialized at all. | ||
* Initial list of history lines. | ||
* This option makes sense only if `terminal` is set to `true` by the user or by an internal `output` check, | ||
* otherwise the history caching mechanism is not initialized at all. | ||
* @default [] | ||
*/ | ||
history?: string[] | undefined; | ||
/** | ||
* Maximum number of history lines retained. | ||
* To disable the history set this value to `0`. | ||
* This option makes sense only if `terminal` is set to `true` by the user or by an internal `output` check, | ||
* otherwise the history caching mechanism is not initialized at all. | ||
* @default 30 | ||
*/ | ||
historySize?: number | undefined; | ||
/** | ||
* If `true`, when a new input line added to the history list duplicates an older one, | ||
* this removes the older line from the list. | ||
* @default false | ||
*/ | ||
removeHistoryDuplicates?: boolean | undefined; | ||
/** | ||
* The prompt string to use. | ||
* @default "> " | ||
*/ | ||
prompt?: string | undefined; | ||
/** | ||
* If the delay between `\r` and `\n` exceeds `crlfDelay` milliseconds, | ||
* both `\r` and `\n` will be treated as separate end-of-line input. | ||
* `crlfDelay` will be coerced to a number no less than `100`. | ||
* It can be set to `Infinity`, in which case | ||
* `\r` followed by `\n` will always be considered a single newline | ||
* (which may be reasonable for [reading files](https://nodejs.org/docs/latest-v22.x/api/readline.html#example-read-file-stream-line-by-line) with `\r\n` line delimiter). | ||
* @default 100 | ||
*/ | ||
crlfDelay?: number | undefined; | ||
/** | ||
* If `true`, when a new input line added | ||
* to the history list duplicates an older one, this removes the older line | ||
* from the list. | ||
* @default false | ||
* The duration `readline` will wait for a character | ||
* (when reading an ambiguous key sequence in milliseconds | ||
* one that can both form a complete key sequence using the input read so far | ||
* and can take additional input to complete a longer key sequence). | ||
* @default 500 | ||
*/ | ||
removeHistoryDuplicates?: boolean | undefined; | ||
escapeCodeTimeout?: number | undefined; | ||
/** | ||
* The number of spaces a tab is equal to (minimum 1). | ||
* @default 8 | ||
*/ | ||
tabSize?: number | undefined; | ||
/** | ||
* Allows closing the interface using an AbortSignal. | ||
* Aborting the signal will internally call `close` on the interface. | ||
*/ | ||
signal?: AbortSignal | undefined; | ||
} | ||
@@ -342,0 +391,0 @@ /** |
@@ -6,4 +6,9 @@ /** | ||
declare module "readline/promises" { | ||
import { AsyncCompleter, Completer, Direction, Interface as _Interface, ReadLineOptions } from "node:readline"; | ||
import { Abortable } from "node:events"; | ||
import { | ||
CompleterResult, | ||
Direction, | ||
Interface as _Interface, | ||
ReadLineOptions as _ReadLineOptions, | ||
} from "node:readline"; | ||
/** | ||
@@ -115,2 +120,9 @@ * Instances of the `readlinePromises.Interface` class are constructed using the `readlinePromises.createInterface()` method. Every instance is associated with a | ||
} | ||
type Completer = (line: string) => CompleterResult | Promise<CompleterResult>; | ||
interface ReadLineOptions extends Omit<_ReadLineOptions, "completer"> { | ||
/** | ||
* An optional function used for Tab autocompletion. | ||
*/ | ||
completer?: Completer | undefined; | ||
} | ||
/** | ||
@@ -145,3 +157,3 @@ * The `readlinePromises.createInterface()` method creates a new `readlinePromises.Interface` instance. | ||
output?: NodeJS.WritableStream, | ||
completer?: Completer | AsyncCompleter, | ||
completer?: Completer, | ||
terminal?: boolean, | ||
@@ -148,0 +160,0 @@ ): Interface; |
@@ -11,3 +11,3 @@ # Installation | ||
### Additional Details | ||
* Last updated: Thu, 31 Oct 2024 18:02:52 GMT | ||
* Last updated: Sun, 03 Nov 2024 04:02:17 GMT | ||
* Dependencies: [undici-types](https://npmjs.com/package/undici-types) | ||
@@ -14,0 +14,0 @@ |
{ | ||
"name": "@types/node", | ||
"version": "22.8.6", | ||
"version": "22.8.7", | ||
"description": "TypeScript definitions for node", | ||
@@ -223,4 +223,4 @@ "homepage": "https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node", | ||
"peerDependencies": {}, | ||
"typesPublisherContentHash": "b5e95f7873a1811a61b3409c809ee30655d0268d76d767dbe9efc27cb421459f", | ||
"typesPublisherContentHash": "eb4a12d3db7d5c2f973b35f0ccc659d77637fdcdc340900124be3f5602cc29bc", | ||
"typeScriptVersion": "4.8" | ||
} |
@@ -317,25 +317,74 @@ /** | ||
export interface ReadLineOptions { | ||
/** | ||
* The [`Readable`](https://nodejs.org/docs/latest-v22.x/api/stream.html#readable-streams) stream to listen to | ||
*/ | ||
input: NodeJS.ReadableStream; | ||
/** | ||
* The [`Writable`](https://nodejs.org/docs/latest-v22.x/api/stream.html#writable-streams) stream to write readline data to. | ||
*/ | ||
output?: NodeJS.WritableStream | undefined; | ||
/** | ||
* An optional function used for Tab autocompletion. | ||
*/ | ||
completer?: Completer | AsyncCompleter | undefined; | ||
/** | ||
* `true` if the `input` and `output` streams should be treated like a TTY, | ||
* and have ANSI/VT100 escape codes written to it. | ||
* Default: checking `isTTY` on the `output` stream upon instantiation. | ||
*/ | ||
terminal?: boolean | undefined; | ||
/** | ||
* Initial list of history lines. This option makes sense | ||
* only if `terminal` is set to `true` by the user or by an internal `output` | ||
* check, otherwise the history caching mechanism is not initialized at all. | ||
* Initial list of history lines. | ||
* This option makes sense only if `terminal` is set to `true` by the user or by an internal `output` check, | ||
* otherwise the history caching mechanism is not initialized at all. | ||
* @default [] | ||
*/ | ||
history?: string[] | undefined; | ||
/** | ||
* Maximum number of history lines retained. | ||
* To disable the history set this value to `0`. | ||
* This option makes sense only if `terminal` is set to `true` by the user or by an internal `output` check, | ||
* otherwise the history caching mechanism is not initialized at all. | ||
* @default 30 | ||
*/ | ||
historySize?: number | undefined; | ||
/** | ||
* If `true`, when a new input line added to the history list duplicates an older one, | ||
* this removes the older line from the list. | ||
* @default false | ||
*/ | ||
removeHistoryDuplicates?: boolean | undefined; | ||
/** | ||
* The prompt string to use. | ||
* @default "> " | ||
*/ | ||
prompt?: string | undefined; | ||
/** | ||
* If the delay between `\r` and `\n` exceeds `crlfDelay` milliseconds, | ||
* both `\r` and `\n` will be treated as separate end-of-line input. | ||
* `crlfDelay` will be coerced to a number no less than `100`. | ||
* It can be set to `Infinity`, in which case | ||
* `\r` followed by `\n` will always be considered a single newline | ||
* (which may be reasonable for [reading files](https://nodejs.org/docs/latest-v22.x/api/readline.html#example-read-file-stream-line-by-line) with `\r\n` line delimiter). | ||
* @default 100 | ||
*/ | ||
crlfDelay?: number | undefined; | ||
/** | ||
* If `true`, when a new input line added | ||
* to the history list duplicates an older one, this removes the older line | ||
* from the list. | ||
* @default false | ||
* The duration `readline` will wait for a character | ||
* (when reading an ambiguous key sequence in milliseconds | ||
* one that can both form a complete key sequence using the input read so far | ||
* and can take additional input to complete a longer key sequence). | ||
* @default 500 | ||
*/ | ||
removeHistoryDuplicates?: boolean | undefined; | ||
escapeCodeTimeout?: number | undefined; | ||
/** | ||
* The number of spaces a tab is equal to (minimum 1). | ||
* @default 8 | ||
*/ | ||
tabSize?: number | undefined; | ||
/** | ||
* Allows closing the interface using an AbortSignal. | ||
* Aborting the signal will internally call `close` on the interface. | ||
*/ | ||
signal?: AbortSignal | undefined; | ||
} | ||
@@ -342,0 +391,0 @@ /** |
@@ -6,4 +6,9 @@ /** | ||
declare module "readline/promises" { | ||
import { AsyncCompleter, Completer, Direction, Interface as _Interface, ReadLineOptions } from "node:readline"; | ||
import { Abortable } from "node:events"; | ||
import { | ||
CompleterResult, | ||
Direction, | ||
Interface as _Interface, | ||
ReadLineOptions as _ReadLineOptions, | ||
} from "node:readline"; | ||
/** | ||
@@ -115,2 +120,9 @@ * Instances of the `readlinePromises.Interface` class are constructed using the `readlinePromises.createInterface()` method. Every instance is associated with a | ||
} | ||
type Completer = (line: string) => CompleterResult | Promise<CompleterResult>; | ||
interface ReadLineOptions extends Omit<_ReadLineOptions, "completer"> { | ||
/** | ||
* An optional function used for Tab autocompletion. | ||
*/ | ||
completer?: Completer | undefined; | ||
} | ||
/** | ||
@@ -145,3 +157,3 @@ * The `readlinePromises.createInterface()` method creates a new `readlinePromises.Interface` instance. | ||
output?: NodeJS.WritableStream, | ||
completer?: Completer | AsyncCompleter, | ||
completer?: Completer, | ||
terminal?: boolean, | ||
@@ -148,0 +160,0 @@ ): Interface; |
@@ -11,3 +11,3 @@ # Installation | ||
### Additional Details | ||
* Last updated: Thu, 31 Oct 2024 18:02:52 GMT | ||
* Last updated: Sun, 03 Nov 2024 04:02:17 GMT | ||
* Dependencies: [undici-types](https://npmjs.com/package/undici-types) | ||
@@ -14,0 +14,0 @@ |
@@ -96,3 +96,3 @@ { | ||
}, | ||
"version": "3.0.132", | ||
"version": "3.0.133", | ||
"jest": { | ||
@@ -99,0 +99,0 @@ "coverageProvider": "v8", |
Sorry, the diff of this file is not supported yet
8545538
170603