@aws-cdk/toolkit-lib 0.1.5 → 0.1.7

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.
@@ -49,7 +49,7 @@ class ContextAwareCloudAssembly {
49
49
  previouslyMissingKeys = missingKeysSet;
50
50
  if (tryLookup) {
51
51
  await this.ioHelper.notify(private_1.IO.CDK_ASSEMBLY_I0241.msg('Some context information is missing. Fetching...', { missingKeys }));
52
- await aws_cdk_1.contextproviders.provideContextValues(assembly.manifest.missing, this.context, this.props.services.sdkProvider);
52
+ await aws_cdk_1.contextproviders.provideContextValues(assembly.manifest.missing, this.context, this.props.services.sdkProvider, this.ioHelper);
53
53
  // Cache the new context to disk
54
54
  await this.ioHelper.notify(private_1.IO.CDK_ASSEMBLY_I0042.msg(`Writing updated context to ${this.contextFile}...`, {
55
55
  contextFile: this.contextFile,
@@ -85,4 +85,4 @@ function equalSets(a, b) {
85
85
  }
86
86
  return true;
87
87
  }
88
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-aware-source.js","sourceRoot":"","sources":["context-aware-source.ts"],"names":[],"mappings":"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","sourcesContent":["import type { MissingContext } from '@aws-cdk/cloud-assembly-schema';\nimport type * as cxapi from '@aws-cdk/cx-api';\nimport type { ToolkitServices } from '../../../toolkit/private';\nimport { type Context, contextproviders, PROJECT_CONTEXT } from '../../aws-cdk';\nimport { IO } from '../../io/private';\nimport type { IoHelper } from '../../shared-private';\nimport { ToolkitError } from '../../shared-public';\nimport type { ICloudAssemblySource } from '../types';\n\nexport interface ContextAwareCloudAssemblyProps {\n  /**\n   * AWS object (used by contextprovider)\n   * @deprecated context should be moved to the toolkit itself\n   */\n  readonly services: ToolkitServices;\n\n  /**\n   * Application context\n   */\n  readonly context: Context;\n\n  /**\n   * The file used to store application context in (relative to cwd).\n   *\n   * @default \"cdk.context.json\"\n   */\n  readonly contextFile?: string;\n\n  /**\n   * Enable context lookups.\n   *\n   * Producing a `cxapi.CloudAssembly` will fail if this is disabled and context lookups need to be performed.\n   *\n   * @default true\n   */\n  readonly lookups?: boolean;\n}\n\n/**\n * Represent the Cloud Executable and the synthesis we can do on it\n */\nexport class ContextAwareCloudAssembly implements ICloudAssemblySource {\n  private canLookup: boolean;\n  private context: Context;\n  private contextFile: string;\n  private ioHelper: IoHelper;\n\n  constructor(private readonly source: ICloudAssemblySource, private readonly props: ContextAwareCloudAssemblyProps) {\n    this.canLookup = props.lookups ?? true;\n    this.context = props.context;\n    this.contextFile = props.contextFile ?? PROJECT_CONTEXT; // @todo new feature not needed right now\n    this.ioHelper = props.services.ioHelper;\n  }\n\n  /**\n   * Produce a Cloud Assembly, i.e. a set of stacks\n   */\n  public async produce(): Promise<cxapi.CloudAssembly> {\n    // We may need to run the cloud assembly source multiple times in order to satisfy all missing context\n    // (When the source producer runs, it will tell us about context it wants to use\n    // but it missing. We'll then look up the context and run the executable again, and\n    // again, until it doesn't complain anymore or we've stopped making progress).\n    let previouslyMissingKeys: Set<string> | undefined;\n    while (true) {\n      const assembly = await this.source.produce();\n\n      if (assembly.manifest.missing && assembly.manifest.missing.length > 0) {\n        const missingKeysSet = missingContextKeys(assembly.manifest.missing);\n        const missingKeys = Array.from(missingKeysSet);\n\n        if (!this.canLookup) {\n          throw new ToolkitError(\n            'Context lookups have been disabled. '\n            + 'Make sure all necessary context is already in \\'cdk.context.json\\' by running \\'cdk synth\\' on a machine with sufficient AWS credentials and committing the result. '\n            + `Missing context keys: '${missingKeys.join(', ')}'`);\n        }\n\n        let tryLookup = true;\n        if (previouslyMissingKeys && equalSets(missingKeysSet, previouslyMissingKeys)) {\n          await this.ioHelper.notify(IO.CDK_ASSEMBLY_I0240.msg('Not making progress trying to resolve environmental context. Giving up.', { missingKeys }));\n          tryLookup = false;\n        }\n\n        previouslyMissingKeys = missingKeysSet;\n\n        if (tryLookup) {\n          await this.ioHelper.notify(IO.CDK_ASSEMBLY_I0241.msg('Some context information is missing. Fetching...', { missingKeys }));\n          await contextproviders.provideContextValues(\n            assembly.manifest.missing,\n            this.context,\n            this.props.services.sdkProvider,\n          );\n\n          // Cache the new context to disk\n          await this.ioHelper.notify(IO.CDK_ASSEMBLY_I0042.msg(`Writing updated context to ${this.contextFile}...`, {\n            contextFile: this.contextFile,\n            context: this.context.all,\n          }));\n          await this.context.save(this.contextFile);\n\n          // Execute again\n          continue;\n        }\n      }\n\n      return assembly;\n    }\n  }\n}\n\n/**\n * Return all keys of missing context items\n */\nfunction missingContextKeys(missing?: MissingContext[]): Set<string> {\n  return new Set((missing || []).map(m => m.key));\n}\n\n/**\n * Are two sets equal to each other\n */\nfunction equalSets<A>(a: Set<A>, b: Set<A>) {\n  if (a.size !== b.size) {\n    return false;\n  }\n  for (const x of a) {\n    if (!b.has(x)) {\n      return false;\n    }\n  }\n  return true;\n}\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-aware-source.js","sourceRoot":"","sources":["context-aware-source.ts"],"names":[],"mappings":"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","sourcesContent":["import type { MissingContext } from '@aws-cdk/cloud-assembly-schema';\nimport type * as cxapi from '@aws-cdk/cx-api';\nimport type { ToolkitServices } from '../../../toolkit/private';\nimport { type Context, contextproviders, PROJECT_CONTEXT } from '../../aws-cdk';\nimport { IO } from '../../io/private';\nimport type { IoHelper } from '../../shared-private';\nimport { ToolkitError } from '../../shared-public';\nimport type { ICloudAssemblySource } from '../types';\n\nexport interface ContextAwareCloudAssemblyProps {\n  /**\n   * AWS object (used by contextprovider)\n   * @deprecated context should be moved to the toolkit itself\n   */\n  readonly services: ToolkitServices;\n\n  /**\n   * Application context\n   */\n  readonly context: Context;\n\n  /**\n   * The file used to store application context in (relative to cwd).\n   *\n   * @default \"cdk.context.json\"\n   */\n  readonly contextFile?: string;\n\n  /**\n   * Enable context lookups.\n   *\n   * Producing a `cxapi.CloudAssembly` will fail if this is disabled and context lookups need to be performed.\n   *\n   * @default true\n   */\n  readonly lookups?: boolean;\n}\n\n/**\n * Represent the Cloud Executable and the synthesis we can do on it\n */\nexport class ContextAwareCloudAssembly implements ICloudAssemblySource {\n  private canLookup: boolean;\n  private context: Context;\n  private contextFile: string;\n  private ioHelper: IoHelper;\n\n  constructor(private readonly source: ICloudAssemblySource, private readonly props: ContextAwareCloudAssemblyProps) {\n    this.canLookup = props.lookups ?? true;\n    this.context = props.context;\n    this.contextFile = props.contextFile ?? PROJECT_CONTEXT; // @todo new feature not needed right now\n    this.ioHelper = props.services.ioHelper;\n  }\n\n  /**\n   * Produce a Cloud Assembly, i.e. a set of stacks\n   */\n  public async produce(): Promise<cxapi.CloudAssembly> {\n    // We may need to run the cloud assembly source multiple times in order to satisfy all missing context\n    // (When the source producer runs, it will tell us about context it wants to use\n    // but it missing. We'll then look up the context and run the executable again, and\n    // again, until it doesn't complain anymore or we've stopped making progress).\n    let previouslyMissingKeys: Set<string> | undefined;\n    while (true) {\n      const assembly = await this.source.produce();\n\n      if (assembly.manifest.missing && assembly.manifest.missing.length > 0) {\n        const missingKeysSet = missingContextKeys(assembly.manifest.missing);\n        const missingKeys = Array.from(missingKeysSet);\n\n        if (!this.canLookup) {\n          throw new ToolkitError(\n            'Context lookups have been disabled. '\n            + 'Make sure all necessary context is already in \\'cdk.context.json\\' by running \\'cdk synth\\' on a machine with sufficient AWS credentials and committing the result. '\n            + `Missing context keys: '${missingKeys.join(', ')}'`);\n        }\n\n        let tryLookup = true;\n        if (previouslyMissingKeys && equalSets(missingKeysSet, previouslyMissingKeys)) {\n          await this.ioHelper.notify(IO.CDK_ASSEMBLY_I0240.msg('Not making progress trying to resolve environmental context. Giving up.', { missingKeys }));\n          tryLookup = false;\n        }\n\n        previouslyMissingKeys = missingKeysSet;\n\n        if (tryLookup) {\n          await this.ioHelper.notify(IO.CDK_ASSEMBLY_I0241.msg('Some context information is missing. Fetching...', { missingKeys }));\n          await contextproviders.provideContextValues(\n            assembly.manifest.missing,\n            this.context,\n            this.props.services.sdkProvider,\n            this.ioHelper,\n          );\n\n          // Cache the new context to disk\n          await this.ioHelper.notify(IO.CDK_ASSEMBLY_I0042.msg(`Writing updated context to ${this.contextFile}...`, {\n            contextFile: this.contextFile,\n            context: this.context.all,\n          }));\n          await this.context.save(this.contextFile);\n\n          // Execute again\n          continue;\n        }\n      }\n\n      return assembly;\n    }\n  }\n}\n\n/**\n * Return all keys of missing context items\n */\nfunction missingContextKeys(missing?: MissingContext[]): Set<string> {\n  return new Set((missing || []).map(m => m.key));\n}\n\n/**\n * Are two sets equal to each other\n */\nfunction equalSets<A>(a: Set<A>, b: Set<A>) {\n  if (a.size !== b.size) {\n    return false;\n  }\n  for (const x of a) {\n    if (!b.has(x)) {\n      return false;\n    }\n  }\n  return true;\n}\n"]}
@@ -45,7 +45,7 @@ export declare function withContext<T>(inputContext: Context, env: Env, synthOpt
45
45
  *
46
46
  * @param assembly the assembly to check
47
47
  */
48
- export declare function checkContextOverflowSupport(assembly: cxapi.CloudAssembly, ioHost: IoHelper): Promise<void>;
48
+ export declare function checkContextOverflowSupport(assembly: cxapi.CloudAssembly, ioHelper: IoHelper): Promise<void>;
49
49
  /**
50
50
  * Safely create an assembly from a cloud assembly directory
51
51
  */
@@ -117,8 +117,8 @@ async function withContext(inputContext, env, synthOpts = {}, block) {
117
117
  *
118
118
  * @param assembly the assembly to check
119
119
  */
120
- async function checkContextOverflowSupport(assembly, ioHost) {
121
- const tree = (0, aws_cdk_1.loadTree)(assembly);
120
+ async function checkContextOverflowSupport(assembly, ioHelper) {
121
+ const tree = (0, aws_cdk_1.loadTree)(assembly, (msg) => void ioHelper.notify(private_1.IO.DEFAULT_ASSEMBLY_TRACE.msg(msg)));
122
122
  const frameworkDoesNotSupportContextOverflow = (0, aws_cdk_1.some)(tree, node => {
123
123
  const fqn = node.constructInfo?.fqn;
124
124
  const version = node.constructInfo?.version;
@@ -128,7 +128,7 @@ async function checkContextOverflowSupport(assembly, ioHost) {
128
128
  // We're dealing with an old version of the framework here. It is unaware of the temporary
129
129
  // file, which means that it will ignore the context overflow.
130
130
  if (frameworkDoesNotSupportContextOverflow) {
131
- await ioHost.notify(private_1.IO.CDK_ASSEMBLY_W0010.msg('Part of the context could not be sent to the application. Please update the AWS CDK library to the latest version.'));
131
+ await ioHelper.notify(private_1.IO.CDK_ASSEMBLY_W0010.msg('Part of the context could not be sent to the application. Please update the AWS CDK library to the latest version.'));
132
132
  }
133
133
  }
134
134
  /**
@@ -166,4 +166,4 @@ function synthOptsDefaults(synthOpts = {}) {
166
166
  ...synthOpts,
167
167
  }, true);
168
168
  }
169
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prepare-source.js","sourceRoot":"","sources":["prepare-source.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'node:os';\nimport * as path from 'node:path';\nimport { format } from 'node:util';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as fs from 'fs-extra';\nimport { lte } from 'semver';\nimport { prepareDefaultEnvironment as oldPrepare, prepareContext, spaceAvailableForContext, Settings, loadTree, some, versionNumber } from '../../../api/aws-cdk';\nimport { splitBySize } from '../../../private/util';\nimport type { ToolkitServices } from '../../../toolkit/private';\nimport { IO } from '../../io/private';\nimport type { IoHelper } from '../../shared-private';\nimport { ToolkitError } from '../../shared-public';\nimport type { AppSynthOptions, LoadAssemblyOptions } from '../source-builder';\n\nexport { guessExecutable } from '../../../api/aws-cdk';\n\ntype Env = { [key: string]: string };\ntype Context = { [key: string]: any };\n\n/**\n * Turn the given optional output directory into a fixed output directory\n */\nexport function determineOutputDirectory(outdir?: string) {\n  return outdir ?? fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), 'cdk.out'));\n}\n\n/**\n * If we don't have region/account defined in context, we fall back to the default SDK behavior\n * where region is retrieved from ~/.aws/config and account is based on default credentials provider\n * chain and then STS is queried.\n *\n * This is done opportunistically: for example, if we can't access STS for some reason or the region\n * is not configured, the context value will be 'null' and there could failures down the line. In\n * some cases, synthesis does not require region/account information at all, so that might be perfectly\n * fine in certain scenarios.\n *\n * @param context The context key/value bash.\n */\nexport async function prepareDefaultEnvironment(services: ToolkitServices, props: { outdir?: string } = {}): Promise<Env> {\n  const logFn = (msg: string, ...args: any) => services.ioHelper.notify(IO.CDK_ASSEMBLY_I0010.msg(format(msg, ...args)));\n  const env = await oldPrepare(services.sdkProvider, logFn);\n\n  if (props.outdir) {\n    env[cxapi.OUTDIR_ENV] = props.outdir;\n    await logFn('outdir:', props.outdir);\n  }\n\n  // CLI version information\n  env[cxapi.CLI_ASM_VERSION_ENV] = cxschema.Manifest.version();\n  env[cxapi.CLI_VERSION_ENV] = versionNumber();\n\n  await logFn('env:', env);\n  return env;\n}\n\n/**\n * Run code from a different working directory\n */\nexport async function changeDir<T>(block: () => Promise<T>, workingDir?: string) {\n  const originalWorkingDir = process.cwd();\n  try {\n    if (workingDir) {\n      process.chdir(workingDir);\n    }\n\n    return await block();\n  } finally {\n    if (workingDir) {\n      process.chdir(originalWorkingDir);\n    }\n  }\n}\n\n/**\n * Run code with additional environment variables\n */\nexport async function withEnv<T>(env: Env = {}, block: () => Promise<T>) {\n  const originalEnv = process.env;\n  try {\n    process.env = {\n      ...originalEnv,\n      ...env,\n    };\n\n    return await block();\n  } finally {\n    process.env = originalEnv;\n  }\n}\n\n/**\n * Run code with context setup inside the environment\n */\nexport async function withContext<T>(\n  inputContext: Context,\n  env: Env,\n  synthOpts: AppSynthOptions = {},\n  block: (env: Env, context: Context) => Promise<T>,\n) {\n  const context = await prepareContext(synthOptsDefaults(synthOpts), inputContext, env);\n  let contextOverflowLocation = null;\n\n  try {\n    const envVariableSizeLimit = os.platform() === 'win32' ? 32760 : 131072;\n    const [smallContext, overflow] = splitBySize(context, spaceAvailableForContext(env, envVariableSizeLimit));\n\n    // Store the safe part in the environment variable\n    env[cxapi.CONTEXT_ENV] = JSON.stringify(smallContext);\n\n    // If there was any overflow, write it to a temporary file\n    if (Object.keys(overflow ?? {}).length > 0) {\n      const contextDir = fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-context'));\n      contextOverflowLocation = path.join(contextDir, 'context-overflow.json');\n      fs.writeJSONSync(contextOverflowLocation, overflow);\n      env[cxapi.CONTEXT_OVERFLOW_LOCATION_ENV] = contextOverflowLocation;\n    }\n\n    // call the block code with new environment\n    return await block(env, context);\n  } finally {\n    if (contextOverflowLocation) {\n      fs.removeSync(path.dirname(contextOverflowLocation));\n    }\n  }\n}\n\n/**\n * Checks if a given assembly supports context overflow, warn otherwise.\n *\n * @param assembly the assembly to check\n */\nexport async function checkContextOverflowSupport(assembly: cxapi.CloudAssembly, ioHost: IoHelper): Promise<void> {\n  const tree = loadTree(assembly);\n  const frameworkDoesNotSupportContextOverflow = some(tree, node => {\n    const fqn = node.constructInfo?.fqn;\n    const version = node.constructInfo?.version;\n    return (fqn === 'aws-cdk-lib.App' && version != null && lte(version, '2.38.0')) // v2\n    || fqn === '@aws-cdk/core.App'; // v1\n  });\n\n  // We're dealing with an old version of the framework here. It is unaware of the temporary\n  // file, which means that it will ignore the context overflow.\n  if (frameworkDoesNotSupportContextOverflow) {\n    await ioHost.notify(IO.CDK_ASSEMBLY_W0010.msg('Part of the context could not be sent to the application. Please update the AWS CDK library to the latest version.'));\n  }\n}\n\n/**\n * Safely create an assembly from a cloud assembly directory\n */\nexport async function assemblyFromDirectory(assemblyDir: string, ioHost: IoHelper, loadOptions: LoadAssemblyOptions = {}) {\n  try {\n    const assembly = new cxapi.CloudAssembly(assemblyDir, {\n      skipVersionCheck: !(loadOptions.checkVersion ?? true),\n      skipEnumCheck: !(loadOptions.checkEnums ?? true),\n      // We sort as we deploy\n      topoSort: false,\n    });\n    await checkContextOverflowSupport(assembly, ioHost);\n    return assembly;\n  } catch (err: any) {\n    if (err.message.includes(cxschema.VERSION_MISMATCH)) {\n      // this means the CLI version is too old.\n      // we instruct the user to upgrade.\n      const message = 'This AWS CDK Toolkit is not compatible with the AWS CDK library used by your application. Please upgrade to the latest version.';\n      await ioHost.notify(IO.CDK_ASSEMBLY_E1111.msg(message, { error: err }));\n      throw new ToolkitError(`${message}\\n(${err.message}`);\n    }\n    throw err;\n  }\n}\n\nfunction synthOptsDefaults(synthOpts: AppSynthOptions = {}): Settings {\n  return new Settings({\n    debug: false,\n    pathMetadata: true,\n    versionReporting: true,\n    assetMetadata: true,\n    assetStaging: true,\n    ...synthOpts,\n  }, true);\n}\n"]}
169
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prepare-source.js","sourceRoot":"","sources":["prepare-source.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'node:os';\nimport * as path from 'node:path';\nimport { format } from 'node:util';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as fs from 'fs-extra';\nimport { lte } from 'semver';\nimport { prepareDefaultEnvironment as oldPrepare, prepareContext, spaceAvailableForContext, Settings, loadTree, some, versionNumber } from '../../../api/aws-cdk';\nimport { splitBySize } from '../../../private/util';\nimport type { ToolkitServices } from '../../../toolkit/private';\nimport { IO } from '../../io/private';\nimport type { IoHelper } from '../../shared-private';\nimport { ToolkitError } from '../../shared-public';\nimport type { AppSynthOptions, LoadAssemblyOptions } from '../source-builder';\n\nexport { guessExecutable } from '../../../api/aws-cdk';\n\ntype Env = { [key: string]: string };\ntype Context = { [key: string]: any };\n\n/**\n * Turn the given optional output directory into a fixed output directory\n */\nexport function determineOutputDirectory(outdir?: string) {\n  return outdir ?? fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), 'cdk.out'));\n}\n\n/**\n * If we don't have region/account defined in context, we fall back to the default SDK behavior\n * where region is retrieved from ~/.aws/config and account is based on default credentials provider\n * chain and then STS is queried.\n *\n * This is done opportunistically: for example, if we can't access STS for some reason or the region\n * is not configured, the context value will be 'null' and there could failures down the line. In\n * some cases, synthesis does not require region/account information at all, so that might be perfectly\n * fine in certain scenarios.\n *\n * @param context The context key/value bash.\n */\nexport async function prepareDefaultEnvironment(services: ToolkitServices, props: { outdir?: string } = {}): Promise<Env> {\n  const logFn = (msg: string, ...args: any) => services.ioHelper.notify(IO.CDK_ASSEMBLY_I0010.msg(format(msg, ...args)));\n  const env = await oldPrepare(services.sdkProvider, logFn);\n\n  if (props.outdir) {\n    env[cxapi.OUTDIR_ENV] = props.outdir;\n    await logFn('outdir:', props.outdir);\n  }\n\n  // CLI version information\n  env[cxapi.CLI_ASM_VERSION_ENV] = cxschema.Manifest.version();\n  env[cxapi.CLI_VERSION_ENV] = versionNumber();\n\n  await logFn('env:', env);\n  return env;\n}\n\n/**\n * Run code from a different working directory\n */\nexport async function changeDir<T>(block: () => Promise<T>, workingDir?: string) {\n  const originalWorkingDir = process.cwd();\n  try {\n    if (workingDir) {\n      process.chdir(workingDir);\n    }\n\n    return await block();\n  } finally {\n    if (workingDir) {\n      process.chdir(originalWorkingDir);\n    }\n  }\n}\n\n/**\n * Run code with additional environment variables\n */\nexport async function withEnv<T>(env: Env = {}, block: () => Promise<T>) {\n  const originalEnv = process.env;\n  try {\n    process.env = {\n      ...originalEnv,\n      ...env,\n    };\n\n    return await block();\n  } finally {\n    process.env = originalEnv;\n  }\n}\n\n/**\n * Run code with context setup inside the environment\n */\nexport async function withContext<T>(\n  inputContext: Context,\n  env: Env,\n  synthOpts: AppSynthOptions = {},\n  block: (env: Env, context: Context) => Promise<T>,\n) {\n  const context = await prepareContext(synthOptsDefaults(synthOpts), inputContext, env);\n  let contextOverflowLocation = null;\n\n  try {\n    const envVariableSizeLimit = os.platform() === 'win32' ? 32760 : 131072;\n    const [smallContext, overflow] = splitBySize(context, spaceAvailableForContext(env, envVariableSizeLimit));\n\n    // Store the safe part in the environment variable\n    env[cxapi.CONTEXT_ENV] = JSON.stringify(smallContext);\n\n    // If there was any overflow, write it to a temporary file\n    if (Object.keys(overflow ?? {}).length > 0) {\n      const contextDir = fs.mkdtempSync(path.join(os.tmpdir(), 'cdk-context'));\n      contextOverflowLocation = path.join(contextDir, 'context-overflow.json');\n      fs.writeJSONSync(contextOverflowLocation, overflow);\n      env[cxapi.CONTEXT_OVERFLOW_LOCATION_ENV] = contextOverflowLocation;\n    }\n\n    // call the block code with new environment\n    return await block(env, context);\n  } finally {\n    if (contextOverflowLocation) {\n      fs.removeSync(path.dirname(contextOverflowLocation));\n    }\n  }\n}\n\n/**\n * Checks if a given assembly supports context overflow, warn otherwise.\n *\n * @param assembly the assembly to check\n */\nexport async function checkContextOverflowSupport(assembly: cxapi.CloudAssembly, ioHelper: IoHelper): Promise<void> {\n  const tree = loadTree(assembly, (msg: string) => void ioHelper.notify(IO.DEFAULT_ASSEMBLY_TRACE.msg(msg)));\n  const frameworkDoesNotSupportContextOverflow = some(tree, node => {\n    const fqn = node.constructInfo?.fqn;\n    const version = node.constructInfo?.version;\n    return (fqn === 'aws-cdk-lib.App' && version != null && lte(version, '2.38.0')) // v2\n    || fqn === '@aws-cdk/core.App'; // v1\n  });\n\n  // We're dealing with an old version of the framework here. It is unaware of the temporary\n  // file, which means that it will ignore the context overflow.\n  if (frameworkDoesNotSupportContextOverflow) {\n    await ioHelper.notify(IO.CDK_ASSEMBLY_W0010.msg('Part of the context could not be sent to the application. Please update the AWS CDK library to the latest version.'));\n  }\n}\n\n/**\n * Safely create an assembly from a cloud assembly directory\n */\nexport async function assemblyFromDirectory(assemblyDir: string, ioHost: IoHelper, loadOptions: LoadAssemblyOptions = {}) {\n  try {\n    const assembly = new cxapi.CloudAssembly(assemblyDir, {\n      skipVersionCheck: !(loadOptions.checkVersion ?? true),\n      skipEnumCheck: !(loadOptions.checkEnums ?? true),\n      // We sort as we deploy\n      topoSort: false,\n    });\n    await checkContextOverflowSupport(assembly, ioHost);\n    return assembly;\n  } catch (err: any) {\n    if (err.message.includes(cxschema.VERSION_MISMATCH)) {\n      // this means the CLI version is too old.\n      // we instruct the user to upgrade.\n      const message = 'This AWS CDK Toolkit is not compatible with the AWS CDK library used by your application. Please upgrade to the latest version.';\n      await ioHost.notify(IO.CDK_ASSEMBLY_E1111.msg(message, { error: err }));\n      throw new ToolkitError(`${message}\\n(${err.message}`);\n    }\n    throw err;\n  }\n}\n\nfunction synthOptsDefaults(synthOpts: AppSynthOptions = {}): Settings {\n  return new Settings({\n    debug: false,\n    pathMetadata: true,\n    versionReporting: true,\n    assetMetadata: true,\n    assetStaging: true,\n    ...synthOpts,\n  }, true);\n}\n"]}
@@ -30,10 +30,13 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
30
30
  // lib/api/shared-private.ts
31
31
  var shared_private_exports = {};
32
32
  __export(shared_private_exports, {
33
+ FakeIoHost: () => FakeIoHost,
33
34
  IO: () => IO,
35
+ IoDefaultMessages: () => IoDefaultMessages,
34
36
  IoHelper: () => IoHelper,
35
37
  SPAN: () => SPAN,
36
38
  SpanMaker: () => SpanMaker,
39
+ TestIoHost: () => TestIoHost,
37
40
  asIoHelper: () => asIoHelper,
38
41
  confirm: () => confirm,
39
42
  debug: () => debug,
@@ -130,19 +133,20 @@ var SpanMaker = class {
130
133
  this.definition = definition;
131
134
  this.ioHelper = ioHelper;
132
135
  }
133
- async begin(first, second) {
136
+ async begin(a, b) {
134
137
  const spanId = uuid.v4();
135
138
  const startTime = (/* @__PURE__ */ new Date()).getTime();
136
139
  const notify = (msg) => {
137
140
  return this.ioHelper.notify(withSpanId(spanId, msg));
138
141
  };
139
- const startMsg = second ? first : "Starting %s ...";
140
- const startPayload = second ?? first;
142
+ const startInput = parseArgs(a, b);
143
+ const startMsg = startInput.message ?? `Starting ${this.definition.name} ...`;
144
+ const startPayload = startInput.payload;
141
145
  await notify(this.definition.start.msg(
142
- util.format(startMsg, this.definition.name),
146
+ startMsg,
143
147
  startPayload
144
148
  ));
145
- const timingMsg = "\n\u2728 %s time: %ds\n";
149
+ const timingMsgTemplate = "\n\u2728 %s time: %ds\n";
146
150
  const time = () => {
147
151
  const elapsedTime = (/* @__PURE__ */ new Date()).getTime() - startTime;
148
152
  return {
@@ -151,13 +155,7 @@ var SpanMaker = class {
151
155
  };
152
156
  };
153
157
  return {
154
- elapsedTime: async (msg) => {
155
- if (msg) {
156
- await notify({
157
- ...msg,
158
- data: msg.data
159
- });
160
- }
158
+ elapsedTime: async () => {
161
159
  return time();
162
160
  },
163
161
  notify: async (msg) => {
@@ -165,18 +163,19 @@ var SpanMaker = class {
165
163
  },
166
164
  timing: async (maker, message2) => {
167
165
  const duration = time();
168
- const endMsg = message2 ? message2 : timingMsg;
169
- await notify(maker.msg(util.format(endMsg, this.definition.name, duration.asSec), {
166
+ const timingMsg = message2 ? message2 : util.format(timingMsgTemplate, this.definition.name, duration.asSec);
167
+ await notify(maker.msg(timingMsg, {
170
168
  duration: duration.asMs
171
169
  }));
172
170
  return duration;
173
171
  },
174
- end: async (a, b) => {
172
+ end: async (x, y) => {
175
173
  const duration = time();
176
- const endMsg = b ? a : timingMsg;
177
- const endPayload = b ?? a;
174
+ const endInput = parseArgs(x, y);
175
+ const endMsg = endInput.message ?? util.format(timingMsgTemplate, this.definition.name, duration.asSec);
176
+ const endPayload = endInput.payload;
178
177
  await notify(this.definition.end.msg(
179
- util.format(endMsg, this.definition.name, duration.asSec),
178
+ endMsg,
180
179
  {
181
180
  duration: duration.asMs,
182
181
  ...endPayload
@@ -187,6 +186,15 @@ var SpanMaker = class {
187
186
  };
188
187
  }
189
188
  };
189
+ function parseArgs(first, second) {
190
+ const firstIsMessage = typeof first === "string";
191
+ const message2 = firstIsMessage || second ? first : void 0;
192
+ const payload = firstIsMessage || second ? second : first;
193
+ return {
194
+ message: message2,
195
+ payload
196
+ };
197
+ }
190
198
  function withSpanId(span, message2) {
191
199
  return {
192
200
  ...message2,
@@ -295,7 +303,7 @@ var confirm = (details) => request("info", {
295
303
 
296
304
  // ../tmp-toolkit-helpers/src/api/io/private/messages.ts
297
305
  var IO = {
298
- // Defaults
306
+ // Defaults (0000)
299
307
  DEFAULT_TOOLKIT_INFO: info({
300
308
  code: "CDK_TOOLKIT_I0000",
301
309
  description: "Default info messages emitted from the Toolkit"
@@ -308,7 +316,15 @@ var IO = {
308
316
  code: "CDK_TOOLKIT_W0000",
309
317
  description: "Default warning messages emitted from the Toolkit"
310
318
  }),
311
- // 1: Synth
319
+ DEFAULT_TOOLKIT_ERROR: error({
320
+ code: "CDK_TOOLKIT_E0000",
321
+ description: "Default error messages emitted from the Toolkit"
322
+ }),
323
+ DEFAULT_TOOLKIT_TRACE: trace({
324
+ code: "CDK_TOOLKIT_I0000",
325
+ description: "Default trace messages emitted from the Toolkit"
326
+ }),
327
+ // 1: Synth (1xxx)
312
328
  CDK_TOOLKIT_I1000: info({
313
329
  code: "CDK_TOOLKIT_I1000",
314
330
  description: "Provides synthesis times.",
@@ -329,7 +345,7 @@ var IO = {
329
345
  description: "Successfully deployed stacks",
330
346
  interface: "AssemblyData"
331
347
  }),
332
- // 2: List
348
+ // 2: List (2xxx)
333
349
  CDK_TOOLKIT_I2901: result({
334
350
  code: "CDK_TOOLKIT_I2901",
335
351
  description: "Provides details on the selected stacks and their dependencies",
@@ -338,10 +354,11 @@ var IO = {
338
354
  // 3: Import & Migrate
339
355
  CDK_TOOLKIT_E3900: error({
340
356
  code: "CDK_TOOLKIT_E3900",
341
- description: "Resource import failed"
357
+ description: "Resource import failed",
358
+ interface: "ErrorPayload"
342
359
  }),
343
- // 4: Diff
344
- // 5: Deploy & Watch
360
+ // 4: Diff (4xxx)
361
+ // 5: Deploy & Watch (5xxx)
345
362
  CDK_TOOLKIT_I5000: info({
346
363
  code: "CDK_TOOLKIT_I5000",
347
364
  description: "Provides deployment times",
@@ -354,7 +371,8 @@ var IO = {
354
371
  }),
355
372
  CDK_TOOLKIT_I5002: info({
356
373
  code: "CDK_TOOLKIT_I5002",
357
- description: "Provides time for resource migration"
374
+ description: "Provides time for resource migration",
375
+ interface: "Duration"
358
376
  }),
359
377
  CDK_TOOLKIT_W5021: warn({
360
378
  code: "CDK_TOOLKIT_W5021",
@@ -403,7 +421,7 @@ var IO = {
403
421
  description: "Stack deploy progress",
404
422
  interface: "StackDeployProgress"
405
423
  }),
406
- // Assets
424
+ // Assets (52xx)
407
425
  CDK_TOOLKIT_I5210: trace({
408
426
  code: "CDK_TOOLKIT_I5210",
409
427
  description: "Started building a specific asset",
@@ -424,7 +442,7 @@ var IO = {
424
442
  description: "Publishing the asset has completed",
425
443
  interface: "Duration"
426
444
  }),
427
- // Watch
445
+ // Watch (53xx)
428
446
  CDK_TOOLKIT_I5310: debug({
429
447
  code: "CDK_TOOLKIT_I5310",
430
448
  description: "The computed settings used for file watching",
@@ -453,7 +471,33 @@ var IO = {
453
471
  code: "CDK_TOOLKIT_I5315",
454
472
  description: "Queued watch deployment started"
455
473
  }),
456
- // Stack Monitor
474
+ // Hotswap (54xx)
475
+ CDK_TOOLKIT_I5400: trace({
476
+ code: "CDK_TOOLKIT_I5400",
477
+ description: "Attempting a hotswap deployment",
478
+ interface: "HotswapDeploymentAttempt"
479
+ }),
480
+ CDK_TOOLKIT_I5401: trace({
481
+ code: "CDK_TOOLKIT_I5401",
482
+ description: "Computed details for the hotswap deployment",
483
+ interface: "HotswapDeploymentDetails"
484
+ }),
485
+ CDK_TOOLKIT_I5402: info({
486
+ code: "CDK_TOOLKIT_I5402",
487
+ description: "A hotswappable change is processed as part of a hotswap deployment",
488
+ interface: "HotswappableChange"
489
+ }),
490
+ CDK_TOOLKIT_I5403: info({
491
+ code: "CDK_TOOLKIT_I5403",
492
+ description: "The hotswappable change has completed processing",
493
+ interface: "HotswappableChange"
494
+ }),
495
+ CDK_TOOLKIT_I5410: info({
496
+ code: "CDK_TOOLKIT_I5410",
497
+ description: "Hotswap deployment has ended, a full deployment might still follow if needed",
498
+ interface: "HotswapResult"
499
+ }),
500
+ // Stack Monitor (55xx)
457
501
  CDK_TOOLKIT_I5501: info({
458
502
  code: "CDK_TOOLKIT_I5501",
459
503
  description: "Stack Monitoring: Start monitoring of a single stack",
@@ -469,7 +513,7 @@ var IO = {
469
513
  description: "Stack Monitoring: Finished monitoring of a single stack",
470
514
  interface: "StackMonitoringControlEvent"
471
515
  }),
472
- // Success
516
+ // Success (59xx)
473
517
  CDK_TOOLKIT_I5900: result({
474
518
  code: "CDK_TOOLKIT_I5900",
475
519
  description: "Deployment results on success",
@@ -493,7 +537,7 @@ var IO = {
493
537
  description: "Stack Monitoring error",
494
538
  interface: "ErrorPayload"
495
539
  }),
496
- // 6: Rollback
540
+ // 6: Rollback (6xxx)
497
541
  CDK_TOOLKIT_I6000: info({
498
542
  code: "CDK_TOOLKIT_I6000",
499
543
  description: "Provides rollback times",
@@ -513,7 +557,7 @@ var IO = {
513
557
  description: "Rollback failed",
514
558
  interface: "ErrorPayload"
515
559
  }),
516
- // 7: Destroy
560
+ // 7: Destroy (7xxx)
517
561
  CDK_TOOLKIT_I7000: info({
518
562
  code: "CDK_TOOLKIT_I7000",
519
563
  description: "Provides destroy times",
@@ -553,7 +597,7 @@ var IO = {
553
597
  description: "Stack deletion failed",
554
598
  interface: "ErrorPayload"
555
599
  }),
556
- // 9: Bootstrap
600
+ // 9: Bootstrap (9xxx)
557
601
  CDK_TOOLKIT_I9000: info({
558
602
  code: "CDK_TOOLKIT_I9000",
559
603
  description: "Provides bootstrap times",
@@ -574,7 +618,32 @@ var IO = {
574
618
  description: "Bootstrap failed",
575
619
  interface: "ErrorPayload"
576
620
  }),
621
+ // Notices
622
+ CDK_TOOLKIT_I0100: info({
623
+ code: "CDK_TOOLKIT_I0100",
624
+ description: "Notices decoration (the header or footer of a list of notices)"
625
+ }),
626
+ CDK_TOOLKIT_W0101: warn({
627
+ code: "CDK_TOOLKIT_W0101",
628
+ description: "A notice that is marked as a warning"
629
+ }),
630
+ CDK_TOOLKIT_E0101: error({
631
+ code: "CDK_TOOLKIT_E0101",
632
+ description: "A notice that is marked as an error"
633
+ }),
634
+ CDK_TOOLKIT_I0101: info({
635
+ code: "CDK_TOOLKIT_I0101",
636
+ description: "A notice that is marked as informational"
637
+ }),
577
638
  // Assembly codes
639
+ DEFAULT_ASSEMBLY_TRACE: trace({
640
+ code: "CDK_ASSEMBLY_I0000",
641
+ description: "Default trace messages emitted from Cloud Assembly operations"
642
+ }),
643
+ DEFAULT_ASSEMBLY_DEBUG: debug({
644
+ code: "CDK_ASSEMBLY_I0000",
645
+ description: "Default debug messages emitted from Cloud Assembly operations"
646
+ }),
578
647
  CDK_ASSEMBLY_I0010: debug({
579
648
  code: "CDK_ASSEMBLY_I0010",
580
649
  description: "Generic environment preparation debug messages"
@@ -623,6 +692,16 @@ var IO = {
623
692
  code: "CDK_ASSEMBLY_I0150",
624
693
  description: "Indicates the use of a pre-synthesized cloud assembly directory"
625
694
  }),
695
+ CDK_ASSEMBLY_I0300: info({
696
+ code: "CDK_ASSEMBLY_I0300",
697
+ description: "An info message emitted by a Context Provider",
698
+ interface: "ContextProviderMessageSource"
699
+ }),
700
+ CDK_ASSEMBLY_I0301: debug({
701
+ code: "CDK_ASSEMBLY_I0301",
702
+ description: "A debug message emitted by a Context Provider",
703
+ interface: "ContextProviderMessageSource"
704
+ }),
626
705
  // Assembly Annotations
627
706
  CDK_ASSEMBLY_I9999: info({
628
707
  code: "CDK_ASSEMBLY_I9999",
@@ -690,14 +769,129 @@ var SPAN = {
690
769
  name: "Publish Asset",
691
770
  start: IO.CDK_TOOLKIT_I5220,
692
771
  end: IO.CDK_TOOLKIT_I5221
772
+ },
773
+ HOTSWAP: {
774
+ name: "hotswap-deployment",
775
+ start: IO.CDK_TOOLKIT_I5400,
776
+ end: IO.CDK_TOOLKIT_I5410
777
+ }
778
+ };
779
+
780
+ // ../tmp-toolkit-helpers/src/api/io/private/io-default-messages.ts
781
+ var util2 = __toESM(require("util"));
782
+ var IoDefaultMessages = class {
783
+ constructor(ioHelper) {
784
+ this.ioHelper = ioHelper;
785
+ }
786
+ notify(msg) {
787
+ return this.ioHelper.notify(msg);
788
+ }
789
+ requestResponse(msg) {
790
+ return this.ioHelper.requestResponse(msg);
791
+ }
792
+ error(input, ...args) {
793
+ this.emitMessage(IO.DEFAULT_TOOLKIT_ERROR, input, ...args);
794
+ }
795
+ warn(input, ...args) {
796
+ this.emitMessage(IO.DEFAULT_TOOLKIT_WARN, input, ...args);
797
+ }
798
+ warning(input, ...args) {
799
+ this.emitMessage(IO.DEFAULT_TOOLKIT_WARN, input, ...args);
800
+ }
801
+ info(input, ...args) {
802
+ this.emitMessage(IO.DEFAULT_TOOLKIT_INFO, input, ...args);
803
+ }
804
+ debug(input, ...args) {
805
+ this.emitMessage(IO.DEFAULT_TOOLKIT_DEBUG, input, ...args);
806
+ }
807
+ trace(input, ...args) {
808
+ this.emitMessage(IO.DEFAULT_TOOLKIT_TRACE, input, ...args);
809
+ }
810
+ result(input, ...args) {
811
+ const message2 = args.length > 0 ? util2.format(input, ...args) : input;
812
+ void this.ioHelper.notify({
813
+ time: /* @__PURE__ */ new Date(),
814
+ code: IO.DEFAULT_TOOLKIT_INFO.code,
815
+ level: "result",
816
+ message: message2,
817
+ data: void 0
818
+ });
819
+ }
820
+ emitMessage(maker, input, ...args) {
821
+ const message2 = args.length > 0 ? util2.format(input, ...args) : input;
822
+ void this.ioHelper.notify(maker.msg(message2));
823
+ }
824
+ };
825
+
826
+ // ../tmp-toolkit-helpers/src/api/io/private/testing/test-io-host.ts
827
+ var TestIoHost = class {
828
+ constructor(level = "info") {
829
+ this.level = level;
830
+ this.notifySpy = jest.fn();
831
+ this.requestSpy = jest.fn();
832
+ }
833
+ notifySpy;
834
+ requestSpy;
835
+ requireDeployApproval = "never" /* NEVER */;
836
+ async notify(msg) {
837
+ if (isMessageRelevantForLevel(msg, this.level)) {
838
+ this.notifySpy(msg);
839
+ }
840
+ }
841
+ async requestResponse(msg) {
842
+ if (isMessageRelevantForLevel(msg, this.level) && this.needsApproval(msg)) {
843
+ this.requestSpy(msg);
844
+ }
845
+ return msg.defaultResponse;
846
+ }
847
+ needsApproval(msg) {
848
+ if (!["CDK_TOOLKIT_I5060"].includes(msg.code)) {
849
+ return true;
850
+ }
851
+ switch (this.requireDeployApproval) {
852
+ case "never" /* NEVER */:
853
+ return false;
854
+ case "any-change" /* ANY_CHANGE */:
855
+ return true;
856
+ case "broadening" /* BROADENING */:
857
+ return msg.data?.permissionChangeType === "broadening";
858
+ default:
859
+ return true;
860
+ }
861
+ }
862
+ };
863
+
864
+ // ../tmp-toolkit-helpers/src/api/io/private/testing/fake-io-host.ts
865
+ var FakeIoHost = class {
866
+ messages = [];
867
+ requestResponse;
868
+ constructor() {
869
+ this.clear();
870
+ }
871
+ clear() {
872
+ this.messages.splice(0, this.messages.length);
873
+ this.requestResponse = jest.fn().mockRejectedValue(new Error("requestResponse not mocked"));
874
+ }
875
+ async notify(msg) {
876
+ this.messages.push(msg);
877
+ }
878
+ expectMessage(m) {
879
+ expect(this.messages).toContainEqual(expect.objectContaining({
880
+ ...m.level ? { level: m.level } : void 0,
881
+ // Can be a partial string as well
882
+ message: expect.stringContaining(m.containing)
883
+ }));
693
884
  }
694
885
  };
695
886
  // Annotate the CommonJS export names for ESM import in node:
696
887
  0 && (module.exports = {
888
+ FakeIoHost,
697
889
  IO,
890
+ IoDefaultMessages,
698
891
  IoHelper,
699
892
  SPAN,
700
893
  SpanMaker,
894
+ TestIoHost,
701
895
  asIoHelper,
702
896
  confirm,
703
897
  debug,