@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.
- package/README.md +2 -2
- package/build-info.json +2 -2
- package/db.json.gz +0 -0
- package/lib/actions/bootstrap/index.d.ts +9 -0
- package/lib/actions/bootstrap/index.js +1 -1
- package/lib/actions/deploy/index.d.ts +1 -17
- package/lib/actions/deploy/index.js +2 -20
- package/lib/api/aws-cdk.d.ts +2 -2
- package/lib/api/aws-cdk.js +2524 -2152
- package/lib/api/aws-cdk.js.map +4 -4
- package/lib/api/cloud-assembly/private/context-aware-source.js +2 -2
- package/lib/api/cloud-assembly/private/prepare-source.d.ts +1 -1
- package/lib/api/cloud-assembly/private/prepare-source.js +4 -4
- package/lib/api/shared-private.js +226 -32
- package/lib/api/shared-private.js.map +4 -4
- package/lib/api/shared-public.d.ts +374 -17
- package/lib/api/shared-public.js +39 -7
- package/lib/api/shared-public.js.map +4 -4
- package/lib/private/util.js +50 -4
- package/lib/private/util.js.map +3 -3
- package/lib/toolkit/toolkit.d.ts +2 -2
- package/lib/toolkit/toolkit.js +15 -3
- package/package.json +17 -18
|
@@ -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,
|
|
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,
|
|
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,
|
|
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
|
|
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(
|
|
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
|
|
140
|
-
const
|
|
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
|
-
|
|
146
|
+
startMsg,
|
|
143
147
|
startPayload
|
|
144
148
|
));
|
|
145
|
-
const
|
|
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 (
|
|
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
|
|
169
|
-
await notify(maker.msg(
|
|
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 (
|
|
172
|
+
end: async (x, y) => {
|
|
175
173
|
const duration = time();
|
|
176
|
-
const
|
|
177
|
-
const
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
//
|
|
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,
|