@aws-cdk/toolkit-lib 1.2.3 → 1.3.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/build-info.json +2 -2
- package/db.json.gz +0 -0
- package/lib/actions/diff/index.d.ts +7 -0
- package/lib/actions/diff/index.js +1 -1
- package/lib/actions/diff/private/helpers.js +7 -1
- package/lib/actions/refactor/index.d.ts +15 -34
- package/lib/actions/refactor/index.js +1 -54
- package/lib/actions/refactor/private/mapping-helpers.d.ts +11 -0
- package/lib/actions/refactor/private/mapping-helpers.js +44 -0
- package/lib/api/cloud-assembly/private/context-aware-source.js +3 -16
- package/lib/api/cloud-assembly/private/exec.js +12 -3
- package/lib/api/cloud-assembly/private/prepare-source.d.ts +29 -5
- package/lib/api/cloud-assembly/private/prepare-source.js +45 -20
- package/lib/api/cloud-assembly/source-builder.d.ts +11 -0
- package/lib/api/cloud-assembly/source-builder.js +11 -10
- package/lib/api/cloud-assembly/stack-collection.js +2 -1
- package/lib/api/diff/diff-formatter.d.ts +8 -0
- package/lib/api/diff/diff-formatter.js +29 -7
- package/lib/api/io/private/message-maker.d.ts +5 -5
- package/lib/api/io/private/messages.d.ts +1 -0
- package/lib/api/io/private/messages.js +6 -1
- package/lib/api/io/toolkit-action.d.ts +1 -1
- package/lib/api/io/toolkit-action.js +1 -1
- package/lib/api/refactoring/cloudformation.d.ts +1 -0
- package/lib/api/refactoring/cloudformation.js +6 -4
- package/lib/api/refactoring/context.d.ts +4 -5
- package/lib/api/refactoring/context.js +122 -52
- package/lib/api/refactoring/digest.d.ts +7 -12
- package/lib/api/refactoring/digest.js +22 -42
- package/lib/api/refactoring/graph.d.ts +6 -1
- package/lib/api/refactoring/graph.js +21 -8
- package/lib/api/refactoring/index.d.ts +13 -4
- package/lib/api/refactoring/index.js +38 -18
- package/lib/api/tree.js +1 -1
- package/lib/context-providers/cc-api-provider.js +23 -14
- package/lib/index_bg.wasm +0 -0
- package/lib/payloads/refactor.d.ts +1 -1
- package/lib/payloads/refactor.js +1 -1
- package/lib/payloads/stack-details.d.ts +4 -0
- package/lib/payloads/stack-details.js +1 -1
- package/lib/toolkit/toolkit.d.ts +6 -2
- package/lib/toolkit/toolkit.js +114 -79
- package/lib/toolkit/types.d.ts +7 -0
- package/lib/toolkit/types.js +1 -1
- package/lib/util/arrays.d.ts +1 -0
- package/lib/util/arrays.js +16 -1
- package/lib/util/sets.d.ts +5 -0
- package/lib/util/sets.js +18 -0
- package/package.json +9 -9
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.ExecutionEnvironment = void 0;
|
|
4
4
|
exports.writeContextToEnv = writeContextToEnv;
|
|
5
|
+
exports.frameworkSupportsContextOverflow = frameworkSupportsContextOverflow;
|
|
5
6
|
exports.assemblyFromDirectory = assemblyFromDirectory;
|
|
6
7
|
exports.settingsFromSynthOptions = settingsFromSynthOptions;
|
|
7
8
|
exports.parametersFromSynthOptions = parametersFromSynthOptions;
|
|
@@ -21,8 +22,6 @@ const settings_1 = require("../../settings");
|
|
|
21
22
|
const tree_1 = require("../../tree");
|
|
22
23
|
const environment_1 = require("../environment");
|
|
23
24
|
class ExecutionEnvironment {
|
|
24
|
-
outdir;
|
|
25
|
-
outDirIsTemporary;
|
|
26
25
|
/**
|
|
27
26
|
* Create an ExecutionEnvironment
|
|
28
27
|
*
|
|
@@ -35,33 +34,51 @@ class ExecutionEnvironment {
|
|
|
35
34
|
* If `markSuccessful()` is called, the writer lock is converted to a reader lock
|
|
36
35
|
* and temporary directories will not be cleaned up anymore.
|
|
37
36
|
*/
|
|
38
|
-
static async create(services,
|
|
39
|
-
let
|
|
40
|
-
let dir =
|
|
37
|
+
static async create(services, options) {
|
|
38
|
+
let outDirIsTemporary = false;
|
|
39
|
+
let dir = options.outdir;
|
|
41
40
|
if (!dir) {
|
|
42
|
-
|
|
41
|
+
outDirIsTemporary = true;
|
|
43
42
|
dir = fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), 'cdk.out'));
|
|
44
43
|
}
|
|
45
44
|
const lock = await new rwlock_1.RWLock(dir).acquireWrite();
|
|
46
|
-
|
|
45
|
+
const opts = {
|
|
46
|
+
outdir: dir,
|
|
47
|
+
resolveDefaultAppEnv: options.resolveDefaultAppEnv,
|
|
48
|
+
};
|
|
49
|
+
return new ExecutionEnvironment(services, opts, {
|
|
50
|
+
lock,
|
|
51
|
+
outDirIsTemporary,
|
|
52
|
+
});
|
|
47
53
|
}
|
|
54
|
+
/**
|
|
55
|
+
* Should the outdir be disposed of.
|
|
56
|
+
*/
|
|
57
|
+
get shouldDisposeOutDir() {
|
|
58
|
+
return this.shouldClean;
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* The directory the cloud assembly will be written to.
|
|
62
|
+
*/
|
|
63
|
+
outdir;
|
|
64
|
+
options;
|
|
48
65
|
ioHelper;
|
|
49
66
|
sdkProvider;
|
|
50
67
|
debugFn;
|
|
51
68
|
lock;
|
|
52
69
|
shouldClean;
|
|
53
|
-
constructor(services,
|
|
54
|
-
this.outdir = outdir;
|
|
55
|
-
this.outDirIsTemporary = outDirIsTemporary;
|
|
70
|
+
constructor(services, options, { lock, outDirIsTemporary }) {
|
|
56
71
|
this.ioHelper = services.ioHelper;
|
|
57
72
|
this.sdkProvider = services.sdkProvider;
|
|
58
73
|
this.debugFn = (msg) => this.ioHelper.defaults.debug(msg);
|
|
59
74
|
this.lock = lock;
|
|
60
75
|
this.shouldClean = outDirIsTemporary;
|
|
76
|
+
this.outdir = options.outdir;
|
|
77
|
+
this.options = options;
|
|
61
78
|
}
|
|
62
79
|
async [Symbol.asyncDispose]() {
|
|
63
80
|
await this.lock?.release();
|
|
64
|
-
if (this.
|
|
81
|
+
if (this.shouldDisposeOutDir) {
|
|
65
82
|
await fs.rm(this.outdir, { recursive: true, force: true });
|
|
66
83
|
}
|
|
67
84
|
}
|
|
@@ -125,7 +142,7 @@ class ExecutionEnvironment {
|
|
|
125
142
|
*/
|
|
126
143
|
async defaultEnvVars() {
|
|
127
144
|
const debugFn = (msg) => this.ioHelper.notify(private_1.IO.CDK_ASSEMBLY_I0010.msg(msg));
|
|
128
|
-
const env = await (0, environment_1.prepareDefaultEnvironment)(this.sdkProvider, debugFn);
|
|
145
|
+
const env = this.options.resolveDefaultAppEnv ? await (0, environment_1.prepareDefaultEnvironment)(this.sdkProvider, debugFn) : {};
|
|
129
146
|
env[cxapi.OUTDIR_ENV] = this.outdir;
|
|
130
147
|
await debugFn((0, node_util_1.format)('outdir:', this.outdir));
|
|
131
148
|
// CLI version information
|
|
@@ -200,18 +217,26 @@ function writeContextToEnv(env, context, completeness) {
|
|
|
200
217
|
async function checkContextOverflowSupport(assembly, ioHelper) {
|
|
201
218
|
const traceFn = (msg) => ioHelper.defaults.trace(msg);
|
|
202
219
|
const tree = await (0, tree_1.loadTree)(assembly, traceFn);
|
|
203
|
-
const frameworkDoesNotSupportContextOverflow = (0, tree_1.some)(tree, node => {
|
|
204
|
-
const fqn = node.constructInfo?.fqn;
|
|
205
|
-
const version = node.constructInfo?.version;
|
|
206
|
-
return (fqn === 'aws-cdk-lib.App' && version != null && (0, semver_1.lte)(version, '2.38.0')) // v2
|
|
207
|
-
|| fqn === '@aws-cdk/core.App'; // v1
|
|
208
|
-
});
|
|
209
220
|
// We're dealing with an old version of the framework here. It is unaware of the temporary
|
|
210
221
|
// file, which means that it will ignore the context overflow.
|
|
211
|
-
if (
|
|
222
|
+
if (!frameworkSupportsContextOverflow(tree)) {
|
|
212
223
|
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.'));
|
|
213
224
|
}
|
|
214
225
|
}
|
|
226
|
+
/**
|
|
227
|
+
* Checks if the framework supports context overflow
|
|
228
|
+
*/
|
|
229
|
+
function frameworkSupportsContextOverflow(tree) {
|
|
230
|
+
return !(0, tree_1.some)(tree, node => {
|
|
231
|
+
const fqn = node.constructInfo?.fqn;
|
|
232
|
+
const version = node.constructInfo?.version;
|
|
233
|
+
return (fqn === 'aws-cdk-lib.App' // v2 app
|
|
234
|
+
&& version !== '0.0.0' // ignore developer builds
|
|
235
|
+
&& version != null && (0, semver_1.lte)(version, '2.38.0') // last version not supporting large context
|
|
236
|
+
) // v2
|
|
237
|
+
|| fqn === '@aws-cdk/core.App'; // v1 app => not supported
|
|
238
|
+
});
|
|
239
|
+
}
|
|
215
240
|
/**
|
|
216
241
|
* Safely create an assembly from a cloud assembly directory
|
|
217
242
|
*/
|
|
@@ -256,4 +281,4 @@ function settingsFromSynthOptions(synthOpts = {}) {
|
|
|
256
281
|
function parametersFromSynthOptions(synthOptions) {
|
|
257
282
|
return (0, environment_1.synthParametersFromSettings)(settingsFromSynthOptions(synthOptions ?? {}));
|
|
258
283
|
}
|
|
259
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prepare-source.js","sourceRoot":"","sources":["prepare-source.ts"],"names":[],"mappings":"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","sourcesContent":["import '../../../private/dispose-polyfill';\nimport * 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 type { ToolkitServices } from '../../../toolkit/private';\nimport { ToolkitError } from '../../../toolkit/toolkit-error';\nimport { splitBySize, versionNumber } from '../../../util';\nimport type { SdkProvider } from '../../aws-auth/private';\nimport type { IoHelper } from '../../io/private';\nimport { IO } from '../../io/private';\nimport type { IReadLock, IWriteLock } from '../../rwlock';\nimport { RWLock } from '../../rwlock';\nimport { Settings } from '../../settings';\nimport { loadTree, some } from '../../tree';\nimport type { Context, Env } from '../environment';\nimport { prepareDefaultEnvironment, spaceAvailableForContext, guessExecutable, synthParametersFromSettings } from '../environment';\nimport type { AppSynthOptions, LoadAssemblyOptions } from '../source-builder';\n\nexport class ExecutionEnvironment implements AsyncDisposable {\n  /**\n   * Create an ExecutionEnvironment\n   *\n   * An ExecutionEnvironment holds a writer lock on the given directory which will\n   * be cleaned up when the object is disposed.\n   *\n   * A temporary directory will be created if none is supplied, which will be cleaned\n   * up when this object is disposed.\n   *\n   * If `markSuccessful()` is called, the writer lock is converted to a reader lock\n   * and temporary directories will not be cleaned up anymore.\n   */\n  public static async create(services: ToolkitServices, props: { outdir?: string } = {}) {\n    let tempDir = false;\n    let dir = props.outdir;\n    if (!dir) {\n      tempDir = true;\n      dir = fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), 'cdk.out'));\n    }\n\n    const lock = await new RWLock(dir).acquireWrite();\n    return new ExecutionEnvironment(services, dir, tempDir, lock);\n  }\n\n  private readonly ioHelper: IoHelper;\n  private readonly sdkProvider: SdkProvider;\n  private readonly debugFn: (msg: string) => Promise<void>;\n  private lock: IWriteLock | undefined;\n  private shouldClean: boolean;\n\n  private constructor(\n    services: ToolkitServices,\n    public readonly outdir: string,\n    public readonly outDirIsTemporary: boolean,\n    lock: IWriteLock,\n  ) {\n    this.ioHelper = services.ioHelper;\n    this.sdkProvider = services.sdkProvider;\n    this.debugFn = (msg: string) => this.ioHelper.defaults.debug(msg);\n    this.lock = lock;\n    this.shouldClean = outDirIsTemporary;\n  }\n\n  public async [Symbol.asyncDispose]() {\n    await this.lock?.release();\n\n    if (this.shouldClean) {\n      await fs.rm(this.outdir, { recursive: true, force: true });\n    }\n  }\n\n  /**\n   * Mark the execution as successful, which stops the writer lock from being released upon disposal\n   */\n  public async markSuccessful() {\n    if (!this.lock) {\n      throw new TypeError('Cannot mark successful more than once');\n    }\n    const readLock = await this.lock.convertToReaderLock();\n    this.lock = undefined;\n    this.shouldClean = false;\n    return { readLock };\n  }\n\n  /**\n   * Begin an execution in this environment\n   *\n   * This will acquire a write lock on the given environment. The write lock\n   * will be released automatically when the return object is disposed, unless it\n   * is converted to a reader lock.\n   */\n  public async beginExecution(): Promise<{ writeToReadLock(): Promise<IReadLock> } & AsyncDisposable> {\n    const lock = await new RWLock(this.outdir).acquireWrite();\n\n    let converted = false;\n    return {\n      async writeToReadLock() {\n        converted = true;\n        return lock.convertToReaderLock();\n      },\n      [Symbol.asyncDispose]: async () => {\n        // Release if not converted\n        if (!converted) {\n          await lock.release();\n        }\n      },\n    };\n  }\n\n  /**\n   * Guess the executable from the command-line argument\n   *\n   * Only do this if the file is NOT marked as executable. If it is,\n   * we'll defer to the shebang inside the file itself.\n   *\n   * If we're on Windows, we ALWAYS take the handler, since it's hard to\n   * verify if registry associations have or have not been set up for this\n   * file type, so we'll assume the worst and take control.\n   */\n  public guessExecutable(app: string) {\n    return guessExecutable(app, this.debugFn);\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  public async defaultEnvVars(): Promise<Env> {\n    const debugFn = (msg: string) => this.ioHelper.notify(IO.CDK_ASSEMBLY_I0010.msg(msg));\n    const env = await prepareDefaultEnvironment(this.sdkProvider, debugFn);\n\n    env[cxapi.OUTDIR_ENV] = this.outdir;\n    await debugFn(format('outdir:', this.outdir));\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 debugFn(format('env:', env));\n    return env;\n  }\n\n  /**\n   * Run code from a different working directory\n   */\n  public async 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/**\n * Serializes the given context to a set if environment variables environment variables\n *\n * Needs to know the size of the rest of the env because that's necessary to do\n * an overflow computation on Windows. This function will mutate the given\n * environment in-place. It should be called as the very last operation on the\n * environment, because afterwards is might be at the maximum size.\n *\n * This *would* have returned an `IAsyncDisposable` but that requires messing\n * with TypeScript type definitions to use it in aws-cdk, so returning an\n * explicit cleanup function is easier.\n *\n * `completeness` indicates whether this `env` block represents the full `env`\n * that will be passed to a subprocess, or whether it will be mixed into\n * `process.env` later.\n */\nexport function writeContextToEnv(env: Env, context: Context, completeness: 'add-process-env-later' | 'env-is-complete') {\n  let contextOverflowLocation = null;\n\n  // On Windows, all envvars together must fit in a 32k block (<https://devblogs.microsoft.com/oldnewthing/20100203-00>)\n  // On Linux, a single entry may not exceed 131k; but we're treating it as all together because that's safe\n  // and it's a single execution path for both platforms.\n  const envVariableSizeLimit = os.platform() === 'win32' ? 32760 : 131072;\n\n  const completeEnv = { ...completeness === 'add-process-env-later' ? process.env : {}, ...env };\n  const [smallContext, overflow] = splitBySize(context, spaceAvailableForContext(completeEnv, 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  return async () => {\n    if (contextOverflowLocation) {\n      await fs.promises.rm(path.dirname(contextOverflowLocation), { recursive: true, force: true });\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 */\nasync function checkContextOverflowSupport(assembly: cxapi.CloudAssembly, ioHelper: IoHelper): Promise<void> {\n  const traceFn = (msg: string) => ioHelper.defaults.trace(msg);\n  const tree = await loadTree(assembly, traceFn);\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, ioHelper: 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, ioHelper);\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 ioHelper.notify(IO.CDK_ASSEMBLY_E1111.msg(message, { error: err }));\n      throw new ToolkitError(`${message}\\n(${err.message}`);\n    }\n    throw err;\n  }\n}\n\nexport function settingsFromSynthOptions(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\n/**\n * Turn synthesis options into context/environment variables that will go to the CDK app\n *\n * These are parameters that control the synthesis operation, configurable by the user\n * from the outside of the app.\n */\nexport function parametersFromSynthOptions(synthOptions?: AppSynthOptions) {\n  return synthParametersFromSettings(settingsFromSynthOptions(synthOptions ?? {}));\n}\n"]}
|
|
284
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prepare-source.js","sourceRoot":"","sources":["prepare-source.ts"],"names":[],"mappings":"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","sourcesContent":["import '../../../private/dispose-polyfill';\nimport * 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 type { ToolkitServices } from '../../../toolkit/private';\nimport { ToolkitError } from '../../../toolkit/toolkit-error';\nimport { splitBySize, versionNumber } from '../../../util';\nimport type { SdkProvider } from '../../aws-auth/private';\nimport type { IoHelper } from '../../io/private';\nimport { IO } from '../../io/private';\nimport type { IReadLock, IWriteLock } from '../../rwlock';\nimport { RWLock } from '../../rwlock';\nimport { Settings } from '../../settings';\nimport type { ConstructTreeNode } from '../../tree';\nimport { loadTree, some } from '../../tree';\nimport type { Context, Env } from '../environment';\nimport { prepareDefaultEnvironment, spaceAvailableForContext, guessExecutable, synthParametersFromSettings } from '../environment';\nimport type { AppSynthOptions, LoadAssemblyOptions } from '../source-builder';\n\nexport interface ExecutionEnvironmentOptions {\n  /**\n   * The directory the cloud assembly will be written to.\n   *\n   * @default - use a temporary directory as output directory, this will be cleaned up when this object is disposed\n   */\n  readonly outdir?: string;\n\n  /**\n   * Resolve and add environment variables for the app's default environment.\n   *\n   * This will make a call to STS, which is not always desirable e.g. if the env is explicitly specified.\n   */\n  readonly resolveDefaultAppEnv: boolean;\n}\n\nexport class ExecutionEnvironment implements AsyncDisposable {\n  /**\n   * Create an ExecutionEnvironment\n   *\n   * An ExecutionEnvironment holds a writer lock on the given directory which will\n   * be cleaned up when the object is disposed.\n   *\n   * A temporary directory will be created if none is supplied, which will be cleaned\n   * up when this object is disposed.\n   *\n   * If `markSuccessful()` is called, the writer lock is converted to a reader lock\n   * and temporary directories will not be cleaned up anymore.\n   */\n  public static async create(services: ToolkitServices, options: ExecutionEnvironmentOptions) {\n    let outDirIsTemporary = false;\n    let dir = options.outdir;\n    if (!dir) {\n      outDirIsTemporary = true;\n      dir = fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), 'cdk.out'));\n    }\n    const lock = await new RWLock(dir).acquireWrite();\n\n    const opts = {\n      outdir: dir,\n      resolveDefaultAppEnv: options.resolveDefaultAppEnv,\n    };\n\n    return new ExecutionEnvironment(services, opts, {\n      lock,\n      outDirIsTemporary,\n    });\n  }\n\n  /**\n   * Should the outdir be disposed of.\n   */\n  public get shouldDisposeOutDir(): boolean {\n    return this.shouldClean;\n  }\n\n  /**\n   * The directory the cloud assembly will be written to.\n   */\n  public readonly outdir: string;\n\n  private readonly options: Required<ExecutionEnvironmentOptions>;\n  private readonly ioHelper: IoHelper;\n  private readonly sdkProvider: SdkProvider;\n  private readonly debugFn: (msg: string) => Promise<void>;\n  private lock: IWriteLock | undefined;\n  private shouldClean: boolean;\n\n  private constructor(\n    services: ToolkitServices,\n    options: Required<ExecutionEnvironmentOptions>,\n    { lock, outDirIsTemporary }: {\n      readonly outDirIsTemporary: boolean;\n      readonly lock: IWriteLock;\n    },\n  ) {\n    this.ioHelper = services.ioHelper;\n    this.sdkProvider = services.sdkProvider;\n    this.debugFn = (msg: string) => this.ioHelper.defaults.debug(msg);\n    this.lock = lock;\n    this.shouldClean = outDirIsTemporary;\n    this.outdir = options.outdir;\n    this.options = options;\n  }\n\n  public async [Symbol.asyncDispose]() {\n    await this.lock?.release();\n\n    if (this.shouldDisposeOutDir) {\n      await fs.rm(this.outdir, { recursive: true, force: true });\n    }\n  }\n\n  /**\n   * Mark the execution as successful, which stops the writer lock from being released upon disposal\n   */\n  public async markSuccessful() {\n    if (!this.lock) {\n      throw new TypeError('Cannot mark successful more than once');\n    }\n    const readLock = await this.lock.convertToReaderLock();\n    this.lock = undefined;\n    this.shouldClean = false;\n    return { readLock };\n  }\n\n  /**\n   * Begin an execution in this environment\n   *\n   * This will acquire a write lock on the given environment. The write lock\n   * will be released automatically when the return object is disposed, unless it\n   * is converted to a reader lock.\n   */\n  public async beginExecution(): Promise<{ writeToReadLock(): Promise<IReadLock> } & AsyncDisposable> {\n    const lock = await new RWLock(this.outdir).acquireWrite();\n\n    let converted = false;\n    return {\n      async writeToReadLock() {\n        converted = true;\n        return lock.convertToReaderLock();\n      },\n      [Symbol.asyncDispose]: async () => {\n        // Release if not converted\n        if (!converted) {\n          await lock.release();\n        }\n      },\n    };\n  }\n\n  /**\n   * Guess the executable from the command-line argument\n   *\n   * Only do this if the file is NOT marked as executable. If it is,\n   * we'll defer to the shebang inside the file itself.\n   *\n   * If we're on Windows, we ALWAYS take the handler, since it's hard to\n   * verify if registry associations have or have not been set up for this\n   * file type, so we'll assume the worst and take control.\n   */\n  public guessExecutable(app: string) {\n    return guessExecutable(app, this.debugFn);\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  public async defaultEnvVars(): Promise<Env> {\n    const debugFn = (msg: string) => this.ioHelper.notify(IO.CDK_ASSEMBLY_I0010.msg(msg));\n    const env = this.options.resolveDefaultAppEnv ? await prepareDefaultEnvironment(this.sdkProvider, debugFn) : {};\n\n    env[cxapi.OUTDIR_ENV] = this.outdir;\n    await debugFn(format('outdir:', this.outdir));\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 debugFn(format('env:', env));\n    return env;\n  }\n\n  /**\n   * Run code from a different working directory\n   */\n  public async 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/**\n * Serializes the given context to a set if environment variables environment variables\n *\n * Needs to know the size of the rest of the env because that's necessary to do\n * an overflow computation on Windows. This function will mutate the given\n * environment in-place. It should be called as the very last operation on the\n * environment, because afterwards is might be at the maximum size.\n *\n * This *would* have returned an `IAsyncDisposable` but that requires messing\n * with TypeScript type definitions to use it in aws-cdk, so returning an\n * explicit cleanup function is easier.\n *\n * `completeness` indicates whether this `env` block represents the full `env`\n * that will be passed to a subprocess, or whether it will be mixed into\n * `process.env` later.\n */\nexport function writeContextToEnv(env: Env, context: Context, completeness: 'add-process-env-later' | 'env-is-complete') {\n  let contextOverflowLocation = null;\n\n  // On Windows, all envvars together must fit in a 32k block (<https://devblogs.microsoft.com/oldnewthing/20100203-00>)\n  // On Linux, a single entry may not exceed 131k; but we're treating it as all together because that's safe\n  // and it's a single execution path for both platforms.\n  const envVariableSizeLimit = os.platform() === 'win32' ? 32760 : 131072;\n\n  const completeEnv = { ...completeness === 'add-process-env-later' ? process.env : {}, ...env };\n  const [smallContext, overflow] = splitBySize(context, spaceAvailableForContext(completeEnv, 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  return async () => {\n    if (contextOverflowLocation) {\n      await fs.promises.rm(path.dirname(contextOverflowLocation), { recursive: true, force: true });\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 */\nasync function checkContextOverflowSupport(assembly: cxapi.CloudAssembly, ioHelper: IoHelper): Promise<void> {\n  const traceFn = (msg: string) => ioHelper.defaults.trace(msg);\n  const tree = await loadTree(assembly, traceFn);\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 (!frameworkSupportsContextOverflow(tree)) {\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 * Checks if the framework supports context overflow\n */\nexport function frameworkSupportsContextOverflow(tree: ConstructTreeNode | undefined): boolean {\n  return !some(tree, node => {\n    const fqn = node.constructInfo?.fqn;\n    const version = node.constructInfo?.version;\n    return (\n      fqn === 'aws-cdk-lib.App' // v2 app\n      && version !== '0.0.0' // ignore developer builds\n      && version != null && lte(version, '2.38.0') // last version not supporting large context\n    ) // v2\n    || fqn === '@aws-cdk/core.App'; // v1 app => not supported\n  });\n}\n\n/**\n * Safely create an assembly from a cloud assembly directory\n */\nexport async function assemblyFromDirectory(assemblyDir: string, ioHelper: 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, ioHelper);\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 ioHelper.notify(IO.CDK_ASSEMBLY_E1111.msg(message, { error: err }));\n      throw new ToolkitError(`${message}\\n(${err.message}`);\n    }\n    throw err;\n  }\n}\n\nexport function settingsFromSynthOptions(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\n/**\n * Turn synthesis options into context/environment variables that will go to the CDK app\n *\n * These are parameters that control the synthesis operation, configurable by the user\n * from the outside of the app.\n */\nexport function parametersFromSynthOptions(synthOptions?: AppSynthOptions) {\n  return synthParametersFromSettings(settingsFromSynthOptions(synthOptions ?? {}));\n}\n"]}
|
|
@@ -92,6 +92,17 @@ export interface AssemblySourceProps {
|
|
|
92
92
|
* @default - `true` if `outdir` is not given, `false` otherwise
|
|
93
93
|
*/
|
|
94
94
|
readonly disposeOutdir?: boolean;
|
|
95
|
+
/**
|
|
96
|
+
* Resolve the current default environment an provide as environment variables to the app.
|
|
97
|
+
*
|
|
98
|
+
* This will make a (cached) call to STS to resolve the current account using
|
|
99
|
+
* base credentials. The behavior is not always desirable and can add
|
|
100
|
+
* unnecessary delays, e.g. when an app specifies an environment explicitly
|
|
101
|
+
* or when local actions are be performed without internet access.
|
|
102
|
+
*
|
|
103
|
+
* @default true
|
|
104
|
+
*/
|
|
105
|
+
readonly resolveDefaultEnvironment?: boolean;
|
|
95
106
|
}
|
|
96
107
|
/**
|
|
97
108
|
* Options for the `fromAssemblyBuilder` Assembly Source constructor
|
|
@@ -107,7 +107,10 @@ class CloudAssemblySourceBuilder {
|
|
|
107
107
|
produce: async () => {
|
|
108
108
|
const env_1 = { stack: [], error: void 0, hasError: false };
|
|
109
109
|
try {
|
|
110
|
-
const execution = __addDisposableResource(env_1, await prepare_source_1.ExecutionEnvironment.create(services, {
|
|
110
|
+
const execution = __addDisposableResource(env_1, await prepare_source_1.ExecutionEnvironment.create(services, {
|
|
111
|
+
outdir,
|
|
112
|
+
resolveDefaultAppEnv: props.resolveDefaultEnvironment ?? true,
|
|
113
|
+
}), true);
|
|
111
114
|
const synthParams = (0, prepare_source_1.parametersFromSynthOptions)(props.synthOptions);
|
|
112
115
|
const fullContext = {
|
|
113
116
|
...await contextStore.read(),
|
|
@@ -146,7 +149,7 @@ class CloudAssemblySourceBuilder {
|
|
|
146
149
|
? assembly
|
|
147
150
|
: await (0, prepare_source_1.assemblyFromDirectory)(assembly.directory, services.ioHelper, props.loadAssemblyOptions);
|
|
148
151
|
const success = await execution.markSuccessful();
|
|
149
|
-
const deleteOnDispose = props.disposeOutdir ?? execution.
|
|
152
|
+
const deleteOnDispose = props.disposeOutdir ?? execution.shouldDisposeOutDir;
|
|
150
153
|
return new readable_assembly_1.ReadableCloudAssembly(asm, success.readLock, { deleteOnDispose });
|
|
151
154
|
}
|
|
152
155
|
catch (e_1) {
|
|
@@ -242,18 +245,16 @@ class CloudAssemblySourceBuilder {
|
|
|
242
245
|
produce: async () => {
|
|
243
246
|
const env_2 = { stack: [], error: void 0, hasError: false };
|
|
244
247
|
try {
|
|
245
|
-
// @todo build
|
|
246
|
-
// const build = this.props.configuration.settings.get(['build']);
|
|
247
|
-
// if (build) {
|
|
248
|
-
// await execInChildProcess(build, { cwd: props.workingDirectory });
|
|
249
|
-
// }
|
|
250
248
|
try {
|
|
251
249
|
fs.mkdirpSync(outdir);
|
|
252
250
|
}
|
|
253
251
|
catch (e) {
|
|
254
252
|
throw new toolkit_error_1.ToolkitError(`Could not create output directory at '${outdir}' (${e.message}).`);
|
|
255
253
|
}
|
|
256
|
-
const execution = __addDisposableResource(env_2, await prepare_source_1.ExecutionEnvironment.create(services, {
|
|
254
|
+
const execution = __addDisposableResource(env_2, await prepare_source_1.ExecutionEnvironment.create(services, {
|
|
255
|
+
outdir,
|
|
256
|
+
resolveDefaultAppEnv: props.resolveDefaultEnvironment ?? true,
|
|
257
|
+
}), true);
|
|
257
258
|
const commandLine = await execution.guessExecutable(app);
|
|
258
259
|
const synthParams = (0, prepare_source_1.parametersFromSynthOptions)(props.synthOptions);
|
|
259
260
|
const fullContext = {
|
|
@@ -294,7 +295,7 @@ class CloudAssemblySourceBuilder {
|
|
|
294
295
|
}
|
|
295
296
|
const asm = await (0, prepare_source_1.assemblyFromDirectory)(outdir, services.ioHelper, props.loadAssemblyOptions);
|
|
296
297
|
const success = await execution.markSuccessful();
|
|
297
|
-
const deleteOnDispose = props.disposeOutdir ?? execution.
|
|
298
|
+
const deleteOnDispose = props.disposeOutdir ?? execution.shouldDisposeOutDir;
|
|
298
299
|
return new readable_assembly_1.ReadableCloudAssembly(asm, success.readLock, { deleteOnDispose });
|
|
299
300
|
}
|
|
300
301
|
catch (e_2) {
|
|
@@ -311,4 +312,4 @@ class CloudAssemblySourceBuilder {
|
|
|
311
312
|
}
|
|
312
313
|
}
|
|
313
314
|
exports.CloudAssemblySourceBuilder = CloudAssemblySourceBuilder;
|
|
314
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source-builder.js","sourceRoot":"","sources":["source-builder.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { format } from 'util';\nimport type * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as fs from 'fs-extra';\nimport { CdkAppMultiContext, MemoryContext, type IContextStore } from './context-store';\nimport { RWLock } from '../rwlock';\nimport { CachedCloudAssembly } from './cached-source';\nimport type { ContextAwareCloudAssemblyProps } from './private/context-aware-source';\nimport { ContextAwareCloudAssemblySource } from './private/context-aware-source';\nimport { execInChildProcess } from './private/exec';\nimport { ExecutionEnvironment, assemblyFromDirectory, parametersFromSynthOptions, writeContextToEnv } from './private/prepare-source';\nimport { ReadableCloudAssembly } from './private/readable-assembly';\nimport type { ICloudAssemblySource } from './types';\nimport type { ToolkitServices } from '../../toolkit/private';\nimport { ToolkitError, AssemblyError } from '../../toolkit/toolkit-error';\nimport { noUndefined } from '../../util';\nimport { IO } from '../io/private';\nimport { missingContextKeys, temporarilyWriteEnv } from './private/helpers';\n\n/**\n * Properties the builder function receives.\n */\nexport interface AssemblyBuilderProps {\n  /**\n   * The output directory into which to the builder app will emit synthesized artifacts.\n   */\n  readonly outdir?: string;\n\n  /**\n   * The context provided tp the builder app to synthesize the Cloud Assembly, including looked-up context.\n   */\n  readonly context?: { [key: string]: any };\n\n  /**\n   * Additional configuration that would normally be passed to a CDK app using environment variables\n   *\n   * This contains variables intended for the user portion of a CDK app (notably\n   * `CDK_DEFAULT_ACCOUNT` and `CDK_DEFAULT_REGION`), which you can freely read.\n   *\n   * It also contains variables intended for the CDK Toolkit to communicate with\n   * the internals of the construct library, like `CDK_DEBUG` and\n   * `CDK_CLI_ASM_VERSION`. Reading these latter variables is possible but not\n   * recommended, as their meaning may change without notice.\n   */\n  readonly env: Record<string, string>;\n}\n\n/**\n * A function that takes synthesis parameters and produces a Cloud Assembly\n *\n * Most typically, the properties passed here will be used to construct a\n * `cdk.App`, and the return value is the return value of `app.synth()`.\n */\nexport type AssemblyBuilder = (props: AssemblyBuilderProps) => Promise<cxschema.ICloudAssembly>;\n\n/**\n * Configuration for creating a CLI from an AWS CDK App directory\n */\nexport interface AssemblyDirectoryProps {\n  /**\n   * Options to configure loading of the assembly after it has been synthesized\n   */\n  readonly loadAssemblyOptions?: LoadAssemblyOptions;\n\n  /**\n   * Whether or not to fail if the synthesized assembly contains\n   * missing context\n   *\n   * @default true\n   */\n  readonly failOnMissingContext?: boolean;\n}\n\n/**\n * Configuration for creating a CLI from an AWS CDK App directory\n */\nexport interface AssemblySourceProps {\n  /**\n   * Emits the synthesized cloud assembly into the given directory\n   *\n   * @default \"cdk.out\"\n   */\n  readonly outdir?: string;\n\n  /**\n   * Perform context lookups.\n   *\n   * Synthesis fails if this is disabled and context lookups need to be performed.\n   *\n   * @default true\n   */\n  readonly lookups?: boolean;\n\n  /**\n   * A context store for this operation\n   *\n   * The context store will be used to source initial context values,\n   * and updated values will be stored here.\n   *\n   * @default - Depends on the operation\n   */\n  readonly contextStore?: IContextStore;\n\n  /**\n   * Options that are passed through the context to a CDK app on synth\n   */\n  readonly synthOptions?: AppSynthOptions;\n\n  /**\n   * Options to configure loading of the assembly after it has been synthesized\n   */\n  readonly loadAssemblyOptions?: LoadAssemblyOptions;\n\n  /**\n   * Delete the `outdir` when the assembly is disposed\n   *\n   * @default - `true` if `outdir` is not given, `false` otherwise\n   */\n  readonly disposeOutdir?: boolean;\n}\n\n/**\n * Options for the `fromAssemblyBuilder` Assembly Source constructor\n */\nexport interface FromAssemblyBuilderOptions extends AssemblySourceProps {\n  /**\n   * Mutate current process' environment variables to communicate with CDK app\n   *\n   * There are a number of environment variables the Toolkit uses to pass\n   * information to the CDK app.\n   *\n   * By default, these environment variables will be written to the current\n   * process' global shared environment variables before the builder is invoked,\n   * and you don't need to do anything else. However, because this mutates\n   * shared state it is not safe to run multiple builders concurrently.\n   *\n   * Set this to `false` to avoid mutating the shared environment. Instead,\n   * you will need to pass the `outdir` and `context` to the `App` constructor\n   * directly in your builder, and inspect the `env` map directly\n   * for information like the `CDK_DEFAULT_ACCOUNT` and `CDK_DEFAULT_REGION`.\n   *\n   * ```ts\n   * const cx = await toolkit.fromAssemblyBuilder(async (props) => {\n   *   // Important: pass on synthesis parameters\n   *   const app = new core.App({\n   *     outdir: props.outdir,\n   *     context: props.context,\n   *   });\n   *\n   *   new MyStack(app, 'MyStack', {\n   *     env: {\n   *       account: props.env.CDK_DEFAULT_ACCOUNT,\n   *       region: props.env.CDK_DEFAULT_REGION,\n   *     },\n   *   });\n   *\n   *   // ...\n   * }, {\n   *   clobberEnv: false,\n   * });\n   * ```\n   *\n   * @default true\n   */\n  readonly clobberEnv?: boolean;\n}\n\n/**\n * Options for the `fromCdkApp` Assembly Source constructor\n */\nexport interface FromCdkAppOptions extends AssemblySourceProps {\n  /**\n   * Execute the application in this working directory.\n   *\n   * @default - Current working directory\n   */\n  readonly workingDirectory?: string;\n\n  /**\n   * Additional environment variables\n   *\n   * These environment variables will be set in addition to the environment\n   * variables currently set in the process. A value of `undefined` will\n   * unset a particular environment variable.\n   */\n  readonly env?: Record<string, string | undefined>;\n}\n\n/**\n * Settings that are passed to a CDK app via the context\n */\nexport interface AppSynthOptions {\n  /**\n   * Debug the CDK app.\n   * Logs additional information during synthesis, such as creation stack traces of tokens.\n   * This also sets the `CDK_DEBUG` env variable and will slow down synthesis.\n   *\n   * @default false\n   */\n  readonly debug?: boolean;\n\n  /**\n   * Enables the embedding of the \"aws:cdk:path\" in CloudFormation template metadata.\n   *\n   * @default true\n   */\n  readonly pathMetadata?: boolean;\n\n  /**\n   * Enable the collection and reporting of version information.\n   *\n   * @default true\n   */\n  readonly versionReporting?: boolean;\n\n  /**\n   * Whe enabled, `aws:asset:xxx` metadata entries are added to the template.\n   *\n   * Disabling this can be useful in certain cases like integration tests.\n   *\n   * @default true\n   */\n  readonly assetMetadata?: boolean;\n\n  /**\n   * Enable asset staging.\n   *\n   * Disabling asset staging means that copyable assets will not be copied to the\n   * output directory and will be referenced with absolute paths.\n   *\n   * Not copied to the output directory: this is so users can iterate on the\n   * Lambda source and run SAM CLI without having to re-run CDK (note: we\n   * cannot achieve this for bundled assets, if assets are bundled they\n   * will have to re-run CDK CLI to re-bundle updated versions).\n   *\n   * Absolute path: SAM CLI expects `cwd`-relative paths in a resource's\n   * `aws:asset:path` metadata. In order to be predictable, we will always output\n   * absolute paths.\n   *\n   * @default true\n   */\n  readonly assetStaging?: boolean;\n\n  /**\n   * Select which stacks should have asset bundling enabled\n   *\n   * @default [\"**\"] - all stacks\n   */\n  readonly bundlingForStacks?: string;\n}\n\n/**\n * Options to configure loading of the assembly after it has been synthesized\n */\nexport interface LoadAssemblyOptions {\n  /**\n   * Check the Toolkit supports the Cloud Assembly Schema version\n   *\n   * When disabled, allows to Toolkit to read a newer cloud assembly than the CX API is designed\n   * to support. Your application may not be aware of all features that in use in the Cloud Assembly.\n   *\n   * @default true\n   */\n  readonly checkVersion?: boolean;\n\n  /**\n   * Validate enums to only have known values\n   *\n   * When disabled, the Toolkit may read enum values it doesn't know about yet.\n   * You will have to make sure to always check the values of enums you encounter in the manifest.\n   *\n   * @default true\n   */\n  readonly checkEnums?: boolean;\n}\n\nexport abstract class CloudAssemblySourceBuilder {\n  /**\n   * Helper to provide the CloudAssemblySourceBuilder with required toolkit services\n   * @internal\n   */\n  protected abstract sourceBuilderServices(): Promise<ToolkitServices>;\n\n  /**\n   * Create a Cloud Assembly from a Cloud Assembly builder function.\n   *\n   * ## Outdir\n   *\n   * If no output directory is given, it will synthesize into a temporary system\n   * directory. The temporary directory will be cleaned up, unless\n   * `disposeOutdir: false`.\n   *\n   * A write lock will be acquired on the output directory for the duration of\n   * the CDK app synthesis (which means that no two apps can synthesize at the\n   * same time), and after synthesis a read lock will be acquired on the\n   * directory. This means that while the CloudAssembly is being used, no CDK\n   * app synthesis can take place into that directory.\n   *\n   * ## Context\n   *\n   * If no `contextStore` is given, a `MemoryContext` will be used. This means\n   * no provider lookups will be persisted anywhere by default. Use a different\n   * type of context store if you want persistence between synth operations.\n   *\n   * @param builder - the builder function\n   * @param props - additional configuration properties\n   * @returns the CloudAssembly source\n   */\n  public async fromAssemblyBuilder(\n    builder: AssemblyBuilder,\n    props: FromAssemblyBuilderOptions = {},\n  ): Promise<ICloudAssemblySource> {\n    const services = await this.sourceBuilderServices();\n    const contextStore = props.contextStore ?? new MemoryContext();\n    const contextAssemblyProps: ContextAwareCloudAssemblyProps = {\n      services,\n      contextStore,\n      lookups: props.lookups,\n    };\n\n    const outdir = props.outdir ? path.resolve(props.outdir) : undefined;\n\n    return new ContextAwareCloudAssemblySource(\n      {\n        produce: async () => {\n          await using execution = await ExecutionEnvironment.create(services, { outdir });\n\n          const synthParams = parametersFromSynthOptions(props.synthOptions);\n\n          const fullContext = {\n            ...await contextStore.read(),\n            ...synthParams.context,\n          };\n\n          await services.ioHelper.defaults.debug(format('context:', fullContext));\n\n          const env = noUndefined({\n            // Versioning, outdir, default account and region\n            ...await execution.defaultEnvVars(),\n            // Environment variables derived from settings\n            ...synthParams.env,\n          });\n\n          const cleanupContextTemp = writeContextToEnv(env, fullContext, 'env-is-complete');\n          using _cleanupEnv = (props.clobberEnv ?? true) ? temporarilyWriteEnv(env) : undefined;\n          let assembly;\n          try {\n            assembly = await builder({\n              outdir: execution.outdir,\n              context: fullContext,\n              env,\n            });\n          } catch (error: unknown) {\n            // re-throw toolkit errors unchanged\n            if (ToolkitError.isToolkitError(error)) {\n              throw error;\n            }\n            // otherwise, wrap into an assembly error\n            throw AssemblyError.withCause('Assembly builder failed', error);\n          } finally {\n            await cleanupContextTemp();\n          }\n\n          // Convert what we got to the definitely correct type we're expecting, a cxapi.CloudAssembly\n          const asm = cxapi.CloudAssembly.isCloudAssembly(assembly)\n            ? assembly\n            : await assemblyFromDirectory(assembly.directory, services.ioHelper, props.loadAssemblyOptions);\n\n          const success = await execution.markSuccessful();\n          const deleteOnDispose = props.disposeOutdir ?? execution.outDirIsTemporary;\n          return new ReadableCloudAssembly(asm, success.readLock, { deleteOnDispose });\n        },\n      },\n      contextAssemblyProps,\n    );\n  }\n\n  /**\n   * Creates a Cloud Assembly from an existing assembly directory.\n   *\n   * A read lock will be acquired for the directory. This means that while\n   * the CloudAssembly is being used, no CDK app synthesis can take place into\n   * that directory.\n   *\n   * @param directory - directory the directory of a already produced Cloud Assembly.\n   * @returns the CloudAssembly source\n   */\n  public async fromAssemblyDirectory(directory: string, props: AssemblyDirectoryProps = {}): Promise<ICloudAssemblySource> {\n    const services: ToolkitServices = await this.sourceBuilderServices();\n\n    return {\n      async produce() {\n        await services.ioHelper.notify(IO.CDK_ASSEMBLY_I0150.msg('--app points to a cloud assembly, so we bypass synth'));\n        const readLock = await new RWLock(directory).acquireRead();\n        try {\n          const asm = await assemblyFromDirectory(directory, services.ioHelper, props.loadAssemblyOptions);\n          const assembly = new ReadableCloudAssembly(asm, readLock, { deleteOnDispose: false });\n          if (assembly.cloudAssembly.manifest.missing && assembly.cloudAssembly.manifest.missing.length > 0) {\n            if (props.failOnMissingContext ?? true) {\n              const missingKeysSet = missingContextKeys(assembly.cloudAssembly.manifest.missing);\n              const missingKeys = Array.from(missingKeysSet);\n              throw AssemblyError.withCause(\n                'Assembly contains missing context. ' +\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                'Error producing assembly',\n              );\n            }\n          }\n          return new CachedCloudAssembly(assembly);\n        } catch (e) {\n          await readLock.release();\n          throw e;\n        }\n      },\n    };\n  }\n  /**\n   * Use a directory containing an AWS CDK app as source.\n   *\n   * The subprocess will execute in `workingDirectory`, which defaults to\n   * the current process' working directory if not given.\n   *\n   * ## Outdir\n   *\n   * If an output directory is supplied, relative paths are evaluated with\n   * respect to the current process' working directory. If an output directory\n   * is not supplied, the default is a `cdk.out` directory underneath\n   * `workingDirectory`. The output directory will not be cleaned up unless\n   * `disposeOutdir: true`.\n   *\n   * A write lock will be acquired on the output directory for the duration of\n   * the CDK app synthesis (which means that no two apps can synthesize at the\n   * same time), and after synthesis a read lock will be acquired on the\n   * directory.  This means that while the CloudAssembly is being used, no CDK\n   * app synthesis can take place into that directory.\n   *\n   * ## Context\n   *\n   * If no `contextStore` is given, a `CdkAppMultiContext` will be used, initialized\n   * to the app's `workingDirectory`. This means that context will be loaded from\n   * all the CDK's default context sources, and updates will be written to\n   * `cdk.context.json`.\n   *\n   * @param props - additional configuration properties\n   * @returns the CloudAssembly source\n   */\n  public async fromCdkApp(app: string, props: FromCdkAppOptions = {}): Promise<ICloudAssemblySource> {\n    const services: ToolkitServices = await this.sourceBuilderServices();\n    const workingDirectory = props.workingDirectory ?? process.cwd();\n    const outdir = props.outdir ? path.resolve(props.outdir) : path.resolve(workingDirectory, 'cdk.out');\n\n    const contextStore = props.contextStore ?? new CdkAppMultiContext(workingDirectory);\n\n    const contextAssemblyProps: ContextAwareCloudAssemblyProps = {\n      services,\n      contextStore,\n      lookups: props.lookups,\n    };\n\n    return new ContextAwareCloudAssemblySource(\n      {\n        produce: async () => {\n          // @todo build\n          // const build = this.props.configuration.settings.get(['build']);\n          // if (build) {\n          //   await execInChildProcess(build, { cwd: props.workingDirectory });\n          // }\n\n          try {\n            fs.mkdirpSync(outdir);\n          } catch (e: any) {\n            throw new ToolkitError(`Could not create output directory at '${outdir}' (${e.message}).`);\n          }\n\n          await using execution = await ExecutionEnvironment.create(services, { outdir });\n\n          const commandLine = await execution.guessExecutable(app);\n\n          const synthParams = parametersFromSynthOptions(props.synthOptions);\n\n          const fullContext = {\n            ...await contextStore.read(),\n            ...synthParams.context,\n          };\n\n          await services.ioHelper.defaults.debug(format('context:', fullContext));\n\n          const env = noUndefined({\n            // Need to start with full env of `writeContextToEnv` will not be able to do the size\n            // calculation correctly.\n            ...process.env,\n            // User gave us something\n            ...props.env,\n            // Versioning, outdir, default account and region\n            ...await execution.defaultEnvVars(),\n            // Environment variables derived from settings\n            ...synthParams.env,\n          });\n          const cleanupTemp = writeContextToEnv(env, fullContext, 'env-is-complete');\n          try {\n            await execInChildProcess(commandLine.join(' '), {\n              eventPublisher: async (type, line) => {\n                switch (type) {\n                  case 'data_stdout':\n                    await services.ioHelper.notify(IO.CDK_ASSEMBLY_I1001.msg(line));\n                    break;\n                  case 'data_stderr':\n                    await services.ioHelper.notify(IO.CDK_ASSEMBLY_E1002.msg(line));\n                    break;\n                }\n              },\n              env,\n              cwd: workingDirectory,\n            });\n          } finally {\n            await cleanupTemp();\n          }\n\n          const asm = await assemblyFromDirectory(outdir, services.ioHelper, props.loadAssemblyOptions);\n\n          const success = await execution.markSuccessful();\n          const deleteOnDispose = props.disposeOutdir ?? execution.outDirIsTemporary;\n          return new ReadableCloudAssembly(asm, success.readLock, { deleteOnDispose });\n        },\n      },\n      contextAssemblyProps,\n    );\n  }\n}\n\n"]}
|
|
315
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source-builder.js","sourceRoot":"","sources":["source-builder.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { format } from 'util';\nimport type * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as fs from 'fs-extra';\nimport { CdkAppMultiContext, MemoryContext, type IContextStore } from './context-store';\nimport { RWLock } from '../rwlock';\nimport { CachedCloudAssembly } from './cached-source';\nimport type { ContextAwareCloudAssemblyProps } from './private/context-aware-source';\nimport { ContextAwareCloudAssemblySource } from './private/context-aware-source';\nimport { execInChildProcess } from './private/exec';\nimport { ExecutionEnvironment, assemblyFromDirectory, parametersFromSynthOptions, writeContextToEnv } from './private/prepare-source';\nimport { ReadableCloudAssembly } from './private/readable-assembly';\nimport type { ICloudAssemblySource } from './types';\nimport type { ToolkitServices } from '../../toolkit/private';\nimport { ToolkitError, AssemblyError } from '../../toolkit/toolkit-error';\nimport { noUndefined } from '../../util';\nimport { IO } from '../io/private';\nimport { missingContextKeys, temporarilyWriteEnv } from './private/helpers';\n\n/**\n * Properties the builder function receives.\n */\nexport interface AssemblyBuilderProps {\n  /**\n   * The output directory into which to the builder app will emit synthesized artifacts.\n   */\n  readonly outdir?: string;\n\n  /**\n   * The context provided tp the builder app to synthesize the Cloud Assembly, including looked-up context.\n   */\n  readonly context?: { [key: string]: any };\n\n  /**\n   * Additional configuration that would normally be passed to a CDK app using environment variables\n   *\n   * This contains variables intended for the user portion of a CDK app (notably\n   * `CDK_DEFAULT_ACCOUNT` and `CDK_DEFAULT_REGION`), which you can freely read.\n   *\n   * It also contains variables intended for the CDK Toolkit to communicate with\n   * the internals of the construct library, like `CDK_DEBUG` and\n   * `CDK_CLI_ASM_VERSION`. Reading these latter variables is possible but not\n   * recommended, as their meaning may change without notice.\n   */\n  readonly env: Record<string, string>;\n}\n\n/**\n * A function that takes synthesis parameters and produces a Cloud Assembly\n *\n * Most typically, the properties passed here will be used to construct a\n * `cdk.App`, and the return value is the return value of `app.synth()`.\n */\nexport type AssemblyBuilder = (props: AssemblyBuilderProps) => Promise<cxschema.ICloudAssembly>;\n\n/**\n * Configuration for creating a CLI from an AWS CDK App directory\n */\nexport interface AssemblyDirectoryProps {\n  /**\n   * Options to configure loading of the assembly after it has been synthesized\n   */\n  readonly loadAssemblyOptions?: LoadAssemblyOptions;\n\n  /**\n   * Whether or not to fail if the synthesized assembly contains\n   * missing context\n   *\n   * @default true\n   */\n  readonly failOnMissingContext?: boolean;\n}\n\n/**\n * Configuration for creating a CLI from an AWS CDK App directory\n */\nexport interface AssemblySourceProps {\n  /**\n   * Emits the synthesized cloud assembly into the given directory\n   *\n   * @default \"cdk.out\"\n   */\n  readonly outdir?: string;\n\n  /**\n   * Perform context lookups.\n   *\n   * Synthesis fails if this is disabled and context lookups need to be performed.\n   *\n   * @default true\n   */\n  readonly lookups?: boolean;\n\n  /**\n   * A context store for this operation\n   *\n   * The context store will be used to source initial context values,\n   * and updated values will be stored here.\n   *\n   * @default - Depends on the operation\n   */\n  readonly contextStore?: IContextStore;\n\n  /**\n   * Options that are passed through the context to a CDK app on synth\n   */\n  readonly synthOptions?: AppSynthOptions;\n\n  /**\n   * Options to configure loading of the assembly after it has been synthesized\n   */\n  readonly loadAssemblyOptions?: LoadAssemblyOptions;\n\n  /**\n   * Delete the `outdir` when the assembly is disposed\n   *\n   * @default - `true` if `outdir` is not given, `false` otherwise\n   */\n  readonly disposeOutdir?: boolean;\n\n  /**\n   * Resolve the current default environment an provide as environment variables to the app.\n   *\n   * This will make a (cached) call to STS to resolve the current account using\n   * base credentials. The behavior is not always desirable and can add\n   * unnecessary delays, e.g. when an app specifies an environment explicitly\n   * or when local actions are be performed without internet access.\n   *\n   * @default true\n   */\n  readonly resolveDefaultEnvironment?: boolean;\n}\n\n/**\n * Options for the `fromAssemblyBuilder` Assembly Source constructor\n */\nexport interface FromAssemblyBuilderOptions extends AssemblySourceProps {\n  /**\n   * Mutate current process' environment variables to communicate with CDK app\n   *\n   * There are a number of environment variables the Toolkit uses to pass\n   * information to the CDK app.\n   *\n   * By default, these environment variables will be written to the current\n   * process' global shared environment variables before the builder is invoked,\n   * and you don't need to do anything else. However, because this mutates\n   * shared state it is not safe to run multiple builders concurrently.\n   *\n   * Set this to `false` to avoid mutating the shared environment. Instead,\n   * you will need to pass the `outdir` and `context` to the `App` constructor\n   * directly in your builder, and inspect the `env` map directly\n   * for information like the `CDK_DEFAULT_ACCOUNT` and `CDK_DEFAULT_REGION`.\n   *\n   * ```ts\n   * const cx = await toolkit.fromAssemblyBuilder(async (props) => {\n   *   // Important: pass on synthesis parameters\n   *   const app = new core.App({\n   *     outdir: props.outdir,\n   *     context: props.context,\n   *   });\n   *\n   *   new MyStack(app, 'MyStack', {\n   *     env: {\n   *       account: props.env.CDK_DEFAULT_ACCOUNT,\n   *       region: props.env.CDK_DEFAULT_REGION,\n   *     },\n   *   });\n   *\n   *   // ...\n   * }, {\n   *   clobberEnv: false,\n   * });\n   * ```\n   *\n   * @default true\n   */\n  readonly clobberEnv?: boolean;\n}\n\n/**\n * Options for the `fromCdkApp` Assembly Source constructor\n */\nexport interface FromCdkAppOptions extends AssemblySourceProps {\n  /**\n   * Execute the application in this working directory.\n   *\n   * @default - Current working directory\n   */\n  readonly workingDirectory?: string;\n\n  /**\n   * Additional environment variables\n   *\n   * These environment variables will be set in addition to the environment\n   * variables currently set in the process. A value of `undefined` will\n   * unset a particular environment variable.\n   */\n  readonly env?: Record<string, string | undefined>;\n}\n\n/**\n * Settings that are passed to a CDK app via the context\n */\nexport interface AppSynthOptions {\n  /**\n   * Debug the CDK app.\n   * Logs additional information during synthesis, such as creation stack traces of tokens.\n   * This also sets the `CDK_DEBUG` env variable and will slow down synthesis.\n   *\n   * @default false\n   */\n  readonly debug?: boolean;\n\n  /**\n   * Enables the embedding of the \"aws:cdk:path\" in CloudFormation template metadata.\n   *\n   * @default true\n   */\n  readonly pathMetadata?: boolean;\n\n  /**\n   * Enable the collection and reporting of version information.\n   *\n   * @default true\n   */\n  readonly versionReporting?: boolean;\n\n  /**\n   * Whe enabled, `aws:asset:xxx` metadata entries are added to the template.\n   *\n   * Disabling this can be useful in certain cases like integration tests.\n   *\n   * @default true\n   */\n  readonly assetMetadata?: boolean;\n\n  /**\n   * Enable asset staging.\n   *\n   * Disabling asset staging means that copyable assets will not be copied to the\n   * output directory and will be referenced with absolute paths.\n   *\n   * Not copied to the output directory: this is so users can iterate on the\n   * Lambda source and run SAM CLI without having to re-run CDK (note: we\n   * cannot achieve this for bundled assets, if assets are bundled they\n   * will have to re-run CDK CLI to re-bundle updated versions).\n   *\n   * Absolute path: SAM CLI expects `cwd`-relative paths in a resource's\n   * `aws:asset:path` metadata. In order to be predictable, we will always output\n   * absolute paths.\n   *\n   * @default true\n   */\n  readonly assetStaging?: boolean;\n\n  /**\n   * Select which stacks should have asset bundling enabled\n   *\n   * @default [\"**\"] - all stacks\n   */\n  readonly bundlingForStacks?: string;\n}\n\n/**\n * Options to configure loading of the assembly after it has been synthesized\n */\nexport interface LoadAssemblyOptions {\n  /**\n   * Check the Toolkit supports the Cloud Assembly Schema version\n   *\n   * When disabled, allows to Toolkit to read a newer cloud assembly than the CX API is designed\n   * to support. Your application may not be aware of all features that in use in the Cloud Assembly.\n   *\n   * @default true\n   */\n  readonly checkVersion?: boolean;\n\n  /**\n   * Validate enums to only have known values\n   *\n   * When disabled, the Toolkit may read enum values it doesn't know about yet.\n   * You will have to make sure to always check the values of enums you encounter in the manifest.\n   *\n   * @default true\n   */\n  readonly checkEnums?: boolean;\n}\n\nexport abstract class CloudAssemblySourceBuilder {\n  /**\n   * Helper to provide the CloudAssemblySourceBuilder with required toolkit services\n   * @internal\n   */\n  protected abstract sourceBuilderServices(): Promise<ToolkitServices>;\n\n  /**\n   * Create a Cloud Assembly from a Cloud Assembly builder function.\n   *\n   * ## Outdir\n   *\n   * If no output directory is given, it will synthesize into a temporary system\n   * directory. The temporary directory will be cleaned up, unless\n   * `disposeOutdir: false`.\n   *\n   * A write lock will be acquired on the output directory for the duration of\n   * the CDK app synthesis (which means that no two apps can synthesize at the\n   * same time), and after synthesis a read lock will be acquired on the\n   * directory. This means that while the CloudAssembly is being used, no CDK\n   * app synthesis can take place into that directory.\n   *\n   * ## Context\n   *\n   * If no `contextStore` is given, a `MemoryContext` will be used. This means\n   * no provider lookups will be persisted anywhere by default. Use a different\n   * type of context store if you want persistence between synth operations.\n   *\n   * @param builder - the builder function\n   * @param props - additional configuration properties\n   * @returns the CloudAssembly source\n   */\n  public async fromAssemblyBuilder(\n    builder: AssemblyBuilder,\n    props: FromAssemblyBuilderOptions = {},\n  ): Promise<ICloudAssemblySource> {\n    const services = await this.sourceBuilderServices();\n    const contextStore = props.contextStore ?? new MemoryContext();\n    const contextAssemblyProps: ContextAwareCloudAssemblyProps = {\n      services,\n      contextStore,\n      lookups: props.lookups,\n    };\n\n    const outdir = props.outdir ? path.resolve(props.outdir) : undefined;\n\n    return new ContextAwareCloudAssemblySource(\n      {\n        produce: async () => {\n          await using execution = await ExecutionEnvironment.create(services, {\n            outdir,\n            resolveDefaultAppEnv: props.resolveDefaultEnvironment ?? true,\n          });\n\n          const synthParams = parametersFromSynthOptions(props.synthOptions);\n\n          const fullContext = {\n            ...await contextStore.read(),\n            ...synthParams.context,\n          };\n\n          await services.ioHelper.defaults.debug(format('context:', fullContext));\n\n          const env = noUndefined({\n            // Versioning, outdir, default account and region\n            ...await execution.defaultEnvVars(),\n            // Environment variables derived from settings\n            ...synthParams.env,\n          });\n\n          const cleanupContextTemp = writeContextToEnv(env, fullContext, 'env-is-complete');\n          using _cleanupEnv = (props.clobberEnv ?? true) ? temporarilyWriteEnv(env) : undefined;\n          let assembly;\n          try {\n            assembly = await builder({\n              outdir: execution.outdir,\n              context: fullContext,\n              env,\n            });\n          } catch (error: unknown) {\n            // re-throw toolkit errors unchanged\n            if (ToolkitError.isToolkitError(error)) {\n              throw error;\n            }\n            // otherwise, wrap into an assembly error\n            throw AssemblyError.withCause('Assembly builder failed', error);\n          } finally {\n            await cleanupContextTemp();\n          }\n\n          // Convert what we got to the definitely correct type we're expecting, a cxapi.CloudAssembly\n          const asm = cxapi.CloudAssembly.isCloudAssembly(assembly)\n            ? assembly\n            : await assemblyFromDirectory(assembly.directory, services.ioHelper, props.loadAssemblyOptions);\n\n          const success = await execution.markSuccessful();\n          const deleteOnDispose = props.disposeOutdir ?? execution.shouldDisposeOutDir;\n          return new ReadableCloudAssembly(asm, success.readLock, { deleteOnDispose });\n        },\n      },\n      contextAssemblyProps,\n    );\n  }\n\n  /**\n   * Creates a Cloud Assembly from an existing assembly directory.\n   *\n   * A read lock will be acquired for the directory. This means that while\n   * the CloudAssembly is being used, no CDK app synthesis can take place into\n   * that directory.\n   *\n   * @param directory - directory the directory of a already produced Cloud Assembly.\n   * @returns the CloudAssembly source\n   */\n  public async fromAssemblyDirectory(directory: string, props: AssemblyDirectoryProps = {}): Promise<ICloudAssemblySource> {\n    const services: ToolkitServices = await this.sourceBuilderServices();\n\n    return {\n      async produce() {\n        await services.ioHelper.notify(IO.CDK_ASSEMBLY_I0150.msg('--app points to a cloud assembly, so we bypass synth'));\n        const readLock = await new RWLock(directory).acquireRead();\n        try {\n          const asm = await assemblyFromDirectory(directory, services.ioHelper, props.loadAssemblyOptions);\n          const assembly = new ReadableCloudAssembly(asm, readLock, { deleteOnDispose: false });\n          if (assembly.cloudAssembly.manifest.missing && assembly.cloudAssembly.manifest.missing.length > 0) {\n            if (props.failOnMissingContext ?? true) {\n              const missingKeysSet = missingContextKeys(assembly.cloudAssembly.manifest.missing);\n              const missingKeys = Array.from(missingKeysSet);\n              throw AssemblyError.withCause(\n                'Assembly contains missing context. ' +\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                'Error producing assembly',\n              );\n            }\n          }\n          return new CachedCloudAssembly(assembly);\n        } catch (e) {\n          await readLock.release();\n          throw e;\n        }\n      },\n    };\n  }\n  /**\n   * Use a directory containing an AWS CDK app as source.\n   *\n   * The subprocess will execute in `workingDirectory`, which defaults to\n   * the current process' working directory if not given.\n   *\n   * ## Outdir\n   *\n   * If an output directory is supplied, relative paths are evaluated with\n   * respect to the current process' working directory. If an output directory\n   * is not supplied, the default is a `cdk.out` directory underneath\n   * `workingDirectory`. The output directory will not be cleaned up unless\n   * `disposeOutdir: true`.\n   *\n   * A write lock will be acquired on the output directory for the duration of\n   * the CDK app synthesis (which means that no two apps can synthesize at the\n   * same time), and after synthesis a read lock will be acquired on the\n   * directory.  This means that while the CloudAssembly is being used, no CDK\n   * app synthesis can take place into that directory.\n   *\n   * ## Context\n   *\n   * If no `contextStore` is given, a `CdkAppMultiContext` will be used, initialized\n   * to the app's `workingDirectory`. This means that context will be loaded from\n   * all the CDK's default context sources, and updates will be written to\n   * `cdk.context.json`.\n   *\n   * @param props - additional configuration properties\n   * @returns the CloudAssembly source\n   */\n  public async fromCdkApp(app: string, props: FromCdkAppOptions = {}): Promise<ICloudAssemblySource> {\n    const services: ToolkitServices = await this.sourceBuilderServices();\n    const workingDirectory = props.workingDirectory ?? process.cwd();\n    const outdir = props.outdir ? path.resolve(props.outdir) : path.resolve(workingDirectory, 'cdk.out');\n\n    const contextStore = props.contextStore ?? new CdkAppMultiContext(workingDirectory);\n\n    const contextAssemblyProps: ContextAwareCloudAssemblyProps = {\n      services,\n      contextStore,\n      lookups: props.lookups,\n    };\n\n    return new ContextAwareCloudAssemblySource(\n      {\n        produce: async () => {\n          try {\n            fs.mkdirpSync(outdir);\n          } catch (e: any) {\n            throw new ToolkitError(`Could not create output directory at '${outdir}' (${e.message}).`);\n          }\n\n          await using execution = await ExecutionEnvironment.create(services, {\n            outdir,\n            resolveDefaultAppEnv: props.resolveDefaultEnvironment ?? true,\n          });\n\n          const commandLine = await execution.guessExecutable(app);\n\n          const synthParams = parametersFromSynthOptions(props.synthOptions);\n\n          const fullContext = {\n            ...await contextStore.read(),\n            ...synthParams.context,\n          };\n\n          await services.ioHelper.defaults.debug(format('context:', fullContext));\n\n          const env = noUndefined({\n            // Need to start with full env of `writeContextToEnv` will not be able to do the size\n            // calculation correctly.\n            ...process.env,\n            // User gave us something\n            ...props.env,\n            // Versioning, outdir, default account and region\n            ...await execution.defaultEnvVars(),\n            // Environment variables derived from settings\n            ...synthParams.env,\n          });\n          const cleanupTemp = writeContextToEnv(env, fullContext, 'env-is-complete');\n          try {\n            await execInChildProcess(commandLine.join(' '), {\n              eventPublisher: async (type, line) => {\n                switch (type) {\n                  case 'data_stdout':\n                    await services.ioHelper.notify(IO.CDK_ASSEMBLY_I1001.msg(line));\n                    break;\n                  case 'data_stderr':\n                    await services.ioHelper.notify(IO.CDK_ASSEMBLY_E1002.msg(line));\n                    break;\n                }\n              },\n              env,\n              cwd: workingDirectory,\n            });\n          } finally {\n            await cleanupTemp();\n          }\n\n          const asm = await assemblyFromDirectory(outdir, services.ioHelper, props.loadAssemblyOptions);\n\n          const success = await execution.markSuccessful();\n          const deleteOnDispose = props.disposeOutdir ?? execution.shouldDisposeOutDir;\n          return new ReadableCloudAssembly(asm, success.readLock, { deleteOnDispose });\n        },\n      },\n      contextAssemblyProps,\n    );\n  }\n}\n\n"]}
|
|
@@ -39,6 +39,7 @@ class StackCollection {
|
|
|
39
39
|
id: stack.displayName ?? stack.id,
|
|
40
40
|
name: stack.stackName,
|
|
41
41
|
environment: stack.environment,
|
|
42
|
+
metadata: stack.manifest.metadata,
|
|
42
43
|
dependencies: [],
|
|
43
44
|
};
|
|
44
45
|
for (const dependencyId of stack.dependencies.map(x => x.id)) {
|
|
@@ -109,4 +110,4 @@ class StackCollection {
|
|
|
109
110
|
}
|
|
110
111
|
}
|
|
111
112
|
exports.StackCollection = StackCollection;
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack-collection.js","sourceRoot":"","sources":["stack-collection.ts"],"names":[],"mappings":"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","sourcesContent":["import type * as cxapi from '@aws-cdk/cx-api';\nimport { SynthesisMessageLevel } from '@aws-cdk/cx-api';\nimport type { IStackAssembly } from './stack-assembly';\nimport { type StackDetails } from '../../payloads/stack-details';\nimport { AssemblyError, ToolkitError } from '../../toolkit/toolkit-error';\n\n/**\n * A collection of stacks and related artifacts\n *\n * In practice, not all artifacts in the CloudAssembly are created equal;\n * stacks can be selected independently, but other artifacts such as asset\n * bundles cannot.\n */\nexport class StackCollection {\n  constructor(public readonly assembly: IStackAssembly, public readonly stackArtifacts: cxapi.CloudFormationStackArtifact[]) {\n  }\n\n  public get stackCount() {\n    return this.stackArtifacts.length;\n  }\n\n  public get firstStack() {\n    if (this.stackCount < 1) {\n      throw new ToolkitError('StackCollection contains no stack artifacts (trying to access the first one)');\n    }\n    return this.stackArtifacts[0];\n  }\n\n  public get stackIds(): string[] {\n    return this.stackArtifacts.map(s => s.id);\n  }\n\n  public get hierarchicalIds(): string[] {\n    return this.stackArtifacts.map(s => s.hierarchicalId);\n  }\n\n  public withDependencies(): StackDetails[] {\n    const allData: StackDetails[] = [];\n\n    for (const stack of this.stackArtifacts) {\n      const data: StackDetails = {\n        id: stack.displayName ?? stack.id,\n        name: stack.stackName,\n        environment: stack.environment,\n        metadata: stack.manifest.metadata,\n        dependencies: [],\n      };\n\n      for (const dependencyId of stack.dependencies.map(x => x.id)) {\n        if (dependencyId.includes('.assets')) {\n          continue;\n        }\n\n        const depStack = this.assembly.stackById(dependencyId);\n\n        if (depStack.firstStack.dependencies.filter((dep) => !(dep.id).includes('.assets')).length > 0) {\n          for (const stackDetail of depStack.withDependencies()) {\n            data.dependencies.push({\n              id: stackDetail.id,\n              dependencies: stackDetail.dependencies,\n            });\n          }\n        } else {\n          data.dependencies.push({\n            id: depStack.firstStack.displayName ?? depStack.firstStack.id,\n            dependencies: [],\n          });\n        }\n      }\n\n      allData.push(data);\n    }\n\n    return allData;\n  }\n\n  public reversed() {\n    const arts = [...this.stackArtifacts];\n    arts.reverse();\n    return new StackCollection(this.assembly, arts);\n  }\n\n  public filter(predicate: (art: cxapi.CloudFormationStackArtifact) => boolean): StackCollection {\n    return new StackCollection(this.assembly, this.stackArtifacts.filter(predicate));\n  }\n\n  public concat(...others: StackCollection[]): StackCollection {\n    return new StackCollection(this.assembly, this.stackArtifacts.concat(...others.map(o => o.stackArtifacts)));\n  }\n\n  /**\n   * Extracts 'aws:cdk:warning|info|error' metadata entries from the stack synthesis\n   */\n  public async validateMetadata(\n    failAt: 'warn' | 'error' | 'none' = 'error',\n    logger: (level: 'info' | 'error' | 'warn', msg: cxapi.SynthesisMessage) => Promise<void> = async () => {\n    },\n  ) {\n    let warnings = false;\n    let errors = false;\n\n    for (const stack of this.stackArtifacts) {\n      for (const message of stack.messages) {\n        switch (message.level) {\n          case SynthesisMessageLevel.WARNING:\n            warnings = true;\n            await logger('warn', message);\n            break;\n          case SynthesisMessageLevel.ERROR:\n            errors = true;\n            await logger('error', message);\n            break;\n          case SynthesisMessageLevel.INFO:\n            await logger('info', message);\n            break;\n        }\n      }\n    }\n\n    if (errors && failAt != 'none') {\n      throw AssemblyError.withStacks('Found errors', this.stackArtifacts);\n    }\n\n    if (warnings && failAt === 'warn') {\n      throw AssemblyError.withStacks('Found warnings (--strict mode)', this.stackArtifacts);\n    }\n  }\n}\n"]}
|
|
@@ -96,6 +96,13 @@ export interface TemplateInfo {
|
|
|
96
96
|
readonly nestedStacks?: {
|
|
97
97
|
[nestedStackLogicalId: string]: NestedStackTemplates;
|
|
98
98
|
};
|
|
99
|
+
/**
|
|
100
|
+
* Mappings of old locations to new locations. If these are provided,
|
|
101
|
+
* for all resources that were moved, their corresponding addition
|
|
102
|
+
* and removal lines will be augmented with the location they were
|
|
103
|
+
* moved fom and to, respectively.
|
|
104
|
+
*/
|
|
105
|
+
readonly mappings?: Record<string, string>;
|
|
99
106
|
}
|
|
100
107
|
/**
|
|
101
108
|
* Class for formatting the diff output
|
|
@@ -107,6 +114,7 @@ export declare class DiffFormatter {
|
|
|
107
114
|
private readonly changeSet?;
|
|
108
115
|
private readonly nestedStacks;
|
|
109
116
|
private readonly isImport;
|
|
117
|
+
private readonly mappings;
|
|
110
118
|
/**
|
|
111
119
|
* Stores the TemplateDiffs that get calculated in this DiffFormatter,
|
|
112
120
|
* indexed by the stack name.
|