aws-cdk 2.24.0 → 2.26.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.
package/README.md CHANGED
@@ -510,10 +510,11 @@ $ cdk destroy --app='node bin/main.js' MyStackName
510
510
 
511
511
  ### `cdk bootstrap`
512
512
 
513
- Deploys a `CDKToolkit` CloudFormation stack into the specified environment(s), that provides an S3 bucket that
514
- `cdk deploy` will use to store synthesized templates and the related assets, before triggering a CloudFormation stack
515
- update. The name of the deployed stack can be configured using the `--toolkit-stack-name` argument. The S3 Bucket
516
- Public Access Block Configuration can be configured using the `--public-access-block-configuration` argument.
513
+ Deploys a `CDKToolkit` CloudFormation stack into the specified environment(s), that provides an S3 bucket
514
+ and ECR reposity that `cdk deploy` will use to store synthesized templates and the related assets, before
515
+ triggering a CloudFormation stack update. The name of the deployed stack can be configured using the
516
+ `--toolkit-stack-name` argument. The S3 Bucket Public Access Block Configuration can be configured using
517
+ the `--public-access-block-configuration` argument. ECR uses immutable tags for images.
517
518
 
518
519
  ```console
519
520
  $ # Deploys to all environments
package/build-info.json CHANGED
@@ -1,4 +1,4 @@
1
1
  {
2
- "comment": "Generated at 2022-05-11T18:53:07Z by generate.sh",
3
- "commit": "b8d8b9a"
2
+ "comment": "Generated at 2022-05-30T16:33:31Z by generate.sh",
3
+ "commit": "a409d63"
4
4
  }
@@ -1 +1 @@
1
- {"expiration":1652298876484,"notices":[{"title":"Error when building EKS cluster with monocdk import","issueNumber":17061,"overview":"When using monocdk/aws-eks to build a stack containing an EKS cluster, error is thrown about missing lambda-layer-node-proxy-agent/layer/package.json.","components":[{"name":"cli","version":"<1.130.0 >=1.126.0"}],"schemaVersion":"1"}]}
1
+ {"expiration":1653932100454,"notices":[{"title":"Error when building EKS cluster with monocdk import","issueNumber":17061,"overview":"When using monocdk/aws-eks to build a stack containing an EKS cluster, error is thrown about missing lambda-layer-node-proxy-agent/layer/package.json.","components":[{"name":"cli","version":"<1.130.0 >=1.126.0"}],"schemaVersion":"1"}]}
@@ -94,6 +94,9 @@ class PatchedSharedIniFileCredentials extends AWS.SharedIniFileCredentials {
94
94
  throw AWS.util.error(new Error('source_profile ' + sourceProfile + ' using profile '
95
95
  + this.profile + ' does not exist'), { code: 'SharedIniFileCredentialsProviderFailure' });
96
96
  }
97
+ if (sourceProfileExistanceTest.sso_start_url) {
98
+ return new AWS.SsoCredentials({ profile: sourceProfile });
99
+ }
97
100
  return new AWS.SharedIniFileCredentials(AWS.util.merge(this.options || {}, {
98
101
  profile: sourceProfile,
99
102
  preferStaticCredentials: true,
@@ -151,4 +154,4 @@ function loadProfilesProper(filename) {
151
154
  }
152
155
  return profiles;
153
156
  }
154
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-sdk-inifile.js","sourceRoot":"","sources":["aws-sdk-inifile.ts"],"names":[],"mappings":"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","sourcesContent":["import * as AWS from 'aws-sdk';\n\n\n/**\n * Hack-fix\n *\n * There are a number of issues in the upstream version of SharedIniFileCredentials\n * that need fixing:\n *\n *  1. The upstream aws-sdk contains an incorrect instantiation of an `AWS.STS`\n *     client, which *should* have taken the region from the requested profile\n *     but doesn't. It will use the region from the default profile, which\n *     may not exist, defaulting to `us-east-1` (since we switched to\n *     AWS_STS_REGIONAL_ENDPOINTS=regional, that default is not even allowed anymore\n *     and the absence of a default region will lead to an error).\n *\n *  2. The simple fix is to get the region from the `config` file. profiles\n *     are made up of a combination of `credentials` and `config`, and the region is\n *     generally in `config` with the rest in `credentials`. However, a bug in\n *     `getProfilesFromSharedConfig` overwrites ALL `config` data with `credentials`\n *     data, so we also need to do extra work to fish the `region` out of the config.\n *\n * 3.  The 'credential_source' option is not supported. Meaning credentials\n *     for assume-role cannot be fetched using EC2/ESC metadata.\n *\n * See https://github.com/aws/aws-sdk-js/issues/3418 for all the gory details.\n * See https://github.com/aws/aws-sdk-js/issues/1916 for some more glory details.\n */\nexport class PatchedSharedIniFileCredentials extends AWS.SharedIniFileCredentials {\n  declare private profile: string;\n  declare private filename: string;\n  declare private disableAssumeRole: boolean;\n  declare private options: Record<string, string>;\n  declare private roleArn: string;\n  declare private httpOptions?: AWS.HTTPOptions;\n  declare private tokenCodeFn?: (mfaSerial: string, callback: (err?: Error, token?: string) => void) => void;\n\n  public loadRoleProfile(\n    creds: Record<string, Record<string, string>>,\n    roleProfile: Record<string, string>,\n    callback: (err?: Error, data?: any) => void) {\n\n    // Need to duplicate the whole implementation here -- the function is long and has been written in\n    // such a way that there are no small monkey patches possible.\n\n    if (this.disableAssumeRole) {\n      throw (AWS as any).util.error(\n        new Error('Role assumption profiles are disabled. ' +\n                  'Failed to load profile ' + this.profile +\n                  ' from ' + creds.filename),\n        { code: 'SharedIniFileCredentialsProviderFailure' },\n      );\n    }\n\n    var self = this;\n    var roleArn = roleProfile.role_arn;\n    var roleSessionName = roleProfile.role_session_name;\n    var externalId = roleProfile.external_id;\n    var mfaSerial = roleProfile.mfa_serial;\n    var sourceProfile = roleProfile.source_profile;\n    var credentialSource = roleProfile.credential_source;\n\n    const credentialError = (AWS as any).util.error(\n      new Error(`When using 'role_arn' in profile ('${this.profile}'), you must also configure exactly one of 'source_profile' or 'credential_source'`),\n      { code: 'SharedIniFileCredentialsProviderFailure' },\n    );\n\n    if (sourceProfile && credentialSource) {\n      throw credentialError;\n    }\n\n    if (!sourceProfile && !credentialSource) {\n      throw credentialError;\n    }\n\n    const profiles = loadProfilesProper(this.filename);\n    const region = profiles[this.profile]?.region ?? profiles.default?.region ?? 'us-east-1';\n\n    const stsCreds = sourceProfile ? this.sourceProfileCredentials(sourceProfile, creds) : this.credentialSourceCredentials(credentialSource);\n\n    this.roleArn = roleArn;\n    var sts = new AWS.STS({\n      credentials: stsCreds,\n      region,\n      httpOptions: this.httpOptions,\n    });\n\n    var roleParams: AWS.STS.AssumeRoleRequest = {\n      RoleArn: roleArn,\n      RoleSessionName: roleSessionName || 'aws-sdk-js-' + Date.now(),\n    };\n\n    if (externalId) {\n      roleParams.ExternalId = externalId;\n    }\n\n    if (mfaSerial && self.tokenCodeFn) {\n      roleParams.SerialNumber = mfaSerial;\n      self.tokenCodeFn(mfaSerial, function(err, token) {\n        if (err) {\n          var message;\n          if (err instanceof Error) {\n            message = err.message;\n          } else {\n            message = err;\n          }\n          callback(\n            (AWS as any).util.error(\n              new Error('Error fetching MFA token: ' + message),\n              { code: 'SharedIniFileCredentialsProviderFailure' },\n            ));\n          return;\n        }\n\n        roleParams.TokenCode = token;\n        sts.assumeRole(roleParams, callback);\n      });\n      return;\n    }\n    sts.assumeRole(roleParams, callback);\n  }\n\n  private sourceProfileCredentials(sourceProfile: string, profiles: Record<string, Record<string, string>>) {\n\n    var sourceProfileExistanceTest = profiles[sourceProfile];\n\n    if (typeof sourceProfileExistanceTest !== 'object') {\n      throw (AWS as any).util.error(\n        new Error('source_profile ' + sourceProfile + ' using profile '\n          + this.profile + ' does not exist'),\n        { code: 'SharedIniFileCredentialsProviderFailure' },\n      );\n    }\n\n    return new AWS.SharedIniFileCredentials(\n      (AWS as any).util.merge(this.options || {}, {\n        profile: sourceProfile,\n        preferStaticCredentials: true,\n      }),\n    );\n\n  }\n\n  // the aws-sdk for js does not support 'credential_source' (https://github.com/aws/aws-sdk-js/issues/1916)\n  // so unfortunately we need to implement this ourselves.\n  private credentialSourceCredentials(sourceCredential: string) {\n\n    // see https://docs.aws.amazon.com/credref/latest/refdocs/setting-global-credential_source.html\n    switch (sourceCredential) {\n      case 'Environment': {\n        return new AWS.EnvironmentCredentials('AWS');\n      }\n      case 'Ec2InstanceMetadata': {\n        return new AWS.EC2MetadataCredentials();\n      }\n      case 'EcsContainer': {\n        return new AWS.ECSCredentials();\n      }\n      default: {\n        throw new Error(`credential_source ${sourceCredential} in profile ${this.profile} is unsupported. choose one of [Environment, Ec2InstanceMetadata, EcsContainer]`);\n      }\n    }\n\n  }\n}\n\n/**\n * A function to load profiles from disk that MERGES credentials and config instead of overwriting\n *\n * @see https://github.com/aws/aws-sdk-js/blob/5ae5a7d7d24d1000dbc089cc15f8ed2c7b06c542/lib/util.js#L956\n */\nfunction loadProfilesProper(filename: string) {\n  const util = (AWS as any).util; // Does exists even though there aren't any typings for it\n  const iniLoader = util.iniLoader;\n  const profiles: Record<string, Record<string, string>> = {};\n  let profilesFromConfig: Record<string, Record<string, string>> = {};\n  if (process.env[util.configOptInEnv]) {\n    profilesFromConfig = iniLoader.loadFrom({\n      isConfig: true,\n      filename: process.env[util.sharedConfigFileEnv],\n    });\n  }\n  var profilesFromCreds: Record<string, Record<string, string>> = iniLoader.loadFrom({\n    filename: filename ||\n      (process.env[util.configOptInEnv] && process.env[util.sharedCredentialsFileEnv]),\n  });\n  for (const [name, profile] of Object.entries(profilesFromConfig)) {\n    profiles[name] = profile;\n  }\n  for (const [name, profile] of Object.entries(profilesFromCreds)) {\n    profiles[name] = {\n      ...profiles[name],\n      ...profile,\n    };\n  }\n  return profiles;\n}\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-sdk-inifile.js","sourceRoot":"","sources":["aws-sdk-inifile.ts"],"names":[],"mappings":"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","sourcesContent":["import * as AWS from 'aws-sdk';\n\n\n/**\n * Hack-fix\n *\n * There are a number of issues in the upstream version of SharedIniFileCredentials\n * that need fixing:\n *\n *  1. The upstream aws-sdk contains an incorrect instantiation of an `AWS.STS`\n *     client, which *should* have taken the region from the requested profile\n *     but doesn't. It will use the region from the default profile, which\n *     may not exist, defaulting to `us-east-1` (since we switched to\n *     AWS_STS_REGIONAL_ENDPOINTS=regional, that default is not even allowed anymore\n *     and the absence of a default region will lead to an error).\n *\n *  2. The simple fix is to get the region from the `config` file. profiles\n *     are made up of a combination of `credentials` and `config`, and the region is\n *     generally in `config` with the rest in `credentials`. However, a bug in\n *     `getProfilesFromSharedConfig` overwrites ALL `config` data with `credentials`\n *     data, so we also need to do extra work to fish the `region` out of the config.\n *\n * 3.  The 'credential_source' option is not supported. Meaning credentials\n *     for assume-role cannot be fetched using EC2/ESC metadata.\n *\n * See https://github.com/aws/aws-sdk-js/issues/3418 for all the gory details.\n * See https://github.com/aws/aws-sdk-js/issues/1916 for some more glory details.\n */\nexport class PatchedSharedIniFileCredentials extends AWS.SharedIniFileCredentials {\n  declare private profile: string;\n  declare private filename: string;\n  declare private disableAssumeRole: boolean;\n  declare private options: Record<string, string>;\n  declare private roleArn: string;\n  declare private httpOptions?: AWS.HTTPOptions;\n  declare private tokenCodeFn?: (mfaSerial: string, callback: (err?: Error, token?: string) => void) => void;\n\n  public loadRoleProfile(\n    creds: Record<string, Record<string, string>>,\n    roleProfile: Record<string, string>,\n    callback: (err?: Error, data?: any) => void) {\n\n    // Need to duplicate the whole implementation here -- the function is long and has been written in\n    // such a way that there are no small monkey patches possible.\n\n    if (this.disableAssumeRole) {\n      throw (AWS as any).util.error(\n        new Error('Role assumption profiles are disabled. ' +\n                  'Failed to load profile ' + this.profile +\n                  ' from ' + creds.filename),\n        { code: 'SharedIniFileCredentialsProviderFailure' },\n      );\n    }\n\n    var self = this;\n    var roleArn = roleProfile.role_arn;\n    var roleSessionName = roleProfile.role_session_name;\n    var externalId = roleProfile.external_id;\n    var mfaSerial = roleProfile.mfa_serial;\n    var sourceProfile = roleProfile.source_profile;\n    var credentialSource = roleProfile.credential_source;\n\n    const credentialError = (AWS as any).util.error(\n      new Error(`When using 'role_arn' in profile ('${this.profile}'), you must also configure exactly one of 'source_profile' or 'credential_source'`),\n      { code: 'SharedIniFileCredentialsProviderFailure' },\n    );\n\n    if (sourceProfile && credentialSource) {\n      throw credentialError;\n    }\n\n    if (!sourceProfile && !credentialSource) {\n      throw credentialError;\n    }\n\n    const profiles = loadProfilesProper(this.filename);\n    const region = profiles[this.profile]?.region ?? profiles.default?.region ?? 'us-east-1';\n\n    const stsCreds = sourceProfile ? this.sourceProfileCredentials(sourceProfile, creds) : this.credentialSourceCredentials(credentialSource);\n\n    this.roleArn = roleArn;\n    var sts = new AWS.STS({\n      credentials: stsCreds,\n      region,\n      httpOptions: this.httpOptions,\n    });\n\n    var roleParams: AWS.STS.AssumeRoleRequest = {\n      RoleArn: roleArn,\n      RoleSessionName: roleSessionName || 'aws-sdk-js-' + Date.now(),\n    };\n\n    if (externalId) {\n      roleParams.ExternalId = externalId;\n    }\n\n    if (mfaSerial && self.tokenCodeFn) {\n      roleParams.SerialNumber = mfaSerial;\n      self.tokenCodeFn(mfaSerial, function(err, token) {\n        if (err) {\n          var message;\n          if (err instanceof Error) {\n            message = err.message;\n          } else {\n            message = err;\n          }\n          callback(\n            (AWS as any).util.error(\n              new Error('Error fetching MFA token: ' + message),\n              { code: 'SharedIniFileCredentialsProviderFailure' },\n            ));\n          return;\n        }\n\n        roleParams.TokenCode = token;\n        sts.assumeRole(roleParams, callback);\n      });\n      return;\n    }\n    sts.assumeRole(roleParams, callback);\n  }\n\n  private sourceProfileCredentials(sourceProfile: string, profiles: Record<string, Record<string, string>>) {\n\n    var sourceProfileExistanceTest = profiles[sourceProfile];\n\n    if (typeof sourceProfileExistanceTest !== 'object') {\n      throw (AWS as any).util.error(\n        new Error('source_profile ' + sourceProfile + ' using profile '\n          + this.profile + ' does not exist'),\n        { code: 'SharedIniFileCredentialsProviderFailure' },\n      );\n    }\n\n    if (sourceProfileExistanceTest.sso_start_url) {\n      return new AWS.SsoCredentials({ profile: sourceProfile });\n    }\n\n    return new AWS.SharedIniFileCredentials(\n      (AWS as any).util.merge(this.options || {}, {\n        profile: sourceProfile,\n        preferStaticCredentials: true,\n      }),\n    );\n\n  }\n\n  // the aws-sdk for js does not support 'credential_source' (https://github.com/aws/aws-sdk-js/issues/1916)\n  // so unfortunately we need to implement this ourselves.\n  private credentialSourceCredentials(sourceCredential: string) {\n\n    // see https://docs.aws.amazon.com/credref/latest/refdocs/setting-global-credential_source.html\n    switch (sourceCredential) {\n      case 'Environment': {\n        return new AWS.EnvironmentCredentials('AWS');\n      }\n      case 'Ec2InstanceMetadata': {\n        return new AWS.EC2MetadataCredentials();\n      }\n      case 'EcsContainer': {\n        return new AWS.ECSCredentials();\n      }\n      default: {\n        throw new Error(`credential_source ${sourceCredential} in profile ${this.profile} is unsupported. choose one of [Environment, Ec2InstanceMetadata, EcsContainer]`);\n      }\n    }\n\n  }\n}\n\n/**\n * A function to load profiles from disk that MERGES credentials and config instead of overwriting\n *\n * @see https://github.com/aws/aws-sdk-js/blob/5ae5a7d7d24d1000dbc089cc15f8ed2c7b06c542/lib/util.js#L956\n */\nfunction loadProfilesProper(filename: string) {\n  const util = (AWS as any).util; // Does exists even though there aren't any typings for it\n  const iniLoader = util.iniLoader;\n  const profiles: Record<string, Record<string, string>> = {};\n  let profilesFromConfig: Record<string, Record<string, string>> = {};\n  if (process.env[util.configOptInEnv]) {\n    profilesFromConfig = iniLoader.loadFrom({\n      isConfig: true,\n      filename: process.env[util.sharedConfigFileEnv],\n    });\n  }\n  var profilesFromCreds: Record<string, Record<string, string>> = iniLoader.loadFrom({\n    filename: filename ||\n      (process.env[util.configOptInEnv] && process.env[util.sharedCredentialsFileEnv]),\n  });\n  for (const [name, profile] of Object.entries(profilesFromConfig)) {\n    profiles[name] = profile;\n  }\n  for (const [name, profile] of Object.entries(profilesFromCreds)) {\n    profiles[name] = {\n      ...profiles[name],\n      ...profile,\n    };\n  }\n  return profiles;\n}\n"]}
@@ -202,6 +202,7 @@ Resources:
202
202
  ContainerAssetsRepository:
203
203
  Type: AWS::ECR::Repository
204
204
  Properties:
205
+ ImageTagMutability: IMMUTABLE
205
206
  ImageScanningConfiguration:
206
207
  ScanOnPush: true
207
208
  RepositoryName:
@@ -509,7 +510,7 @@ Resources:
509
510
  Type: String
510
511
  Name:
511
512
  Fn::Sub: '/cdk-bootstrap/${Qualifier}/version'
512
- Value: '12'
513
+ Value: '13'
513
514
  Outputs:
514
515
  BucketName:
515
516
  Description: The name of the S3 bucket owned by the CDK toolkit stack
package/lib/assets.js CHANGED
@@ -95,6 +95,7 @@ async function prepareDockerImageAsset(asset, assetManifest, toolkitInfo) {
95
95
  dockerBuildTarget: asset.target,
96
96
  dockerFile: asset.file,
97
97
  networkMode: asset.networkMode,
98
+ platform: asset.platform,
98
99
  }, {
99
100
  repositoryName,
100
101
  imageTag,
@@ -104,4 +105,4 @@ async function prepareDockerImageAsset(asset, assetManifest, toolkitInfo) {
104
105
  }
105
106
  return { [asset.imageNameParameter]: `${repositoryUri}:${imageTag}` };
106
107
  }
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assets.js","sourceRoot":"","sources":["assets.ts"],"names":[],"mappings":"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","sourcesContent":["// eslint-disable-next-line max-len\nimport * as path from 'path';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as chalk from 'chalk';\nimport { ToolkitInfo } from './api/toolkit-info';\nimport { debug } from './logging';\nimport { AssetManifestBuilder } from './util/asset-manifest-builder';\n\n/**\n * Take the metadata assets from the given stack and add them to the given asset manifest\n *\n * Returns the CloudFormation parameters that need to be sent to the template to\n * pass Asset coordinates.\n */\n// eslint-disable-next-line max-len\nexport async function addMetadataAssetsToManifest(stack: cxapi.CloudFormationStackArtifact, assetManifest: AssetManifestBuilder, toolkitInfo: ToolkitInfo, reuse?: string[]): Promise<Record<string, string>> {\n  reuse = reuse || [];\n  const assets = stack.assets;\n\n  if (assets.length === 0) {\n    return {};\n  }\n\n  if (!toolkitInfo.found) {\n    // eslint-disable-next-line max-len\n    throw new Error(`This stack uses assets, so the toolkit stack must be deployed to the environment (Run \"${chalk.blue('cdk bootstrap ' + stack.environment!.name)}\")`);\n  }\n\n  const params: Record<string, string> = {};\n\n  for (const asset of assets) {\n    // FIXME: Should have excluded by construct path here instead of by unique ID, preferably using\n    // minimatch so we can support globs. Maybe take up during artifact refactoring.\n    const reuseAsset = reuse.indexOf(asset.id) > -1;\n\n    if (reuseAsset) {\n      debug(`Reusing asset ${asset.id}: ${JSON.stringify(asset)}`);\n      continue;\n    }\n\n    debug(`Preparing asset ${asset.id}: ${JSON.stringify(asset)}`);\n    if (!stack.assembly) {\n      throw new Error('Unexpected: stack assembly is required in order to find assets in assemly directory');\n    }\n\n    Object.assign(params, await prepareAsset(asset, assetManifest, toolkitInfo));\n  }\n\n  return params;\n}\n\n// eslint-disable-next-line max-len\nasync function prepareAsset(asset: cxschema.AssetMetadataEntry, assetManifest: AssetManifestBuilder, toolkitInfo: ToolkitInfo): Promise<Record<string, string>> {\n  switch (asset.packaging) {\n    case 'zip':\n    case 'file':\n      return prepareFileAsset(\n        asset,\n        assetManifest,\n        toolkitInfo,\n        asset.packaging === 'zip' ? cxschema.FileAssetPackaging.ZIP_DIRECTORY : cxschema.FileAssetPackaging.FILE);\n    case 'container-image':\n      return prepareDockerImageAsset(asset, assetManifest, toolkitInfo);\n    default:\n      // eslint-disable-next-line max-len\n      throw new Error(`Unsupported packaging type: ${(asset as any).packaging}. You might need to upgrade your aws-cdk toolkit to support this asset type.`);\n  }\n}\n\nfunction prepareFileAsset(\n  asset: cxschema.FileAssetMetadataEntry,\n  assetManifest: AssetManifestBuilder,\n  toolkitInfo: ToolkitInfo,\n  packaging: cxschema.FileAssetPackaging): Record<string, string> {\n\n  const extension = packaging === cxschema.FileAssetPackaging.ZIP_DIRECTORY ? '.zip' : path.extname(asset.path);\n  const baseName = `${asset.sourceHash}${extension}`;\n  // Simplify key: assets/abcdef/abcdef.zip is kinda silly and unnecessary, so if they're the same just pick one component.\n  const s3Prefix = asset.id === asset.sourceHash ? 'assets/' : `assets/${asset.id}/`;\n  const key = `${s3Prefix}${baseName}`;\n  const s3url = `s3://${toolkitInfo.bucketName}/${key}`;\n\n  debug(`Storing asset ${asset.path} at ${s3url}`);\n\n  assetManifest.addFileAsset(asset.sourceHash, {\n    path: asset.path,\n    packaging,\n  }, {\n    bucketName: toolkitInfo.bucketName,\n    objectKey: key,\n  });\n\n  return {\n    [asset.s3BucketParameter]: toolkitInfo.bucketName,\n    [asset.s3KeyParameter]: `${s3Prefix}${cxapi.ASSET_PREFIX_SEPARATOR}${baseName}`,\n    [asset.artifactHashParameter]: asset.sourceHash,\n  };\n}\n\nasync function prepareDockerImageAsset(\n  asset: cxschema.ContainerImageAssetMetadataEntry,\n  assetManifest: AssetManifestBuilder,\n  toolkitInfo: ToolkitInfo): Promise<Record<string, string>> {\n\n  // Pre-1.21.0, repositoryName can be specified by the user or can be left out, in which case we make\n  // a per-asset repository which will get adopted and cleaned up along with the stack.\n  // Post-1.21.0, repositoryName will always be specified and it will be a shared repository between\n  // all assets, and asset will have imageTag specified as well. Validate the combination.\n  if (!asset.imageNameParameter && (!asset.repositoryName || !asset.imageTag)) {\n    throw new Error('Invalid Docker image asset configuration: \"repositoryName\" and \"imageTag\" are required when \"imageNameParameter\" is left out');\n  }\n\n  const repositoryName = asset.repositoryName ?? 'cdk/' + asset.id.replace(/[:/]/g, '-').toLowerCase();\n\n  // Make sure the repository exists, since the 'cdk-assets' tool will not create it for us.\n  const { repositoryUri } = await toolkitInfo.prepareEcrRepository(repositoryName);\n  const imageTag = asset.imageTag ?? asset.sourceHash;\n\n  assetManifest.addDockerImageAsset(asset.sourceHash, {\n    directory: asset.path,\n    dockerBuildArgs: asset.buildArgs,\n    dockerBuildTarget: asset.target,\n    dockerFile: asset.file,\n    networkMode: asset.networkMode,\n  }, {\n    repositoryName,\n    imageTag,\n  });\n\n  if (!asset.imageNameParameter) { return {}; }\n  return { [asset.imageNameParameter]: `${repositoryUri}:${imageTag}` };\n}\n"]}
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assets.js","sourceRoot":"","sources":["assets.ts"],"names":[],"mappings":";;;AAAA,mCAAmC;AACnC,6BAA6B;AAC7B,2DAA2D;AAC3D,yCAAyC;AACzC,+BAA+B;AAE/B,uCAAkC;AAGlC;;;;;GAKG;AACH,mCAAmC;AAC5B,KAAK,UAAU,2BAA2B,CAAC,KAAwC,EAAE,aAAmC,EAAE,WAAwB,EAAE,KAAgB;IACzK,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;IACpB,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;IAE5B,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;QACvB,OAAO,EAAE,CAAC;KACX;IAED,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE;QACtB,mCAAmC;QACnC,MAAM,IAAI,KAAK,CAAC,0FAA0F,KAAK,CAAC,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,WAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KACvK;IAED,MAAM,MAAM,GAA2B,EAAE,CAAC;IAE1C,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;QAC1B,+FAA+F;QAC/F,gFAAgF;QAChF,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAEhD,IAAI,UAAU,EAAE;YACd,eAAK,CAAC,iBAAiB,KAAK,CAAC,EAAE,KAAK,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YAC7D,SAAS;SACV;QAED,eAAK,CAAC,mBAAmB,KAAK,CAAC,EAAE,KAAK,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAC/D,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;YACnB,MAAM,IAAI,KAAK,CAAC,qFAAqF,CAAC,CAAC;SACxG;QAED,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,YAAY,CAAC,KAAK,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC,CAAC;KAC9E;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAlCD,kEAkCC;AAED,mCAAmC;AACnC,KAAK,UAAU,YAAY,CAAC,KAAkC,EAAE,aAAmC,EAAE,WAAwB;IAC3H,QAAQ,KAAK,CAAC,SAAS,EAAE;QACvB,KAAK,KAAK,CAAC;QACX,KAAK,MAAM;YACT,OAAO,gBAAgB,CACrB,KAAK,EACL,aAAa,EACb,WAAW,EACX,KAAK,CAAC,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAC9G,KAAK,iBAAiB;YACpB,OAAO,uBAAuB,CAAC,KAAK,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;QACpE;YACE,mCAAmC;YACnC,MAAM,IAAI,KAAK,CAAC,+BAAgC,KAAa,CAAC,SAAS,8EAA8E,CAAC,CAAC;KAC1J;AACH,CAAC;AAED,SAAS,gBAAgB,CACvB,KAAsC,EACtC,aAAmC,EACnC,WAAwB,EACxB,SAAsC;IAEtC,MAAM,SAAS,GAAG,SAAS,KAAK,QAAQ,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC9G,MAAM,QAAQ,GAAG,GAAG,KAAK,CAAC,UAAU,GAAG,SAAS,EAAE,CAAC;IACnD,yHAAyH;IACzH,MAAM,QAAQ,GAAG,KAAK,CAAC,EAAE,KAAK,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,KAAK,CAAC,EAAE,GAAG,CAAC;IACnF,MAAM,GAAG,GAAG,GAAG,QAAQ,GAAG,QAAQ,EAAE,CAAC;IACrC,MAAM,KAAK,GAAG,QAAQ,WAAW,CAAC,UAAU,IAAI,GAAG,EAAE,CAAC;IAEtD,eAAK,CAAC,iBAAiB,KAAK,CAAC,IAAI,OAAO,KAAK,EAAE,CAAC,CAAC;IAEjD,aAAa,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,EAAE;QAC3C,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,SAAS;KACV,EAAE;QACD,UAAU,EAAE,WAAW,CAAC,UAAU;QAClC,SAAS,EAAE,GAAG;KACf,CAAC,CAAC;IAEH,OAAO;QACL,CAAC,KAAK,CAAC,iBAAiB,CAAC,EAAE,WAAW,CAAC,UAAU;QACjD,CAAC,KAAK,CAAC,cAAc,CAAC,EAAE,GAAG,QAAQ,GAAG,KAAK,CAAC,sBAAsB,GAAG,QAAQ,EAAE;QAC/E,CAAC,KAAK,CAAC,qBAAqB,CAAC,EAAE,KAAK,CAAC,UAAU;KAChD,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,uBAAuB,CACpC,KAAgD,EAChD,aAAmC,EACnC,WAAwB;;IAExB,oGAAoG;IACpG,qFAAqF;IACrF,kGAAkG;IAClG,wFAAwF;IACxF,IAAI,CAAC,KAAK,CAAC,kBAAkB,IAAI,CAAC,CAAC,KAAK,CAAC,cAAc,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE;QAC3E,MAAM,IAAI,KAAK,CAAC,8HAA8H,CAAC,CAAC;KACjJ;IAED,MAAM,cAAc,SAAG,KAAK,CAAC,cAAc,mCAAI,MAAM,GAAG,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;IAErG,0FAA0F;IAC1F,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,WAAW,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAC;IACjF,MAAM,QAAQ,SAAG,KAAK,CAAC,QAAQ,mCAAI,KAAK,CAAC,UAAU,CAAC;IAEpD,aAAa,CAAC,mBAAmB,CAAC,KAAK,CAAC,UAAU,EAAE;QAClD,SAAS,EAAE,KAAK,CAAC,IAAI;QACrB,eAAe,EAAE,KAAK,CAAC,SAAS;QAChC,iBAAiB,EAAE,KAAK,CAAC,MAAM;QAC/B,UAAU,EAAE,KAAK,CAAC,IAAI;QACtB,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,QAAQ,EAAE,KAAK,CAAC,QAAQ;KACzB,EAAE;QACD,cAAc;QACd,QAAQ;KACT,CAAC,CAAC;IAEH,IAAI,CAAC,KAAK,CAAC,kBAAkB,EAAE;QAAE,OAAO,EAAE,CAAC;KAAE;IAC7C,OAAO,EAAE,CAAC,KAAK,CAAC,kBAAkB,CAAC,EAAE,GAAG,aAAa,IAAI,QAAQ,EAAE,EAAE,CAAC;AACxE,CAAC","sourcesContent":["// eslint-disable-next-line max-len\nimport * as path from 'path';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as chalk from 'chalk';\nimport { ToolkitInfo } from './api/toolkit-info';\nimport { debug } from './logging';\nimport { AssetManifestBuilder } from './util/asset-manifest-builder';\n\n/**\n * Take the metadata assets from the given stack and add them to the given asset manifest\n *\n * Returns the CloudFormation parameters that need to be sent to the template to\n * pass Asset coordinates.\n */\n// eslint-disable-next-line max-len\nexport async function addMetadataAssetsToManifest(stack: cxapi.CloudFormationStackArtifact, assetManifest: AssetManifestBuilder, toolkitInfo: ToolkitInfo, reuse?: string[]): Promise<Record<string, string>> {\n  reuse = reuse || [];\n  const assets = stack.assets;\n\n  if (assets.length === 0) {\n    return {};\n  }\n\n  if (!toolkitInfo.found) {\n    // eslint-disable-next-line max-len\n    throw new Error(`This stack uses assets, so the toolkit stack must be deployed to the environment (Run \"${chalk.blue('cdk bootstrap ' + stack.environment!.name)}\")`);\n  }\n\n  const params: Record<string, string> = {};\n\n  for (const asset of assets) {\n    // FIXME: Should have excluded by construct path here instead of by unique ID, preferably using\n    // minimatch so we can support globs. Maybe take up during artifact refactoring.\n    const reuseAsset = reuse.indexOf(asset.id) > -1;\n\n    if (reuseAsset) {\n      debug(`Reusing asset ${asset.id}: ${JSON.stringify(asset)}`);\n      continue;\n    }\n\n    debug(`Preparing asset ${asset.id}: ${JSON.stringify(asset)}`);\n    if (!stack.assembly) {\n      throw new Error('Unexpected: stack assembly is required in order to find assets in assemly directory');\n    }\n\n    Object.assign(params, await prepareAsset(asset, assetManifest, toolkitInfo));\n  }\n\n  return params;\n}\n\n// eslint-disable-next-line max-len\nasync function prepareAsset(asset: cxschema.AssetMetadataEntry, assetManifest: AssetManifestBuilder, toolkitInfo: ToolkitInfo): Promise<Record<string, string>> {\n  switch (asset.packaging) {\n    case 'zip':\n    case 'file':\n      return prepareFileAsset(\n        asset,\n        assetManifest,\n        toolkitInfo,\n        asset.packaging === 'zip' ? cxschema.FileAssetPackaging.ZIP_DIRECTORY : cxschema.FileAssetPackaging.FILE);\n    case 'container-image':\n      return prepareDockerImageAsset(asset, assetManifest, toolkitInfo);\n    default:\n      // eslint-disable-next-line max-len\n      throw new Error(`Unsupported packaging type: ${(asset as any).packaging}. You might need to upgrade your aws-cdk toolkit to support this asset type.`);\n  }\n}\n\nfunction prepareFileAsset(\n  asset: cxschema.FileAssetMetadataEntry,\n  assetManifest: AssetManifestBuilder,\n  toolkitInfo: ToolkitInfo,\n  packaging: cxschema.FileAssetPackaging): Record<string, string> {\n\n  const extension = packaging === cxschema.FileAssetPackaging.ZIP_DIRECTORY ? '.zip' : path.extname(asset.path);\n  const baseName = `${asset.sourceHash}${extension}`;\n  // Simplify key: assets/abcdef/abcdef.zip is kinda silly and unnecessary, so if they're the same just pick one component.\n  const s3Prefix = asset.id === asset.sourceHash ? 'assets/' : `assets/${asset.id}/`;\n  const key = `${s3Prefix}${baseName}`;\n  const s3url = `s3://${toolkitInfo.bucketName}/${key}`;\n\n  debug(`Storing asset ${asset.path} at ${s3url}`);\n\n  assetManifest.addFileAsset(asset.sourceHash, {\n    path: asset.path,\n    packaging,\n  }, {\n    bucketName: toolkitInfo.bucketName,\n    objectKey: key,\n  });\n\n  return {\n    [asset.s3BucketParameter]: toolkitInfo.bucketName,\n    [asset.s3KeyParameter]: `${s3Prefix}${cxapi.ASSET_PREFIX_SEPARATOR}${baseName}`,\n    [asset.artifactHashParameter]: asset.sourceHash,\n  };\n}\n\nasync function prepareDockerImageAsset(\n  asset: cxschema.ContainerImageAssetMetadataEntry,\n  assetManifest: AssetManifestBuilder,\n  toolkitInfo: ToolkitInfo): Promise<Record<string, string>> {\n\n  // Pre-1.21.0, repositoryName can be specified by the user or can be left out, in which case we make\n  // a per-asset repository which will get adopted and cleaned up along with the stack.\n  // Post-1.21.0, repositoryName will always be specified and it will be a shared repository between\n  // all assets, and asset will have imageTag specified as well. Validate the combination.\n  if (!asset.imageNameParameter && (!asset.repositoryName || !asset.imageTag)) {\n    throw new Error('Invalid Docker image asset configuration: \"repositoryName\" and \"imageTag\" are required when \"imageNameParameter\" is left out');\n  }\n\n  const repositoryName = asset.repositoryName ?? 'cdk/' + asset.id.replace(/[:/]/g, '-').toLowerCase();\n\n  // Make sure the repository exists, since the 'cdk-assets' tool will not create it for us.\n  const { repositoryUri } = await toolkitInfo.prepareEcrRepository(repositoryName);\n  const imageTag = asset.imageTag ?? asset.sourceHash;\n\n  assetManifest.addDockerImageAsset(asset.sourceHash, {\n    directory: asset.path,\n    dockerBuildArgs: asset.buildArgs,\n    dockerBuildTarget: asset.target,\n    dockerFile: asset.file,\n    networkMode: asset.networkMode,\n    platform: asset.platform,\n  }, {\n    repositoryName,\n    imageTag,\n  });\n\n  if (!asset.imageNameParameter) { return {}; }\n  return { [asset.imageNameParameter]: `${repositoryUri}:${imageTag}` };\n}\n"]}