cdk-assets 3.3.0 → 4.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 (48) hide show
  1. package/README.md +4 -4
  2. package/THIRD_PARTY_LICENSES +18764 -0
  3. package/bin/cdk-assets.js +109830 -62
  4. package/bin/docker-credential-cdk-assets.js +4 -4
  5. package/bin/list.js +3 -3
  6. package/bin/logging.js +3 -1
  7. package/bin/publish.js +6 -6
  8. package/package.json +11 -30
  9. package/lib/asset-manifest.d.ts +0 -186
  10. package/lib/asset-manifest.js +0 -270
  11. package/lib/aws-types.d.ts +0 -1666
  12. package/lib/aws-types.js +0 -144
  13. package/lib/aws.d.ts +0 -71
  14. package/lib/aws.js +0 -131
  15. package/lib/index.d.ts +0 -4
  16. package/lib/index.js +0 -21
  17. package/lib/private/archive.d.ts +0 -3
  18. package/lib/private/archive.js +0 -87
  19. package/lib/private/asset-handler.d.ts +0 -60
  20. package/lib/private/asset-handler.js +0 -3
  21. package/lib/private/docker-credentials.d.ts +0 -35
  22. package/lib/private/docker-credentials.js +0 -90
  23. package/lib/private/docker.d.ts +0 -98
  24. package/lib/private/docker.js +0 -235
  25. package/lib/private/fs-extra.d.ts +0 -3
  26. package/lib/private/fs-extra.js +0 -37
  27. package/lib/private/handlers/client-options.d.ts +0 -3
  28. package/lib/private/handlers/client-options.js +0 -12
  29. package/lib/private/handlers/container-images.d.ts +0 -22
  30. package/lib/private/handlers/container-images.js +0 -224
  31. package/lib/private/handlers/files.d.ts +0 -14
  32. package/lib/private/handlers/files.js +0 -289
  33. package/lib/private/handlers/index.d.ts +0 -3
  34. package/lib/private/handlers/index.js +0 -16
  35. package/lib/private/p-limit.d.ts +0 -10
  36. package/lib/private/p-limit.js +0 -51
  37. package/lib/private/placeholders.d.ts +0 -10
  38. package/lib/private/placeholders.js +0 -34
  39. package/lib/private/shell.d.ts +0 -24
  40. package/lib/private/shell.js +0 -131
  41. package/lib/private/util.d.ts +0 -5
  42. package/lib/private/util.js +0 -16
  43. package/lib/progress.d.ts +0 -114
  44. package/lib/progress.js +0 -104
  45. package/lib/publishing.d.ts +0 -118
  46. package/lib/publishing.js +0 -193
  47. package/scripts/manual-test-manifest.json +0 -12
  48. package/scripts/manual-test.sh +0 -22
package/lib/aws.js DELETED
@@ -1,131 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DefaultAwsClient = void 0;
4
- const os = require("os");
5
- const client_ecr_1 = require("@aws-sdk/client-ecr");
6
- const client_s3_1 = require("@aws-sdk/client-s3");
7
- const client_secrets_manager_1 = require("@aws-sdk/client-secrets-manager");
8
- const client_sts_1 = require("@aws-sdk/client-sts");
9
- const credential_providers_1 = require("@aws-sdk/credential-providers");
10
- const lib_storage_1 = require("@aws-sdk/lib-storage");
11
- const config_resolver_1 = require("@smithy/config-resolver");
12
- const node_config_provider_1 = require("@smithy/node-config-provider");
13
- const USER_AGENT = 'cdk-assets';
14
- /**
15
- * AWS client using the AWS SDK for JS with no special configuration
16
- */
17
- class DefaultAwsClient {
18
- constructor(profile) {
19
- this.profile = profile;
20
- const clientConfig = {
21
- customUserAgent: USER_AGENT,
22
- };
23
- // storing the main credentials separately because
24
- // the `config` object changes every time we assume the file publishing role.
25
- // TODO refactor to make `config` a readonly property and avoid state mutations.
26
- this.mainCredentials = (0, credential_providers_1.fromNodeProviderChain)({
27
- profile: this.profile,
28
- clientConfig,
29
- });
30
- this.config = {
31
- clientConfig,
32
- credentials: this.mainCredentials,
33
- };
34
- }
35
- async s3Client(options) {
36
- const client = new client_s3_1.S3Client(await this.awsOptions(options));
37
- return {
38
- getBucketEncryption: (input) => client.send(new client_s3_1.GetBucketEncryptionCommand(input)),
39
- getBucketLocation: (input) => client.send(new client_s3_1.GetBucketLocationCommand(input)),
40
- listObjectsV2: (input) => client.send(new client_s3_1.ListObjectsV2Command(input)),
41
- upload: (input) => {
42
- const upload = new lib_storage_1.Upload({
43
- client,
44
- params: input,
45
- });
46
- return upload.done();
47
- },
48
- };
49
- }
50
- async ecrClient(options) {
51
- const client = new client_ecr_1.ECRClient(await this.awsOptions(options));
52
- return {
53
- describeImages: (input) => client.send(new client_ecr_1.DescribeImagesCommand(input)),
54
- describeRepositories: (input) => client.send(new client_ecr_1.DescribeRepositoriesCommand(input)),
55
- getAuthorizationToken: (input) => client.send(new client_ecr_1.GetAuthorizationTokenCommand(input ?? {})),
56
- };
57
- }
58
- async secretsManagerClient(options) {
59
- const client = new client_secrets_manager_1.SecretsManagerClient(await this.awsOptions(options));
60
- return {
61
- getSecretValue: (input) => client.send(new client_secrets_manager_1.GetSecretValueCommand(input)),
62
- };
63
- }
64
- async discoverPartition() {
65
- return (await this.discoverCurrentAccount()).partition;
66
- }
67
- async discoverDefaultRegion() {
68
- return (0, node_config_provider_1.loadConfig)(config_resolver_1.NODE_REGION_CONFIG_OPTIONS, config_resolver_1.NODE_REGION_CONFIG_FILE_OPTIONS)() || 'us-east-1';
69
- }
70
- async discoverCurrentAccount() {
71
- if (this.account === undefined) {
72
- this.account = await this.getAccount();
73
- }
74
- return this.account;
75
- }
76
- async discoverTargetAccount(options) {
77
- return this.getAccount(await this.awsOptions(options));
78
- }
79
- async getAccount(options) {
80
- this.config.clientConfig = options ?? this.config.clientConfig;
81
- const stsClient = new client_sts_1.STSClient(await this.awsOptions(options));
82
- const command = new client_sts_1.GetCallerIdentityCommand();
83
- const response = await stsClient.send(command);
84
- if (!response.Account || !response.Arn) {
85
- throw new Error(`Unrecognized response from STS: '${JSON.stringify(response)}'`);
86
- }
87
- return {
88
- accountId: response.Account,
89
- partition: response.Arn.split(':')[1],
90
- };
91
- }
92
- async awsOptions(options) {
93
- const config = this.config;
94
- config.region = options?.region;
95
- if (options) {
96
- config.region = options.region;
97
- if (options.assumeRoleArn) {
98
- config.credentials = (0, credential_providers_1.fromTemporaryCredentials)({
99
- // dont forget the credentials chain.
100
- masterCredentials: this.mainCredentials,
101
- params: {
102
- RoleArn: options.assumeRoleArn,
103
- ExternalId: options.assumeRoleExternalId,
104
- RoleSessionName: `${USER_AGENT}-${safeUsername()}`,
105
- TransitiveTagKeys: options.assumeRoleAdditionalOptions?.Tags
106
- ? options.assumeRoleAdditionalOptions.Tags.map((t) => t.Key)
107
- : undefined,
108
- ...options.assumeRoleAdditionalOptions,
109
- },
110
- clientConfig: this.config.clientConfig,
111
- });
112
- }
113
- }
114
- return config;
115
- }
116
- }
117
- exports.DefaultAwsClient = DefaultAwsClient;
118
- /**
119
- * Return the username with characters invalid for a RoleSessionName removed
120
- *
121
- * @see https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html#API_AssumeRole_RequestParameters
122
- */
123
- function safeUsername() {
124
- try {
125
- return os.userInfo().username.replace(/[^\w+=,.@-]/g, '@');
126
- }
127
- catch {
128
- return 'noname';
129
- }
130
- }
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws.js","sourceRoot":"","sources":["aws.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'os';\nimport {\n  DescribeImagesCommand,\n  DescribeRepositoriesCommand,\n  ECRClient,\n  GetAuthorizationTokenCommand,\n} from '@aws-sdk/client-ecr';\nimport {\n  GetBucketEncryptionCommand,\n  GetBucketLocationCommand,\n  ListObjectsV2Command,\n  S3Client,\n} from '@aws-sdk/client-s3';\nimport { GetSecretValueCommand, SecretsManagerClient } from '@aws-sdk/client-secrets-manager';\nimport type {\n  AssumeRoleCommandInput,\n  STSClientConfig,\n} from '@aws-sdk/client-sts';\nimport {\n  GetCallerIdentityCommand,\n  STSClient,\n} from '@aws-sdk/client-sts';\nimport { fromNodeProviderChain, fromTemporaryCredentials } from '@aws-sdk/credential-providers';\nimport { Upload } from '@aws-sdk/lib-storage';\nimport {\n  NODE_REGION_CONFIG_FILE_OPTIONS,\n  NODE_REGION_CONFIG_OPTIONS,\n} from '@smithy/config-resolver';\nimport { loadConfig } from '@smithy/node-config-provider';\nimport type {\n  AwsCredentialIdentityProvider,\n  CompleteMultipartUploadCommandOutput,\n  DescribeImagesCommandInput,\n  DescribeImagesCommandOutput,\n  DescribeRepositoriesCommandInput,\n  DescribeRepositoriesCommandOutput,\n  GetAuthorizationTokenCommandInput,\n  GetAuthorizationTokenCommandOutput,\n  GetBucketEncryptionCommandInput,\n  GetBucketEncryptionCommandOutput,\n  GetBucketLocationCommandInput,\n  GetBucketLocationCommandOutput,\n  GetSecretValueCommandInput,\n  GetSecretValueCommandOutput,\n  ListObjectsV2CommandInput,\n  ListObjectsV2CommandOutput,\n  PutObjectCommandInput,\n} from './aws-types';\n\nexport type AssumeRoleAdditionalOptions = Partial<\n  Omit<AssumeRoleCommandInput, 'ExternalId' | 'RoleArn'>\n>;\n\nexport interface IS3Client {\n  getBucketEncryption(\n    input: GetBucketEncryptionCommandInput\n  ): Promise<GetBucketEncryptionCommandOutput>;\n  getBucketLocation(input: GetBucketLocationCommandInput): Promise<GetBucketLocationCommandOutput>;\n  listObjectsV2(input: ListObjectsV2CommandInput): Promise<ListObjectsV2CommandOutput>;\n  upload(input: PutObjectCommandInput): Promise<CompleteMultipartUploadCommandOutput>;\n}\n\nexport interface IECRClient {\n  describeImages(input: DescribeImagesCommandInput): Promise<DescribeImagesCommandOutput>;\n  describeRepositories(\n    input: DescribeRepositoriesCommandInput\n  ): Promise<DescribeRepositoriesCommandOutput>;\n  getAuthorizationToken(\n    input?: GetAuthorizationTokenCommandInput\n  ): Promise<GetAuthorizationTokenCommandOutput>;\n}\n\nexport interface ISecretsManagerClient {\n  getSecretValue(input: GetSecretValueCommandInput): Promise<GetSecretValueCommandOutput>;\n}\n\n/**\n * AWS SDK operations required by Asset Publishing\n */\nexport interface IAws {\n  discoverPartition(): Promise<string>;\n  discoverDefaultRegion(): Promise<string>;\n  discoverCurrentAccount(): Promise<Account>;\n\n  discoverTargetAccount(options: ClientOptions): Promise<Account>;\n  s3Client(options: ClientOptions): Promise<IS3Client>;\n  ecrClient(options: ClientOptions): Promise<IECRClient>;\n  secretsManagerClient(options: ClientOptions): Promise<ISecretsManagerClient>;\n}\n\nexport interface ClientOptions {\n  region?: string;\n  assumeRoleArn?: string;\n  assumeRoleExternalId?: string;\n  assumeRoleAdditionalOptions?: AssumeRoleAdditionalOptions;\n  quiet?: boolean;\n}\n\nconst USER_AGENT = 'cdk-assets';\n\ninterface Configuration {\n  clientConfig: STSClientConfig;\n  region?: string;\n  credentials: AwsCredentialIdentityProvider;\n}\n\n/**\n * An AWS account\n *\n * An AWS account always exists in only one partition. Usually we don't care about\n * the partition, but when we need to form ARNs we do.\n */\nexport interface Account {\n  /**\n   * The account number\n   */\n  readonly accountId: string;\n\n  /**\n   * The partition ('aws' or 'aws-cn' or otherwise)\n   */\n  readonly partition: string;\n}\n\n/**\n * AWS client using the AWS SDK for JS with no special configuration\n */\nexport class DefaultAwsClient implements IAws {\n  private account?: Account;\n  private config: Configuration;\n  private readonly mainCredentials: AwsCredentialIdentityProvider;\n\n  constructor(private readonly profile?: string) {\n    const clientConfig: STSClientConfig = {\n      customUserAgent: USER_AGENT,\n    };\n\n    // storing the main credentials separately because\n    // the `config` object changes every time we assume the file publishing role.\n    // TODO refactor to make `config` a readonly property and avoid state mutations.\n    this.mainCredentials = fromNodeProviderChain({\n      profile: this.profile,\n      clientConfig,\n    });\n\n    this.config = {\n      clientConfig,\n      credentials: this.mainCredentials,\n    };\n  }\n\n  public async s3Client(options: ClientOptions): Promise<IS3Client> {\n    const client = new S3Client(await this.awsOptions(options));\n    return {\n      getBucketEncryption: (\n        input: GetBucketEncryptionCommandInput,\n      ): Promise<GetBucketEncryptionCommandOutput> =>\n        client.send(new GetBucketEncryptionCommand(input)),\n      getBucketLocation: (\n        input: GetBucketLocationCommandInput,\n      ): Promise<GetBucketLocationCommandOutput> =>\n        client.send(new GetBucketLocationCommand(input)),\n      listObjectsV2: (input: ListObjectsV2CommandInput): Promise<ListObjectsV2CommandOutput> =>\n        client.send(new ListObjectsV2Command(input)),\n      upload: (input: PutObjectCommandInput): Promise<CompleteMultipartUploadCommandOutput> => {\n        const upload = new Upload({\n          client,\n          params: input,\n        });\n        return upload.done();\n      },\n    };\n  }\n\n  public async ecrClient(options: ClientOptions): Promise<IECRClient> {\n    const client = new ECRClient(await this.awsOptions(options));\n    return {\n      describeImages: (input: DescribeImagesCommandInput): Promise<DescribeImagesCommandOutput> =>\n        client.send(new DescribeImagesCommand(input)),\n      describeRepositories: (\n        input: DescribeRepositoriesCommandInput,\n      ): Promise<DescribeRepositoriesCommandOutput> =>\n        client.send(new DescribeRepositoriesCommand(input)),\n      getAuthorizationToken: (\n        input: GetAuthorizationTokenCommandInput,\n      ): Promise<GetAuthorizationTokenCommandOutput> =>\n        client.send(new GetAuthorizationTokenCommand(input ?? {})),\n    };\n  }\n\n  public async secretsManagerClient(options: ClientOptions): Promise<ISecretsManagerClient> {\n    const client = new SecretsManagerClient(await this.awsOptions(options));\n    return {\n      getSecretValue: (input: GetSecretValueCommandInput): Promise<GetSecretValueCommandOutput> =>\n        client.send(new GetSecretValueCommand(input)),\n    };\n  }\n\n  public async discoverPartition(): Promise<string> {\n    return (await this.discoverCurrentAccount()).partition;\n  }\n\n  public async discoverDefaultRegion(): Promise<string> {\n    return loadConfig(NODE_REGION_CONFIG_OPTIONS, NODE_REGION_CONFIG_FILE_OPTIONS)() || 'us-east-1';\n  }\n\n  public async discoverCurrentAccount(): Promise<Account> {\n    if (this.account === undefined) {\n      this.account = await this.getAccount();\n    }\n    return this.account;\n  }\n\n  public async discoverTargetAccount(options: ClientOptions): Promise<Account> {\n    return this.getAccount(await this.awsOptions(options));\n  }\n\n  private async getAccount(options?: ClientOptions): Promise<Account> {\n    this.config.clientConfig = options ?? this.config.clientConfig;\n    const stsClient = new STSClient(await this.awsOptions(options));\n\n    const command = new GetCallerIdentityCommand();\n    const response = await stsClient.send(command);\n    if (!response.Account || !response.Arn) {\n      throw new Error(`Unrecognized response from STS: '${JSON.stringify(response)}'`);\n    }\n    return {\n      accountId: response.Account!,\n      partition: response.Arn!.split(':')[1],\n    };\n  }\n\n  private async awsOptions(options?: ClientOptions) {\n    const config = this.config;\n    config.region = options?.region;\n    if (options) {\n      config.region = options.region;\n      if (options.assumeRoleArn) {\n        config.credentials = fromTemporaryCredentials({\n          // dont forget the credentials chain.\n          masterCredentials: this.mainCredentials,\n          params: {\n            RoleArn: options.assumeRoleArn,\n            ExternalId: options.assumeRoleExternalId,\n            RoleSessionName: `${USER_AGENT}-${safeUsername()}`,\n            TransitiveTagKeys: options.assumeRoleAdditionalOptions?.Tags\n              ? options.assumeRoleAdditionalOptions.Tags.map((t) => t.Key!)\n              : undefined,\n            ...options.assumeRoleAdditionalOptions,\n          },\n          clientConfig: this.config.clientConfig,\n        });\n      }\n    }\n    return config;\n  }\n}\n\n/**\n * Return the username with characters invalid for a RoleSessionName removed\n *\n * @see https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html#API_AssumeRole_RequestParameters\n */\nfunction safeUsername() {\n  try {\n    return os.userInfo().username.replace(/[^\\w+=,.@-]/g, '@');\n  } catch {\n    return 'noname';\n  }\n}\n"]}
package/lib/index.d.ts DELETED
@@ -1,4 +0,0 @@
1
- export * from './publishing';
2
- export * from './asset-manifest';
3
- export * from './aws';
4
- export * from './progress';
package/lib/index.js DELETED
@@ -1,21 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./publishing"), exports);
18
- __exportStar(require("./asset-manifest"), exports);
19
- __exportStar(require("./aws"), exports);
20
- __exportStar(require("./progress"), exports);
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsK0NBQTZCO0FBQzdCLG1EQUFpQztBQUNqQyx3Q0FBc0I7QUFDdEIsNkNBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wdWJsaXNoaW5nJztcbmV4cG9ydCAqIGZyb20gJy4vYXNzZXQtbWFuaWZlc3QnO1xuZXhwb3J0ICogZnJvbSAnLi9hd3MnO1xuZXhwb3J0ICogZnJvbSAnLi9wcm9ncmVzcyc7XG4iXX0=
@@ -1,3 +0,0 @@
1
- type EventEmitter = (x: string) => void;
2
- export declare function zipDirectory(directory: string, outputFile: string, eventEmitter: EventEmitter): Promise<void>;
3
- export {};
@@ -1,87 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.zipDirectory = zipDirectory;
4
- const fs_1 = require("fs");
5
- const path = require("path");
6
- const glob = require("glob");
7
- // namespace object imports won't work in the bundle for function exports
8
- // eslint-disable-next-line @typescript-eslint/no-require-imports
9
- const archiver = require('archiver');
10
- async function zipDirectory(directory, outputFile, eventEmitter) {
11
- // We write to a temporary file and rename at the last moment. This is so that if we are
12
- // interrupted during this process, we don't leave a half-finished file in the target location.
13
- const temporaryOutputFile = `${outputFile}.${randomString()}._tmp`;
14
- await writeZipFile(directory, temporaryOutputFile);
15
- await moveIntoPlace(temporaryOutputFile, outputFile, eventEmitter);
16
- }
17
- function writeZipFile(directory, outputFile) {
18
- return new Promise(async (ok, fail) => {
19
- // The below options are needed to support following symlinks when building zip files:
20
- // - nodir: This will prevent symlinks themselves from being copied into the zip.
21
- // - follow: This will follow symlinks and copy the files within.
22
- const globOptions = {
23
- dot: true,
24
- nodir: true,
25
- follow: true,
26
- cwd: directory,
27
- };
28
- const files = glob.sync('**', globOptions); // The output here is already sorted
29
- const output = (0, fs_1.createWriteStream)(outputFile);
30
- const archive = archiver('zip');
31
- archive.on('warning', fail);
32
- archive.on('error', fail);
33
- // archive has been finalized and the output file descriptor has closed, resolve promise
34
- // this has to be done before calling `finalize` since the events may fire immediately after.
35
- // see https://www.npmjs.com/package/archiver
36
- output.once('close', ok);
37
- archive.pipe(output);
38
- // Append files serially to ensure file order
39
- for (const file of files) {
40
- const fullPath = path.resolve(directory, file);
41
- // There are exactly 2 promises
42
- // eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism
43
- const [data, stat] = await Promise.all([fs_1.promises.readFile(fullPath), fs_1.promises.stat(fullPath)]);
44
- archive.append(data, {
45
- name: file,
46
- date: new Date('1980-01-01T00:00:00.000Z'), // reset dates to get the same hash for the same content
47
- mode: stat.mode,
48
- });
49
- }
50
- await archive.finalize();
51
- });
52
- }
53
- /**
54
- * Rename the file to the target location, taking into account:
55
- *
56
- * - That we may see EPERM on Windows while an Antivirus scanner still has the
57
- * file open, so retry a couple of times.
58
- * - This same function may be called in parallel and be interrupted at any point.
59
- */
60
- async function moveIntoPlace(source, target, eventEmitter) {
61
- let delay = 100;
62
- let attempts = 5;
63
- while (true) {
64
- try {
65
- // 'rename' is guaranteed to overwrite an existing target, as long as it is a file (not a directory)
66
- await fs_1.promises.rename(source, target);
67
- return;
68
- }
69
- catch (e) {
70
- if (e.code !== 'EPERM' || attempts-- <= 0) {
71
- throw e;
72
- }
73
- eventEmitter(e.message);
74
- await sleep(Math.floor(Math.random() * delay));
75
- delay *= 2;
76
- }
77
- }
78
- }
79
- function sleep(ms) {
80
- return new Promise((ok) => setTimeout(ok, ms));
81
- }
82
- function randomString() {
83
- return Math.random()
84
- .toString(36)
85
- .replace(/[^a-z0-9]+/g, '');
86
- }
87
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"archive.js","sourceRoot":"","sources":["archive.ts"],"names":[],"mappings":"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","sourcesContent":["import { createWriteStream, promises as fs } from 'fs';\nimport * as path from 'path';\nimport * as glob from 'glob';\n\n// namespace object imports won't work in the bundle for function exports\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst archiver = require('archiver');\n\ntype EventEmitter = (x: string) => void;\n\nexport async function zipDirectory(\n  directory: string,\n  outputFile: string,\n  eventEmitter: EventEmitter,\n): Promise<void> {\n  // We write to a temporary file and rename at the last moment. This is so that if we are\n  // interrupted during this process, we don't leave a half-finished file in the target location.\n  const temporaryOutputFile = `${outputFile}.${randomString()}._tmp`;\n  await writeZipFile(directory, temporaryOutputFile);\n  await moveIntoPlace(temporaryOutputFile, outputFile, eventEmitter);\n}\n\nfunction writeZipFile(directory: string, outputFile: string): Promise<void> {\n  return new Promise(async (ok, fail) => {\n    // The below options are needed to support following symlinks when building zip files:\n    // - nodir: This will prevent symlinks themselves from being copied into the zip.\n    // - follow: This will follow symlinks and copy the files within.\n    const globOptions = {\n      dot: true,\n      nodir: true,\n      follow: true,\n      cwd: directory,\n    };\n    const files = glob.sync('**', globOptions); // The output here is already sorted\n\n    const output = createWriteStream(outputFile);\n\n    const archive = archiver('zip');\n    archive.on('warning', fail);\n    archive.on('error', fail);\n\n    // archive has been finalized and the output file descriptor has closed, resolve promise\n    // this has to be done before calling `finalize` since the events may fire immediately after.\n    // see https://www.npmjs.com/package/archiver\n    output.once('close', ok);\n\n    archive.pipe(output);\n\n    // Append files serially to ensure file order\n    for (const file of files) {\n      const fullPath = path.resolve(directory, file);\n      // There are exactly 2 promises\n      // eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism\n      const [data, stat] = await Promise.all([fs.readFile(fullPath), fs.stat(fullPath)]);\n      archive.append(data, {\n        name: file,\n        date: new Date('1980-01-01T00:00:00.000Z'), // reset dates to get the same hash for the same content\n        mode: stat.mode,\n      });\n    }\n\n    await archive.finalize();\n  });\n}\n\n/**\n * Rename the file to the target location, taking into account:\n *\n * - That we may see EPERM on Windows while an Antivirus scanner still has the\n *   file open, so retry a couple of times.\n * - This same function may be called in parallel and be interrupted at any point.\n */\nasync function moveIntoPlace(source: string, target: string, eventEmitter: EventEmitter) {\n  let delay = 100;\n  let attempts = 5;\n  while (true) {\n    try {\n      // 'rename' is guaranteed to overwrite an existing target, as long as it is a file (not a directory)\n      await fs.rename(source, target);\n      return;\n    } catch (e: any) {\n      if (e.code !== 'EPERM' || attempts-- <= 0) {\n        throw e;\n      }\n      eventEmitter(e.message);\n      await sleep(Math.floor(Math.random() * delay));\n      delay *= 2;\n    }\n  }\n}\n\nfunction sleep(ms: number) {\n  return new Promise((ok) => setTimeout(ok, ms));\n}\n\nfunction randomString() {\n  return Math.random()\n    .toString(36)\n    .replace(/[^a-z0-9]+/g, '');\n}\n"]}
@@ -1,60 +0,0 @@
1
- import type { DockerFactory } from './docker';
2
- import type { IAws } from '../aws';
3
- import type { EventEmitter } from '../progress';
4
- /**
5
- * Options for publishing an asset.
6
- */
7
- export interface PublishOptions {
8
- /**
9
- * Whether or not to allow cross account publishing. That is,
10
- * publish to a bucket belonging to a different account than the target account.
11
- *
12
- * @default true
13
- */
14
- readonly allowCrossAccount?: boolean;
15
- /**
16
- * Always upload, even if the target file already exists
17
- *
18
- * @default false
19
- */
20
- readonly force?: boolean;
21
- }
22
- /**
23
- * Handler for asset building and publishing.
24
- */
25
- export interface IAssetHandler {
26
- /**
27
- * Build the asset.
28
- */
29
- build(): Promise<void>;
30
- /**
31
- * Publish the asset.
32
- */
33
- publish(options?: PublishOptions): Promise<void>;
34
- /**
35
- * Return whether the asset already exists
36
- */
37
- isPublished(): Promise<boolean>;
38
- }
39
- export interface IHandlerHost {
40
- readonly aws: IAws;
41
- readonly aborted: boolean;
42
- readonly dockerFactory: DockerFactory;
43
- emitMessage: EventEmitter;
44
- }
45
- export interface IHandlerOptions {
46
- /**
47
- * Where to send output of a subprocesses
48
- *
49
- * @default 'stdio'
50
- */
51
- readonly subprocessOutputDestination: SubprocessOutputDestination;
52
- }
53
- /**
54
- * The potential destinations for subprocess output.
55
- *
56
- * 'stdio' will send output directly to stdout/stderr,
57
- * 'publish' will publish the output to the {@link IPublishProgressListener},
58
- * 'ignore' will ignore the output, and emit it nowhere.
59
- */
60
- export type SubprocessOutputDestination = 'stdio' | 'ignore' | 'publish';
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQtaGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImFzc2V0LWhhbmRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRG9ja2VyRmFjdG9yeSB9IGZyb20gJy4vZG9ja2VyJztcbmltcG9ydCB0eXBlIHsgSUF3cyB9IGZyb20gJy4uL2F3cyc7XG5pbXBvcnQgdHlwZSB7IEV2ZW50RW1pdHRlciB9IGZyb20gJy4uL3Byb2dyZXNzJztcblxuLyoqXG4gKiBPcHRpb25zIGZvciBwdWJsaXNoaW5nIGFuIGFzc2V0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFB1Ymxpc2hPcHRpb25zIHtcbiAgLyoqXG4gICAqIFdoZXRoZXIgb3Igbm90IHRvIGFsbG93IGNyb3NzIGFjY291bnQgcHVibGlzaGluZy4gVGhhdCBpcyxcbiAgICogcHVibGlzaCB0byBhIGJ1Y2tldCBiZWxvbmdpbmcgdG8gYSBkaWZmZXJlbnQgYWNjb3VudCB0aGFuIHRoZSB0YXJnZXQgYWNjb3VudC5cbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgcmVhZG9ubHkgYWxsb3dDcm9zc0FjY291bnQ/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBBbHdheXMgdXBsb2FkLCBldmVuIGlmIHRoZSB0YXJnZXQgZmlsZSBhbHJlYWR5IGV4aXN0c1xuICAgKlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgZm9yY2U/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIEhhbmRsZXIgZm9yIGFzc2V0IGJ1aWxkaW5nIGFuZCBwdWJsaXNoaW5nLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIElBc3NldEhhbmRsZXIge1xuICAvKipcbiAgICogQnVpbGQgdGhlIGFzc2V0LlxuICAgKi9cbiAgYnVpbGQoKTogUHJvbWlzZTx2b2lkPjtcblxuICAvKipcbiAgICogUHVibGlzaCB0aGUgYXNzZXQuXG4gICAqL1xuICBwdWJsaXNoKG9wdGlvbnM/OiBQdWJsaXNoT3B0aW9ucyk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIFJldHVybiB3aGV0aGVyIHRoZSBhc3NldCBhbHJlYWR5IGV4aXN0c1xuICAgKi9cbiAgaXNQdWJsaXNoZWQoKTogUHJvbWlzZTxib29sZWFuPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJSGFuZGxlckhvc3Qge1xuICByZWFkb25seSBhd3M6IElBd3M7XG4gIHJlYWRvbmx5IGFib3J0ZWQ6IGJvb2xlYW47XG4gIHJlYWRvbmx5IGRvY2tlckZhY3Rvcnk6IERvY2tlckZhY3Rvcnk7XG5cbiAgZW1pdE1lc3NhZ2U6IEV2ZW50RW1pdHRlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJSGFuZGxlck9wdGlvbnMge1xuICAvKipcbiAgICogV2hlcmUgdG8gc2VuZCBvdXRwdXQgb2YgYSBzdWJwcm9jZXNzZXNcbiAgICpcbiAgICogQGRlZmF1bHQgJ3N0ZGlvJ1xuICAgKi9cbiAgcmVhZG9ubHkgc3VicHJvY2Vzc091dHB1dERlc3RpbmF0aW9uOiBTdWJwcm9jZXNzT3V0cHV0RGVzdGluYXRpb247XG59XG5cbi8qKlxuICogVGhlIHBvdGVudGlhbCBkZXN0aW5hdGlvbnMgZm9yIHN1YnByb2Nlc3Mgb3V0cHV0LlxuICpcbiAqICdzdGRpbycgd2lsbCBzZW5kIG91dHB1dCBkaXJlY3RseSB0byBzdGRvdXQvc3RkZXJyLFxuICogJ3B1Ymxpc2gnIHdpbGwgcHVibGlzaCB0aGUgb3V0cHV0IHRvIHRoZSB7QGxpbmsgSVB1Ymxpc2hQcm9ncmVzc0xpc3RlbmVyfSxcbiAqICdpZ25vcmUnIHdpbGwgaWdub3JlIHRoZSBvdXRwdXQsIGFuZCBlbWl0IGl0IG5vd2hlcmUuXG4gKi9cbmV4cG9ydCB0eXBlIFN1YnByb2Nlc3NPdXRwdXREZXN0aW5hdGlvbiA9ICdzdGRpbycgfCAnaWdub3JlJyB8ICdwdWJsaXNoJztcbiJdfQ==
@@ -1,35 +0,0 @@
1
- import type { IAws, IECRClient } from '../aws';
2
- import type { EventEmitter } from '../progress';
3
- export interface DockerCredentials {
4
- readonly Username: string;
5
- readonly Secret: string;
6
- }
7
- export interface DockerCredentialsConfig {
8
- readonly version: string;
9
- readonly domainCredentials: Record<string, DockerDomainCredentialSource>;
10
- }
11
- export interface DockerDomainCredentialSource {
12
- readonly secretsManagerSecretId?: string;
13
- readonly secretsUsernameField?: string;
14
- readonly secretsPasswordField?: string;
15
- readonly ecrRepository?: boolean;
16
- readonly assumeRoleArn?: string;
17
- }
18
- /** Returns the presumed location of the CDK Docker credentials config file */
19
- export declare function cdkCredentialsConfigFile(): string;
20
- /** Loads and parses the CDK Docker credentials configuration, if it exists. */
21
- export declare function cdkCredentialsConfig(): DockerCredentialsConfig | undefined;
22
- /**
23
- * Just for testing
24
- */
25
- export declare function _clearCdkCredentialsConfigCache(): void;
26
- /** Fetches login credentials from the configured source (e.g., SecretsManager, ECR) */
27
- export declare function fetchDockerLoginCredentials(aws: IAws, config: DockerCredentialsConfig, endpoint: string): Promise<{
28
- Username: any;
29
- Secret: any;
30
- }>;
31
- export declare function obtainEcrCredentials(ecr: IECRClient, eventEmitter?: EventEmitter): Promise<{
32
- username: string;
33
- password: string;
34
- endpoint: string;
35
- }>;
@@ -1,90 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.cdkCredentialsConfigFile = cdkCredentialsConfigFile;
4
- exports.cdkCredentialsConfig = cdkCredentialsConfig;
5
- exports._clearCdkCredentialsConfigCache = _clearCdkCredentialsConfigCache;
6
- exports.fetchDockerLoginCredentials = fetchDockerLoginCredentials;
7
- exports.obtainEcrCredentials = obtainEcrCredentials;
8
- const fs = require("fs");
9
- const os = require("os");
10
- const path = require("path");
11
- const progress_1 = require("../progress");
12
- /** Returns the presumed location of the CDK Docker credentials config file */
13
- function cdkCredentialsConfigFile() {
14
- return (process.env.CDK_DOCKER_CREDS_FILE ??
15
- path.join((os.userInfo().homedir ?? os.homedir()).trim() || '/', '.cdk', 'cdk-docker-creds.json'));
16
- }
17
- let _cdkCredentials;
18
- /** Loads and parses the CDK Docker credentials configuration, if it exists. */
19
- function cdkCredentialsConfig() {
20
- if (!_cdkCredentials) {
21
- try {
22
- _cdkCredentials = JSON.parse(fs.readFileSync(cdkCredentialsConfigFile(), { encoding: 'utf-8' }));
23
- }
24
- catch {
25
- }
26
- }
27
- return _cdkCredentials;
28
- }
29
- /**
30
- * Just for testing
31
- */
32
- function _clearCdkCredentialsConfigCache() {
33
- _cdkCredentials = undefined;
34
- }
35
- /** Fetches login credentials from the configured source (e.g., SecretsManager, ECR) */
36
- async function fetchDockerLoginCredentials(aws, config, endpoint) {
37
- // Paranoid handling to ensure new URL() doesn't throw if the schema is missing
38
- // For official docker registry, docker will pass https://index.docker.io/v1/
39
- endpoint = endpoint.includes('://') ? endpoint : `https://${endpoint}`;
40
- const domain = new URL(endpoint).hostname;
41
- if (!Object.keys(config.domainCredentials).includes(domain) &&
42
- !Object.keys(config.domainCredentials).includes(endpoint)) {
43
- throw new Error(`unknown domain ${domain}`);
44
- }
45
- let domainConfig = config.domainCredentials[domain] ?? config.domainCredentials[endpoint];
46
- if (domainConfig.secretsManagerSecretId) {
47
- const sm = await aws.secretsManagerClient({ assumeRoleArn: domainConfig.assumeRoleArn });
48
- const secretValue = await sm.getSecretValue({
49
- SecretId: domainConfig.secretsManagerSecretId,
50
- });
51
- if (!secretValue.SecretString) {
52
- throw new Error(`unable to fetch SecretString from secret: ${domainConfig.secretsManagerSecretId}`);
53
- }
54
- const secret = JSON.parse(secretValue.SecretString);
55
- const usernameField = domainConfig.secretsUsernameField ?? 'username';
56
- const secretField = domainConfig.secretsPasswordField ?? 'secret';
57
- if (!secret[usernameField] || !secret[secretField]) {
58
- throw new Error(`malformed secret string ("${usernameField}" or "${secretField}" field missing)`);
59
- }
60
- return { Username: secret[usernameField], Secret: secret[secretField] };
61
- }
62
- else if (domainConfig.ecrRepository) {
63
- const ecr = await aws.ecrClient({ assumeRoleArn: domainConfig.assumeRoleArn });
64
- const ecrAuthData = await obtainEcrCredentials(ecr);
65
- return { Username: ecrAuthData.username, Secret: ecrAuthData.password };
66
- }
67
- else {
68
- throw new Error('unknown credential type: no secret ID or ECR repo');
69
- }
70
- }
71
- async function obtainEcrCredentials(ecr, eventEmitter) {
72
- if (eventEmitter) {
73
- eventEmitter(progress_1.EventType.DEBUG, 'Fetching ECR authorization token');
74
- }
75
- const authData = (await ecr.getAuthorizationToken()).authorizationData || [];
76
- if (authData.length === 0) {
77
- throw new Error('No authorization data received from ECR');
78
- }
79
- const token = Buffer.from(authData[0].authorizationToken, 'base64').toString('ascii');
80
- const [username, password] = token.split(':');
81
- if (!username || !password) {
82
- throw new Error('unexpected ECR authData format');
83
- }
84
- return {
85
- username,
86
- password,
87
- endpoint: authData[0].proxyEndpoint,
88
- };
89
- }
90
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docker-credentials.js","sourceRoot":"","sources":["docker-credentials.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as os from 'os';\nimport * as path from 'path';\nimport type { IAws, IECRClient } from '../aws';\nimport type { EventEmitter } from '../progress';\nimport { EventType } from '../progress';\n\nexport interface DockerCredentials {\n  readonly Username: string;\n  readonly Secret: string;\n}\n\nexport interface DockerCredentialsConfig {\n  readonly version: string;\n  readonly domainCredentials: Record<string, DockerDomainCredentialSource>;\n}\n\nexport interface DockerDomainCredentialSource {\n  readonly secretsManagerSecretId?: string;\n  readonly secretsUsernameField?: string;\n  readonly secretsPasswordField?: string;\n  readonly ecrRepository?: boolean;\n  readonly assumeRoleArn?: string;\n}\n\n/** Returns the presumed location of the CDK Docker credentials config file */\nexport function cdkCredentialsConfigFile(): string {\n  return (\n    process.env.CDK_DOCKER_CREDS_FILE ??\n    path.join(\n      (os.userInfo().homedir ?? os.homedir()).trim() || '/',\n      '.cdk',\n      'cdk-docker-creds.json',\n    )\n  );\n}\n\nlet _cdkCredentials: DockerCredentialsConfig | undefined;\n/** Loads and parses the CDK Docker credentials configuration, if it exists. */\nexport function cdkCredentialsConfig(): DockerCredentialsConfig | undefined {\n  if (!_cdkCredentials) {\n    try {\n      _cdkCredentials = JSON.parse(\n        fs.readFileSync(cdkCredentialsConfigFile(), { encoding: 'utf-8' }),\n      ) as DockerCredentialsConfig;\n    } catch {\n    }\n  }\n  return _cdkCredentials;\n}\n\n/**\n * Just for testing\n */\nexport function _clearCdkCredentialsConfigCache() {\n  _cdkCredentials = undefined;\n}\n\n/** Fetches login credentials from the configured source (e.g., SecretsManager, ECR) */\nexport async function fetchDockerLoginCredentials(\n  aws: IAws,\n  config: DockerCredentialsConfig,\n  endpoint: string,\n) {\n  // Paranoid handling to ensure new URL() doesn't throw if the schema is missing\n  // For official docker registry, docker will pass https://index.docker.io/v1/\n  endpoint = endpoint.includes('://') ? endpoint : `https://${endpoint}`;\n  const domain = new URL(endpoint).hostname;\n\n  if (\n    !Object.keys(config.domainCredentials).includes(domain) &&\n    !Object.keys(config.domainCredentials).includes(endpoint)\n  ) {\n    throw new Error(`unknown domain ${domain}`);\n  }\n\n  let domainConfig = config.domainCredentials[domain] ?? config.domainCredentials[endpoint];\n\n  if (domainConfig.secretsManagerSecretId) {\n    const sm = await aws.secretsManagerClient({ assumeRoleArn: domainConfig.assumeRoleArn });\n    const secretValue = await sm.getSecretValue({\n      SecretId: domainConfig.secretsManagerSecretId,\n    });\n    if (!secretValue.SecretString) {\n      throw new Error(\n        `unable to fetch SecretString from secret: ${domainConfig.secretsManagerSecretId}`,\n      );\n    }\n\n    const secret = JSON.parse(secretValue.SecretString);\n\n    const usernameField = domainConfig.secretsUsernameField ?? 'username';\n    const secretField = domainConfig.secretsPasswordField ?? 'secret';\n    if (!secret[usernameField] || !secret[secretField]) {\n      throw new Error(\n        `malformed secret string (\"${usernameField}\" or \"${secretField}\" field missing)`,\n      );\n    }\n\n    return { Username: secret[usernameField], Secret: secret[secretField] };\n  } else if (domainConfig.ecrRepository) {\n    const ecr = await aws.ecrClient({ assumeRoleArn: domainConfig.assumeRoleArn });\n    const ecrAuthData = await obtainEcrCredentials(ecr);\n\n    return { Username: ecrAuthData.username, Secret: ecrAuthData.password };\n  } else {\n    throw new Error('unknown credential type: no secret ID or ECR repo');\n  }\n}\n\nexport async function obtainEcrCredentials(ecr: IECRClient, eventEmitter?: EventEmitter) {\n  if (eventEmitter) {\n    eventEmitter(EventType.DEBUG, 'Fetching ECR authorization token');\n  }\n\n  const authData = (await ecr.getAuthorizationToken()).authorizationData || [];\n  if (authData.length === 0) {\n    throw new Error('No authorization data received from ECR');\n  }\n  const token = Buffer.from(authData[0].authorizationToken!, 'base64').toString('ascii');\n  const [username, password] = token.split(':');\n  if (!username || !password) {\n    throw new Error('unexpected ECR authData format');\n  }\n\n  return {\n    username,\n    password,\n    endpoint: authData[0].proxyEndpoint!,\n  };\n}\n"]}
@@ -1,98 +0,0 @@
1
- import type { IECRClient } from '../aws';
2
- import type { SubprocessOutputDestination } from './asset-handler';
3
- import type { EventEmitter } from '../progress';
4
- interface BuildOptions {
5
- readonly directory: string;
6
- /**
7
- * Tag the image with a given repoName:tag combination
8
- */
9
- readonly tag: string;
10
- readonly target?: string;
11
- readonly file?: string;
12
- readonly buildArgs?: Record<string, string>;
13
- readonly buildSecrets?: Record<string, string>;
14
- readonly buildSsh?: string;
15
- readonly networkMode?: string;
16
- readonly platform?: string;
17
- readonly outputs?: string[];
18
- readonly cacheFrom?: DockerCacheOption[];
19
- readonly cacheTo?: DockerCacheOption;
20
- readonly cacheDisabled?: boolean;
21
- }
22
- interface PushOptions {
23
- readonly tag: string;
24
- }
25
- export interface DockerCredentialsConfig {
26
- readonly version: string;
27
- readonly domainCredentials: Record<string, DockerDomainCredentials>;
28
- }
29
- export interface DockerDomainCredentials {
30
- readonly secretsManagerSecretId?: string;
31
- readonly ecrRepository?: string;
32
- }
33
- export interface DockerCacheOption {
34
- readonly type: string;
35
- readonly params?: {
36
- [key: string]: string;
37
- };
38
- }
39
- export declare class Docker {
40
- private readonly eventEmitter;
41
- private readonly subprocessOutputDestination;
42
- private configDir;
43
- constructor(eventEmitter: EventEmitter, subprocessOutputDestination: SubprocessOutputDestination);
44
- /**
45
- * Whether an image with the given tag exists
46
- */
47
- exists(tag: string): Promise<boolean>;
48
- build(options: BuildOptions): Promise<void>;
49
- /**
50
- * Get credentials from ECR and run docker login
51
- */
52
- login(ecr: IECRClient): Promise<void>;
53
- tag(sourceTag: string, targetTag: string): Promise<void>;
54
- push(options: PushOptions): Promise<void>;
55
- /**
56
- * If a CDK Docker Credentials file exists, creates a new Docker config directory.
57
- * Sets up `docker-credential-cdk-assets` to be the credential helper for each domain in the CDK config.
58
- * All future commands (e.g., `build`, `push`) will use this config.
59
- *
60
- * See https://docs.docker.com/engine/reference/commandline/login/#credential-helpers for more details on cred helpers.
61
- *
62
- * @returns true if CDK config was found and configured, false otherwise
63
- */
64
- configureCdkCredentials(): boolean;
65
- /**
66
- * Removes any configured Docker config directory.
67
- * All future commands (e.g., `build`, `push`) will use the default config.
68
- *
69
- * This is useful after calling `configureCdkCredentials` to reset to default credentials.
70
- */
71
- resetAuthPlugins(): void;
72
- private execute;
73
- private cacheOptionToFlag;
74
- }
75
- export interface DockerFactoryOptions {
76
- readonly repoUri: string;
77
- readonly ecr: IECRClient;
78
- readonly eventEmitter: EventEmitter;
79
- readonly subprocessOutputDestination: SubprocessOutputDestination;
80
- }
81
- /**
82
- * Helps get appropriately configured Docker instances during the container
83
- * image publishing process.
84
- */
85
- export declare class DockerFactory {
86
- private enterLoggedInDestinationsCriticalSection;
87
- private loggedInDestinations;
88
- /**
89
- * Gets a Docker instance for building images.
90
- */
91
- forBuild(options: DockerFactoryOptions): Promise<Docker>;
92
- /**
93
- * Gets a Docker instance for pushing images to ECR.
94
- */
95
- forEcrPush(options: DockerFactoryOptions): Promise<Docker>;
96
- private loginOncePerDestination;
97
- }
98
- export {};