Socket
Socket
Sign inDemoInstall

@aws-cdk/core

Package Overview
Dependencies
Maintainers
5
Versions
248
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/core - npm Package Compare versions

Comparing version 1.44.0 to 1.45.0

lib/bundling.d.ts

17

lib/app.d.ts

@@ -1,3 +0,2 @@

import * as cxapi from '@aws-cdk/cx-api';
import { Construct } from './construct-compat';
import { Stage } from './stage';
/**

@@ -69,3 +68,3 @@ * Initialization props for apps.

*/
export declare class App extends Construct {
export declare class App extends Stage {
/**

@@ -77,5 +76,2 @@ * Checks if an object is an instance of the `App` class.

static isApp(obj: any): obj is App;
private _assembly?;
private readonly runtimeInfo;
private readonly outdir?;
/**

@@ -86,12 +82,3 @@ * Initializes a CDK application.

constructor(props?: AppProps);
/**
* Synthesizes a cloud assembly for this app. Emits it to the directory
* specified by `outdir`.
*
* @returns a `CloudAssembly` which can be used to inspect synthesized
* artifacts such as CloudFormation templates and assets.
*/
synth(): cxapi.CloudAssembly;
protected prepare(): void;
private loadContext;
}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const cxapi = require("@aws-cdk/cx-api");
const construct_compat_1 = require("./construct-compat");
const prepare_app_1 = require("./private/prepare-app");
const runtime_info_1 = require("./private/runtime-info");
const tree_metadata_1 = require("./private/tree-metadata");
const stage_1 = require("./stage");
const APP_SYMBOL = Symbol.for('@aws-cdk/core.App');

@@ -24,4 +22,12 @@ /**

*/
class App extends construct_compat_1.Construct {
class App extends stage_1.Stage {
/**
* Checks if an object is an instance of the `App` class.
* @returns `true` if `obj` is an `App`.
* @param obj The object to evaluate
*/
static isApp(obj) {
return APP_SYMBOL in obj;
}
/**
* Initializes a CDK application.

@@ -31,3 +37,6 @@ * @param props initialization properties

constructor(props = {}) {
super(undefined, '');
var _a;
super(undefined, '', {
outdir: (_a = props.outdir) !== null && _a !== void 0 ? _a : process.env[cxapi.OUTDIR_ENV],
});
Object.defineProperty(this, APP_SYMBOL, { value: true });

@@ -41,5 +50,2 @@ this.loadContext(props.context);

}
// both are reverse logic
this.runtimeInfo = this.node.tryGetContext(cxapi.DISABLE_VERSION_REPORTING) ? false : true;
this.outdir = props.outdir || process.env[cxapi.OUTDIR_ENV];
const autoSynth = props.autoSynth !== undefined ? props.autoSynth : cxapi.OUTDIR_ENV in process.env;

@@ -55,33 +61,2 @@ if (autoSynth) {

}
/**
* Checks if an object is an instance of the `App` class.
* @returns `true` if `obj` is an `App`.
* @param obj The object to evaluate
*/
static isApp(obj) {
return APP_SYMBOL in obj;
}
/**
* Synthesizes a cloud assembly for this app. Emits it to the directory
* specified by `outdir`.
*
* @returns a `CloudAssembly` which can be used to inspect synthesized
* artifacts such as CloudFormation templates and assets.
*/
synth() {
// we already have a cloud assembly, no-op for you
if (this._assembly) {
return this._assembly;
}
const assembly = construct_compat_1.ConstructNode.synth(this.node, {
outdir: this.outdir,
runtimeInfo: this.runtimeInfo ? runtime_info_1.collectRuntimeInformation() : undefined,
});
this._assembly = assembly;
return assembly;
}
prepare() {
super.prepare();
prepare_app_1.prepareApp(this);
}
loadContext(defaults = {}) {

@@ -103,2 +78,2 @@ // prime with defaults passed through constructor

exports.App = App;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.js","sourceRoot":"","sources":["app.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cxapi from '@aws-cdk/cx-api';\nimport { Construct, ConstructNode } from './construct-compat';\nimport { prepareApp } from './private/prepare-app';\nimport { collectRuntimeInformation } from './private/runtime-info';\nimport { TreeMetadata } from './private/tree-metadata';\n\nconst APP_SYMBOL = Symbol.for('@aws-cdk/core.App');\n\n/**\n * Initialization props for apps.\n */\nexport interface AppProps {\n  /**\n   * Automatically call `synth()` before the program exits.\n   *\n   * If you set this, you don't have to call `synth()` explicitly. Note that\n   * this feature is only available for certain programming languages, and\n   * calling `synth()` is still recommended.\n   *\n   * @default true if running via CDK CLI (`CDK_OUTDIR` is set), `false`\n   * otherwise\n   */\n  readonly autoSynth?: boolean;\n\n  /**\n   * The output directory into which to emit synthesized artifacts.\n   *\n   * @default - If this value is _not_ set, considers the environment variable `CDK_OUTDIR`.\n   *            If `CDK_OUTDIR` is not defined, uses a temp directory.\n   */\n  readonly outdir?: string;\n\n  /**\n   * Include construct creation stack trace in the `aws:cdk:trace` metadata key of all constructs.\n   * @default true stack traces are included unless `aws:cdk:disable-stack-trace` is set in the context.\n   */\n  readonly stackTraces?: boolean;\n\n  /**\n   * Include runtime versioning information in cloud assembly manifest\n   * @default true runtime info is included unless `aws:cdk:disable-runtime-info` is set in the context.\n   */\n  readonly runtimeInfo?: boolean;\n\n  /**\n   * Additional context values for the application.\n   *\n   * Context set by the CLI or the `context` key in `cdk.json` has precedence.\n   *\n   * Context can be read from any construct using `node.getContext(key)`.\n   *\n   * @default - no additional context\n   */\n  readonly context?: { [key: string]: string };\n\n  /**\n   * Include construct tree metadata as part of the Cloud Assembly.\n   *\n   * @default true\n   */\n  readonly treeMetadata?: boolean;\n}\n\n/**\n * A construct which represents an entire CDK app. This construct is normally\n * the root of the construct tree.\n *\n * You would normally define an `App` instance in your program's entrypoint,\n * then define constructs where the app is used as the parent scope.\n *\n * After all the child constructs are defined within the app, you should call\n * `app.synth()` which will emit a \"cloud assembly\" from this app into the\n * directory specified by `outdir`. Cloud assemblies includes artifacts such as\n * CloudFormation templates and assets that are needed to deploy this app into\n * the AWS cloud.\n *\n * @see https://docs.aws.amazon.com/cdk/latest/guide/apps.html\n */\nexport class App extends Construct {\n\n  /**\n   * Checks if an object is an instance of the `App` class.\n   * @returns `true` if `obj` is an `App`.\n   * @param obj The object to evaluate\n   */\n  public static isApp(obj: any): obj is App {\n    return APP_SYMBOL in obj;\n  }\n\n  private _assembly?: cxapi.CloudAssembly;\n  private readonly runtimeInfo: boolean;\n  private readonly outdir?: string;\n\n  /**\n   * Initializes a CDK application.\n   * @param props initialization properties\n   */\n  constructor(props: AppProps = {}) {\n    super(undefined as any, '');\n\n    Object.defineProperty(this, APP_SYMBOL, { value: true });\n\n    this.loadContext(props.context);\n\n    if (props.stackTraces === false) {\n      this.node.setContext(cxapi.DISABLE_METADATA_STACK_TRACE, true);\n    }\n\n    if (props.runtimeInfo === false) {\n      this.node.setContext(cxapi.DISABLE_VERSION_REPORTING, true);\n    }\n\n    // both are reverse logic\n    this.runtimeInfo = this.node.tryGetContext(cxapi.DISABLE_VERSION_REPORTING) ? false : true;\n    this.outdir = props.outdir || process.env[cxapi.OUTDIR_ENV];\n\n    const autoSynth = props.autoSynth !== undefined ? props.autoSynth : cxapi.OUTDIR_ENV in process.env;\n    if (autoSynth) {\n      // synth() guarantuees it will only execute once, so a default of 'true'\n      // doesn't bite manual calling of the function.\n      process.once('beforeExit', () => this.synth());\n    }\n\n    if (props.treeMetadata === undefined || props.treeMetadata) {\n      new TreeMetadata(this);\n    }\n  }\n\n  /**\n   * Synthesizes a cloud assembly for this app. Emits it to the directory\n   * specified by `outdir`.\n   *\n   * @returns a `CloudAssembly` which can be used to inspect synthesized\n   * artifacts such as CloudFormation templates and assets.\n   */\n  public synth(): cxapi.CloudAssembly {\n    // we already have a cloud assembly, no-op for you\n    if (this._assembly) {\n      return this._assembly;\n    }\n\n    const assembly = ConstructNode.synth(this.node, {\n      outdir: this.outdir,\n      runtimeInfo: this.runtimeInfo ? collectRuntimeInformation() : undefined,\n    });\n\n    this._assembly = assembly;\n    return assembly;\n  }\n\n  protected prepare() {\n    super.prepare();\n    prepareApp(this);\n  }\n\n  private loadContext(defaults: { [key: string]: string } = { }) {\n    // prime with defaults passed through constructor\n    for (const [ k, v ] of Object.entries(defaults)) {\n      this.node.setContext(k, v);\n    }\n\n    // read from environment\n    const contextJson = process.env[cxapi.CONTEXT_ENV];\n    const contextFromEnvironment = contextJson\n      ? JSON.parse(contextJson)\n      : { };\n\n    for (const [ k, v ] of Object.entries(contextFromEnvironment)) {\n      this.node.setContext(k, v);\n    }\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.js","sourceRoot":"","sources":["app.ts"],"names":[],"mappings":";;AAAA,yCAAyC;AACzC,2DAAuD;AACvD,mCAAgC;AAEhC,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;AAyDnD;;;;;;;;;;;;;;GAcG;AACH,MAAa,GAAI,SAAQ,aAAK;IAC5B;;;;OAIG;IACI,MAAM,CAAC,KAAK,CAAC,GAAQ;QAC1B,OAAO,UAAU,IAAI,GAAG,CAAC;IAC3B,CAAC;IAED;;;OAGG;IACH,YAAY,QAAkB,EAAE;;QAC9B,KAAK,CAAC,SAAgB,EAAE,EAAE,EAAE;YAC1B,MAAM,QAAE,KAAK,CAAC,MAAM,mCAAI,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC;SACtD,CAAC,CAAC;QAEH,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,UAAU,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QAEzD,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAEhC,IAAI,KAAK,CAAC,WAAW,KAAK,KAAK,EAAE;YAC/B,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,4BAA4B,EAAE,IAAI,CAAC,CAAC;SAChE;QAED,IAAI,KAAK,CAAC,WAAW,KAAK,KAAK,EAAE;YAC/B,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,yBAAyB,EAAE,IAAI,CAAC,CAAC;SAC7D;QAED,MAAM,SAAS,GAAG,KAAK,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,IAAI,OAAO,CAAC,GAAG,CAAC;QACpG,IAAI,SAAS,EAAE;YACb,wEAAwE;YACxE,+CAA+C;YAC/C,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;SAChD;QAED,IAAI,KAAK,CAAC,YAAY,KAAK,SAAS,IAAI,KAAK,CAAC,YAAY,EAAE;YAC1D,IAAI,4BAAY,CAAC,IAAI,CAAC,CAAC;SACxB;IACH,CAAC;IAEO,WAAW,CAAC,WAAsC,EAAG;QAC3D,iDAAiD;QACjD,KAAK,MAAM,CAAE,CAAC,EAAE,CAAC,CAAE,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;YAC/C,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;SAC5B;QAED,wBAAwB;QACxB,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QACnD,MAAM,sBAAsB,GAAG,WAAW;YACxC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;YACzB,CAAC,CAAC,EAAG,CAAC;QAER,KAAK,MAAM,CAAE,CAAC,EAAE,CAAC,CAAE,IAAI,MAAM,CAAC,OAAO,CAAC,sBAAsB,CAAC,EAAE;YAC7D,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;SAC5B;IACH,CAAC;CACF;AA3DD,kBA2DC","sourcesContent":["import * as cxapi from '@aws-cdk/cx-api';\nimport { TreeMetadata } from './private/tree-metadata';\nimport { Stage } from './stage';\n\nconst APP_SYMBOL = Symbol.for('@aws-cdk/core.App');\n\n/**\n * Initialization props for apps.\n */\nexport interface AppProps {\n  /**\n   * Automatically call `synth()` before the program exits.\n   *\n   * If you set this, you don't have to call `synth()` explicitly. Note that\n   * this feature is only available for certain programming languages, and\n   * calling `synth()` is still recommended.\n   *\n   * @default true if running via CDK CLI (`CDK_OUTDIR` is set), `false`\n   * otherwise\n   */\n  readonly autoSynth?: boolean;\n\n  /**\n   * The output directory into which to emit synthesized artifacts.\n   *\n   * @default - If this value is _not_ set, considers the environment variable `CDK_OUTDIR`.\n   *            If `CDK_OUTDIR` is not defined, uses a temp directory.\n   */\n  readonly outdir?: string;\n\n  /**\n   * Include construct creation stack trace in the `aws:cdk:trace` metadata key of all constructs.\n   * @default true stack traces are included unless `aws:cdk:disable-stack-trace` is set in the context.\n   */\n  readonly stackTraces?: boolean;\n\n  /**\n   * Include runtime versioning information in cloud assembly manifest\n   * @default true runtime info is included unless `aws:cdk:disable-runtime-info` is set in the context.\n   */\n  readonly runtimeInfo?: boolean;\n\n  /**\n   * Additional context values for the application.\n   *\n   * Context set by the CLI or the `context` key in `cdk.json` has precedence.\n   *\n   * Context can be read from any construct using `node.getContext(key)`.\n   *\n   * @default - no additional context\n   */\n  readonly context?: { [key: string]: string };\n\n  /**\n   * Include construct tree metadata as part of the Cloud Assembly.\n   *\n   * @default true\n   */\n  readonly treeMetadata?: boolean;\n}\n\n/**\n * A construct which represents an entire CDK app. This construct is normally\n * the root of the construct tree.\n *\n * You would normally define an `App` instance in your program's entrypoint,\n * then define constructs where the app is used as the parent scope.\n *\n * After all the child constructs are defined within the app, you should call\n * `app.synth()` which will emit a \"cloud assembly\" from this app into the\n * directory specified by `outdir`. Cloud assemblies includes artifacts such as\n * CloudFormation templates and assets that are needed to deploy this app into\n * the AWS cloud.\n *\n * @see https://docs.aws.amazon.com/cdk/latest/guide/apps.html\n */\nexport class App extends Stage {\n  /**\n   * Checks if an object is an instance of the `App` class.\n   * @returns `true` if `obj` is an `App`.\n   * @param obj The object to evaluate\n   */\n  public static isApp(obj: any): obj is App {\n    return APP_SYMBOL in obj;\n  }\n\n  /**\n   * Initializes a CDK application.\n   * @param props initialization properties\n   */\n  constructor(props: AppProps = {}) {\n    super(undefined as any, '', {\n      outdir: props.outdir ?? process.env[cxapi.OUTDIR_ENV],\n    });\n\n    Object.defineProperty(this, APP_SYMBOL, { value: true });\n\n    this.loadContext(props.context);\n\n    if (props.stackTraces === false) {\n      this.node.setContext(cxapi.DISABLE_METADATA_STACK_TRACE, true);\n    }\n\n    if (props.runtimeInfo === false) {\n      this.node.setContext(cxapi.DISABLE_VERSION_REPORTING, true);\n    }\n\n    const autoSynth = props.autoSynth !== undefined ? props.autoSynth : cxapi.OUTDIR_ENV in process.env;\n    if (autoSynth) {\n      // synth() guarantuees it will only execute once, so a default of 'true'\n      // doesn't bite manual calling of the function.\n      process.once('beforeExit', () => this.synth());\n    }\n\n    if (props.treeMetadata === undefined || props.treeMetadata) {\n      new TreeMetadata(this);\n    }\n  }\n\n  private loadContext(defaults: { [key: string]: string } = { }) {\n    // prime with defaults passed through constructor\n    for (const [ k, v ] of Object.entries(defaults)) {\n      this.node.setContext(k, v);\n    }\n\n    // read from environment\n    const contextJson = process.env[cxapi.CONTEXT_ENV];\n    const contextFromEnvironment = contextJson\n      ? JSON.parse(contextJson)\n      : { };\n\n    for (const [ k, v ] of Object.entries(contextFromEnvironment)) {\n      this.node.setContext(k, v);\n    }\n  }\n}\n"]}

@@ -0,1 +1,2 @@

import { AssetOptions } from './assets';
import { Construct, ISynthesisSession } from './construct-compat';

@@ -6,3 +7,3 @@ import { FingerprintOptions } from './fs';

*/
export interface AssetStagingProps extends FingerprintOptions {
export interface AssetStagingProps extends FingerprintOptions, AssetOptions {
/**

@@ -44,9 +45,18 @@ * The source file or directory to copy from.

/**
* A cryptographic hash of the source document(s).
* A cryptographic hash of the asset.
*
* @deprecated see `assetHash`.
*/
readonly sourceHash: string;
/**
* A cryptographic hash of the asset.
*/
readonly assetHash: string;
private readonly fingerprintOptions;
private readonly relativePath?;
private readonly bundleDir?;
constructor(scope: Construct, id: string, props: AssetStagingProps);
protected synthesize(session: ISynthesisSession): void;
private bundle;
private calculateHash;
}

@@ -5,3 +5,6 @@ "use strict";

const fs = require("fs");
const os = require("os");
const path = require("path");
const assets_1 = require("./assets");
const bundling_1 = require("./bundling");
const construct_compat_1 = require("./construct-compat");

@@ -29,16 +32,22 @@ const fs_1 = require("./fs");

constructor(scope, id, props) {
var _a, _b;
super(scope, id);
this.sourcePath = props.sourcePath;
this.fingerprintOptions = props;
this.sourceHash = fs_1.FileSystem.fingerprint(this.sourcePath, props);
if (props.bundling) {
this.bundleDir = this.bundle(props.bundling);
}
this.assetHash = this.calculateHash(props);
const stagingDisabled = this.node.tryGetContext(cxapi.DISABLE_ASSET_STAGING_CONTEXT);
if (stagingDisabled) {
this.stagedPath = this.sourcePath;
this.stagedPath = (_a = this.bundleDir) !== null && _a !== void 0 ? _a : this.sourcePath;
}
else {
this.relativePath = 'asset.' + this.sourceHash + path.extname(this.sourcePath);
this.stagedPath = this.relativePath; // always relative to outdir
this.relativePath = `asset.${this.assetHash}${path.extname((_b = this.bundleDir) !== null && _b !== void 0 ? _b : this.sourcePath)}`;
this.stagedPath = this.relativePath;
}
this.sourceHash = this.assetHash;
}
synthesize(session) {
// Staging is disabled
if (!this.relativePath) {

@@ -48,7 +57,26 @@ return;

const targetPath = path.join(session.assembly.outdir, this.relativePath);
// asset already staged
// Already staged
if (fs.existsSync(targetPath)) {
return;
}
// copy file/directory to staging directory
// Asset has been bundled
if (this.bundleDir) {
// Try to rename bundling directory to staging directory
try {
fs.renameSync(this.bundleDir, targetPath);
return;
}
catch (err) {
// /tmp and cdk.out could be mounted across different mount points
// in this case we will fallback to copying. This can happen in Windows
// Subsystem for Linux (WSL).
if (err.code === 'EXDEV') {
fs.mkdirSync(targetPath);
fs_1.FileSystem.copyDirectory(this.bundleDir, targetPath, this.fingerprintOptions);
return;
}
throw err;
}
}
// Copy file/directory to staging directory
const stat = fs.statSync(this.sourcePath);

@@ -66,4 +94,67 @@ if (stat.isFile()) {

}
bundle(options) {
var _a, _b;
// Create temporary directory for bundling
const bundleDir = fs.mkdtempSync(path.resolve(path.join(os.tmpdir(), 'cdk-asset-bundle-')));
// Always mount input and output dir
const volumes = [
{
hostPath: this.sourcePath,
containerPath: bundling_1.BUNDLING_INPUT_DIR,
},
{
hostPath: bundleDir,
containerPath: bundling_1.BUNDLING_OUTPUT_DIR,
},
...(_a = options.volumes) !== null && _a !== void 0 ? _a : [],
];
try {
options.image._run({
command: options.command,
volumes,
environment: options.environment,
workingDirectory: (_b = options.workingDirectory) !== null && _b !== void 0 ? _b : bundling_1.BUNDLING_INPUT_DIR,
});
}
catch (err) {
throw new Error(`Failed to run bundling Docker image for asset ${this.node.path}: ${err}`);
}
if (fs_1.FileSystem.isEmpty(bundleDir)) {
throw new Error(`Bundling did not produce any output. Check that your container writes content to ${bundling_1.BUNDLING_OUTPUT_DIR}.`);
}
return bundleDir;
}
calculateHash(props) {
let hashType;
if (props.assetHash) {
if (props.assetHashType && props.assetHashType !== assets_1.AssetHashType.CUSTOM) {
throw new Error(`Cannot specify \`${props.assetHashType}\` for \`assetHashType\` when \`assetHash\` is specified. Use \`CUSTOM\` or leave \`undefined\`.`);
}
hashType = assets_1.AssetHashType.CUSTOM;
}
else if (props.assetHashType) {
hashType = props.assetHashType;
}
else {
hashType = assets_1.AssetHashType.SOURCE;
}
switch (hashType) {
case assets_1.AssetHashType.SOURCE:
return fs_1.FileSystem.fingerprint(this.sourcePath, this.fingerprintOptions);
case assets_1.AssetHashType.BUNDLE:
if (!this.bundleDir) {
throw new Error('Cannot use `AssetHashType.BUNDLE` when `bundling` is not specified.');
}
return fs_1.FileSystem.fingerprint(this.bundleDir, this.fingerprintOptions);
case assets_1.AssetHashType.CUSTOM:
if (!props.assetHash) {
throw new Error('`assetHash` must be specified when `assetHashType` is set to `AssetHashType.CUSTOM`.');
}
return props.assetHash;
default:
throw new Error('Unknown asset hash type.');
}
}
}
exports.AssetStaging = AssetStaging;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQtc3RhZ2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImFzc2V0LXN0YWdpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx5Q0FBeUM7QUFDekMseUJBQXlCO0FBQ3pCLDZCQUE2QjtBQUM3Qix5REFBa0U7QUFDbEUsNkJBQXNEO0FBWXREOzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCRztBQUNILE1BQWEsWUFBYSxTQUFRLDRCQUFTO0lBd0J6QyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQXdCO1FBQ2hFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDO1FBQ25DLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxLQUFLLENBQUM7UUFDaEMsSUFBSSxDQUFDLFVBQVUsR0FBRyxlQUFVLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFFakUsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLDZCQUE2QixDQUFDLENBQUM7UUFDckYsSUFBSSxlQUFlLEVBQUU7WUFDbkIsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDO1NBQ25DO2FBQU07WUFDTCxJQUFJLENBQUMsWUFBWSxHQUFHLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQy9FLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLDRCQUE0QjtTQUNsRTtJQUNILENBQUM7SUFFUyxVQUFVLENBQUMsT0FBMEI7UUFDN0MsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDdEIsT0FBTztTQUNSO1FBRUQsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7UUFFekUsdUJBQXVCO1FBQ3ZCLElBQUksRUFBRSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUM3QixPQUFPO1NBQ1I7UUFFRCwyQ0FBMkM7UUFDM0MsTUFBTSxJQUFJLEdBQUcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDMUMsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUU7WUFDakIsRUFBRSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1NBQzlDO2FBQU0sSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLEVBQUU7WUFDN0IsRUFBRSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsQ0FBQztZQUN6QixlQUFVLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsVUFBVSxFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1NBQ2hGO2FBQU07WUFDTCxNQUFNLElBQUksS0FBSyxDQUFDLHNCQUFzQixJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQztTQUMxRDtJQUNILENBQUM7Q0FDRjtBQS9ERCxvQ0ErREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjeGFwaSBmcm9tICdAYXdzLWNkay9jeC1hcGknO1xuaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IENvbnN0cnVjdCwgSVN5bnRoZXNpc1Nlc3Npb24gfSBmcm9tICcuL2NvbnN0cnVjdC1jb21wYXQnO1xuaW1wb3J0IHsgRmlsZVN5c3RlbSwgRmluZ2VycHJpbnRPcHRpb25zIH0gZnJvbSAnLi9mcyc7XG5cbi8qKlxuICogSW5pdGlhbGl6YXRpb24gcHJvcGVydGllcyBmb3IgYEFzc2V0U3RhZ2luZ2AuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXNzZXRTdGFnaW5nUHJvcHMgZXh0ZW5kcyBGaW5nZXJwcmludE9wdGlvbnMge1xuICAvKipcbiAgICogVGhlIHNvdXJjZSBmaWxlIG9yIGRpcmVjdG9yeSB0byBjb3B5IGZyb20uXG4gICAqL1xuICByZWFkb25seSBzb3VyY2VQYXRoOiBzdHJpbmc7XG59XG5cbi8qKlxuICogU3RhZ2VzIGEgZmlsZSBvciBkaXJlY3RvcnkgZnJvbSBhIGxvY2F0aW9uIG9uIHRoZSBmaWxlIHN5c3RlbSBpbnRvIGEgc3RhZ2luZ1xuICogZGlyZWN0b3J5LlxuICpcbiAqIFRoaXMgaXMgY29udHJvbGxlZCBieSB0aGUgY29udGV4dCBrZXkgJ2F3czpjZGs6YXNzZXQtc3RhZ2luZycgYW5kIGVuYWJsZWRcbiAqIGJ5IHRoZSBDTEkgYnkgZGVmYXVsdCBpbiBvcmRlciB0byBlbnN1cmUgdGhhdCB3aGVuIHRoZSBDREsgYXBwIGV4aXN0cywgYWxsXG4gKiBhc3NldHMgYXJlIGF2YWlsYWJsZSBmb3IgZGVwbG95bWVudC4gT3RoZXJ3aXNlLCBpZiBhbiBhcHAgcmVmZXJlbmNlcyBhc3NldHNcbiAqIGluIHRlbXBvcmFyeSBsb2NhdGlvbnMsIHRob3NlIHdpbGwgbm90IGJlIGF2YWlsYWJsZSB3aGVuIGl0IGV4aXN0cyAoc2VlXG4gKiBodHRwczovL2dpdGh1Yi5jb20vYXdzL2F3cy1jZGsvaXNzdWVzLzE3MTYpLlxuICpcbiAqIFRoZSBgc3RhZ2VkUGF0aGAgcHJvcGVydHkgaXMgYSBzdHJpbmdpZmllZCB0b2tlbiB0aGF0IHJlcHJlc2VudHMgdGhlIGxvY2F0aW9uXG4gKiBvZiB0aGUgZmlsZSBvciBkaXJlY3RvcnkgYWZ0ZXIgc3RhZ2luZy4gSXQgd2lsbCBiZSByZXNvbHZlZCBvbmx5IGR1cmluZyB0aGVcbiAqIFwicHJlcGFyZVwiIHN0YWdlIGFuZCBtYXkgYmUgZWl0aGVyIHRoZSBvcmlnaW5hbCBwYXRoIG9yIHRoZSBzdGFnZWQgcGF0aFxuICogZGVwZW5kaW5nIG9uIHRoZSBjb250ZXh0IHNldHRpbmcuXG4gKlxuICogVGhlIGZpbGUvZGlyZWN0b3J5IGFyZSBzdGFnZWQgYmFzZWQgb24gdGhlaXIgY29udGVudCBoYXNoIChmaW5nZXJwcmludCkuIFRoaXNcbiAqIG1lYW5zIHRoYXQgb25seSBpZiBjb250ZW50IHdhcyBjaGFuZ2VkLCBjb3B5IHdpbGwgaGFwcGVuLlxuICovXG5leHBvcnQgY2xhc3MgQXNzZXRTdGFnaW5nIGV4dGVuZHMgQ29uc3RydWN0IHtcblxuICAvKipcbiAgICogVGhlIHBhdGggdG8gdGhlIGFzc2V0IChzdHJpbmdpbmZpZWQgdG9rZW4pLlxuICAgKlxuICAgKiBJZiBhc3NldCBzdGFnaW5nIGlzIGRpc2FibGVkLCB0aGlzIHdpbGwganVzdCBiZSB0aGUgb3JpZ2luYWwgcGF0aC5cbiAgICogSWYgYXNzZXQgc3RhZ2luZyBpcyBlbmFibGVkIGl0IHdpbGwgYmUgdGhlIHN0YWdlZCBwYXRoLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHN0YWdlZFBhdGg6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHBhdGggb2YgdGhlIGFzc2V0IGFzIGl0IHdhcyByZWZlcmVuY2VkIGJ5IHRoZSB1c2VyLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHNvdXJjZVBhdGg6IHN0cmluZztcblxuICAvKipcbiAgICogQSBjcnlwdG9ncmFwaGljIGhhc2ggb2YgdGhlIHNvdXJjZSBkb2N1bWVudChzKS5cbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBzb3VyY2VIYXNoOiBzdHJpbmc7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBmaW5nZXJwcmludE9wdGlvbnM6IEZpbmdlcnByaW50T3B0aW9ucztcblxuICBwcml2YXRlIHJlYWRvbmx5IHJlbGF0aXZlUGF0aD86IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogQXNzZXRTdGFnaW5nUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy5zb3VyY2VQYXRoID0gcHJvcHMuc291cmNlUGF0aDtcbiAgICB0aGlzLmZpbmdlcnByaW50T3B0aW9ucyA9IHByb3BzO1xuICAgIHRoaXMuc291cmNlSGFzaCA9IEZpbGVTeXN0ZW0uZmluZ2VycHJpbnQodGhpcy5zb3VyY2VQYXRoLCBwcm9wcyk7XG5cbiAgICBjb25zdCBzdGFnaW5nRGlzYWJsZWQgPSB0aGlzLm5vZGUudHJ5R2V0Q29udGV4dChjeGFwaS5ESVNBQkxFX0FTU0VUX1NUQUdJTkdfQ09OVEVYVCk7XG4gICAgaWYgKHN0YWdpbmdEaXNhYmxlZCkge1xuICAgICAgdGhpcy5zdGFnZWRQYXRoID0gdGhpcy5zb3VyY2VQYXRoO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnJlbGF0aXZlUGF0aCA9ICdhc3NldC4nICsgdGhpcy5zb3VyY2VIYXNoICsgcGF0aC5leHRuYW1lKHRoaXMuc291cmNlUGF0aCk7XG4gICAgICB0aGlzLnN0YWdlZFBhdGggPSB0aGlzLnJlbGF0aXZlUGF0aDsgLy8gYWx3YXlzIHJlbGF0aXZlIHRvIG91dGRpclxuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBzeW50aGVzaXplKHNlc3Npb246IElTeW50aGVzaXNTZXNzaW9uKSB7XG4gICAgaWYgKCF0aGlzLnJlbGF0aXZlUGF0aCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IHRhcmdldFBhdGggPSBwYXRoLmpvaW4oc2Vzc2lvbi5hc3NlbWJseS5vdXRkaXIsIHRoaXMucmVsYXRpdmVQYXRoKTtcblxuICAgIC8vIGFzc2V0IGFscmVhZHkgc3RhZ2VkXG4gICAgaWYgKGZzLmV4aXN0c1N5bmModGFyZ2V0UGF0aCkpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICAvLyBjb3B5IGZpbGUvZGlyZWN0b3J5IHRvIHN0YWdpbmcgZGlyZWN0b3J5XG4gICAgY29uc3Qgc3RhdCA9IGZzLnN0YXRTeW5jKHRoaXMuc291cmNlUGF0aCk7XG4gICAgaWYgKHN0YXQuaXNGaWxlKCkpIHtcbiAgICAgIGZzLmNvcHlGaWxlU3luYyh0aGlzLnNvdXJjZVBhdGgsIHRhcmdldFBhdGgpO1xuICAgIH0gZWxzZSBpZiAoc3RhdC5pc0RpcmVjdG9yeSgpKSB7XG4gICAgICBmcy5ta2RpclN5bmModGFyZ2V0UGF0aCk7XG4gICAgICBGaWxlU3lzdGVtLmNvcHlEaXJlY3RvcnkodGhpcy5zb3VyY2VQYXRoLCB0YXJnZXRQYXRoLCB0aGlzLmZpbmdlcnByaW50T3B0aW9ucyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgVW5rbm93biBmaWxlIHR5cGU6ICR7dGhpcy5zb3VyY2VQYXRofWApO1xuICAgIH1cbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset-staging.js","sourceRoot":"","sources":["asset-staging.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cxapi from '@aws-cdk/cx-api';\nimport * as fs from 'fs';\nimport * as os from 'os';\nimport * as path from 'path';\nimport { AssetHashType, AssetOptions } from './assets';\nimport { BUNDLING_INPUT_DIR, BUNDLING_OUTPUT_DIR, BundlingOptions } from './bundling';\nimport { Construct, ISynthesisSession } from './construct-compat';\nimport { FileSystem, FingerprintOptions } from './fs';\n\n/**\n * Initialization properties for `AssetStaging`.\n */\nexport interface AssetStagingProps extends FingerprintOptions, AssetOptions {\n  /**\n   * The source file or directory to copy from.\n   */\n  readonly sourcePath: string;\n}\n\n/**\n * Stages a file or directory from a location on the file system into a staging\n * directory.\n *\n * This is controlled by the context key 'aws:cdk:asset-staging' and enabled\n * by the CLI by default in order to ensure that when the CDK app exists, all\n * assets are available for deployment. Otherwise, if an app references assets\n * in temporary locations, those will not be available when it exists (see\n * https://github.com/aws/aws-cdk/issues/1716).\n *\n * The `stagedPath` property is a stringified token that represents the location\n * of the file or directory after staging. It will be resolved only during the\n * \"prepare\" stage and may be either the original path or the staged path\n * depending on the context setting.\n *\n * The file/directory are staged based on their content hash (fingerprint). This\n * means that only if content was changed, copy will happen.\n */\nexport class AssetStaging extends Construct {\n  /**\n   * The path to the asset (stringinfied token).\n   *\n   * If asset staging is disabled, this will just be the original path.\n   * If asset staging is enabled it will be the staged path.\n   */\n  public readonly stagedPath: string;\n\n  /**\n   * The path of the asset as it was referenced by the user.\n   */\n  public readonly sourcePath: string;\n\n  /**\n   * A cryptographic hash of the asset.\n   *\n   * @deprecated see `assetHash`.\n   */\n  public readonly sourceHash: string;\n\n  /**\n   * A cryptographic hash of the asset.\n   */\n  public readonly assetHash: string;\n\n  private readonly fingerprintOptions: FingerprintOptions;\n\n  private readonly relativePath?: string;\n\n  private readonly bundleDir?: string;\n\n  constructor(scope: Construct, id: string, props: AssetStagingProps) {\n    super(scope, id);\n\n    this.sourcePath = props.sourcePath;\n    this.fingerprintOptions = props;\n\n    if (props.bundling) {\n      this.bundleDir = this.bundle(props.bundling);\n    }\n\n    this.assetHash = this.calculateHash(props);\n\n    const stagingDisabled = this.node.tryGetContext(cxapi.DISABLE_ASSET_STAGING_CONTEXT);\n    if (stagingDisabled) {\n      this.stagedPath = this.bundleDir ?? this.sourcePath;\n    } else {\n      this.relativePath = `asset.${this.assetHash}${path.extname(this.bundleDir ?? this.sourcePath)}`;\n      this.stagedPath = this.relativePath;\n    }\n\n    this.sourceHash = this.assetHash;\n  }\n\n  protected synthesize(session: ISynthesisSession) {\n    // Staging is disabled\n    if (!this.relativePath) {\n      return;\n    }\n\n    const targetPath = path.join(session.assembly.outdir, this.relativePath);\n\n    // Already staged\n    if (fs.existsSync(targetPath)) {\n      return;\n    }\n\n    // Asset has been bundled\n    if (this.bundleDir) {\n      // Try to rename bundling directory to staging directory\n      try {\n        fs.renameSync(this.bundleDir, targetPath);\n        return;\n      } catch (err) {\n        // /tmp and cdk.out could be mounted across different mount points\n        // in this case we will fallback to copying. This can happen in Windows\n        // Subsystem for Linux (WSL).\n        if (err.code === 'EXDEV') {\n          fs.mkdirSync(targetPath);\n          FileSystem.copyDirectory(this.bundleDir, targetPath, this.fingerprintOptions);\n          return;\n        }\n\n        throw err;\n      }\n    }\n\n    // Copy file/directory to staging directory\n    const stat = fs.statSync(this.sourcePath);\n    if (stat.isFile()) {\n      fs.copyFileSync(this.sourcePath, targetPath);\n    } else if (stat.isDirectory()) {\n      fs.mkdirSync(targetPath);\n      FileSystem.copyDirectory(this.sourcePath, targetPath, this.fingerprintOptions);\n    } else {\n      throw new Error(`Unknown file type: ${this.sourcePath}`);\n    }\n  }\n\n  private bundle(options: BundlingOptions): string {\n    // Create temporary directory for bundling\n    const bundleDir = fs.mkdtempSync(path.resolve(path.join(os.tmpdir(), 'cdk-asset-bundle-')));\n\n    // Always mount input and output dir\n    const volumes = [\n      {\n        hostPath: this.sourcePath,\n        containerPath: BUNDLING_INPUT_DIR,\n      },\n      {\n        hostPath: bundleDir,\n        containerPath: BUNDLING_OUTPUT_DIR,\n      },\n      ...options.volumes ?? [],\n    ];\n\n    try {\n      options.image._run({\n        command: options.command,\n        volumes,\n        environment: options.environment,\n        workingDirectory: options.workingDirectory ?? BUNDLING_INPUT_DIR,\n      });\n    } catch (err) {\n      throw new Error(`Failed to run bundling Docker image for asset ${this.node.path}: ${err}`);\n    }\n\n    if (FileSystem.isEmpty(bundleDir)) {\n      throw new Error(`Bundling did not produce any output. Check that your container writes content to ${BUNDLING_OUTPUT_DIR}.`);\n    }\n\n    return bundleDir;\n  }\n\n  private calculateHash(props: AssetStagingProps): string {\n    let hashType: AssetHashType;\n\n    if (props.assetHash) {\n      if (props.assetHashType && props.assetHashType !== AssetHashType.CUSTOM) {\n        throw new Error(`Cannot specify \\`${props.assetHashType}\\` for \\`assetHashType\\` when \\`assetHash\\` is specified. Use \\`CUSTOM\\` or leave \\`undefined\\`.`);\n      }\n      hashType = AssetHashType.CUSTOM;\n    } else if (props.assetHashType) {\n      hashType = props.assetHashType;\n    } else {\n      hashType = AssetHashType.SOURCE;\n    }\n\n    switch (hashType) {\n      case AssetHashType.SOURCE:\n        return FileSystem.fingerprint(this.sourcePath, this.fingerprintOptions);\n      case AssetHashType.BUNDLE:\n        if (!this.bundleDir) {\n          throw new Error('Cannot use `AssetHashType.BUNDLE` when `bundling` is not specified.');\n        }\n        return FileSystem.fingerprint(this.bundleDir, this.fingerprintOptions);\n      case AssetHashType.CUSTOM:\n        if (!props.assetHash) {\n          throw new Error('`assetHash` must be specified when `assetHashType` is set to `AssetHashType.CUSTOM`.');\n        }\n        return props.assetHash;\n      default:\n        throw new Error('Unknown asset hash type.');\n    }\n  }\n}\n"]}

@@ -0,2 +1,72 @@

import { BundlingOptions } from './bundling';
/**
* Common interface for all assets.
*/
export interface IAsset {
/**
* A hash of this asset, which is available at construction time. As this is a plain string, it
* can be used in construct IDs in order to enforce creation of a new resource when the content
* hash has changed.
*/
readonly assetHash: string;
}
/**
* Asset hash options
*/
export interface AssetOptions {
/**
* Specify a custom hash for this asset. If `assetHashType` is set it must
* be set to `AssetHashType.CUSTOM`.
*
* NOTE: the hash is used in order to identify a specific revision of the asset, and
* used for optimizing and caching deployment activities related to this asset such as
* packaging, uploading to Amazon S3, etc. If you chose to customize the hash, you will
* need to make sure it is updated every time the asset changes, or otherwise it is
* possible that some deployments will not be invalidated.
*
* @default - based on `assetHashType`
*/
readonly assetHash?: string;
/**
* Specifies the type of hash to calculate for this asset.
*
* If `assetHash` is configured, this option must be `undefined` or
* `AssetHashType.CUSTOM`.
*
* @default - the default is `AssetHashType.SOURCE`, but if `assetHash` is
* explicitly specified this value defaults to `AssetHashType.CUSTOM`.
*/
readonly assetHashType?: AssetHashType;
/**
* Bundle the asset by executing a command in a Docker container.
* The asset path will be mounted at `/asset-input`. The Docker
* container is responsible for putting content at `/asset-output`.
* The content at `/asset-output` will be zipped and used as the
* final asset.
*
* @default - uploaded as-is to S3 if the asset is a regular file or a .zip file,
* archived into a .zip file and uploaded to S3 otherwise
*
* @experimental
*/
readonly bundling?: BundlingOptions;
}
/**
* The type of asset hash
*/
export declare enum AssetHashType {
/**
* Based on the content of the source path
*/
SOURCE = "source",
/**
* Based on the content of the bundled path
*/
BUNDLE = "bundle",
/**
* Use a custom hash
*/
CUSTOM = "custom"
}
/**
* Represents the source for a file asset.

@@ -3,0 +73,0 @@ */

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
/**
* The type of asset hash
*/
var AssetHashType;
(function (AssetHashType) {
/**
* Based on the content of the source path
*/
AssetHashType["SOURCE"] = "source";
/**
* Based on the content of the bundled path
*/
AssetHashType["BUNDLE"] = "bundle";
/**
* Use a custom hash
*/
AssetHashType["CUSTOM"] = "custom";
})(AssetHashType = exports.AssetHashType || (exports.AssetHashType = {}));
/**
* Packaging modes for file assets.

@@ -19,2 +37,2 @@ */

})(FileAssetPackaging = exports.FileAssetPackaging || (exports.FileAssetPackaging = {}));
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXNzZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBK0VBOztHQUVHO0FBQ0gsSUFBWSxrQkFZWDtBQVpELFdBQVksa0JBQWtCO0lBQzVCOzs7T0FHRztJQUNILDJDQUFxQixDQUFBO0lBRXJCOzs7T0FHRztJQUNILG1DQUFhLENBQUE7QUFDZixDQUFDLEVBWlcsa0JBQWtCLEdBQWxCLDBCQUFrQixLQUFsQiwwQkFBa0IsUUFZN0IiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFJlcHJlc2VudHMgdGhlIHNvdXJjZSBmb3IgYSBmaWxlIGFzc2V0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEZpbGVBc3NldFNvdXJjZSB7XG4gIC8qKlxuICAgKiBBIGhhc2ggb24gdGhlIGNvbnRlbnQgc291cmNlLiBUaGlzIGhhc2ggaXMgdXNlZCB0byB1bmlxdWVseSBpZGVudGlmeSB0aGlzXG4gICAqIGFzc2V0IHRocm91Z2hvdXQgdGhlIHN5c3RlbS4gSWYgdGhpcyB2YWx1ZSBkb2Vzbid0IGNoYW5nZSwgdGhlIGFzc2V0IHdpbGxcbiAgICogbm90IGJlIHJlYnVpbHQgb3IgcmVwdWJsaXNoZWQuXG4gICAqL1xuICByZWFkb25seSBzb3VyY2VIYXNoOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBwYXRoLCByZWxhdGl2ZSB0byB0aGUgcm9vdCBvZiB0aGUgY2xvdWQgYXNzZW1ibHksIGluIHdoaWNoIHRoaXMgYXNzZXRcbiAgICogc291cmNlIHJlc2lkZXMuIFRoaXMgY2FuIGJlIGEgcGF0aCB0byBhIGZpbGUgb3IgYSBkaXJlY3RvcnksIGRlcGVuZG5pbmcgb24gdGhlXG4gICAqIHBhY2thZ2luZyB0eXBlLlxuICAgKi9cbiAgcmVhZG9ubHkgZmlsZU5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogV2hpY2ggdHlwZSBvZiBwYWNrYWdpbmcgdG8gcGVyZm9ybS5cbiAgICovXG4gIHJlYWRvbmx5IHBhY2thZ2luZzogRmlsZUFzc2V0UGFja2FnaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERvY2tlckltYWdlQXNzZXRTb3VyY2Uge1xuICAvKipcbiAgICogVGhlIGhhc2ggb2YgdGhlIGNvbnRlbnRzIG9mIHRoZSBkb2NrZXIgYnVpbGQgY29udGV4dC4gVGhpcyBoYXNoIGlzIHVzZWRcbiAgICogdGhyb3VnaG91dCB0aGUgc3lzdGVtIHRvIGlkZW50aWZ5IHRoaXMgaW1hZ2UgYW5kIGF2b2lkIGR1cGxpY2F0ZSB3b3JrXG4gICAqIGluIGNhc2UgdGhlIHNvdXJjZSBkaWQgbm90IGNoYW5nZS5cbiAgICpcbiAgICogTk9URTogdGhpcyBtZWFucyB0aGF0IGlmIHlvdSB3aXNoIHRvIHVwZGF0ZSB5b3VyIGRvY2tlciBpbWFnZSwgeW91XG4gICAqIG11c3QgbWFrZSBhIG1vZGlmaWNhdGlvbiB0byB0aGUgc291cmNlIChlLmcuIGFkZCBzb21lIG1ldGFkYXRhIHRvIHlvdXIgRG9ja2VyZmlsZSkuXG4gICAqL1xuICByZWFkb25seSBzb3VyY2VIYXNoOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBkaXJlY3Rvcnkgd2hlcmUgdGhlIERvY2tlcmZpbGUgaXMgc3RvcmVkLCBtdXN0IGJlIHJlbGF0aXZlXG4gICAqIHRvIHRoZSBjbG91ZCBhc3NlbWJseSByb290LlxuICAgKi9cbiAgcmVhZG9ubHkgZGlyZWN0b3J5TmFtZTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBCdWlsZCBhcmdzIHRvIHBhc3MgdG8gdGhlIGBkb2NrZXIgYnVpbGRgIGNvbW1hbmQuXG4gICAqXG4gICAqIFNpbmNlIERvY2tlciBidWlsZCBhcmd1bWVudHMgYXJlIHJlc29sdmVkIGJlZm9yZSBkZXBsb3ltZW50LCBrZXlzIGFuZFxuICAgKiB2YWx1ZXMgY2Fubm90IHJlZmVyIHRvIHVucmVzb2x2ZWQgdG9rZW5zIChzdWNoIGFzIGBsYW1iZGEuZnVuY3Rpb25Bcm5gIG9yXG4gICAqIGBxdWV1ZS5xdWV1ZVVybGApLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIGJ1aWxkIGFyZ3MgYXJlIHBhc3NlZFxuICAgKi9cbiAgcmVhZG9ubHkgZG9ja2VyQnVpbGRBcmdzPzogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfTtcblxuICAvKipcbiAgICogRG9ja2VyIHRhcmdldCB0byBidWlsZCB0b1xuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIHRhcmdldFxuICAgKi9cbiAgcmVhZG9ubHkgZG9ja2VyQnVpbGRUYXJnZXQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFBhdGggdG8gdGhlIERvY2tlcmZpbGUgKHJlbGF0aXZlIHRvIHRoZSBkaXJlY3RvcnkpLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIGZpbGVcbiAgICovXG4gIHJlYWRvbmx5IGRvY2tlckZpbGU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEVDUiByZXBvc2l0b3J5IG5hbWVcbiAgICpcbiAgICogU3BlY2lmeSB0aGlzIHByb3BlcnR5IGlmIHlvdSBuZWVkIHRvIHN0YXRpY2FsbHkgYWRkcmVzcyB0aGUgaW1hZ2UsIGUuZy5cbiAgICogZnJvbSBhIEt1YmVybmV0ZXMgUG9kLiBOb3RlLCB0aGlzIGlzIG9ubHkgdGhlIHJlcG9zaXRvcnkgbmFtZSwgd2l0aG91dCB0aGVcbiAgICogcmVnaXN0cnkgYW5kIHRoZSB0YWcgcGFydHMuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gYXV0b21hdGljYWxseSBkZXJpdmVkIGZyb20gdGhlIGFzc2V0J3MgSUQuXG4gICAqIEBkZXByZWNhdGVkIHJlcG9zaXRvcnkgbmFtZSBzaG91bGQgYmUgc3BlY2lmaWVkIGF0IHRoZSBlbnZpcm9ubWVudC1sZXZlbCBhbmQgbm90IGF0IHRoZSBpbWFnZSBsZXZlbFxuICAgKi9cbiAgcmVhZG9ubHkgcmVwb3NpdG9yeU5hbWU/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogUGFja2FnaW5nIG1vZGVzIGZvciBmaWxlIGFzc2V0cy5cbiAqL1xuZXhwb3J0IGVudW0gRmlsZUFzc2V0UGFja2FnaW5nIHtcbiAgLyoqXG4gICAqIFRoZSBhc3NldCBzb3VyY2UgcGF0aCBwb2ludHMgdG8gYSBkaXJlY3RvcnksIHdoaWNoIHNob3VsZCBiZSBhcmNoaXZlZCB1c2luZ1xuICAgKiB6aXAgYW5kIGFuZCB0aGVuIHVwbG9hZGVkIHRvIEFtYXpvbiBTMy5cbiAgICovXG4gIFpJUF9ESVJFQ1RPUlkgPSAnemlwJyxcblxuICAvKipcbiAgICogVGhlIGFzc2V0IHNvdXJjZSBwYXRoIHBvaW50cyB0byBhIHNpbmdsZSBmaWxlLCB3aGljaCBzaG91bGQgYmUgdXBsb2FkZWRcbiAgICogdG8gQW1hem9uIFMzLlxuICAgKi9cbiAgRklMRSA9ICdmaWxlJ1xufVxuXG4vKipcbiAqIFRoZSBsb2NhdGlvbiBvZiB0aGUgcHVibGlzaGVkIGZpbGUgYXNzZXQuIFRoaXMgaXMgd2hlcmUgdGhlIGFzc2V0XG4gKiBjYW4gYmUgY29uc3VtZWQgYXQgcnVudGltZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBGaWxlQXNzZXRMb2NhdGlvbiB7XG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB0aGUgQW1hem9uIFMzIGJ1Y2tldC5cbiAgICovXG4gIHJlYWRvbmx5IGJ1Y2tldE5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIEFtYXpvbiBTMyBvYmplY3Qga2V5LlxuICAgKi9cbiAgcmVhZG9ubHkgb2JqZWN0S2V5OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBIVFRQIFVSTCBvZiB0aGlzIGFzc2V0IG9uIEFtYXpvbiBTMy5cbiAgICogQGRlcHJlY2F0ZWQgdXNlIGBodHRwVXJsYFxuICAgKi9cbiAgcmVhZG9ubHkgczNVcmw6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIEhUVFAgVVJMIG9mIHRoaXMgYXNzZXQgb24gQW1hem9uIFMzLlxuICAgKlxuICAgKiBAZXhhbXBsZSBodHRwczovL3MzLXVzLWVhc3QtMS5hbWF6b25hd3MuY29tL215YnVja2V0L215b2JqZWN0XG4gICAqL1xuICByZWFkb25seSBodHRwVXJsOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBTMyBVUkwgb2YgdGhpcyBhc3NldCBvbiBBbWF6b24gUzMuXG4gICAqXG4gICAqIEBleGFtcGxlIHMzOi8vbXlidWNrZXQvbXlvYmplY3RcbiAgICovXG4gIHJlYWRvbmx5IHMzT2JqZWN0VXJsOiBzdHJpbmc7XG59XG5cbi8qKlxuICogVGhlIGxvY2F0aW9uIG9mIHRoZSBwdWJsaXNoZWQgZG9ja2VyIGltYWdlLiBUaGlzIGlzIHdoZXJlIHRoZSBpbWFnZSBjYW4gYmVcbiAqIGNvbnN1bWVkIGF0IHJ1bnRpbWUuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRG9ja2VySW1hZ2VBc3NldExvY2F0aW9uIHtcbiAgLyoqXG4gICAqIFRoZSBVUkkgb2YgdGhlIGltYWdlIGluIEFtYXpvbiBFQ1IuXG4gICAqL1xuICByZWFkb25seSBpbWFnZVVyaTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB0aGUgRUNSIHJlcG9zaXRvcnkuXG4gICAqL1xuICByZWFkb25seSByZXBvc2l0b3J5TmFtZTogc3RyaW5nO1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assets.js","sourceRoot":"","sources":["assets.ts"],"names":[],"mappings":";;AA0DA;;GAEG;AACH,IAAY,aAeX;AAfD,WAAY,aAAa;IACvB;;OAEG;IACH,kCAAiB,CAAA;IAEjB;;OAEG;IACH,kCAAiB,CAAA;IAEjB;;OAEG;IACH,kCAAiB,CAAA;AACnB,CAAC,EAfW,aAAa,GAAb,qBAAa,KAAb,qBAAa,QAexB;AAiFD;;GAEG;AACH,IAAY,kBAYX;AAZD,WAAY,kBAAkB;IAC5B;;;OAGG;IACH,2CAAqB,CAAA;IAErB;;;OAGG;IACH,mCAAa,CAAA;AACf,CAAC,EAZW,kBAAkB,GAAlB,0BAAkB,KAAlB,0BAAkB,QAY7B","sourcesContent":["import { BundlingOptions } from './bundling';\n\n/**\n * Common interface for all assets.\n */\nexport interface IAsset {\n  /**\n   * A hash of this asset, which is available at construction time. As this is a plain string, it\n   * can be used in construct IDs in order to enforce creation of a new resource when the content\n   * hash has changed.\n   */\n  readonly assetHash: string;\n}\n\n/**\n * Asset hash options\n */\nexport interface AssetOptions {\n  /**\n   * Specify a custom hash for this asset. If `assetHashType` is set it must\n   * be set to `AssetHashType.CUSTOM`.\n   *\n   * NOTE: the hash is used in order to identify a specific revision of the asset, and\n   * used for optimizing and caching deployment activities related to this asset such as\n   * packaging, uploading to Amazon S3, etc. If you chose to customize the hash, you will\n   * need to make sure it is updated every time the asset changes, or otherwise it is\n   * possible that some deployments will not be invalidated.\n   *\n   * @default - based on `assetHashType`\n   */\n  readonly assetHash?: string;\n\n  /**\n   * Specifies the type of hash to calculate for this asset.\n   *\n   * If `assetHash` is configured, this option must be `undefined` or\n   * `AssetHashType.CUSTOM`.\n   *\n   * @default - the default is `AssetHashType.SOURCE`, but if `assetHash` is\n   * explicitly specified this value defaults to `AssetHashType.CUSTOM`.\n   */\n  readonly assetHashType?: AssetHashType;\n\n  /**\n   * Bundle the asset by executing a command in a Docker container.\n   * The asset path will be mounted at `/asset-input`. The Docker\n   * container is responsible for putting content at `/asset-output`.\n   * The content at `/asset-output` will be zipped and used as the\n   * final asset.\n   *\n   * @default - uploaded as-is to S3 if the asset is a regular file or a .zip file,\n   * archived into a .zip file and uploaded to S3 otherwise\n   *\n   * @experimental\n   */\n  readonly bundling?: BundlingOptions;\n}\n\n/**\n * The type of asset hash\n */\nexport enum AssetHashType {\n  /**\n   * Based on the content of the source path\n   */\n  SOURCE = 'source',\n\n  /**\n   * Based on the content of the bundled path\n   */\n  BUNDLE = 'bundle',\n\n  /**\n   * Use a custom hash\n   */\n  CUSTOM = 'custom',\n}\n\n/**\n * Represents the source for a file asset.\n */\nexport interface FileAssetSource {\n  /**\n   * A hash on the content source. This hash is used to uniquely identify this\n   * asset throughout the system. If this value doesn't change, the asset will\n   * not be rebuilt or republished.\n   */\n  readonly sourceHash: string;\n\n  /**\n   * The path, relative to the root of the cloud assembly, in which this asset\n   * source resides. This can be a path to a file or a directory, dependning on the\n   * packaging type.\n   */\n  readonly fileName: string;\n\n  /**\n   * Which type of packaging to perform.\n   */\n  readonly packaging: FileAssetPackaging;\n}\n\nexport interface DockerImageAssetSource {\n  /**\n   * The hash of the contents of the docker build context. This hash is used\n   * throughout the system to identify this image and avoid duplicate work\n   * in case the source did not change.\n   *\n   * NOTE: this means that if you wish to update your docker image, you\n   * must make a modification to the source (e.g. add some metadata to your Dockerfile).\n   */\n  readonly sourceHash: string;\n\n  /**\n   * The directory where the Dockerfile is stored, must be relative\n   * to the cloud assembly root.\n   */\n  readonly directoryName: string;\n\n  /**\n   * Build args to pass to the `docker build` command.\n   *\n   * Since Docker build arguments are resolved before deployment, keys and\n   * values cannot refer to unresolved tokens (such as `lambda.functionArn` or\n   * `queue.queueUrl`).\n   *\n   * @default - no build args are passed\n   */\n  readonly dockerBuildArgs?: { [key: string]: string };\n\n  /**\n   * Docker target to build to\n   *\n   * @default - no target\n   */\n  readonly dockerBuildTarget?: string;\n\n  /**\n   * Path to the Dockerfile (relative to the directory).\n   *\n   * @default - no file\n   */\n  readonly dockerFile?: string;\n\n  /**\n   * ECR repository name\n   *\n   * Specify this property if you need to statically address the image, e.g.\n   * from a Kubernetes Pod. Note, this is only the repository name, without the\n   * registry and the tag parts.\n   *\n   * @default - automatically derived from the asset's ID.\n   * @deprecated repository name should be specified at the environment-level and not at the image level\n   */\n  readonly repositoryName?: string;\n}\n\n/**\n * Packaging modes for file assets.\n */\nexport enum FileAssetPackaging {\n  /**\n   * The asset source path points to a directory, which should be archived using\n   * zip and and then uploaded to Amazon S3.\n   */\n  ZIP_DIRECTORY = 'zip',\n\n  /**\n   * The asset source path points to a single file, which should be uploaded\n   * to Amazon S3.\n   */\n  FILE = 'file'\n}\n\n/**\n * The location of the published file asset. This is where the asset\n * can be consumed at runtime.\n */\nexport interface FileAssetLocation {\n  /**\n   * The name of the Amazon S3 bucket.\n   */\n  readonly bucketName: string;\n\n  /**\n   * The Amazon S3 object key.\n   */\n  readonly objectKey: string;\n\n  /**\n   * The HTTP URL of this asset on Amazon S3.\n   * @deprecated use `httpUrl`\n   */\n  readonly s3Url: string;\n\n  /**\n   * The HTTP URL of this asset on Amazon S3.\n   *\n   * @example https://s3-us-east-1.amazonaws.com/mybucket/myobject\n   */\n  readonly httpUrl: string;\n\n  /**\n   * The S3 URL of this asset on Amazon S3.\n   *\n   * @example s3://mybucket/myobject\n   */\n  readonly s3ObjectUrl: string;\n}\n\n/**\n * The location of the published docker image. This is where the image can be\n * consumed at runtime.\n */\nexport interface DockerImageAssetLocation {\n  /**\n   * The URI of the image in Amazon ECR.\n   */\n  readonly imageUri: string;\n\n  /**\n   * The name of the ECR repository.\n   */\n  readonly repositoryName: string;\n}\n"]}

@@ -128,2 +128,4 @@ /**

* Options for synthesis.
*
* @deprecated use `app.synth()` or `stage.synth()` instead
*/

@@ -152,9 +154,11 @@ export interface SynthesisOptions extends cxapi.AssemblyBuildOptions {

* Synthesizes a CloudAssembly from a construct tree.
* @param root The root of the construct tree.
* @param node The root of the construct tree.
* @param options Synthesis options.
* @deprecated Use `app.synth()` or `stage.synth()` instead
*/
static synth(root: ConstructNode, options?: SynthesisOptions): cxapi.CloudAssembly;
static synth(node: ConstructNode, options?: SynthesisOptions): cxapi.CloudAssembly;
/**
* Invokes "prepare" on all constructs (depth-first, post-order) in the tree under `node`.
* @param node The root node
* @deprecated Use `app.synth()` instead
*/

@@ -161,0 +165,0 @@ static prepare(node: ConstructNode): void;

@@ -165,15 +165,10 @@ "use strict";

* Synthesizes a CloudAssembly from a construct tree.
* @param root The root of the construct tree.
* @param node The root of the construct tree.
* @param options Synthesis options.
* @deprecated Use `app.synth()` or `stage.synth()` instead
*/
static synth(root, options = {}) {
const builder = new cxapi.CloudAssemblyBuilder(options.outdir);
root._actualNode.synthesize({
outdir: builder.outdir,
skipValidation: options.skipValidation,
sessionContext: {
assembly: builder,
},
});
return builder.buildAssembly(options);
static synth(node, options = {}) {
// eslint-disable-next-line @typescript-eslint/no-require-imports
const a = require('./private/synthesis');
return a.synthesize(node.root, options);
}

@@ -183,4 +178,8 @@ /**

* @param node The root node
* @deprecated Use `app.synth()` instead
*/
static prepare(node) {
// eslint-disable-next-line @typescript-eslint/no-require-imports
const p = require('./private/prepare-app');
p.prepareApp(node.root); // resolve cross refs and nested stack assets.
return node._actualNode.prepare();

@@ -382,2 +381,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"construct-compat.js","sourceRoot":"","sources":["construct-compat.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Constructs compatibility layer.\n *\n * This file includes types that shadow types in the \"constructs\" module in\n * order to allow backwards-compatiblity in the AWS CDK v1.0 release line.\n *\n * There are pretty ugly hacks here, which mostly involve downcasting types to\n * adhere to legacy AWS CDK APIs.\n *\n * This file, in its entirety, is expected to be removed in v2.0.\n */\n\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as constructs from 'constructs';\nimport { IAspect } from './aspect';\nimport { IDependable } from './dependency';\nimport { Token } from './token';\n\nconst ORIGINAL_CONSTRUCT_NODE_SYMBOL = Symbol.for('@aws-cdk/core.ConstructNode');\nconst CONSTRUCT_SYMBOL = Symbol.for('@aws-cdk/core.Construct');\n\n/**\n * Represents a construct.\n */\nexport interface IConstruct extends constructs.IConstruct, IDependable {\n  /**\n   * The construct tree node for this construct.\n   */\n  readonly node: ConstructNode;\n}\n\n/**\n * Represents a single session of synthesis. Passed into `Construct.synthesize()` methods.\n */\nexport interface ISynthesisSession {\n  /**\n   * The output directory for this synthesis session.\n   */\n  outdir: string;\n\n  /**\n   * Cloud assembly builder.\n   */\n  assembly: cxapi.CloudAssemblyBuilder;\n}\n\n/**\n * Represents the building block of the construct graph.\n *\n * All constructs besides the root construct must be created within the scope of\n * another construct.\n */\nexport class Construct extends constructs.Construct implements IConstruct {\n  /**\n   * Return whether the given object is a Construct\n   */\n  public static isConstruct(x: any): x is Construct {\n    return typeof x === 'object' && x !== null && CONSTRUCT_SYMBOL in x;\n  }\n\n  /**\n   * The construct tree node associated with this construct.\n   */\n  public readonly node: ConstructNode;\n\n  constructor(scope: Construct, id: string) {\n    super(scope, id, {\n      nodeFactory: {\n        createNode: (h: constructs.Construct, s: constructs.IConstruct, i: string) =>\n          new ConstructNode(h as Construct, s as IConstruct, i)._actualNode,\n      },\n    });\n\n    if (Token.isUnresolved(id)) {\n      throw new Error(`Cannot use tokens in construct ID: ${id}`);\n    }\n\n    Object.defineProperty(this, CONSTRUCT_SYMBOL, { value: true });\n    this.node = ConstructNode._unwrap(constructs.Node.of(this));\n\n    const disableTrace = this.node.tryGetContext(cxapi.DISABLE_METADATA_STACK_TRACE);\n    if (disableTrace) {\n      this.node.setContext(constructs.ConstructMetadata.DISABLE_STACK_TRACE_IN_METADATA, true);\n    }\n  }\n\n  /**\n   * Validate the current construct.\n   *\n   * This method can be implemented by derived constructs in order to perform\n   * validation logic. It is called on all constructs before synthesis.\n   *\n   * @returns An array of validation error messages, or an empty array if the construct is valid.\n   */\n  protected onValidate(): string[] {\n    return this.validate();\n  }\n\n  /**\n   * Perform final modifications before synthesis\n   *\n   * This method can be implemented by derived constructs in order to perform\n   * final changes before synthesis. prepare() will be called after child\n   * constructs have been prepared.\n   *\n   * This is an advanced framework feature. Only use this if you\n   * understand the implications.\n   */\n  protected onPrepare(): void {\n    this.prepare();\n  }\n\n  /**\n   * Allows this construct to emit artifacts into the cloud assembly during synthesis.\n   *\n   * This method is usually implemented by framework-level constructs such as `Stack` and `Asset`\n   * as they participate in synthesizing the cloud assembly.\n   *\n   * @param session The synthesis session.\n   */\n  protected onSynthesize(session: constructs.ISynthesisSession): void {\n    this.synthesize({\n      outdir: session.outdir,\n      assembly: session.assembly!,\n    });\n  }\n\n  /**\n   * Validate the current construct.\n   *\n   * This method can be implemented by derived constructs in order to perform\n   * validation logic. It is called on all constructs before synthesis.\n   *\n   * @returns An array of validation error messages, or an empty array if the construct is valid.\n   */\n  protected validate(): string[] {\n    return [];\n  }\n\n  /**\n   * Perform final modifications before synthesis\n   *\n   * This method can be implemented by derived constructs in order to perform\n   * final changes before synthesis. prepare() will be called after child\n   * constructs have been prepared.\n   *\n   * This is an advanced framework feature. Only use this if you\n   * understand the implications.\n   */\n  protected prepare(): void {\n    return;\n  }\n\n  /**\n   * Allows this construct to emit artifacts into the cloud assembly during synthesis.\n   *\n   * This method is usually implemented by framework-level constructs such as `Stack` and `Asset`\n   * as they participate in synthesizing the cloud assembly.\n   *\n   * @param session The synthesis session.\n   */\n  protected synthesize(session: ISynthesisSession): void {\n    ignore(session);\n  }\n}\n\n/**\n * In what order to return constructs\n */\nexport enum ConstructOrder {\n  /**\n   * Depth-first, pre-order\n   */\n  PREORDER,\n\n  /**\n   * Depth-first, post-order (leaf nodes first)\n   */\n  POSTORDER\n}\n\n/**\n * Options for synthesis.\n */\nexport interface SynthesisOptions extends cxapi.AssemblyBuildOptions {\n  /**\n   * The output directory into which to synthesize the cloud assembly.\n   * @default - creates a temporary directory\n   */\n  readonly outdir?: string;\n\n  /**\n   * Whether synthesis should skip the validation phase.\n   * @default false\n   */\n  readonly skipValidation?: boolean;\n}\n\n/**\n * Represents the construct node in the scope tree.\n */\nexport class ConstructNode {\n  /**\n   * Separator used to delimit construct path components.\n   */\n  public static readonly PATH_SEP = '/';\n\n  /**\n   * Returns the wrapping `@aws-cdk/core.ConstructNode` instance from a `constructs.ConstructNode`.\n   *\n   * @internal\n   */\n  public static _unwrap(c: constructs.Node): ConstructNode {\n    const x = (c as any)[ORIGINAL_CONSTRUCT_NODE_SYMBOL];\n    if (!x) {\n      throw new Error('invalid ConstructNode type');\n    }\n\n    return x;\n  }\n\n  /**\n   * Synthesizes a CloudAssembly from a construct tree.\n   * @param root The root of the construct tree.\n   * @param options Synthesis options.\n   */\n  public static synth(root: ConstructNode, options: SynthesisOptions = { }): cxapi.CloudAssembly {\n    const builder = new cxapi.CloudAssemblyBuilder(options.outdir);\n\n    root._actualNode.synthesize({\n      outdir: builder.outdir,\n      skipValidation: options.skipValidation,\n      sessionContext: {\n        assembly: builder,\n      },\n    });\n\n    return builder.buildAssembly(options);\n  }\n\n  /**\n   * Invokes \"prepare\" on all constructs (depth-first, post-order) in the tree under `node`.\n   * @param node The root node\n   */\n  public static prepare(node: ConstructNode) {\n    return node._actualNode.prepare();\n  }\n\n  /**\n   * Invokes \"validate\" on all constructs in the tree (depth-first, pre-order) and returns\n   * the list of all errors. An empty list indicates that there are no errors.\n   *\n   * @param node The root node\n   */\n  public static validate(node: ConstructNode): ValidationError[] {\n    return node._actualNode.validate().map(e => ({ source: e.source as Construct, message: e.message }));\n  }\n\n  /**\n   * @internal\n   */\n  public readonly _actualNode: constructs.Node;\n\n  constructor(host: Construct, scope: IConstruct, id: string) {\n    this._actualNode = new constructs.Node(host, scope, id);\n\n    // store a back reference on _actualNode so we can our ConstructNode from it\n    Object.defineProperty(this._actualNode, ORIGINAL_CONSTRUCT_NODE_SYMBOL, {\n      value: this,\n      configurable: false,\n      enumerable: false,\n    });\n  }\n\n  /**\n   * Returns the scope in which this construct is defined.\n   *\n   * The value is `undefined` at the root of the construct scope tree.\n   */\n  public get scope(): IConstruct | undefined {\n    return this._actualNode.scope as IConstruct;\n  }\n\n  /**\n   * The id of this construct within the current scope.\n   *\n   * This is a a scope-unique id. To obtain an app-unique id for this construct, use `uniqueId`.\n   */\n  public get id() { return this._actualNode.id; }\n\n  /**\n   * The full, absolute path of this construct in the tree.\n   *\n   * Components are separated by '/'.\n   */\n  public get path(): string { return this._actualNode.path; }\n\n  /**\n   * A tree-global unique alphanumeric identifier for this construct.\n   * Includes all components of the tree.\n   */\n  public get uniqueId(): string { return this._actualNode.uniqueId; }\n\n  /**\n   * Return a direct child by id, or undefined\n   *\n   * @param id Identifier of direct child\n   * @returns the child if found, or undefined\n   */\n  public tryFindChild(id: string): IConstruct | undefined { return this._actualNode.tryFindChild(id) as IConstruct; }\n\n  /**\n   * Return a direct child by id\n   *\n   * Throws an error if the child is not found.\n   *\n   * @param id Identifier of direct child\n   * @returns Child with the given id.\n   */\n  public findChild(id: string): IConstruct { return this._actualNode.findChild(id) as IConstruct; }\n\n  /**\n   * Returns the child construct that has the id `Default` or `Resource\"`.\n   * This is usually the construct that provides the bulk of the underlying functionality.\n   * Useful for modifications of the underlying construct that are not available at the higher levels.\n   *\n   * @throws if there is more than one child\n   * @returns a construct or undefined if there is no default child\n   */\n  public get defaultChild(): IConstruct | undefined { return this._actualNode.defaultChild as IConstruct; }\n\n  /**\n   * Override the defaultChild property.\n   *\n   * This should only be used in the cases where the correct\n   * default child is not named 'Resource' or 'Default' as it\n   * should be.\n   *\n   * If you set this to undefined, the default behavior of finding\n   * the child named 'Resource' or 'Default' will be used.\n   */\n  public set defaultChild(value: IConstruct | undefined) { this._actualNode.defaultChild = value; }\n\n  /**\n   * All direct children of this construct.\n   */\n  public get children(): IConstruct[] { return this._actualNode.children as IConstruct[]; }\n\n  /**\n   * Return this construct and all of its children in the given order\n   */\n  public findAll(order: ConstructOrder = ConstructOrder.PREORDER): IConstruct[] { return this._actualNode.findAll(order) as IConstruct[]; }\n\n  /**\n   * This can be used to set contextual values.\n   * Context must be set before any children are added, since children may consult context info during construction.\n   * If the key already exists, it will be overridden.\n   * @param key The context key\n   * @param value The context value\n   */\n  public setContext(key: string, value: any) {\n    if (Token.isUnresolved(key)) {\n      throw new Error('Invalid context key: context keys can\\'t include tokens');\n    }\n    this._actualNode.setContext(key, value);\n  }\n\n  /**\n   * Retrieves a value from tree context.\n   *\n   * Context is usually initialized at the root, but can be overridden at any point in the tree.\n   *\n   * @param key The context key\n   * @returns The context value or `undefined` if there is no context value for thie key.\n   */\n  public tryGetContext(key: string): any {\n    if (Token.isUnresolved(key)) {\n      throw new Error('Invalid context key: context keys can\\'t include tokens');\n    }\n    return this._actualNode.tryGetContext(key);\n  }\n\n  /**\n   * An immutable array of metadata objects associated with this construct.\n   * This can be used, for example, to implement support for deprecation notices, source mapping, etc.\n   */\n  public get metadata() { return this._actualNode.metadata as cxapi.MetadataEntry[]; }\n\n  /**\n   * Adds a metadata entry to this construct.\n   * Entries are arbitrary values and will also include a stack trace to allow tracing back to\n   * the code location for when the entry was added. It can be used, for example, to include source\n   * mapping in CloudFormation templates to improve diagnostics.\n   *\n   * @param type a string denoting the type of metadata\n   * @param data the value of the metadata (can be a Token). If null/undefined, metadata will not be added.\n   * @param fromFunction a function under which to restrict the metadata entry's stack trace (defaults to this.addMetadata)\n   */\n  public addMetadata(type: string, data: any, fromFunction?: any): void { this._actualNode.addMetadata(type, data, fromFunction); }\n\n  /**\n   * Adds a { \"info\": <message> } metadata entry to this construct.\n   * The toolkit will display the info message when apps are synthesized.\n   * @param message The info message.\n   */\n  public addInfo(message: string): void {\n    this._actualNode.addMetadata(cxschema.ArtifactMetadataEntryType.INFO, message);\n  }\n\n  /**\n   * Adds a { \"warning\": <message> } metadata entry to this construct.\n   * The toolkit will display the warning when an app is synthesized, or fail\n   * if run in --strict mode.\n   * @param message The warning message.\n   */\n  public addWarning(message: string): void {\n    this._actualNode.addMetadata(cxschema.ArtifactMetadataEntryType.WARN, message);\n  }\n\n  /**\n   * Adds an { \"error\": <message> } metadata entry to this construct.\n   * The toolkit will fail synthesis when errors are reported.\n   * @param message The error message.\n   */\n  public addError(message: string) {\n    this._actualNode.addMetadata(cxschema.ArtifactMetadataEntryType.ERROR, message);\n  }\n\n  /**\n   * Applies the aspect to this Constructs node\n   */\n  public applyAspect(aspect: IAspect): void { this._actualNode.applyAspect(aspect); }\n\n  /**\n   * All parent scopes of this construct.\n   *\n   * @returns a list of parent scopes. The last element in the list will always\n   * be the current construct and the first element will be the root of the\n   * tree.\n   */\n  public get scopes(): IConstruct[] { return this._actualNode.scopes as IConstruct[]; }\n\n  /**\n   * @returns The root of the construct tree.\n   */\n  public get root(): IConstruct { return this._actualNode.root as IConstruct; }\n\n  /**\n   * Returns true if this construct or the scopes in which it is defined are\n   * locked.\n   */\n  public get locked() { return this._actualNode.locked; }\n\n  /**\n   * Add an ordering dependency on another Construct.\n   *\n   * All constructs in the dependency's scope will be deployed before any\n   * construct in this construct's scope.\n   */\n  public addDependency(...dependencies: IDependable[]) { this._actualNode.addDependency(...dependencies); }\n\n  /**\n   * Return all dependencies registered on this node or any of its children\n   */\n  public get dependencies(): Dependency[] { return this._actualNode.dependencies as Dependency[]; }\n\n  /**\n   * Remove the child with the given name, if present.\n   *\n   * @returns Whether a child with the given name was deleted.\n   * @experimental\n   */\n  public tryRemoveChild(childName: string): boolean { return this._actualNode.tryRemoveChild(childName); }\n}\n\n/**\n * An error returned during the validation phase.\n */\nexport interface ValidationError {\n  /**\n   * The construct which emitted the error.\n   */\n  readonly source: Construct;\n\n  /**\n   * The error message.\n   */\n  readonly message: string;\n}\n\n/**\n * A single dependency\n */\nexport interface Dependency {\n  /**\n   * Source the dependency\n   */\n  readonly source: IConstruct;\n\n  /**\n   * Target of the dependency\n   */\n  readonly target: IConstruct;\n}\n\nfunction ignore(_x: any) {\n  return;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"construct-compat.js","sourceRoot":"","sources":["construct-compat.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Constructs compatibility layer.\n *\n * This file includes types that shadow types in the \"constructs\" module in\n * order to allow backwards-compatiblity in the AWS CDK v1.0 release line.\n *\n * There are pretty ugly hacks here, which mostly involve downcasting types to\n * adhere to legacy AWS CDK APIs.\n *\n * This file, in its entirety, is expected to be removed in v2.0.\n */\n\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as constructs from 'constructs';\nimport { IAspect } from './aspect';\nimport { IDependable } from './dependency';\nimport { Token } from './token';\n\nconst ORIGINAL_CONSTRUCT_NODE_SYMBOL = Symbol.for('@aws-cdk/core.ConstructNode');\nconst CONSTRUCT_SYMBOL = Symbol.for('@aws-cdk/core.Construct');\n\n/**\n * Represents a construct.\n */\nexport interface IConstruct extends constructs.IConstruct, IDependable {\n  /**\n   * The construct tree node for this construct.\n   */\n  readonly node: ConstructNode;\n}\n\n/**\n * Represents a single session of synthesis. Passed into `Construct.synthesize()` methods.\n */\nexport interface ISynthesisSession {\n  /**\n   * The output directory for this synthesis session.\n   */\n  outdir: string;\n\n  /**\n   * Cloud assembly builder.\n   */\n  assembly: cxapi.CloudAssemblyBuilder;\n}\n\n/**\n * Represents the building block of the construct graph.\n *\n * All constructs besides the root construct must be created within the scope of\n * another construct.\n */\nexport class Construct extends constructs.Construct implements IConstruct {\n  /**\n   * Return whether the given object is a Construct\n   */\n  public static isConstruct(x: any): x is Construct {\n    return typeof x === 'object' && x !== null && CONSTRUCT_SYMBOL in x;\n  }\n\n  /**\n   * The construct tree node associated with this construct.\n   */\n  public readonly node: ConstructNode;\n\n  constructor(scope: Construct, id: string) {\n    super(scope, id, {\n      nodeFactory: {\n        createNode: (h: constructs.Construct, s: constructs.IConstruct, i: string) =>\n          new ConstructNode(h as Construct, s as IConstruct, i)._actualNode,\n      },\n    });\n\n    if (Token.isUnresolved(id)) {\n      throw new Error(`Cannot use tokens in construct ID: ${id}`);\n    }\n\n    Object.defineProperty(this, CONSTRUCT_SYMBOL, { value: true });\n    this.node = ConstructNode._unwrap(constructs.Node.of(this));\n\n    const disableTrace = this.node.tryGetContext(cxapi.DISABLE_METADATA_STACK_TRACE);\n    if (disableTrace) {\n      this.node.setContext(constructs.ConstructMetadata.DISABLE_STACK_TRACE_IN_METADATA, true);\n    }\n  }\n\n  /**\n   * Validate the current construct.\n   *\n   * This method can be implemented by derived constructs in order to perform\n   * validation logic. It is called on all constructs before synthesis.\n   *\n   * @returns An array of validation error messages, or an empty array if the construct is valid.\n   */\n  protected onValidate(): string[] {\n    return this.validate();\n  }\n\n  /**\n   * Perform final modifications before synthesis\n   *\n   * This method can be implemented by derived constructs in order to perform\n   * final changes before synthesis. prepare() will be called after child\n   * constructs have been prepared.\n   *\n   * This is an advanced framework feature. Only use this if you\n   * understand the implications.\n   */\n  protected onPrepare(): void {\n    this.prepare();\n  }\n\n  /**\n   * Allows this construct to emit artifacts into the cloud assembly during synthesis.\n   *\n   * This method is usually implemented by framework-level constructs such as `Stack` and `Asset`\n   * as they participate in synthesizing the cloud assembly.\n   *\n   * @param session The synthesis session.\n   */\n  protected onSynthesize(session: constructs.ISynthesisSession): void {\n    this.synthesize({\n      outdir: session.outdir,\n      assembly: session.assembly!,\n    });\n  }\n\n  /**\n   * Validate the current construct.\n   *\n   * This method can be implemented by derived constructs in order to perform\n   * validation logic. It is called on all constructs before synthesis.\n   *\n   * @returns An array of validation error messages, or an empty array if the construct is valid.\n   */\n  protected validate(): string[] {\n    return [];\n  }\n\n  /**\n   * Perform final modifications before synthesis\n   *\n   * This method can be implemented by derived constructs in order to perform\n   * final changes before synthesis. prepare() will be called after child\n   * constructs have been prepared.\n   *\n   * This is an advanced framework feature. Only use this if you\n   * understand the implications.\n   */\n  protected prepare(): void {\n    return;\n  }\n\n  /**\n   * Allows this construct to emit artifacts into the cloud assembly during synthesis.\n   *\n   * This method is usually implemented by framework-level constructs such as `Stack` and `Asset`\n   * as they participate in synthesizing the cloud assembly.\n   *\n   * @param session The synthesis session.\n   */\n  protected synthesize(session: ISynthesisSession): void {\n    ignore(session);\n  }\n}\n\n/**\n * In what order to return constructs\n */\nexport enum ConstructOrder {\n  /**\n   * Depth-first, pre-order\n   */\n  PREORDER,\n\n  /**\n   * Depth-first, post-order (leaf nodes first)\n   */\n  POSTORDER\n}\n\n/**\n * Options for synthesis.\n *\n * @deprecated use `app.synth()` or `stage.synth()` instead\n */\nexport interface SynthesisOptions extends cxapi.AssemblyBuildOptions {\n  /**\n   * The output directory into which to synthesize the cloud assembly.\n   * @default - creates a temporary directory\n   */\n  readonly outdir?: string;\n\n  /**\n   * Whether synthesis should skip the validation phase.\n   * @default false\n   */\n  readonly skipValidation?: boolean;\n}\n\n/**\n * Represents the construct node in the scope tree.\n */\nexport class ConstructNode {\n  /**\n   * Separator used to delimit construct path components.\n   */\n  public static readonly PATH_SEP = '/';\n\n  /**\n   * Returns the wrapping `@aws-cdk/core.ConstructNode` instance from a `constructs.ConstructNode`.\n   *\n   * @internal\n   */\n  public static _unwrap(c: constructs.Node): ConstructNode {\n    const x = (c as any)[ORIGINAL_CONSTRUCT_NODE_SYMBOL];\n    if (!x) {\n      throw new Error('invalid ConstructNode type');\n    }\n\n    return x;\n  }\n\n  /**\n   * Synthesizes a CloudAssembly from a construct tree.\n   * @param node The root of the construct tree.\n   * @param options Synthesis options.\n   * @deprecated Use `app.synth()` or `stage.synth()` instead\n   */\n  public static synth(node: ConstructNode, options: SynthesisOptions = { }): cxapi.CloudAssembly {\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    const a: typeof import('././private/synthesis') = require('./private/synthesis');\n    return a.synthesize(node.root, options);\n  }\n\n  /**\n   * Invokes \"prepare\" on all constructs (depth-first, post-order) in the tree under `node`.\n   * @param node The root node\n   * @deprecated Use `app.synth()` instead\n   */\n  public static prepare(node: ConstructNode) {\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    const p: typeof import('./private/prepare-app') = require('./private/prepare-app');\n    p.prepareApp(node.root); // resolve cross refs and nested stack assets.\n    return node._actualNode.prepare();\n  }\n\n  /**\n   * Invokes \"validate\" on all constructs in the tree (depth-first, pre-order) and returns\n   * the list of all errors. An empty list indicates that there are no errors.\n   *\n   * @param node The root node\n   */\n  public static validate(node: ConstructNode): ValidationError[] {\n    return node._actualNode.validate().map(e => ({ source: e.source as Construct, message: e.message }));\n  }\n\n  /**\n   * @internal\n   */\n  public readonly _actualNode: constructs.Node;\n\n  constructor(host: Construct, scope: IConstruct, id: string) {\n    this._actualNode = new constructs.Node(host, scope, id);\n\n    // store a back reference on _actualNode so we can our ConstructNode from it\n    Object.defineProperty(this._actualNode, ORIGINAL_CONSTRUCT_NODE_SYMBOL, {\n      value: this,\n      configurable: false,\n      enumerable: false,\n    });\n  }\n\n  /**\n   * Returns the scope in which this construct is defined.\n   *\n   * The value is `undefined` at the root of the construct scope tree.\n   */\n  public get scope(): IConstruct | undefined {\n    return this._actualNode.scope as IConstruct;\n  }\n\n  /**\n   * The id of this construct within the current scope.\n   *\n   * This is a a scope-unique id. To obtain an app-unique id for this construct, use `uniqueId`.\n   */\n  public get id() { return this._actualNode.id; }\n\n  /**\n   * The full, absolute path of this construct in the tree.\n   *\n   * Components are separated by '/'.\n   */\n  public get path(): string { return this._actualNode.path; }\n\n  /**\n   * A tree-global unique alphanumeric identifier for this construct.\n   * Includes all components of the tree.\n   */\n  public get uniqueId(): string { return this._actualNode.uniqueId; }\n\n  /**\n   * Return a direct child by id, or undefined\n   *\n   * @param id Identifier of direct child\n   * @returns the child if found, or undefined\n   */\n  public tryFindChild(id: string): IConstruct | undefined { return this._actualNode.tryFindChild(id) as IConstruct; }\n\n  /**\n   * Return a direct child by id\n   *\n   * Throws an error if the child is not found.\n   *\n   * @param id Identifier of direct child\n   * @returns Child with the given id.\n   */\n  public findChild(id: string): IConstruct { return this._actualNode.findChild(id) as IConstruct; }\n\n  /**\n   * Returns the child construct that has the id `Default` or `Resource\"`.\n   * This is usually the construct that provides the bulk of the underlying functionality.\n   * Useful for modifications of the underlying construct that are not available at the higher levels.\n   *\n   * @throws if there is more than one child\n   * @returns a construct or undefined if there is no default child\n   */\n  public get defaultChild(): IConstruct | undefined { return this._actualNode.defaultChild as IConstruct; }\n\n  /**\n   * Override the defaultChild property.\n   *\n   * This should only be used in the cases where the correct\n   * default child is not named 'Resource' or 'Default' as it\n   * should be.\n   *\n   * If you set this to undefined, the default behavior of finding\n   * the child named 'Resource' or 'Default' will be used.\n   */\n  public set defaultChild(value: IConstruct | undefined) { this._actualNode.defaultChild = value; }\n\n  /**\n   * All direct children of this construct.\n   */\n  public get children(): IConstruct[] { return this._actualNode.children as IConstruct[]; }\n\n  /**\n   * Return this construct and all of its children in the given order\n   */\n  public findAll(order: ConstructOrder = ConstructOrder.PREORDER): IConstruct[] { return this._actualNode.findAll(order) as IConstruct[]; }\n\n  /**\n   * This can be used to set contextual values.\n   * Context must be set before any children are added, since children may consult context info during construction.\n   * If the key already exists, it will be overridden.\n   * @param key The context key\n   * @param value The context value\n   */\n  public setContext(key: string, value: any) {\n    if (Token.isUnresolved(key)) {\n      throw new Error('Invalid context key: context keys can\\'t include tokens');\n    }\n    this._actualNode.setContext(key, value);\n  }\n\n  /**\n   * Retrieves a value from tree context.\n   *\n   * Context is usually initialized at the root, but can be overridden at any point in the tree.\n   *\n   * @param key The context key\n   * @returns The context value or `undefined` if there is no context value for thie key.\n   */\n  public tryGetContext(key: string): any {\n    if (Token.isUnresolved(key)) {\n      throw new Error('Invalid context key: context keys can\\'t include tokens');\n    }\n    return this._actualNode.tryGetContext(key);\n  }\n\n  /**\n   * An immutable array of metadata objects associated with this construct.\n   * This can be used, for example, to implement support for deprecation notices, source mapping, etc.\n   */\n  public get metadata() { return this._actualNode.metadata as cxapi.MetadataEntry[]; }\n\n  /**\n   * Adds a metadata entry to this construct.\n   * Entries are arbitrary values and will also include a stack trace to allow tracing back to\n   * the code location for when the entry was added. It can be used, for example, to include source\n   * mapping in CloudFormation templates to improve diagnostics.\n   *\n   * @param type a string denoting the type of metadata\n   * @param data the value of the metadata (can be a Token). If null/undefined, metadata will not be added.\n   * @param fromFunction a function under which to restrict the metadata entry's stack trace (defaults to this.addMetadata)\n   */\n  public addMetadata(type: string, data: any, fromFunction?: any): void { this._actualNode.addMetadata(type, data, fromFunction); }\n\n  /**\n   * Adds a { \"info\": <message> } metadata entry to this construct.\n   * The toolkit will display the info message when apps are synthesized.\n   * @param message The info message.\n   */\n  public addInfo(message: string): void {\n    this._actualNode.addMetadata(cxschema.ArtifactMetadataEntryType.INFO, message);\n  }\n\n  /**\n   * Adds a { \"warning\": <message> } metadata entry to this construct.\n   * The toolkit will display the warning when an app is synthesized, or fail\n   * if run in --strict mode.\n   * @param message The warning message.\n   */\n  public addWarning(message: string): void {\n    this._actualNode.addMetadata(cxschema.ArtifactMetadataEntryType.WARN, message);\n  }\n\n  /**\n   * Adds an { \"error\": <message> } metadata entry to this construct.\n   * The toolkit will fail synthesis when errors are reported.\n   * @param message The error message.\n   */\n  public addError(message: string) {\n    this._actualNode.addMetadata(cxschema.ArtifactMetadataEntryType.ERROR, message);\n  }\n\n  /**\n   * Applies the aspect to this Constructs node\n   */\n  public applyAspect(aspect: IAspect): void { this._actualNode.applyAspect(aspect); }\n\n  /**\n   * All parent scopes of this construct.\n   *\n   * @returns a list of parent scopes. The last element in the list will always\n   * be the current construct and the first element will be the root of the\n   * tree.\n   */\n  public get scopes(): IConstruct[] { return this._actualNode.scopes as IConstruct[]; }\n\n  /**\n   * @returns The root of the construct tree.\n   */\n  public get root(): IConstruct { return this._actualNode.root as IConstruct; }\n\n  /**\n   * Returns true if this construct or the scopes in which it is defined are\n   * locked.\n   */\n  public get locked() { return this._actualNode.locked; }\n\n  /**\n   * Add an ordering dependency on another Construct.\n   *\n   * All constructs in the dependency's scope will be deployed before any\n   * construct in this construct's scope.\n   */\n  public addDependency(...dependencies: IDependable[]) { this._actualNode.addDependency(...dependencies); }\n\n  /**\n   * Return all dependencies registered on this node or any of its children\n   */\n  public get dependencies(): Dependency[] { return this._actualNode.dependencies as Dependency[]; }\n\n  /**\n   * Remove the child with the given name, if present.\n   *\n   * @returns Whether a child with the given name was deleted.\n   * @experimental\n   */\n  public tryRemoveChild(childName: string): boolean { return this._actualNode.tryRemoveChild(childName); }\n}\n\n/**\n * An error returned during the validation phase.\n */\nexport interface ValidationError {\n  /**\n   * The construct which emitted the error.\n   */\n  readonly source: Construct;\n\n  /**\n   * The error message.\n   */\n  readonly message: string;\n}\n\n/**\n * A single dependency\n */\nexport interface Dependency {\n  /**\n   * Source the dependency\n   */\n  readonly source: IConstruct;\n\n  /**\n   * Target of the dependency\n   */\n  readonly target: IConstruct;\n}\n\nfunction ignore(_x: any) {\n  return;\n}\n"]}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const stack_1 = require("./stack");
const stage_1 = require("./stage");
const util_1 = require("./util");

@@ -30,2 +31,7 @@ /**

const targetStack = stack_1.Stack.of(target);
const sourceStage = stage_1.Stage.of(sourceStack);
const targetStage = stage_1.Stage.of(targetStack);
if (sourceStage !== targetStage) {
throw new Error(`You cannot add a dependency from '${source.node.path}' (in ${describeStage(sourceStage)}) to '${target.node.path}' (in ${describeStage(targetStage)}): dependency cannot cross stage boundaries`);
}
// find the deepest common stack between the two elements

@@ -35,3 +41,3 @@ const sourcePath = util_1.pathToTopLevelStack(sourceStack);

const commonStack = util_1.findLastCommonElement(sourcePath, targetPath);
// if there is no common stack, then define an assembly-level dependency
// if there is no common stack, then define a assembly-level dependency
// between the two top-level stacks

@@ -81,2 +87,14 @@ if (!commonStack) {

exports.addDependency = addDependency;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVwcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImRlcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSxtQ0FBZ0M7QUFDaEMsaUNBQWtGO0FBSWxGOzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FrQkc7QUFDSCxTQUFnQixhQUFhLENBQW9CLE1BQVMsRUFBRSxNQUFTLEVBQUUsTUFBZTtJQUNwRixJQUFJLE1BQU0sS0FBSyxNQUFNLEVBQUU7UUFDckIsT0FBTztLQUNSO0lBRUQsTUFBTSxXQUFXLEdBQUcsYUFBSyxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNyQyxNQUFNLFdBQVcsR0FBRyxhQUFLLENBQUMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBRXJDLHlEQUF5RDtJQUN6RCxNQUFNLFVBQVUsR0FBRywwQkFBVSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQzNDLE1BQU0sVUFBVSxHQUFHLDBCQUFVLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDM0MsTUFBTSxXQUFXLEdBQUcsNEJBQXFCLENBQUMsVUFBVSxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBRWxFLHdFQUF3RTtJQUN4RSxtQ0FBbUM7SUFDbkMsSUFBSSxDQUFDLFdBQVcsRUFBRTtRQUNoQixNQUFNLGNBQWMsR0FBRyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyw0Q0FBNEM7UUFDbEYsTUFBTSxjQUFjLEdBQUcsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3JDLGNBQWMsQ0FBQyxzQkFBc0IsQ0FBQyxjQUFjLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDOUQsT0FBTztLQUNSO0lBRUQsb0ZBQW9GO0lBQ3BGLHlFQUF5RTtJQUN6RSw0RUFBNEU7SUFDNUUsdUJBQXVCO0lBRXZCLHVFQUF1RTtJQUN2RSw2RUFBNkU7SUFDN0UsMkVBQTJFO0lBQzNFLHdCQUF3QjtJQUN4QixJQUFJLFdBQVcsS0FBSyxNQUFNLEVBQUU7UUFDMUIsT0FBTztLQUNSO0lBRUQsdUVBQXVFO0lBQ3ZFLDZFQUE2RTtJQUM3RSwyREFBMkQ7SUFDM0QsSUFBSSxXQUFXLEtBQUssTUFBTSxFQUFFO1FBQzFCLE1BQU0sSUFBSSxLQUFLLENBQUMsaUJBQWlCLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxzQ0FBc0MsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLE1BQU0sTUFBTSxFQUFFLENBQUMsQ0FBQztLQUNsSTtJQUVELDRFQUE0RTtJQUM1RSw2RUFBNkU7SUFDN0UsZ0RBQWdEO0lBQ2hELE1BQU0sY0FBYyxHQUFHLHdCQUF3QixDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3hELE1BQU0sY0FBYyxHQUFHLHdCQUF3QixDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3hELGNBQWMsQ0FBQyxzQkFBc0IsQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUV0RCxTQUFTLHdCQUF3QixDQUFDLE9BQTRCO1FBQzVELE1BQU0sUUFBUSxHQUFHLGFBQUssQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDO1FBQ2hGLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDYixNQUFNLElBQUksS0FBSyxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyx3QkFBd0I7U0FDL0Q7UUFFRCxNQUFNLGFBQWEsR0FBRyxhQUFLLENBQUMsRUFBRSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRXpDLG9EQUFvRDtRQUNwRCxJQUFJLFdBQVcsS0FBSyxhQUFhLEVBQUU7WUFDakMsT0FBTyxRQUFRLENBQUM7U0FDakI7UUFFRCxPQUFPLHdCQUF3QixDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ2pELENBQUM7QUFDSCxDQUFDO0FBaEVELHNDQWdFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENmblJlc291cmNlIH0gZnJvbSAnLi9jZm4tcmVzb3VyY2UnO1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuL3N0YWNrJztcbmltcG9ydCB7IGZpbmRMYXN0Q29tbW9uRWxlbWVudCwgcGF0aFRvVG9wTGV2ZWxTdGFjayBhcyBwYXRoVG9Sb290IH0gZnJvbSAnLi91dGlsJztcblxudHlwZSBFbGVtZW50ID0gQ2ZuUmVzb3VyY2UgfCBTdGFjaztcblxuLyoqXG4gKiBBZGRzIGEgZGVwZW5kZW5jeSBiZXR3ZWVuIHR3byByZXNvdXJjZXMgb3Igc3RhY2tzLCBhY3Jvc3Mgc3RhY2sgYW5kIG5lc3RlZFxuICogc3RhY2sgYm91bmRhcmllcy5cbiAqXG4gKiBUaGUgYWxnb3JpdGhtIGNvbnNpc3RzIG9mOlxuICogLSBUcnkgdG8gZmluZCB0aGUgZGVlcGVzdCBjb21tb24gc3RhY2sgYmV0d2VlbiB0aGUgdHdvIGVsZW1lbnRzXG4gKiAtIElmIHRoZXJlIGlzbid0IGEgY29tbW9uIHN0YWNrLCBpdCBtZWFucyB0aGUgZWxlbWVudHMgYmVsb25nIHRvIHR3b1xuICogICBkaXNqb2luZWQgc3RhY2stdHJlZXMgYW5kIHRoZXJlZm9yZSB3ZSBhcHBseSB0aGUgZGVwZW5kZW5jeSBhdCB0aGVcbiAqICAgYXNzZW1ibHkvYXBwIGxldmVsIGJldHdlZW4gdGhlIHR3byB0b3BsLWxldmVsIHN0YWNrcy5cbiAqIC0gSWYgd2UgZGlkIGZpbmQgYSBjb21tb24gc3RhY2ssIHdlIGFwcGx5IHRoZSBkZXBlbmRlbmN5IGFzIGEgQ2xvdWRGb3JtYXRpb25cbiAqICAgXCJEZXBlbmRzT25cIiBiZXR3ZWVuIHRoZSByZXNvdXJjZXMgdGhhdCBcInJlcHJlc2VudFwiIG91ciBzb3VyY2UgYW5kIHRhcmdldFxuICogICBlaXRoZXIgZGlyZWN0bHkgb3IgdGhyb3VnaCB0aGUgQVdTOjpDbG91ZEZvcm1hdGlvbjo6U3RhY2sgcmVzb3VyY2VzIHRoYXRcbiAqICAgXCJsZWFkXCIgdG8gdGhlbS5cbiAqXG4gKiBAcGFyYW0gc291cmNlIFRoZSBzb3VyY2UgcmVzb3VyY2Uvc3RhY2sgKHRoZSBkZXBlZGVudClcbiAqIEBwYXJhbSB0YXJnZXQgVGhlIHRhcmdldCByZXNvdXJjZS9zdGFjayAodGhlIGRlcGVuZGVuY3kpXG4gKiBAcGFyYW0gcmVhc29uIE9wdGlvbmFsIHJlc291cmNlIHRvIGFzc29jaWF0ZSB3aXRoIHRoZSBkZXBlbmRlbmN5IGZvclxuICogZGlhZ25vc3RpY3NcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGFkZERlcGVuZGVuY3k8VCBleHRlbmRzIEVsZW1lbnQ+KHNvdXJjZTogVCwgdGFyZ2V0OiBULCByZWFzb24/OiBzdHJpbmcpIHtcbiAgaWYgKHNvdXJjZSA9PT0gdGFyZ2V0KSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3Qgc291cmNlU3RhY2sgPSBTdGFjay5vZihzb3VyY2UpO1xuICBjb25zdCB0YXJnZXRTdGFjayA9IFN0YWNrLm9mKHRhcmdldCk7XG5cbiAgLy8gZmluZCB0aGUgZGVlcGVzdCBjb21tb24gc3RhY2sgYmV0d2VlbiB0aGUgdHdvIGVsZW1lbnRzXG4gIGNvbnN0IHNvdXJjZVBhdGggPSBwYXRoVG9Sb290KHNvdXJjZVN0YWNrKTtcbiAgY29uc3QgdGFyZ2V0UGF0aCA9IHBhdGhUb1Jvb3QodGFyZ2V0U3RhY2spO1xuICBjb25zdCBjb21tb25TdGFjayA9IGZpbmRMYXN0Q29tbW9uRWxlbWVudChzb3VyY2VQYXRoLCB0YXJnZXRQYXRoKTtcblxuICAvLyBpZiB0aGVyZSBpcyBubyBjb21tb24gc3RhY2ssIHRoZW4gZGVmaW5lIGFuIGFzc2VtYmx5LWxldmVsIGRlcGVuZGVuY3lcbiAgLy8gYmV0d2VlbiB0aGUgdHdvIHRvcC1sZXZlbCBzdGFja3NcbiAgaWYgKCFjb21tb25TdGFjaykge1xuICAgIGNvbnN0IHRvcExldmVsU291cmNlID0gc291cmNlUGF0aFswXTsgLy8gZmlyc3QgcGF0aCBlbGVtZW50IGlzIHRoZSB0b3AtbGV2ZWwgc3RhY2tcbiAgICBjb25zdCB0b3BMZXZlbFRhcmdldCA9IHRhcmdldFBhdGhbMF07XG4gICAgdG9wTGV2ZWxTb3VyY2UuX2FkZEFzc2VtYmx5RGVwZW5kZW5jeSh0b3BMZXZlbFRhcmdldCwgcmVhc29uKTtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBhc3NlcnRpb246IGF0IHRoaXMgcG9pbnQgaWYgc291cmNlIGFuZCB0YXJnZXQgYXJlIHN0YWNrcywgYm90aCBhcmUgbmVzdGVkIHN0YWNrcy5cbiAgLy8gc2luY2Ugd2UgaGF2ZSBhIGNvbW1vbiBzdGFjaywgaXQgaXMgaW1wb3NzaWJsZSB0aGF0IGJvdGggYXJlIHRvcC1sZXZlbFxuICAvLyBzdGFja3MsIHNvIGxldCdzIGV4YW1pbmUgdGhlIHR3byBjYXNlcyB3aGVyZSBvbmUgb2YgdGhlbSBpcyB0b3AtbGV2ZWwgYW5kXG4gIC8vIHRoZSBvdGhlciBpcyBuZXN0ZWQuXG5cbiAgLy8gY2FzZSAxIC0gc291cmNlIGlzIHRvcC1sZXZlbCBhbmQgdGFyZ2V0IGlzIG5lc3RlZDogdGhpcyBpbXBsaWVzIHRoYXRcbiAgLy8gYHRhcmdldGAgaXMgYSBkaXJlY3Qgb3IgaW5kaXJlY3QgbmVzdGVkIHN0YWNrIG9mIGBzb3VyY2VgLCBhbmQgYW4gZXhwbGljaXRcbiAgLy8gZGVwZW5kZW5jeSBpcyBub3QgcmVxdWlyZWQgYmVjYXVzZSBuZXN0ZWQgc3RhY2tzIHdpbGwgYWx3YXlzIGJlIGRlcGxveWVkXG4gIC8vIGJlZm9yZSB0aGVpciBwYXJlbnRzLlxuICBpZiAoY29tbW9uU3RhY2sgPT09IHNvdXJjZSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIGNhc2UgMiAtIHNvdXJjZSBpcyBuZXN0ZWQgYW5kIHRhcmdldCBpcyB0b3AtbGV2ZWw6IHRoaXMgaW1wbGllcyB0aGF0XG4gIC8vIGBzb3VyY2VgIGlzIGEgZGlyZWN0IG9yIGluZGlyZWN0IG5lc3RlZCBzdGFjayBvZiBgdGFyZ2V0YCwgYW5kIHRoaXMgaXMgbm90XG4gIC8vIHBvc3NpYmxlIChuZXN0ZWQgc3RhY2tzIGNhbm5vdCBkZXBlbmQgb24gdGhlaXIgcGFyZW50cykuXG4gIGlmIChjb21tb25TdGFjayA9PT0gdGFyZ2V0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBOZXN0ZWQgc3RhY2sgJyR7c291cmNlU3RhY2subm9kZS5wYXRofScgY2Fubm90IGRlcGVuZCBvbiBhIHBhcmVudCBzdGFjayAnJHt0YXJnZXRTdGFjay5ub2RlLnBhdGh9JzogJHtyZWFzb259YCk7XG4gIH1cblxuICAvLyB3ZSBoYXZlIGEgY29tbW9uIHN0YWNrIGZyb20gd2hpY2ggd2UgY2FuIHJlYWNoIGJvdGggYHNvdXJjZWAgYW5kIGB0YXJnZXRgXG4gIC8vIG5vdyB3ZSBuZWVkIHRvIGZpbmQgdHdvIHJlc291cmNlcyB3aGljaCBhcmUgZGVmaW5lZCBkaXJlY3RseSBpbiB0aGlzIHN0YWNrXG4gIC8vIGFuZCB3aGljaCBjYW4gXCJsZWFkIHVzXCIgdG8gdGhlIHNvdXJjZS90YXJnZXQuXG4gIGNvbnN0IHNvdXJjZVJlc291cmNlID0gcmVzb3VyY2VJbkNvbW1vblN0YWNrRm9yKHNvdXJjZSk7XG4gIGNvbnN0IHRhcmdldFJlc291cmNlID0gcmVzb3VyY2VJbkNvbW1vblN0YWNrRm9yKHRhcmdldCk7XG4gIHNvdXJjZVJlc291cmNlLl9hZGRSZXNvdXJjZURlcGVuZGVuY3kodGFyZ2V0UmVzb3VyY2UpO1xuXG4gIGZ1bmN0aW9uIHJlc291cmNlSW5Db21tb25TdGFja0ZvcihlbGVtZW50OiBDZm5SZXNvdXJjZSB8IFN0YWNrKTogQ2ZuUmVzb3VyY2Uge1xuICAgIGNvbnN0IHJlc291cmNlID0gU3RhY2suaXNTdGFjayhlbGVtZW50KSA/IGVsZW1lbnQubmVzdGVkU3RhY2tSZXNvdXJjZSA6IGVsZW1lbnQ7XG4gICAgaWYgKCFyZXNvdXJjZSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdhc3NlcnRpb24gZmFpbHVyZScpOyAvLyBzZWUgXCJhc3NlcnRpb25cIiBhYm92ZVxuICAgIH1cblxuICAgIGNvbnN0IHJlc291cmNlU3RhY2sgPSBTdGFjay5vZihyZXNvdXJjZSk7XG5cbiAgICAvLyB3ZSByZWFjaGVkIGEgcmVzb3VyY2UgZGVmaW5lZCBpbiB0aGUgY29tbW9uIHN0YWNrXG4gICAgaWYgKGNvbW1vblN0YWNrID09PSByZXNvdXJjZVN0YWNrKSB7XG4gICAgICByZXR1cm4gcmVzb3VyY2U7XG4gICAgfVxuXG4gICAgcmV0dXJuIHJlc291cmNlSW5Db21tb25TdGFja0ZvcihyZXNvdXJjZVN0YWNrKTtcbiAgfVxufVxuIl19
/**
* Return a string representation of the given assembler, for use in error messages
*/
function describeStage(assembly) {
if (!assembly) {
return 'an unrooted construct tree';
}
if (!assembly.parentStage) {
return 'the App';
}
return `Stage '${assembly.node.path}'`;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deps.js","sourceRoot":"","sources":["deps.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnResource } from './cfn-resource';\nimport { Stack } from './stack';\nimport { Stage } from './stage';\nimport { findLastCommonElement, pathToTopLevelStack as pathToRoot } from './util';\n\ntype Element = CfnResource | Stack;\n\n/**\n * Adds a dependency between two resources or stacks, across stack and nested\n * stack boundaries.\n *\n * The algorithm consists of:\n * - Try to find the deepest common stack between the two elements\n * - If there isn't a common stack, it means the elements belong to two\n *   disjoined stack-trees and therefore we apply the dependency at the\n *   assembly/app level between the two topl-level stacks.\n * - If we did find a common stack, we apply the dependency as a CloudFormation\n *   \"DependsOn\" between the resources that \"represent\" our source and target\n *   either directly or through the AWS::CloudFormation::Stack resources that\n *   \"lead\" to them.\n *\n * @param source The source resource/stack (the depedent)\n * @param target The target resource/stack (the dependency)\n * @param reason Optional resource to associate with the dependency for\n * diagnostics\n */\nexport function addDependency<T extends Element>(source: T, target: T, reason?: string) {\n  if (source === target) {\n    return;\n  }\n\n  const sourceStack = Stack.of(source);\n  const targetStack = Stack.of(target);\n\n  const sourceStage = Stage.of(sourceStack);\n  const targetStage = Stage.of(targetStack);\n  if (sourceStage !== targetStage) {\n    throw new Error(`You cannot add a dependency from '${source.node.path}' (in ${describeStage(sourceStage)}) to '${target.node.path}' (in ${describeStage(targetStage)}): dependency cannot cross stage boundaries`);\n  }\n\n  // find the deepest common stack between the two elements\n  const sourcePath = pathToRoot(sourceStack);\n  const targetPath = pathToRoot(targetStack);\n  const commonStack = findLastCommonElement(sourcePath, targetPath);\n\n  // if there is no common stack, then define a assembly-level dependency\n  // between the two top-level stacks\n  if (!commonStack) {\n    const topLevelSource = sourcePath[0]; // first path element is the top-level stack\n    const topLevelTarget = targetPath[0];\n    topLevelSource._addAssemblyDependency(topLevelTarget, reason);\n    return;\n  }\n\n  // assertion: at this point if source and target are stacks, both are nested stacks.\n  // since we have a common stack, it is impossible that both are top-level\n  // stacks, so let's examine the two cases where one of them is top-level and\n  // the other is nested.\n\n  // case 1 - source is top-level and target is nested: this implies that\n  // `target` is a direct or indirect nested stack of `source`, and an explicit\n  // dependency is not required because nested stacks will always be deployed\n  // before their parents.\n  if (commonStack === source) {\n    return;\n  }\n\n  // case 2 - source is nested and target is top-level: this implies that\n  // `source` is a direct or indirect nested stack of `target`, and this is not\n  // possible (nested stacks cannot depend on their parents).\n  if (commonStack === target) {\n    throw new Error(`Nested stack '${sourceStack.node.path}' cannot depend on a parent stack '${targetStack.node.path}': ${reason}`);\n  }\n\n  // we have a common stack from which we can reach both `source` and `target`\n  // now we need to find two resources which are defined directly in this stack\n  // and which can \"lead us\" to the source/target.\n  const sourceResource = resourceInCommonStackFor(source);\n  const targetResource = resourceInCommonStackFor(target);\n  sourceResource._addResourceDependency(targetResource);\n\n  function resourceInCommonStackFor(element: CfnResource | Stack): CfnResource {\n    const resource = Stack.isStack(element) ? element.nestedStackResource : element;\n    if (!resource) {\n      throw new Error('assertion failure'); // see \"assertion\" above\n    }\n\n    const resourceStack = Stack.of(resource);\n\n    // we reached a resource defined in the common stack\n    if (commonStack === resourceStack) {\n      return resource;\n    }\n\n    return resourceInCommonStackFor(resourceStack);\n  }\n}\n\n/**\n * Return a string representation of the given assembler, for use in error messages\n */\nfunction describeStage(assembly: Stage | undefined): string {\n  if (!assembly) { return 'an unrooted construct tree'; }\n  if (!assembly.parentStage) { return 'the App'; }\n  return `Stage '${assembly.node.path}'`;\n}\n"]}

@@ -27,2 +27,8 @@ import { CopyOptions, FingerprintOptions } from './options';

static fingerprint(fileOrDirectory: string, options?: FingerprintOptions): string;
/**
* Checks whether a directory is empty
*
* @param dir The directory to check
*/
static isEmpty(dir: string): boolean;
}

@@ -6,2 +6,3 @@ "use strict";

Object.defineProperty(exports, "__esModule", { value: true });
const fs = require("fs");
const copy_1 = require("./copy");

@@ -38,4 +39,12 @@ const fingerprint_1 = require("./fingerprint");

}
/**
* Checks whether a directory is empty
*
* @param dir The directory to check
*/
static isEmpty(dir) {
return fs.readdirSync(dir).length === 0;
}
}
exports.FileSystem = FileSystem;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGlDQUF1QztBQUN2QywrQ0FBNEM7QUFHNUMsK0JBQTBCO0FBRTFCOztHQUVHO0FBQ0gsTUFBYSxVQUFVO0lBQ3JCOzs7Ozs7T0FNRztJQUNJLE1BQU0sQ0FBQyxhQUFhLENBQUMsTUFBYyxFQUFFLE9BQWUsRUFBRSxVQUF1QixFQUFHLEVBQUUsT0FBZ0I7UUFDdkcsT0FBTyxvQkFBYSxDQUFDLE1BQU0sRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFFRDs7Ozs7Ozs7OztPQVVHO0lBQ0ksTUFBTSxDQUFDLFdBQVcsQ0FBQyxlQUF1QixFQUFFLFVBQThCLEVBQUc7UUFDbEYsT0FBTyx5QkFBVyxDQUFDLGVBQWUsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUMvQyxDQUFDO0NBQ0Y7QUExQkQsZ0NBMEJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY29weURpcmVjdG9yeSB9IGZyb20gJy4vY29weSc7XG5pbXBvcnQgeyBmaW5nZXJwcmludCB9IGZyb20gJy4vZmluZ2VycHJpbnQnO1xuaW1wb3J0IHsgQ29weU9wdGlvbnMsIEZpbmdlcnByaW50T3B0aW9ucyB9IGZyb20gJy4vb3B0aW9ucyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vb3B0aW9ucyc7XG5cbi8qKlxuICogRmlsZSBzeXN0ZW0gdXRpbGl0aWVzLlxuICovXG5leHBvcnQgY2xhc3MgRmlsZVN5c3RlbSB7XG4gIC8qKlxuICAgKiBDb3BpZXMgYW4gZW50aXJlIGRpcmVjdG9yeSBzdHJ1Y3R1cmUuXG4gICAqIEBwYXJhbSBzcmNEaXIgU291cmNlIGRpcmVjdG9yeVxuICAgKiBAcGFyYW0gZGVzdERpciBEZXN0aW5hdGlvbiBkaXJlY3RvcnlcbiAgICogQHBhcmFtIG9wdGlvbnMgb3B0aW9uc1xuICAgKiBAcGFyYW0gcm9vdERpciBSb290IGRpcmVjdG9yeSB0byBjYWxjdWxhdGUgZXhjbHVzaW9ucyBmcm9tXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGNvcHlEaXJlY3Rvcnkoc3JjRGlyOiBzdHJpbmcsIGRlc3REaXI6IHN0cmluZywgb3B0aW9uczogQ29weU9wdGlvbnMgPSB7IH0sIHJvb3REaXI/OiBzdHJpbmcpIHtcbiAgICByZXR1cm4gY29weURpcmVjdG9yeShzcmNEaXIsIGRlc3REaXIsIG9wdGlvbnMsIHJvb3REaXIpO1xuICB9XG5cbiAgLyoqXG4gICAqIFByb2R1Y2VzIGZpbmdlcnByaW50IGJhc2VkIG9uIHRoZSBjb250ZW50cyBvZiBhIHNpbmdsZSBmaWxlIG9yIGFuIGVudGlyZSBkaXJlY3RvcnkgdHJlZS5cbiAgICpcbiAgICogVGhlIGZpbmdlcnByaW50IHdpbGwgYWxzbyBpbmNsdWRlOlxuICAgKiAxLiBBbiBleHRyYSBzdHJpbmcgaWYgZGVmaW5lZCBpbiBgb3B0aW9ucy5leHRyYWAuXG4gICAqIDIuIFRoZSBzZXQgb2YgZXhjbHVkZSBwYXR0ZXJucywgaWYgZGVmaW5lZCBpbiBgb3B0aW9ucy5leGNsdWRlYFxuICAgKiAzLiBUaGUgc3ltbGluayBmb2xsb3cgbW9kZSB2YWx1ZS5cbiAgICpcbiAgICogQHBhcmFtIGZpbGVPckRpcmVjdG9yeSBUaGUgZGlyZWN0b3J5IG9yIGZpbGUgdG8gZmluZ2VycHJpbnRcbiAgICogQHBhcmFtIG9wdGlvbnMgRmluZ2VycHJpbnRpbmcgb3B0aW9uc1xuICAgKi9cbiAgcHVibGljIHN0YXRpYyBmaW5nZXJwcmludChmaWxlT3JEaXJlY3Rvcnk6IHN0cmluZywgb3B0aW9uczogRmluZ2VycHJpbnRPcHRpb25zID0geyB9KSB7XG4gICAgcmV0dXJuIGZpbmdlcnByaW50KGZpbGVPckRpcmVjdG9yeSwgb3B0aW9ucyk7XG4gIH1cbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHlCQUF5QjtBQUN6QixpQ0FBdUM7QUFDdkMsK0NBQTRDO0FBRzVDLCtCQUEwQjtBQUUxQjs7R0FFRztBQUNILE1BQWEsVUFBVTtJQUNyQjs7Ozs7O09BTUc7SUFDSSxNQUFNLENBQUMsYUFBYSxDQUFDLE1BQWMsRUFBRSxPQUFlLEVBQUUsVUFBdUIsRUFBRyxFQUFFLE9BQWdCO1FBQ3ZHLE9BQU8sb0JBQWEsQ0FBQyxNQUFNLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQztJQUMxRCxDQUFDO0lBRUQ7Ozs7Ozs7Ozs7T0FVRztJQUNJLE1BQU0sQ0FBQyxXQUFXLENBQUMsZUFBdUIsRUFBRSxVQUE4QixFQUFHO1FBQ2xGLE9BQU8seUJBQVcsQ0FBQyxlQUFlLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVEOzs7O09BSUc7SUFDSSxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQVc7UUFDL0IsT0FBTyxFQUFFLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUM7SUFDMUMsQ0FBQztDQUNGO0FBbkNELGdDQW1DQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGZzIGZyb20gJ2ZzJztcbmltcG9ydCB7IGNvcHlEaXJlY3RvcnkgfSBmcm9tICcuL2NvcHknO1xuaW1wb3J0IHsgZmluZ2VycHJpbnQgfSBmcm9tICcuL2ZpbmdlcnByaW50JztcbmltcG9ydCB7IENvcHlPcHRpb25zLCBGaW5nZXJwcmludE9wdGlvbnMgfSBmcm9tICcuL29wdGlvbnMnO1xuXG5leHBvcnQgKiBmcm9tICcuL29wdGlvbnMnO1xuXG4vKipcbiAqIEZpbGUgc3lzdGVtIHV0aWxpdGllcy5cbiAqL1xuZXhwb3J0IGNsYXNzIEZpbGVTeXN0ZW0ge1xuICAvKipcbiAgICogQ29waWVzIGFuIGVudGlyZSBkaXJlY3Rvcnkgc3RydWN0dXJlLlxuICAgKiBAcGFyYW0gc3JjRGlyIFNvdXJjZSBkaXJlY3RvcnlcbiAgICogQHBhcmFtIGRlc3REaXIgRGVzdGluYXRpb24gZGlyZWN0b3J5XG4gICAqIEBwYXJhbSBvcHRpb25zIG9wdGlvbnNcbiAgICogQHBhcmFtIHJvb3REaXIgUm9vdCBkaXJlY3RvcnkgdG8gY2FsY3VsYXRlIGV4Y2x1c2lvbnMgZnJvbVxuICAgKi9cbiAgcHVibGljIHN0YXRpYyBjb3B5RGlyZWN0b3J5KHNyY0Rpcjogc3RyaW5nLCBkZXN0RGlyOiBzdHJpbmcsIG9wdGlvbnM6IENvcHlPcHRpb25zID0geyB9LCByb290RGlyPzogc3RyaW5nKSB7XG4gICAgcmV0dXJuIGNvcHlEaXJlY3Rvcnkoc3JjRGlyLCBkZXN0RGlyLCBvcHRpb25zLCByb290RGlyKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBQcm9kdWNlcyBmaW5nZXJwcmludCBiYXNlZCBvbiB0aGUgY29udGVudHMgb2YgYSBzaW5nbGUgZmlsZSBvciBhbiBlbnRpcmUgZGlyZWN0b3J5IHRyZWUuXG4gICAqXG4gICAqIFRoZSBmaW5nZXJwcmludCB3aWxsIGFsc28gaW5jbHVkZTpcbiAgICogMS4gQW4gZXh0cmEgc3RyaW5nIGlmIGRlZmluZWQgaW4gYG9wdGlvbnMuZXh0cmFgLlxuICAgKiAyLiBUaGUgc2V0IG9mIGV4Y2x1ZGUgcGF0dGVybnMsIGlmIGRlZmluZWQgaW4gYG9wdGlvbnMuZXhjbHVkZWBcbiAgICogMy4gVGhlIHN5bWxpbmsgZm9sbG93IG1vZGUgdmFsdWUuXG4gICAqXG4gICAqIEBwYXJhbSBmaWxlT3JEaXJlY3RvcnkgVGhlIGRpcmVjdG9yeSBvciBmaWxlIHRvIGZpbmdlcnByaW50XG4gICAqIEBwYXJhbSBvcHRpb25zIEZpbmdlcnByaW50aW5nIG9wdGlvbnNcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgZmluZ2VycHJpbnQoZmlsZU9yRGlyZWN0b3J5OiBzdHJpbmcsIG9wdGlvbnM6IEZpbmdlcnByaW50T3B0aW9ucyA9IHsgfSkge1xuICAgIHJldHVybiBmaW5nZXJwcmludChmaWxlT3JEaXJlY3RvcnksIG9wdGlvbnMpO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrcyB3aGV0aGVyIGEgZGlyZWN0b3J5IGlzIGVtcHR5XG4gICAqXG4gICAqIEBwYXJhbSBkaXIgVGhlIGRpcmVjdG9yeSB0byBjaGVja1xuICAgKi9cbiAgcHVibGljIHN0YXRpYyBpc0VtcHR5KGRpcjogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGZzLnJlYWRkaXJTeW5jKGRpcikubGVuZ3RoID09PSAwO1xuICB9XG59XG4iXX0=

@@ -23,2 +23,3 @@ export * from './aspect';

export * from './stack';
export * from './stage';
export * from './cfn-element';

@@ -44,2 +45,3 @@ export * from './cfn-dynamic-reference';

export * from './asset-staging';
export * from './bundling';
export * from './fs';

@@ -46,0 +48,0 @@ export * from './custom-resource';

@@ -27,2 +27,3 @@ "use strict";

__export(require("./stack"));
__export(require("./stage"));
__export(require("./cfn-element"));

@@ -45,2 +46,3 @@ __export(require("./cfn-dynamic-reference"));

__export(require("./asset-staging"));
__export(require("./bundling"));
__export(require("./fs"));

@@ -55,2 +57,2 @@ __export(require("./custom-resource"));

__export(require("./private/intrinsic"));
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUNBLGtDQUE2QjtBQUU3Qix3Q0FBbUM7QUFDbkMsNkJBQXdCO0FBQ3hCLGtDQUE2QjtBQUM3Qiw0QkFBdUI7QUFDdkIsbUNBQThCO0FBQzlCLGtDQUE2QjtBQUM3Qix3Q0FBbUM7QUFDbkMsMENBQXFDO0FBRXJDLGlDQUE0QjtBQUM1QixxQ0FBZ0M7QUFDaEMsOEJBQXlCO0FBQ3pCLG1DQUE4QjtBQUM5QixtQ0FBOEI7QUFDOUIsa0NBQTZCO0FBQzdCLHFDQUFnQztBQUNoQyxrQ0FBNkI7QUFDN0Isb0NBQStCO0FBQy9CLDJDQUFzQztBQUN0QyxnQ0FBMkI7QUFDM0IsNkJBQXdCO0FBQ3hCLG1DQUE4QjtBQUM5Qiw2Q0FBd0M7QUFFeEMsZ0NBQTJCO0FBQzNCLHNDQUFpQztBQUNqQywyQkFBc0I7QUFDdEIsZ0NBQTJCO0FBRTNCLDRCQUF1QjtBQUN2QixtQ0FBOEI7QUFFOUIsMkJBQXNCO0FBQ3RCLHdDQUFtQztBQUduQywrQkFBMEI7QUFDMUIsb0NBQStCO0FBRS9CLGdDQUEyQjtBQUMzQixxQ0FBZ0M7QUFDaEMsOEJBQXlCO0FBRXpCLDRCQUF1QjtBQUV2QixxQ0FBZ0M7QUFDaEMsMEJBQXFCO0FBRXJCLHVDQUFrQztBQUNsQyxvQ0FBK0I7QUFDL0IsZ0RBQTJDO0FBRTNDLHdDQUFtQztBQUNuQyxnREFBMkM7QUFFM0MsOEVBQThFO0FBQzlFLDBDQUEwQztBQUMxQyx5Q0FBb0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FzcGVjdCc7XG5leHBvcnQgKiBmcm9tICcuL3RhZy1hc3BlY3QnO1xuXG5leHBvcnQgKiBmcm9tICcuL2NvbnN0cnVjdC1jb21wYXQnO1xuZXhwb3J0ICogZnJvbSAnLi90b2tlbic7XG5leHBvcnQgKiBmcm9tICcuL3Jlc29sdmFibGUnO1xuZXhwb3J0ICogZnJvbSAnLi9sYXp5JztcbmV4cG9ydCAqIGZyb20gJy4vdGFnLW1hbmFnZXInO1xuZXhwb3J0ICogZnJvbSAnLi9kZXBlbmRlbmN5JztcbmV4cG9ydCAqIGZyb20gJy4vc3RyaW5nLWZyYWdtZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL3N0YWNrLXN5bnRoZXNpemVycyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vcmVmZXJlbmNlJztcbmV4cG9ydCAqIGZyb20gJy4vY2ZuLWNvbmRpdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL2Nmbi1mbic7XG5leHBvcnQgKiBmcm9tICcuL2Nmbi1pbmNsdWRlJztcbmV4cG9ydCAqIGZyb20gJy4vY2ZuLW1hcHBpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi9jZm4tb3V0cHV0JztcbmV4cG9ydCAqIGZyb20gJy4vY2ZuLXBhcmFtZXRlcic7XG5leHBvcnQgKiBmcm9tICcuL2Nmbi1wc2V1ZG8nO1xuZXhwb3J0ICogZnJvbSAnLi9jZm4tcmVzb3VyY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jZm4tcmVzb3VyY2UtcG9saWN5JztcbmV4cG9ydCAqIGZyb20gJy4vY2ZuLXJ1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9zdGFjayc7XG5leHBvcnQgKiBmcm9tICcuL2Nmbi1lbGVtZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2ZuLWR5bmFtaWMtcmVmZXJlbmNlJztcbmV4cG9ydCAqIGZyb20gJy4vY2ZuLXRhZyc7XG5leHBvcnQgKiBmcm9tICcuL2Nmbi1qc29uJztcbmV4cG9ydCAqIGZyb20gJy4vcmVtb3ZhbC1wb2xpY3knO1xuZXhwb3J0ICogZnJvbSAnLi9hcm4nO1xuZXhwb3J0ICogZnJvbSAnLi9kdXJhdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL2Zyb20tY2ZuJztcbmV4cG9ydCAqIGZyb20gJy4vc2l6ZSc7XG5leHBvcnQgKiBmcm9tICcuL3N0YWNrLXRyYWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi9hcHAnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250ZXh0LXByb3ZpZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vZW52aXJvbm1lbnQnO1xuXG5leHBvcnQgKiBmcm9tICcuL3J1bnRpbWUnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWNyZXQtdmFsdWUnO1xuXG5leHBvcnQgKiBmcm9tICcuL3Jlc291cmNlJztcbmV4cG9ydCAqIGZyb20gJy4vcGh5c2ljYWwtbmFtZSc7XG5leHBvcnQgKiBmcm9tICcuL2Fzc2V0cyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vdHJlZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vYXNzZXQtc3RhZ2luZyc7XG5leHBvcnQgKiBmcm9tICcuL2ZzJztcblxuZXhwb3J0ICogZnJvbSAnLi9jdXN0b20tcmVzb3VyY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9uZXN0ZWQtc3RhY2snO1xuZXhwb3J0ICogZnJvbSAnLi9jdXN0b20tcmVzb3VyY2UtcHJvdmlkZXInO1xuXG5leHBvcnQgKiBmcm9tICcuL2Nmbi1jYXBhYmlsaXRpZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9jbG91ZGZvcm1hdGlvbi5nZW5lcmF0ZWQnO1xuXG4vLyBXQVJOSU5HOiBTaG91bGQgbm90IGJlIGV4cG9ydGVkLCBidXQgY3VycmVudGx5IGlzIGJlY2F1c2Ugb2YgYSBidWcuIFNlZSB0aGVcbi8vIGNsYXNzIGRlc2NyaXB0aW9uIGZvciBtb3JlIGluZm9ybWF0aW9uLlxuZXhwb3J0ICogZnJvbSAnLi9wcml2YXRlL2ludHJpbnNpYyc7XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUNBLGtDQUE2QjtBQUU3Qix3Q0FBbUM7QUFDbkMsNkJBQXdCO0FBQ3hCLGtDQUE2QjtBQUM3Qiw0QkFBdUI7QUFDdkIsbUNBQThCO0FBQzlCLGtDQUE2QjtBQUM3Qix3Q0FBbUM7QUFDbkMsMENBQXFDO0FBRXJDLGlDQUE0QjtBQUM1QixxQ0FBZ0M7QUFDaEMsOEJBQXlCO0FBQ3pCLG1DQUE4QjtBQUM5QixtQ0FBOEI7QUFDOUIsa0NBQTZCO0FBQzdCLHFDQUFnQztBQUNoQyxrQ0FBNkI7QUFDN0Isb0NBQStCO0FBQy9CLDJDQUFzQztBQUN0QyxnQ0FBMkI7QUFDM0IsNkJBQXdCO0FBQ3hCLDZCQUF3QjtBQUN4QixtQ0FBOEI7QUFDOUIsNkNBQXdDO0FBRXhDLGdDQUEyQjtBQUMzQixzQ0FBaUM7QUFDakMsMkJBQXNCO0FBQ3RCLGdDQUEyQjtBQUUzQiw0QkFBdUI7QUFDdkIsbUNBQThCO0FBRTlCLDJCQUFzQjtBQUN0Qix3Q0FBbUM7QUFHbkMsK0JBQTBCO0FBQzFCLG9DQUErQjtBQUUvQixnQ0FBMkI7QUFDM0IscUNBQWdDO0FBQ2hDLDhCQUF5QjtBQUV6Qiw0QkFBdUI7QUFFdkIscUNBQWdDO0FBQ2hDLGdDQUEyQjtBQUMzQiwwQkFBcUI7QUFFckIsdUNBQWtDO0FBQ2xDLG9DQUErQjtBQUMvQixnREFBMkM7QUFFM0Msd0NBQW1DO0FBQ25DLGdEQUEyQztBQUUzQyw4RUFBOEU7QUFDOUUsMENBQTBDO0FBQzFDLHlDQUFvQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYXNwZWN0JztcbmV4cG9ydCAqIGZyb20gJy4vdGFnLWFzcGVjdCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vY29uc3RydWN0LWNvbXBhdCc7XG5leHBvcnQgKiBmcm9tICcuL3Rva2VuJztcbmV4cG9ydCAqIGZyb20gJy4vcmVzb2x2YWJsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xhenknO1xuZXhwb3J0ICogZnJvbSAnLi90YWctbWFuYWdlcic7XG5leHBvcnQgKiBmcm9tICcuL2RlcGVuZGVuY3knO1xuZXhwb3J0ICogZnJvbSAnLi9zdHJpbmctZnJhZ21lbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vc3RhY2stc3ludGhlc2l6ZXJzJztcblxuZXhwb3J0ICogZnJvbSAnLi9yZWZlcmVuY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jZm4tY29uZGl0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vY2ZuLWZuJztcbmV4cG9ydCAqIGZyb20gJy4vY2ZuLWluY2x1ZGUnO1xuZXhwb3J0ICogZnJvbSAnLi9jZm4tbWFwcGluZyc7XG5leHBvcnQgKiBmcm9tICcuL2Nmbi1vdXRwdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9jZm4tcGFyYW1ldGVyJztcbmV4cG9ydCAqIGZyb20gJy4vY2ZuLXBzZXVkbyc7XG5leHBvcnQgKiBmcm9tICcuL2Nmbi1yZXNvdXJjZSc7XG5leHBvcnQgKiBmcm9tICcuL2Nmbi1yZXNvdXJjZS1wb2xpY3knO1xuZXhwb3J0ICogZnJvbSAnLi9jZm4tcnVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3N0YWNrJztcbmV4cG9ydCAqIGZyb20gJy4vc3RhZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jZm4tZWxlbWVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Nmbi1keW5hbWljLXJlZmVyZW5jZSc7XG5leHBvcnQgKiBmcm9tICcuL2Nmbi10YWcnO1xuZXhwb3J0ICogZnJvbSAnLi9jZm4tanNvbic7XG5leHBvcnQgKiBmcm9tICcuL3JlbW92YWwtcG9saWN5JztcbmV4cG9ydCAqIGZyb20gJy4vYXJuJztcbmV4cG9ydCAqIGZyb20gJy4vZHVyYXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9mcm9tLWNmbic7XG5leHBvcnQgKiBmcm9tICcuL3NpemUnO1xuZXhwb3J0ICogZnJvbSAnLi9zdGFjay10cmFjZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vYXBwJztcbmV4cG9ydCAqIGZyb20gJy4vY29udGV4dC1wcm92aWRlcic7XG5leHBvcnQgKiBmcm9tICcuL2Vudmlyb25tZW50JztcblxuZXhwb3J0ICogZnJvbSAnLi9ydW50aW1lJztcbmV4cG9ydCAqIGZyb20gJy4vc2VjcmV0LXZhbHVlJztcblxuZXhwb3J0ICogZnJvbSAnLi9yZXNvdXJjZSc7XG5leHBvcnQgKiBmcm9tICcuL3BoeXNpY2FsLW5hbWUnO1xuZXhwb3J0ICogZnJvbSAnLi9hc3NldHMnO1xuXG5leHBvcnQgKiBmcm9tICcuL3RyZWUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2Fzc2V0LXN0YWdpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi9idW5kbGluZyc7XG5leHBvcnQgKiBmcm9tICcuL2ZzJztcblxuZXhwb3J0ICogZnJvbSAnLi9jdXN0b20tcmVzb3VyY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9uZXN0ZWQtc3RhY2snO1xuZXhwb3J0ICogZnJvbSAnLi9jdXN0b20tcmVzb3VyY2UtcHJvdmlkZXInO1xuXG5leHBvcnQgKiBmcm9tICcuL2Nmbi1jYXBhYmlsaXRpZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9jbG91ZGZvcm1hdGlvbi5nZW5lcmF0ZWQnO1xuXG4vLyBXQVJOSU5HOiBTaG91bGQgbm90IGJlIGV4cG9ydGVkLCBidXQgY3VycmVudGx5IGlzIGJlY2F1c2Ugb2YgYSBidWcuIFNlZSB0aGVcbi8vIGNsYXNzIGRlc2NyaXB0aW9uIGZvciBtb3JlIGluZm9ybWF0aW9uLlxuZXhwb3J0ICogZnJvbSAnLi9wcml2YXRlL2ludHJpbnNpYyc7XG4iXX0=

@@ -1,2 +0,2 @@

import { Construct } from '../construct-compat';
import { IConstruct } from '../construct-compat';
/**

@@ -12,2 +12,2 @@ * Prepares the app for synthesis. This function is called by the root `prepare`

*/
export declare function prepareApp(root: Construct): void;
export declare function prepareApp(root: IConstruct): void;

@@ -6,2 +6,3 @@ "use strict";

const stack_1 = require("../stack");
const stage_1 = require("../stage");
const refs_1 = require("./refs");

@@ -19,4 +20,4 @@ /**

function prepareApp(root) {
if (root.node.scope) {
throw new Error('prepareApp must be called on the root node');
if (root.node.scope && !stage_1.Stage.isStage(root)) {
throw new Error('prepareApp can only be called on a stage or a root construct');
}

@@ -34,3 +35,3 @@ // apply dependencies between resources in depending subtrees

// depth-first (children first) queue of nested stacks. We will pop a stack
// from the head of this queue to prepare it's template asset.
// from the head of this queue to prepare its template asset.
const queue = findAllNestedStacks(root);

@@ -60,6 +61,19 @@ while (true) {

const result = new Array();
const includeStack = (stack) => {
if (!stack_1.Stack.isStack(stack)) {
return false;
}
if (!stack.nested) {
return false;
}
// test: if we are not within a stage, then include it.
if (!stage_1.Stage.of(stack)) {
return true;
}
return stage_1.Stage.of(stack) === root;
};
// create a list of all nested stacks in depth-first post order this means
// that we first prepare the leaves and then work our way up.
for (const stack of root.node.findAll(constructs_1.ConstructOrder.POSTORDER /* <== important */)) {
if (stack_1.Stack.isStack(stack) && stack.nested) {
if (includeStack(stack)) {
result.push(stack);

@@ -76,2 +90,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJlcGFyZS1hcHAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJwcmVwYXJlLWFwcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDJDQUE0QztBQUM1QyxrREFBOEM7QUFFOUMsb0NBQWlDO0FBQ2pDLGlDQUEyQztBQUUzQzs7Ozs7Ozs7O0dBU0c7QUFDSCxTQUFnQixVQUFVLENBQUMsSUFBZTtJQUN4QyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFO1FBQ25CLE1BQU0sSUFBSSxLQUFLLENBQUMsNENBQTRDLENBQUMsQ0FBQztLQUMvRDtJQUVELDZEQUE2RDtJQUM3RCxLQUFLLE1BQU0sVUFBVSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFO1FBQy9DLE1BQU0sa0JBQWtCLEdBQUcsZ0JBQWdCLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQy9ELE1BQU0sa0JBQWtCLEdBQUcsZ0JBQWdCLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRS9ELEtBQUssTUFBTSxNQUFNLElBQUksa0JBQWtCLEVBQUU7WUFDdkMsS0FBSyxNQUFNLE1BQU0sSUFBSSxrQkFBa0IsRUFBRTtnQkFDdkMsTUFBTSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsQ0FBQzthQUM3QjtTQUNGO0tBQ0Y7SUFFRCwyRUFBMkU7SUFDM0UsOERBQThEO0lBQzlELE1BQU0sS0FBSyxHQUFHLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDO0lBRXhDLE9BQU8sSUFBSSxFQUFFO1FBQ1gsd0JBQWlCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFeEIsTUFBTSxNQUFNLEdBQUcsS0FBSyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzdCLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDWCxNQUFNO1NBQ1A7UUFFRCxzQkFBc0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztLQUNoQztBQUNILENBQUM7QUEvQkQsZ0NBK0JDO0FBRUQ7Ozs7O0dBS0c7QUFDSCxTQUFTLHNCQUFzQixDQUFDLFdBQWtCO0lBQ2hELDJFQUEyRTtJQUMzRSxNQUFNLE1BQU0sR0FBMkIsV0FBa0IsQ0FBQztJQUMxRCxNQUFNLENBQUMscUJBQXFCLEVBQUUsQ0FBQztBQUNqQyxDQUFDO0FBRUQsU0FBUyxtQkFBbUIsQ0FBQyxJQUFlO0lBQzFDLE1BQU0sTUFBTSxHQUFHLElBQUksS0FBSyxFQUFTLENBQUM7SUFFbEMsMEVBQTBFO0lBQzFFLDZEQUE2RDtJQUM3RCxLQUFLLE1BQU0sS0FBSyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLDJCQUFjLENBQUMsU0FBUyxDQUFDLG1CQUFtQixDQUFDLEVBQUU7UUFDbkYsSUFBSSxhQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLEtBQUssQ0FBQyxNQUFNLEVBQUU7WUFDeEMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUNwQjtLQUNGO0lBRUQsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVEOztHQUVHO0FBQ0gsU0FBUyxnQkFBZ0IsQ0FBQyxJQUFnQjtJQUN4QyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsTUFBTSxDQUFDLDBCQUFXLENBQUMsYUFBYSxDQUFDLENBQUM7QUFDL0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdE9yZGVyIH0gZnJvbSAnY29uc3RydWN0cyc7XG5pbXBvcnQgeyBDZm5SZXNvdXJjZSB9IGZyb20gJy4uL2Nmbi1yZXNvdXJjZSc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QsIElDb25zdHJ1Y3QgfSBmcm9tICcuLi9jb25zdHJ1Y3QtY29tcGF0JztcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vc3RhY2snO1xuaW1wb3J0IHsgcmVzb2x2ZVJlZmVyZW5jZXMgfSBmcm9tICcuL3JlZnMnO1xuXG4vKipcbiAqIFByZXBhcmVzIHRoZSBhcHAgZm9yIHN5bnRoZXNpcy4gVGhpcyBmdW5jdGlvbiBpcyBjYWxsZWQgYnkgdGhlIHJvb3QgYHByZXBhcmVgXG4gKiAobm9ybWFsbHkgdGhpcyB0aGUgQXBwLCBidXQgaWYgYSBTdGFjayBpcyBhIHJvb3QsIGl0IGlzIGNhbGxlZCBieSB0aGUgc3RhY2spLFxuICogd2hpY2ggbWVhbnMgaXQncyB0aGUgbGFzdCAncHJlcGFyZScgdGhhdCBleGVjdXRlcy5cbiAqXG4gKiBJdCB0YWtlcyBjYXJlIG9mIHJlaWZ5aW5nIGNyb3NzLXJlZmVyZW5jZXMgYmV0d2VlbiBzdGFja3MgKG9yIG5lc3RlZCBzdGFja3MpLFxuICogYW5kIG9mIGNyZWF0aW5nIGFzc2V0cyBmb3IgbmVzdGVkIHN0YWNrIHRlbXBsYXRlcy5cbiAqXG4gKiBAcGFyYW0gcm9vdCBUaGUgcm9vdCBvZiB0aGUgY29uc3RydWN0IHRyZWUuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwcmVwYXJlQXBwKHJvb3Q6IENvbnN0cnVjdCkge1xuICBpZiAocm9vdC5ub2RlLnNjb3BlKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdwcmVwYXJlQXBwIG11c3QgYmUgY2FsbGVkIG9uIHRoZSByb290IG5vZGUnKTtcbiAgfVxuXG4gIC8vIGFwcGx5IGRlcGVuZGVuY2llcyBiZXR3ZWVuIHJlc291cmNlcyBpbiBkZXBlbmRpbmcgc3VidHJlZXNcbiAgZm9yIChjb25zdCBkZXBlbmRlbmN5IG9mIHJvb3Qubm9kZS5kZXBlbmRlbmNpZXMpIHtcbiAgICBjb25zdCB0YXJnZXRDZm5SZXNvdXJjZXMgPSBmaW5kQ2ZuUmVzb3VyY2VzKGRlcGVuZGVuY3kudGFyZ2V0KTtcbiAgICBjb25zdCBzb3VyY2VDZm5SZXNvdXJjZXMgPSBmaW5kQ2ZuUmVzb3VyY2VzKGRlcGVuZGVuY3kuc291cmNlKTtcblxuICAgIGZvciAoY29uc3QgdGFyZ2V0IG9mIHRhcmdldENmblJlc291cmNlcykge1xuICAgICAgZm9yIChjb25zdCBzb3VyY2Ugb2Ygc291cmNlQ2ZuUmVzb3VyY2VzKSB7XG4gICAgICAgIHNvdXJjZS5hZGREZXBlbmRzT24odGFyZ2V0KTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICAvLyBkZXB0aC1maXJzdCAoY2hpbGRyZW4gZmlyc3QpIHF1ZXVlIG9mIG5lc3RlZCBzdGFja3MuIFdlIHdpbGwgcG9wIGEgc3RhY2tcbiAgLy8gZnJvbSB0aGUgaGVhZCBvZiB0aGlzIHF1ZXVlIHRvIHByZXBhcmUgaXQncyB0ZW1wbGF0ZSBhc3NldC5cbiAgY29uc3QgcXVldWUgPSBmaW5kQWxsTmVzdGVkU3RhY2tzKHJvb3QpO1xuXG4gIHdoaWxlICh0cnVlKSB7XG4gICAgcmVzb2x2ZVJlZmVyZW5jZXMocm9vdCk7XG5cbiAgICBjb25zdCBuZXN0ZWQgPSBxdWV1ZS5zaGlmdCgpO1xuICAgIGlmICghbmVzdGVkKSB7XG4gICAgICBicmVhaztcbiAgICB9XG5cbiAgICBkZWZpbmVOZXN0ZWRTdGFja0Fzc2V0KG5lc3RlZCk7XG4gIH1cbn1cblxuLyoqXG4gKiBQcmVwYXJlcyB0aGUgYXNzZXRzIGZvciBuZXN0ZWQgc3RhY2tzIGluIHRoaXMgYXBwLlxuICogQHJldHVybnMgYHRydWVgIGlmIGFzc2V0cyB3ZXJlIGFkZGVkIHRvIHRoZSBwYXJlbnQgb2YgYSBuZXN0ZWQgc3RhY2ssIHdoaWNoXG4gKiBpbXBsaWVzIHRoYXQgYW5vdGhlciByb3VuZCBvZiByZWZlcmVuY2UgcmVzb2x1dGlvbiBpcyBpbiBvcmRlci4gSWYgdGhpc1xuICogZnVuY3Rpb24gcmV0dXJucyBgZmFsc2VgLCB3ZSBrbm93IHdlIGFyZSBkb25lLlxuICovXG5mdW5jdGlvbiBkZWZpbmVOZXN0ZWRTdGFja0Fzc2V0KG5lc3RlZFN0YWNrOiBTdGFjaykge1xuICAvLyB0aGlzIGlzIG5lZWRlZCB0ZW1wb3JhcmlseSB1bnRpbCB3ZSBtb3ZlIE5lc3RlZFN0YWNrIHRvICdAYXdzLWNkay9jb3JlJy5cbiAgY29uc3QgbmVzdGVkOiBJTmVzdGVkU3RhY2tQcml2YXRlQXBpID0gbmVzdGVkU3RhY2sgYXMgYW55O1xuICBuZXN0ZWQuX3ByZXBhcmVUZW1wbGF0ZUFzc2V0KCk7XG59XG5cbmZ1bmN0aW9uIGZpbmRBbGxOZXN0ZWRTdGFja3Mocm9vdDogQ29uc3RydWN0KSB7XG4gIGNvbnN0IHJlc3VsdCA9IG5ldyBBcnJheTxTdGFjaz4oKTtcblxuICAvLyBjcmVhdGUgYSBsaXN0IG9mIGFsbCBuZXN0ZWQgc3RhY2tzIGluIGRlcHRoLWZpcnN0IHBvc3Qgb3JkZXIgdGhpcyBtZWFuc1xuICAvLyB0aGF0IHdlIGZpcnN0IHByZXBhcmUgdGhlIGxlYXZlcyBhbmQgdGhlbiB3b3JrIG91ciB3YXkgdXAuXG4gIGZvciAoY29uc3Qgc3RhY2sgb2Ygcm9vdC5ub2RlLmZpbmRBbGwoQ29uc3RydWN0T3JkZXIuUE9TVE9SREVSIC8qIDw9PSBpbXBvcnRhbnQgKi8pKSB7XG4gICAgaWYgKFN0YWNrLmlzU3RhY2soc3RhY2spICYmIHN0YWNrLm5lc3RlZCkge1xuICAgICAgcmVzdWx0LnB1c2goc3RhY2spO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiByZXN1bHQ7XG59XG5cbi8qKlxuICogRmluZCBhbGwgcmVzb3VyY2VzIGluIGEgc2V0IG9mIGNvbnN0cnVjdHNcbiAqL1xuZnVuY3Rpb24gZmluZENmblJlc291cmNlcyhyb290OiBJQ29uc3RydWN0KTogQ2ZuUmVzb3VyY2VbXSB7XG4gIHJldHVybiByb290Lm5vZGUuZmluZEFsbCgpLmZpbHRlcihDZm5SZXNvdXJjZS5pc0NmblJlc291cmNlKTtcbn1cblxuaW50ZXJmYWNlIElOZXN0ZWRTdGFja1ByaXZhdGVBcGkge1xuICBfcHJlcGFyZVRlbXBsYXRlQXNzZXQoKTogYm9vbGVhbjtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJlcGFyZS1hcHAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJwcmVwYXJlLWFwcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDJDQUE0QztBQUM1QyxrREFBOEM7QUFFOUMsb0NBQWlDO0FBQ2pDLG9DQUFpQztBQUNqQyxpQ0FBMkM7QUFFM0M7Ozs7Ozs7OztHQVNHO0FBQ0gsU0FBZ0IsVUFBVSxDQUFDLElBQWdCO0lBQ3pDLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksQ0FBQyxhQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQzNDLE1BQU0sSUFBSSxLQUFLLENBQUMsOERBQThELENBQUMsQ0FBQztLQUNqRjtJQUVELDZEQUE2RDtJQUM3RCxLQUFLLE1BQU0sVUFBVSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFO1FBQy9DLE1BQU0sa0JBQWtCLEdBQUcsZ0JBQWdCLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQy9ELE1BQU0sa0JBQWtCLEdBQUcsZ0JBQWdCLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRS9ELEtBQUssTUFBTSxNQUFNLElBQUksa0JBQWtCLEVBQUU7WUFDdkMsS0FBSyxNQUFNLE1BQU0sSUFBSSxrQkFBa0IsRUFBRTtnQkFDdkMsTUFBTSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsQ0FBQzthQUM3QjtTQUNGO0tBQ0Y7SUFFRCwyRUFBMkU7SUFDM0UsNkRBQTZEO0lBQzdELE1BQU0sS0FBSyxHQUFHLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDO0lBRXhDLE9BQU8sSUFBSSxFQUFFO1FBQ1gsd0JBQWlCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFeEIsTUFBTSxNQUFNLEdBQUcsS0FBSyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzdCLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDWCxNQUFNO1NBQ1A7UUFFRCxzQkFBc0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztLQUNoQztBQUNILENBQUM7QUEvQkQsZ0NBK0JDO0FBRUQ7Ozs7O0dBS0c7QUFDSCxTQUFTLHNCQUFzQixDQUFDLFdBQWtCO0lBQ2hELDJFQUEyRTtJQUMzRSxNQUFNLE1BQU0sR0FBMkIsV0FBa0IsQ0FBQztJQUMxRCxNQUFNLENBQUMscUJBQXFCLEVBQUUsQ0FBQztBQUNqQyxDQUFDO0FBRUQsU0FBUyxtQkFBbUIsQ0FBQyxJQUFnQjtJQUMzQyxNQUFNLE1BQU0sR0FBRyxJQUFJLEtBQUssRUFBUyxDQUFDO0lBRWxDLE1BQU0sWUFBWSxHQUFHLENBQUMsS0FBaUIsRUFBa0IsRUFBRTtRQUN6RCxJQUFJLENBQUMsYUFBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUFFLE9BQU8sS0FBSyxDQUFDO1NBQUU7UUFDNUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUU7WUFBRSxPQUFPLEtBQUssQ0FBQztTQUFFO1FBRXBDLHVEQUF1RDtRQUN2RCxJQUFJLENBQUMsYUFBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUFFLE9BQU8sSUFBSSxDQUFDO1NBQUU7UUFFdEMsT0FBTyxhQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksQ0FBQztJQUNsQyxDQUFDLENBQUM7SUFFRiwwRUFBMEU7SUFDMUUsNkRBQTZEO0lBQzdELEtBQUssTUFBTSxLQUFLLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsMkJBQWMsQ0FBQyxTQUFTLENBQUMsbUJBQW1CLENBQUMsRUFBRTtRQUNuRixJQUFJLFlBQVksQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUN2QixNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3BCO0tBQ0Y7SUFFRCxPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFTLGdCQUFnQixDQUFDLElBQWdCO0lBQ3hDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxNQUFNLENBQUMsMEJBQVcsQ0FBQyxhQUFhLENBQUMsQ0FBQztBQUMvRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0T3JkZXIgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IENmblJlc291cmNlIH0gZnJvbSAnLi4vY2ZuLXJlc291cmNlJztcbmltcG9ydCB7IElDb25zdHJ1Y3QgfSBmcm9tICcuLi9jb25zdHJ1Y3QtY29tcGF0JztcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vc3RhY2snO1xuaW1wb3J0IHsgU3RhZ2UgfSBmcm9tICcuLi9zdGFnZSc7XG5pbXBvcnQgeyByZXNvbHZlUmVmZXJlbmNlcyB9IGZyb20gJy4vcmVmcyc7XG5cbi8qKlxuICogUHJlcGFyZXMgdGhlIGFwcCBmb3Igc3ludGhlc2lzLiBUaGlzIGZ1bmN0aW9uIGlzIGNhbGxlZCBieSB0aGUgcm9vdCBgcHJlcGFyZWBcbiAqIChub3JtYWxseSB0aGlzIHRoZSBBcHAsIGJ1dCBpZiBhIFN0YWNrIGlzIGEgcm9vdCwgaXQgaXMgY2FsbGVkIGJ5IHRoZSBzdGFjayksXG4gKiB3aGljaCBtZWFucyBpdCdzIHRoZSBsYXN0ICdwcmVwYXJlJyB0aGF0IGV4ZWN1dGVzLlxuICpcbiAqIEl0IHRha2VzIGNhcmUgb2YgcmVpZnlpbmcgY3Jvc3MtcmVmZXJlbmNlcyBiZXR3ZWVuIHN0YWNrcyAob3IgbmVzdGVkIHN0YWNrcyksXG4gKiBhbmQgb2YgY3JlYXRpbmcgYXNzZXRzIGZvciBuZXN0ZWQgc3RhY2sgdGVtcGxhdGVzLlxuICpcbiAqIEBwYXJhbSByb290IFRoZSByb290IG9mIHRoZSBjb25zdHJ1Y3QgdHJlZS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHByZXBhcmVBcHAocm9vdDogSUNvbnN0cnVjdCkge1xuICBpZiAocm9vdC5ub2RlLnNjb3BlICYmICFTdGFnZS5pc1N0YWdlKHJvb3QpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdwcmVwYXJlQXBwIGNhbiBvbmx5IGJlIGNhbGxlZCBvbiBhIHN0YWdlIG9yIGEgcm9vdCBjb25zdHJ1Y3QnKTtcbiAgfVxuXG4gIC8vIGFwcGx5IGRlcGVuZGVuY2llcyBiZXR3ZWVuIHJlc291cmNlcyBpbiBkZXBlbmRpbmcgc3VidHJlZXNcbiAgZm9yIChjb25zdCBkZXBlbmRlbmN5IG9mIHJvb3Qubm9kZS5kZXBlbmRlbmNpZXMpIHtcbiAgICBjb25zdCB0YXJnZXRDZm5SZXNvdXJjZXMgPSBmaW5kQ2ZuUmVzb3VyY2VzKGRlcGVuZGVuY3kudGFyZ2V0KTtcbiAgICBjb25zdCBzb3VyY2VDZm5SZXNvdXJjZXMgPSBmaW5kQ2ZuUmVzb3VyY2VzKGRlcGVuZGVuY3kuc291cmNlKTtcblxuICAgIGZvciAoY29uc3QgdGFyZ2V0IG9mIHRhcmdldENmblJlc291cmNlcykge1xuICAgICAgZm9yIChjb25zdCBzb3VyY2Ugb2Ygc291cmNlQ2ZuUmVzb3VyY2VzKSB7XG4gICAgICAgIHNvdXJjZS5hZGREZXBlbmRzT24odGFyZ2V0KTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICAvLyBkZXB0aC1maXJzdCAoY2hpbGRyZW4gZmlyc3QpIHF1ZXVlIG9mIG5lc3RlZCBzdGFja3MuIFdlIHdpbGwgcG9wIGEgc3RhY2tcbiAgLy8gZnJvbSB0aGUgaGVhZCBvZiB0aGlzIHF1ZXVlIHRvIHByZXBhcmUgaXRzIHRlbXBsYXRlIGFzc2V0LlxuICBjb25zdCBxdWV1ZSA9IGZpbmRBbGxOZXN0ZWRTdGFja3Mocm9vdCk7XG5cbiAgd2hpbGUgKHRydWUpIHtcbiAgICByZXNvbHZlUmVmZXJlbmNlcyhyb290KTtcblxuICAgIGNvbnN0IG5lc3RlZCA9IHF1ZXVlLnNoaWZ0KCk7XG4gICAgaWYgKCFuZXN0ZWQpIHtcbiAgICAgIGJyZWFrO1xuICAgIH1cblxuICAgIGRlZmluZU5lc3RlZFN0YWNrQXNzZXQobmVzdGVkKTtcbiAgfVxufVxuXG4vKipcbiAqIFByZXBhcmVzIHRoZSBhc3NldHMgZm9yIG5lc3RlZCBzdGFja3MgaW4gdGhpcyBhcHAuXG4gKiBAcmV0dXJucyBgdHJ1ZWAgaWYgYXNzZXRzIHdlcmUgYWRkZWQgdG8gdGhlIHBhcmVudCBvZiBhIG5lc3RlZCBzdGFjaywgd2hpY2hcbiAqIGltcGxpZXMgdGhhdCBhbm90aGVyIHJvdW5kIG9mIHJlZmVyZW5jZSByZXNvbHV0aW9uIGlzIGluIG9yZGVyLiBJZiB0aGlzXG4gKiBmdW5jdGlvbiByZXR1cm5zIGBmYWxzZWAsIHdlIGtub3cgd2UgYXJlIGRvbmUuXG4gKi9cbmZ1bmN0aW9uIGRlZmluZU5lc3RlZFN0YWNrQXNzZXQobmVzdGVkU3RhY2s6IFN0YWNrKSB7XG4gIC8vIHRoaXMgaXMgbmVlZGVkIHRlbXBvcmFyaWx5IHVudGlsIHdlIG1vdmUgTmVzdGVkU3RhY2sgdG8gJ0Bhd3MtY2RrL2NvcmUnLlxuICBjb25zdCBuZXN0ZWQ6IElOZXN0ZWRTdGFja1ByaXZhdGVBcGkgPSBuZXN0ZWRTdGFjayBhcyBhbnk7XG4gIG5lc3RlZC5fcHJlcGFyZVRlbXBsYXRlQXNzZXQoKTtcbn1cblxuZnVuY3Rpb24gZmluZEFsbE5lc3RlZFN0YWNrcyhyb290OiBJQ29uc3RydWN0KSB7XG4gIGNvbnN0IHJlc3VsdCA9IG5ldyBBcnJheTxTdGFjaz4oKTtcblxuICBjb25zdCBpbmNsdWRlU3RhY2sgPSAoc3RhY2s6IElDb25zdHJ1Y3QpOiBzdGFjayBpcyBTdGFjayA9PiB7XG4gICAgaWYgKCFTdGFjay5pc1N0YWNrKHN0YWNrKSkgeyByZXR1cm4gZmFsc2U7IH1cbiAgICBpZiAoIXN0YWNrLm5lc3RlZCkgeyByZXR1cm4gZmFsc2U7IH1cblxuICAgIC8vIHRlc3Q6IGlmIHdlIGFyZSBub3Qgd2l0aGluIGEgc3RhZ2UsIHRoZW4gaW5jbHVkZSBpdC5cbiAgICBpZiAoIVN0YWdlLm9mKHN0YWNrKSkgeyByZXR1cm4gdHJ1ZTsgfVxuXG4gICAgcmV0dXJuIFN0YWdlLm9mKHN0YWNrKSA9PT0gcm9vdDtcbiAgfTtcblxuICAvLyBjcmVhdGUgYSBsaXN0IG9mIGFsbCBuZXN0ZWQgc3RhY2tzIGluIGRlcHRoLWZpcnN0IHBvc3Qgb3JkZXIgdGhpcyBtZWFuc1xuICAvLyB0aGF0IHdlIGZpcnN0IHByZXBhcmUgdGhlIGxlYXZlcyBhbmQgdGhlbiB3b3JrIG91ciB3YXkgdXAuXG4gIGZvciAoY29uc3Qgc3RhY2sgb2Ygcm9vdC5ub2RlLmZpbmRBbGwoQ29uc3RydWN0T3JkZXIuUE9TVE9SREVSIC8qIDw9PSBpbXBvcnRhbnQgKi8pKSB7XG4gICAgaWYgKGluY2x1ZGVTdGFjayhzdGFjaykpIHtcbiAgICAgIHJlc3VsdC5wdXNoKHN0YWNrKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gcmVzdWx0O1xufVxuXG4vKipcbiAqIEZpbmQgYWxsIHJlc291cmNlcyBpbiBhIHNldCBvZiBjb25zdHJ1Y3RzXG4gKi9cbmZ1bmN0aW9uIGZpbmRDZm5SZXNvdXJjZXMocm9vdDogSUNvbnN0cnVjdCk6IENmblJlc291cmNlW10ge1xuICByZXR1cm4gcm9vdC5ub2RlLmZpbmRBbGwoKS5maWx0ZXIoQ2ZuUmVzb3VyY2UuaXNDZm5SZXNvdXJjZSk7XG59XG5cbmludGVyZmFjZSBJTmVzdGVkU3RhY2tQcml2YXRlQXBpIHtcbiAgX3ByZXBhcmVUZW1wbGF0ZUFzc2V0KCk6IGJvb2xlYW47XG59XG4iXX0=

@@ -1,2 +0,2 @@

import { Construct } from '../construct-compat';
import { IConstruct } from '../construct-compat';
/**

@@ -6,2 +6,2 @@ * This is called from the App level to resolve all references defined. Each

*/
export declare function resolveReferences(scope: Construct): void;
export declare function resolveReferences(scope: IConstruct): void;

@@ -229,2 +229,2 @@ "use strict";

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"refs.js","sourceRoot":"","sources":["refs.ts"],"names":[],"mappings":"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","sourcesContent":["// ----------------------------------------------------\n// CROSS REFERENCES\n// ----------------------------------------------------\nimport { CfnElement } from '../cfn-element';\nimport { CfnOutput } from '../cfn-output';\nimport { CfnParameter } from '../cfn-parameter';\nimport { Construct } from '../construct-compat';\nimport { Reference } from '../reference';\nimport { IResolvable } from '../resolvable';\nimport { Stack } from '../stack';\nimport { Token } from '../token';\nimport { CfnReference } from './cfn-reference';\nimport { Intrinsic } from './intrinsic';\nimport { findTokens } from './resolve';\nimport { makeUniqueId } from './uniqueid';\n\n/**\n * This is called from the App level to resolve all references defined. Each\n * reference is resolved based on it's consumption context.\n */\nexport function resolveReferences(scope: Construct): void {\n  const edges = findAllReferences(scope);\n\n  for (const { source, value } of edges) {\n    const consumer = Stack.of(source);\n\n    // resolve the value in the context of the consumer\n    if (!value.hasValueForStack(consumer)) {\n      const resolved = resolveValue(consumer, value);\n      value.assignValueForStack(consumer, resolved);\n    }\n  }\n}\n\n/**\n * Resolves the value for `reference` in the context of `consumer`.\n */\nfunction resolveValue(consumer: Stack, reference: CfnReference): IResolvable {\n  const producer = Stack.of(reference.target);\n\n  // produce and consumer stacks are the same, we can just return the value itself.\n  if (producer === consumer) {\n    return reference;\n  }\n\n  // unsupported: stacks from different apps\n  if (producer.node.root !== consumer.node.root) {\n    throw new Error('Cannot reference across apps. Consuming and producing stacks must be defined within the same CDK app.');\n  }\n\n  // unsupported: stacks are not in the same environment\n  if (producer.environment !== consumer.environment) {\n    throw new Error(\n      `Stack \"${consumer.node.path}\" cannot consume a cross reference from stack \"${producer.node.path}\". ` +\n      'Cross stack references are only supported for stacks deployed to the same environment or between nested stacks and their parent stack');\n  }\n\n  // ----------------------------------------------------------------------\n  // consumer is nested in the producer (directly or indirectly)\n  // ----------------------------------------------------------------------\n\n  // if the consumer is nested within the producer (directly or indirectly),\n  // wire through a CloudFormation parameter and then resolve the reference with\n  // the parent stack as the consumer.\n  if (consumer.nestedStackParent && isNested(consumer, producer)) {\n    const parameterValue = resolveValue(consumer.nestedStackParent, reference);\n    return createNestedStackParameter(consumer, reference, parameterValue);\n  }\n\n  // ----------------------------------------------------------------------\n  // producer is a nested stack\n  // ----------------------------------------------------------------------\n\n  // if the producer is nested, always publish the value through a\n  // cloudformation output and resolve recursively with the Fn::GetAtt\n  // of the output in the parent stack.\n\n  // one might ask, if the consumer is not a parent of the producer,\n  // why not just use export/import? the reason is that we cannot\n  // generate an \"export name\" from a nested stack because the export\n  // name must contain the stack name to ensure uniqueness, and we\n  // don't know the stack name of a nested stack before we deploy it.\n  // therefore, we can only export from a top-level stack.\n  if (producer.nested) {\n    const outputValue = createNestedStackOutput(producer, reference);\n    return resolveValue(consumer, outputValue);\n  }\n\n  // ----------------------------------------------------------------------\n  // export/import\n  // ----------------------------------------------------------------------\n\n  // export the value through a cloudformation \"export name\" and use an\n  // Fn::ImportValue in the consumption site.\n\n  // add a dependency between the producer and the consumer. dependency logic\n  // will take care of applying the dependency at the right level (e.g. the\n  // top-level stacks).\n  consumer.addDependency(producer,\n    `${consumer.node.path} -> ${reference.target.node.path}.${reference.displayName}`);\n\n  return createImportValue(reference);\n}\n\n/**\n * Finds all the CloudFormation references in a construct tree.\n */\nfunction findAllReferences(root: Construct) {\n  const result = new Array<{ source: CfnElement, value: CfnReference }>();\n  for (const consumer of root.node.findAll()) {\n\n    // include only CfnElements (i.e. resources)\n    if (!CfnElement.isCfnElement(consumer)) {\n      continue;\n    }\n\n    try {\n      const tokens = findTokens(consumer, () => consumer._toCloudFormation());\n\n      // iterate over all the tokens (e.g. intrinsic functions, lazies, etc) that\n      // were found in the cloudformation representation of this resource.\n      for (const token of tokens) {\n\n        // include only CfnReferences (i.e. \"Ref\" and \"Fn::GetAtt\")\n        if (!CfnReference.isCfnReference(token)) {\n          continue;\n        }\n\n        result.push({\n          source: consumer,\n          value: token,\n        });\n      }\n    }  catch (e) {\n      // Note: it might be that the properties of the CFN object aren't valid.\n      // This will usually be preventatively caught in a construct's validate()\n      // and turned into a nicely descriptive error, but we're running prepare()\n      // before validate(). Swallow errors that occur because the CFN layer\n      // doesn't validate completely.\n      //\n      // This does make the assumption that the error will not be rectified,\n      // but the error will be thrown later on anyway. If the error doesn't\n      // get thrown down the line, we may miss references.\n      if (e.type === 'CfnSynthesisError') {\n        continue;\n      }\n\n      throw e;\n    }\n  }\n\n  return result;\n}\n\n// ------------------------------------------------------------------------------------------------\n// export/import\n// ------------------------------------------------------------------------------------------------\n\n/**\n * Imports a value from another stack by creating an \"Output\" with an \"ExportName\"\n * and returning an \"Fn::ImportValue\" token.\n */\nfunction createImportValue(reference: Reference): Intrinsic {\n  const exportingStack = Stack.of(reference.target);\n\n  // Ensure a singleton \"Exports\" scoping Construct\n  // This mostly exists to trigger LogicalID munging, which would be\n  // disabled if we parented constructs directly under Stack.\n  // Also it nicely prevents likely construct name clashes\n  const exportsScope = getCreateExportsScope(exportingStack);\n\n  // Ensure a singleton CfnOutput for this value\n  const resolved = exportingStack.resolve(reference);\n  const id = 'Output' + JSON.stringify(resolved);\n  const exportName = generateExportName(exportsScope, id);\n\n  if (Token.isUnresolved(exportName)) {\n    throw new Error(`unresolved token in generated export name: ${JSON.stringify(exportingStack.resolve(exportName))}`);\n  }\n\n  const output = exportsScope.node.tryFindChild(id) as CfnOutput;\n  if (!output) {\n    new CfnOutput(exportsScope, id, { value: Token.asString(reference), exportName });\n  }\n\n  // We want to return an actual FnImportValue Token here, but Fn.importValue() returns a 'string',\n  // so construct one in-place.\n  return new Intrinsic({ 'Fn::ImportValue': exportName });\n}\n\nfunction getCreateExportsScope(stack: Stack) {\n  const exportsName = 'Exports';\n  let stackExports = stack.node.tryFindChild(exportsName) as Construct;\n  if (stackExports === undefined) {\n    stackExports = new Construct(stack, exportsName);\n  }\n\n  return stackExports;\n}\n\nfunction generateExportName(stackExports: Construct, id: string) {\n  const stack = Stack.of(stackExports);\n  const components = [...stackExports.node.scopes.slice(2).map(c => c.node.id), id];\n  const prefix = stack.stackName ? stack.stackName + ':' : '';\n  const exportName = prefix + makeUniqueId(components);\n  return exportName;\n}\n\n// ------------------------------------------------------------------------------------------------\n// nested stacks\n// ------------------------------------------------------------------------------------------------\n\n/**\n * Adds a CloudFormation parameter to a nested stack and assigns it with the\n * value of the reference.\n */\nfunction createNestedStackParameter(nested: Stack, reference: CfnReference, value: IResolvable) {\n  // we call \"this.resolve\" to ensure that tokens do not creep in (for example, if the reference display name includes tokens)\n  const paramId = nested.resolve(`reference-to-${reference.target.node.uniqueId}.${reference.displayName}`);\n  let param = nested.node.tryFindChild(paramId) as CfnParameter;\n  if (!param) {\n    param = new CfnParameter(nested, paramId, { type: 'String' });\n\n    // Ugly little hack until we move NestedStack to this module.\n    if (!('setParameter' in nested)) {\n      throw new Error('assertion failed: nested stack should have a \"setParameter\" method');\n    }\n\n    (nested as any).setParameter(param.logicalId, Token.asString(value));\n  }\n\n  return param.value as CfnReference;\n}\n\n/**\n * Adds a CloudFormation output to a nested stack and returns an \"Fn::GetAtt\"\n * intrinsic that can be used to reference this output in the parent stack.\n */\nfunction createNestedStackOutput(producer: Stack, reference: Reference): CfnReference {\n  const outputId = `${reference.target.node.uniqueId}${reference.displayName}`;\n  let output = producer.node.tryFindChild(outputId) as CfnOutput;\n  if (!output) {\n    output = new CfnOutput(producer, outputId, { value: Token.asString(reference) });\n  }\n\n  if (!producer.nestedStackResource) {\n    throw new Error('assertion failed');\n  }\n\n  return producer.nestedStackResource.getAtt(`Outputs.${output.logicalId}`) as CfnReference;\n}\n\n/**\n * @returns true if this stack is a direct or indirect parent of the nested\n * stack `nested`.\n *\n * If `child` is not a nested stack, always returns `false` because it can't\n * have a parent, dah.\n */\nfunction isNested(nested: Stack, parent: Stack): boolean {\n  // if the parent is a direct parent\n  if (nested.nestedStackParent === parent) {\n    return true;\n  }\n\n  // we reached a top-level (non-nested) stack without finding the parent\n  if (!nested.nestedStackParent) {\n    return false;\n  }\n\n  // recurse with the child's direct parent\n  return isNested(nested.nestedStackParent, parent);\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"refs.js","sourceRoot":"","sources":["refs.ts"],"names":[],"mappings":"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","sourcesContent":["// ----------------------------------------------------\n// CROSS REFERENCES\n// ----------------------------------------------------\nimport { CfnElement } from '../cfn-element';\nimport { CfnOutput } from '../cfn-output';\nimport { CfnParameter } from '../cfn-parameter';\nimport { Construct, IConstruct } from '../construct-compat';\nimport { Reference } from '../reference';\nimport { IResolvable } from '../resolvable';\nimport { Stack } from '../stack';\nimport { Token } from '../token';\nimport { CfnReference } from './cfn-reference';\nimport { Intrinsic } from './intrinsic';\nimport { findTokens } from './resolve';\nimport { makeUniqueId } from './uniqueid';\n\n/**\n * This is called from the App level to resolve all references defined. Each\n * reference is resolved based on it's consumption context.\n */\nexport function resolveReferences(scope: IConstruct): void {\n  const edges = findAllReferences(scope);\n\n  for (const { source, value } of edges) {\n    const consumer = Stack.of(source);\n\n    // resolve the value in the context of the consumer\n    if (!value.hasValueForStack(consumer)) {\n      const resolved = resolveValue(consumer, value);\n      value.assignValueForStack(consumer, resolved);\n    }\n  }\n}\n\n/**\n * Resolves the value for `reference` in the context of `consumer`.\n */\nfunction resolveValue(consumer: Stack, reference: CfnReference): IResolvable {\n  const producer = Stack.of(reference.target);\n\n  // produce and consumer stacks are the same, we can just return the value itself.\n  if (producer === consumer) {\n    return reference;\n  }\n\n  // unsupported: stacks from different apps\n  if (producer.node.root !== consumer.node.root) {\n    throw new Error('Cannot reference across apps. Consuming and producing stacks must be defined within the same CDK app.');\n  }\n\n  // unsupported: stacks are not in the same environment\n  if (producer.environment !== consumer.environment) {\n    throw new Error(\n      `Stack \"${consumer.node.path}\" cannot consume a cross reference from stack \"${producer.node.path}\". ` +\n      'Cross stack references are only supported for stacks deployed to the same environment or between nested stacks and their parent stack');\n  }\n\n  // ----------------------------------------------------------------------\n  // consumer is nested in the producer (directly or indirectly)\n  // ----------------------------------------------------------------------\n\n  // if the consumer is nested within the producer (directly or indirectly),\n  // wire through a CloudFormation parameter and then resolve the reference with\n  // the parent stack as the consumer.\n  if (consumer.nestedStackParent && isNested(consumer, producer)) {\n    const parameterValue = resolveValue(consumer.nestedStackParent, reference);\n    return createNestedStackParameter(consumer, reference, parameterValue);\n  }\n\n  // ----------------------------------------------------------------------\n  // producer is a nested stack\n  // ----------------------------------------------------------------------\n\n  // if the producer is nested, always publish the value through a\n  // cloudformation output and resolve recursively with the Fn::GetAtt\n  // of the output in the parent stack.\n\n  // one might ask, if the consumer is not a parent of the producer,\n  // why not just use export/import? the reason is that we cannot\n  // generate an \"export name\" from a nested stack because the export\n  // name must contain the stack name to ensure uniqueness, and we\n  // don't know the stack name of a nested stack before we deploy it.\n  // therefore, we can only export from a top-level stack.\n  if (producer.nested) {\n    const outputValue = createNestedStackOutput(producer, reference);\n    return resolveValue(consumer, outputValue);\n  }\n\n  // ----------------------------------------------------------------------\n  // export/import\n  // ----------------------------------------------------------------------\n\n  // export the value through a cloudformation \"export name\" and use an\n  // Fn::ImportValue in the consumption site.\n\n  // add a dependency between the producer and the consumer. dependency logic\n  // will take care of applying the dependency at the right level (e.g. the\n  // top-level stacks).\n  consumer.addDependency(producer,\n    `${consumer.node.path} -> ${reference.target.node.path}.${reference.displayName}`);\n\n  return createImportValue(reference);\n}\n\n/**\n * Finds all the CloudFormation references in a construct tree.\n */\nfunction findAllReferences(root: IConstruct) {\n  const result = new Array<{ source: CfnElement, value: CfnReference }>();\n  for (const consumer of root.node.findAll()) {\n\n    // include only CfnElements (i.e. resources)\n    if (!CfnElement.isCfnElement(consumer)) {\n      continue;\n    }\n\n    try {\n      const tokens = findTokens(consumer, () => consumer._toCloudFormation());\n\n      // iterate over all the tokens (e.g. intrinsic functions, lazies, etc) that\n      // were found in the cloudformation representation of this resource.\n      for (const token of tokens) {\n\n        // include only CfnReferences (i.e. \"Ref\" and \"Fn::GetAtt\")\n        if (!CfnReference.isCfnReference(token)) {\n          continue;\n        }\n\n        result.push({\n          source: consumer,\n          value: token,\n        });\n      }\n    }  catch (e) {\n      // Note: it might be that the properties of the CFN object aren't valid.\n      // This will usually be preventatively caught in a construct's validate()\n      // and turned into a nicely descriptive error, but we're running prepare()\n      // before validate(). Swallow errors that occur because the CFN layer\n      // doesn't validate completely.\n      //\n      // This does make the assumption that the error will not be rectified,\n      // but the error will be thrown later on anyway. If the error doesn't\n      // get thrown down the line, we may miss references.\n      if (e.type === 'CfnSynthesisError') {\n        continue;\n      }\n\n      throw e;\n    }\n  }\n\n  return result;\n}\n\n// ------------------------------------------------------------------------------------------------\n// export/import\n// ------------------------------------------------------------------------------------------------\n\n/**\n * Imports a value from another stack by creating an \"Output\" with an \"ExportName\"\n * and returning an \"Fn::ImportValue\" token.\n */\nfunction createImportValue(reference: Reference): Intrinsic {\n  const exportingStack = Stack.of(reference.target);\n\n  // Ensure a singleton \"Exports\" scoping Construct\n  // This mostly exists to trigger LogicalID munging, which would be\n  // disabled if we parented constructs directly under Stack.\n  // Also it nicely prevents likely construct name clashes\n  const exportsScope = getCreateExportsScope(exportingStack);\n\n  // Ensure a singleton CfnOutput for this value\n  const resolved = exportingStack.resolve(reference);\n  const id = 'Output' + JSON.stringify(resolved);\n  const exportName = generateExportName(exportsScope, id);\n\n  if (Token.isUnresolved(exportName)) {\n    throw new Error(`unresolved token in generated export name: ${JSON.stringify(exportingStack.resolve(exportName))}`);\n  }\n\n  const output = exportsScope.node.tryFindChild(id) as CfnOutput;\n  if (!output) {\n    new CfnOutput(exportsScope, id, { value: Token.asString(reference), exportName });\n  }\n\n  // We want to return an actual FnImportValue Token here, but Fn.importValue() returns a 'string',\n  // so construct one in-place.\n  return new Intrinsic({ 'Fn::ImportValue': exportName });\n}\n\nfunction getCreateExportsScope(stack: Stack) {\n  const exportsName = 'Exports';\n  let stackExports = stack.node.tryFindChild(exportsName) as Construct;\n  if (stackExports === undefined) {\n    stackExports = new Construct(stack, exportsName);\n  }\n\n  return stackExports;\n}\n\nfunction generateExportName(stackExports: Construct, id: string) {\n  const stack = Stack.of(stackExports);\n  const components = [...stackExports.node.scopes.slice(2).map(c => c.node.id), id];\n  const prefix = stack.stackName ? stack.stackName + ':' : '';\n  const exportName = prefix + makeUniqueId(components);\n  return exportName;\n}\n\n// ------------------------------------------------------------------------------------------------\n// nested stacks\n// ------------------------------------------------------------------------------------------------\n\n/**\n * Adds a CloudFormation parameter to a nested stack and assigns it with the\n * value of the reference.\n */\nfunction createNestedStackParameter(nested: Stack, reference: CfnReference, value: IResolvable) {\n  // we call \"this.resolve\" to ensure that tokens do not creep in (for example, if the reference display name includes tokens)\n  const paramId = nested.resolve(`reference-to-${reference.target.node.uniqueId}.${reference.displayName}`);\n  let param = nested.node.tryFindChild(paramId) as CfnParameter;\n  if (!param) {\n    param = new CfnParameter(nested, paramId, { type: 'String' });\n\n    // Ugly little hack until we move NestedStack to this module.\n    if (!('setParameter' in nested)) {\n      throw new Error('assertion failed: nested stack should have a \"setParameter\" method');\n    }\n\n    (nested as any).setParameter(param.logicalId, Token.asString(value));\n  }\n\n  return param.value as CfnReference;\n}\n\n/**\n * Adds a CloudFormation output to a nested stack and returns an \"Fn::GetAtt\"\n * intrinsic that can be used to reference this output in the parent stack.\n */\nfunction createNestedStackOutput(producer: Stack, reference: Reference): CfnReference {\n  const outputId = `${reference.target.node.uniqueId}${reference.displayName}`;\n  let output = producer.node.tryFindChild(outputId) as CfnOutput;\n  if (!output) {\n    output = new CfnOutput(producer, outputId, { value: Token.asString(reference) });\n  }\n\n  if (!producer.nestedStackResource) {\n    throw new Error('assertion failed');\n  }\n\n  return producer.nestedStackResource.getAtt(`Outputs.${output.logicalId}`) as CfnReference;\n}\n\n/**\n * @returns true if this stack is a direct or indirect parent of the nested\n * stack `nested`.\n *\n * If `child` is not a nested stack, always returns `false` because it can't\n * have a parent, dah.\n */\nfunction isNested(nested: Stack, parent: Stack): boolean {\n  // if the parent is a direct parent\n  if (nested.nestedStackParent === parent) {\n    return true;\n  }\n\n  // we reached a top-level (non-nested) stack without finding the parent\n  if (!nested.nestedStackParent) {\n    return false;\n  }\n\n  // recurse with the child's direct parent\n  return isNested(nested.nestedStackParent, parent);\n}\n"]}

@@ -35,3 +35,3 @@ import { DockerImageAssetLocation, DockerImageAssetSource, FileAssetLocation, FileAssetSource } from '../assets';

/**
* The role to use to publish assets to this environment
* The role to use to publish file assets to the S3 bucket in this environment
*

@@ -44,12 +44,30 @@ * You must supply this if you have given a non-standard name to the publishing role.

*
* @default DefaultStackSynthesizer.DEFAULT_ASSET_PUBLISHING_ROLE_ARN
* @default DefaultStackSynthesizer.DEFAULT_FILE_ASSET_PUBLISHING_ROLE_ARN
*/
readonly assetPublishingRoleArn?: string;
readonly fileAssetPublishingRoleArn?: string;
/**
* External ID to use when assuming role for asset publishing
* External ID to use when assuming role for file asset publishing
*
* @default - No external ID
*/
readonly assetPublishingExternalId?: string;
readonly fileAssetPublishingExternalId?: string;
/**
* The role to use to publish image assets to the ECR repository in this environment
*
* You must supply this if you have given a non-standard name to the publishing role.
*
* The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will
* be replaced with the values of qualifier and the stack's account and region,
* respectively.
*
* @default DefaultStackSynthesizer.DEFAULT_IMAGE_ASSET_PUBLISHING_ROLE_ARN
*/
readonly imageAssetPublishingRoleArn?: string;
/**
* External ID to use when assuming role for image asset publishing
*
* @default - No external ID
*/
readonly imageAssetPublishingExternalId?: string;
/**
* The role to assume to initiate a deployment in this environment

@@ -112,6 +130,10 @@ *

/**
* Default asset publishing role ARN.
* Default asset publishing role ARN for file (S3) assets.
*/
static readonly DEFAULT_ASSET_PUBLISHING_ROLE_ARN = "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-publishing-role-${AWS::AccountId}-${AWS::Region}";
static readonly DEFAULT_FILE_ASSET_PUBLISHING_ROLE_ARN = "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-file-publishing-role-${AWS::AccountId}-${AWS::Region}";
/**
* Default asset publishing role ARN for image (ECR) assets.
*/
static readonly DEFAULT_IMAGE_ASSET_PUBLISHING_ROLE_ARN = "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-image-publishing-role-${AWS::AccountId}-${AWS::Region}";
/**
* Default image assets repository name

@@ -129,3 +151,4 @@ */

private _cloudFormationExecutionRoleArn?;
private assetPublishingRoleArn?;
private fileAssetPublishingRoleArn?;
private imageAssetPublishingRoleArn?;
private readonly files;

@@ -132,0 +155,0 @@ private readonly dockerImages;

@@ -14,2 +14,6 @@ "use strict";

/**
* The minimum bootstrap stack version required by this app.
*/
const MIN_BOOTSTRAP_STACK_VERSION = 2;
/**
* Uses conventionally named roles and reify asset storage locations

@@ -30,3 +34,3 @@ *

bind(stack) {
var _a, _b, _c, _d, _e, _f, _g;
var _a, _b, _c, _d, _e, _f, _g, _h;
this._stack = stack;

@@ -53,3 +57,4 @@ const qualifier = (_b = (_a = this.props.qualifier) !== null && _a !== void 0 ? _a : stack.node.tryGetContext(exports.BOOTSTRAP_QUALIFIER_CONTEXT)) !== null && _b !== void 0 ? _b : DefaultStackSynthesizer.DEFAULT_QUALIFIER;

this._cloudFormationExecutionRoleArn = specialize((_f = this.props.cloudFormationExecutionRole) !== null && _f !== void 0 ? _f : DefaultStackSynthesizer.DEFAULT_CLOUDFORMATION_ROLE_ARN);
this.assetPublishingRoleArn = specialize((_g = this.props.assetPublishingRoleArn) !== null && _g !== void 0 ? _g : DefaultStackSynthesizer.DEFAULT_ASSET_PUBLISHING_ROLE_ARN);
this.fileAssetPublishingRoleArn = specialize((_g = this.props.fileAssetPublishingRoleArn) !== null && _g !== void 0 ? _g : DefaultStackSynthesizer.DEFAULT_FILE_ASSET_PUBLISHING_ROLE_ARN);
this.imageAssetPublishingRoleArn = specialize((_h = this.props.imageAssetPublishingRoleArn) !== null && _h !== void 0 ? _h : DefaultStackSynthesizer.DEFAULT_IMAGE_ASSET_PUBLISHING_ROLE_ARN);
// tslint:enable:max-line-length

@@ -72,4 +77,4 @@ }

region: resolvedOr(this.stack.region, undefined),
assumeRoleArn: this.assetPublishingRoleArn,
assumeRoleExternalId: this.props.assetPublishingExternalId,
assumeRoleArn: this.fileAssetPublishingRoleArn,
assumeRoleExternalId: this.props.fileAssetPublishingExternalId,
},

@@ -106,4 +111,4 @@ },

region: resolvedOr(this.stack.region, undefined),
assumeRoleArn: this.assetPublishingRoleArn,
assumeRoleExternalId: this.props.assetPublishingExternalId,
assumeRoleArn: this.imageAssetPublishingRoleArn,
assumeRoleExternalId: this.props.imageAssetPublishingExternalId,
},

@@ -127,3 +132,3 @@ },

stackTemplateAssetObjectUrl: templateManifestUrl,
requiresBootstrapStackVersion: 1,
requiresBootstrapStackVersion: MIN_BOOTSTRAP_STACK_VERSION,
}, [artifactId]);

@@ -198,3 +203,3 @@ }

file: manifestFile,
requiresBootstrapStackVersion: 1,
requiresBootstrapStackVersion: MIN_BOOTSTRAP_STACK_VERSION,
},

@@ -226,6 +231,10 @@ });

/**
* Default asset publishing role ARN.
* Default asset publishing role ARN for file (S3) assets.
*/
DefaultStackSynthesizer.DEFAULT_ASSET_PUBLISHING_ROLE_ARN = 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-publishing-role-${AWS::AccountId}-${AWS::Region}';
DefaultStackSynthesizer.DEFAULT_FILE_ASSET_PUBLISHING_ROLE_ARN = 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-file-publishing-role-${AWS::AccountId}-${AWS::Region}';
/**
* Default asset publishing role ARN for image (ECR) assets.
*/
DefaultStackSynthesizer.DEFAULT_IMAGE_ASSET_PUBLISHING_ROLE_ARN = 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-image-publishing-role-${AWS::AccountId}-${AWS::Region}';
/**
* Default image assets repository name

@@ -259,2 +268,2 @@ */

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-synthesizer.js","sourceRoot":"","sources":["default-synthesizer.ts"],"names":[],"mappings":"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","sourcesContent":["import * as asset_schema from '@aws-cdk/cdk-assets-schema';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { DockerImageAssetLocation, DockerImageAssetSource, FileAssetLocation, FileAssetPackaging, FileAssetSource } from '../assets';\nimport { Fn } from '../cfn-fn';\nimport { ISynthesisSession } from '../construct-compat';\nimport { Stack } from '../stack';\nimport { Token } from '../token';\nimport { addStackArtifactToAssembly, assertBound, contentHash } from './_shared';\nimport { IStackSynthesizer } from './types';\n\nexport const BOOTSTRAP_QUALIFIER_CONTEXT = '@aws-cdk/core:bootstrapQualifier';\n\n/**\n * Configuration properties for DefaultStackSynthesizer\n */\nexport interface DefaultStackSynthesizerProps {\n  /**\n   * Name of the S3 bucket to hold file assets\n   *\n   * You must supply this if you have given a non-standard name to the staging bucket.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_FILE_ASSETS_BUCKET_NAME\n   */\n  readonly fileAssetsBucketName?: string;\n\n  /**\n   * Name of the ECR repository to hold Docker Image assets\n   *\n   * You must supply this if you have given a non-standard name to the ECR repository.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_IMAGE_ASSETS_REPOSITORY_NAME\n   */\n  readonly imageAssetsRepositoryName?: string;\n\n  /**\n   * The role to use to publish assets to this environment\n   *\n   * You must supply this if you have given a non-standard name to the publishing role.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_ASSET_PUBLISHING_ROLE_ARN\n   */\n  readonly assetPublishingRoleArn?: string;\n\n  /**\n   * External ID to use when assuming role for asset publishing\n   *\n   * @default - No external ID\n   */\n  readonly assetPublishingExternalId?: string;\n\n  /**\n   * The role to assume to initiate a deployment in this environment\n   *\n   * You must supply this if you have given a non-standard name to the publishing role.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_DEPLOY_ROLE_ARN\n   */\n  readonly deployRoleArn?: string;\n\n  /**\n   * The role CloudFormation will assume when deploying the Stack\n   *\n   * You must supply this if you have given a non-standard name to the execution role.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_CLOUDFORMATION_ROLE_ARN\n   */\n  readonly cloudFormationExecutionRole?: string;\n\n  /**\n   * Qualifier to disambiguate multiple environments in the same account\n   *\n   * You can use this and leave the other naming properties empty if you have deployed\n   * the bootstrap environment with standard names but only differnet qualifiers.\n   *\n   * @default - Value of context key '@aws-cdk/core:bootstrapQualifier' if set, otherwise `DefaultStackSynthesizer.DEFAULT_QUALIFIER`\n   */\n  readonly qualifier?: string;\n}\n\n/**\n * Uses conventionally named roles and reify asset storage locations\n *\n * This synthesizer is the only StackSynthesizer that generates\n * an asset manifest, and is required to deploy CDK applications using the\n * `@aws-cdk/app-delivery` CI/CD library.\n *\n * Requires the environment to have been bootstrapped with Bootstrap Stack V2.\n */\nexport class DefaultStackSynthesizer implements IStackSynthesizer {\n  /**\n   * Default ARN qualifier\n   */\n  public static readonly DEFAULT_QUALIFIER = 'hnb659fds';\n\n  /**\n   * Default CloudFormation role ARN.\n   */\n  public static readonly DEFAULT_CLOUDFORMATION_ROLE_ARN = 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-cfn-exec-role-${AWS::AccountId}-${AWS::Region}';\n\n  /**\n   * Default deploy role ARN.\n   */\n  public static readonly DEFAULT_DEPLOY_ROLE_ARN = 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-deploy-role-${AWS::AccountId}-${AWS::Region}';\n\n  /**\n   * Default asset publishing role ARN.\n   */\n  public static readonly DEFAULT_ASSET_PUBLISHING_ROLE_ARN = 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-publishing-role-${AWS::AccountId}-${AWS::Region}';\n\n  /**\n   * Default image assets repository name\n   */\n  public static readonly DEFAULT_IMAGE_ASSETS_REPOSITORY_NAME = 'cdk-${Qualifier}-container-assets-${AWS::AccountId}-${AWS::Region}';\n\n  /**\n   * Default file assets bucket name\n   */\n  public static readonly DEFAULT_FILE_ASSETS_BUCKET_NAME = 'cdk-${Qualifier}-assets-${AWS::AccountId}-${AWS::Region}';\n\n  private _stack?: Stack;\n  private bucketName?: string;\n  private repositoryName?: string;\n  private _deployRoleArn?: string;\n  private _cloudFormationExecutionRoleArn?: string;\n  private assetPublishingRoleArn?: string;\n\n  private readonly files: NonNullable<asset_schema.ManifestFile['files']> = {};\n  private readonly dockerImages: NonNullable<asset_schema.ManifestFile['dockerImages']> = {};\n\n  constructor(private readonly props: DefaultStackSynthesizerProps = {}) {\n  }\n\n  public bind(stack: Stack): void {\n    this._stack = stack;\n\n    const qualifier = this.props.qualifier ?? stack.node.tryGetContext(BOOTSTRAP_QUALIFIER_CONTEXT) ?? DefaultStackSynthesizer.DEFAULT_QUALIFIER;\n\n    // Function to replace placeholders in the input string as much as possible\n    //\n    // We replace:\n    // - ${Qualifier}: always\n    // - ${AWS::AccountId}, ${AWS::Region}: only if we have the actual values available\n    // - ${AWS::Partition}: never, since we never have the actual partition value.\n    const specialize = (s: string) => {\n      s = replaceAll(s, '${Qualifier}', qualifier);\n      return cxapi.EnvironmentPlaceholders.replace(s, {\n        region: resolvedOr(stack.region, cxapi.EnvironmentPlaceholders.CURRENT_REGION),\n        accountId: resolvedOr(stack.account, cxapi.EnvironmentPlaceholders.CURRENT_ACCOUNT),\n        partition: cxapi.EnvironmentPlaceholders.CURRENT_PARTITION,\n      });\n    };\n\n    // tslint:disable:max-line-length\n    this.bucketName = specialize(this.props.fileAssetsBucketName ?? DefaultStackSynthesizer.DEFAULT_FILE_ASSETS_BUCKET_NAME);\n    this.repositoryName = specialize(this.props.imageAssetsRepositoryName ?? DefaultStackSynthesizer.DEFAULT_IMAGE_ASSETS_REPOSITORY_NAME);\n    this._deployRoleArn = specialize(this.props.deployRoleArn ?? DefaultStackSynthesizer.DEFAULT_DEPLOY_ROLE_ARN);\n    this._cloudFormationExecutionRoleArn = specialize(this.props.cloudFormationExecutionRole ?? DefaultStackSynthesizer.DEFAULT_CLOUDFORMATION_ROLE_ARN);\n    this.assetPublishingRoleArn = specialize(this.props.assetPublishingRoleArn ?? DefaultStackSynthesizer.DEFAULT_ASSET_PUBLISHING_ROLE_ARN);\n    // tslint:enable:max-line-length\n  }\n\n  public addFileAsset(asset: FileAssetSource): FileAssetLocation {\n    assertBound(this.stack);\n    assertBound(this.bucketName);\n\n    const objectKey = asset.sourceHash + (asset.packaging === FileAssetPackaging.ZIP_DIRECTORY ? '.zip' : '');\n\n    // Add to manifest\n    this.files[asset.sourceHash] = {\n      source: {\n        path: asset.fileName,\n        packaging: asset.packaging,\n      },\n      destinations: {\n        [this.manifestEnvName]: {\n          bucketName: this.bucketName,\n          objectKey,\n          region: resolvedOr(this.stack.region, undefined),\n          assumeRoleArn: this.assetPublishingRoleArn,\n          assumeRoleExternalId: this.props.assetPublishingExternalId,\n        },\n      },\n    };\n\n    const httpUrl = cfnify(`https://s3.${this.stack.region}.${this.stack.urlSuffix}/${this.bucketName}/${objectKey}`);\n    const s3ObjectUrl = cfnify(`s3://${this.bucketName}/${objectKey}`);\n\n    // Return CFN expression\n    return {\n      bucketName: cfnify(this.bucketName),\n      objectKey,\n      httpUrl,\n      s3ObjectUrl,\n      s3Url: httpUrl,\n    };\n  }\n\n  public addDockerImageAsset(asset: DockerImageAssetSource): DockerImageAssetLocation {\n    assertBound(this.stack);\n    assertBound(this.repositoryName);\n\n    const imageTag = asset.sourceHash;\n\n    // Add to manifest\n    this.dockerImages[asset.sourceHash] = {\n      source: {\n        directory: asset.directoryName,\n        dockerBuildArgs: asset.dockerBuildArgs,\n        dockerBuildTarget: asset.dockerBuildTarget,\n        dockerFile: asset.dockerFile,\n      },\n      destinations: {\n        [this.manifestEnvName]: {\n          repositoryName: this.repositoryName,\n          imageTag,\n          region: resolvedOr(this.stack.region, undefined),\n          assumeRoleArn: this.assetPublishingRoleArn,\n          assumeRoleExternalId: this.props.assetPublishingExternalId,\n        },\n      },\n    };\n\n    // Return CFN expression\n    return {\n      repositoryName: cfnify(this.repositoryName),\n      imageUri: cfnify(`${this.stack.account}.dkr.ecr.${this.stack.region}.${this.stack.urlSuffix}/${this.repositoryName}:${imageTag}`),\n    };\n  }\n\n  public synthesizeStackArtifacts(session: ISynthesisSession): void {\n    assertBound(this.stack);\n\n    // Add the stack's template to the artifact manifest\n    const templateManifestUrl = this.addStackTemplateToAssetManifest(session);\n\n    const artifactId = this.writeAssetManifest(session);\n\n    addStackArtifactToAssembly(session, this.stack, {\n      assumeRoleArn: this._deployRoleArn,\n      cloudFormationExecutionRoleArn: this._cloudFormationExecutionRoleArn,\n      stackTemplateAssetObjectUrl: templateManifestUrl,\n      requiresBootstrapStackVersion: 1,\n    }, [artifactId]);\n  }\n\n  /**\n   * Returns the ARN of the deploy Role.\n   */\n  public get deployRoleArn(): string {\n    if (!this._deployRoleArn) {\n      throw new Error('deployRoleArn getter can only be called after the synthesizer has been bound to a Stack');\n    }\n    return this._deployRoleArn;\n  }\n\n  /**\n   * Returns the ARN of the CFN execution Role.\n   */\n  public get cloudFormationExecutionRoleArn(): string {\n    if (!this._cloudFormationExecutionRoleArn) {\n      throw new Error('cloudFormationExecutionRoleArn getter can only be called after the synthesizer has been bound to a Stack');\n    }\n    return this._cloudFormationExecutionRoleArn;\n  }\n\n  protected get stack(): Stack | undefined {\n    return this._stack;\n  }\n\n  /**\n   * Add the stack's template as one of the manifest assets\n   *\n   * This will make it get uploaded to S3 automatically by S3-assets. Return\n   * the manifest URL.\n   *\n   * (We can't return the location returned from `addFileAsset`, as that\n   * contains CloudFormation intrinsics which can't go into the manifest).\n   */\n  private addStackTemplateToAssetManifest(session: ISynthesisSession) {\n    assertBound(this.stack);\n\n    const templatePath = path.join(session.assembly.outdir, this.stack.templateFile);\n    const template = fs.readFileSync(templatePath, { encoding: 'utf-8' });\n\n    const sourceHash = contentHash(template);\n\n    this.addFileAsset({\n      fileName: this.stack.templateFile,\n      packaging: FileAssetPackaging.FILE,\n      sourceHash,\n    });\n\n    // We should technically return an 'https://s3.REGION.amazonaws.com[.cn]/name/hash' URL here,\n    // because that is what CloudFormation expects to see.\n    //\n    // However, there's no way for us to actually know the UrlSuffix a priori, so we can't construct it here.\n    //\n    // Instead, we'll have a protocol with the CLI that we put an 's3://.../...' URL here, and the CLI\n    // is going to resolve it to the correct 'https://.../' URL before it gives it to CloudFormation.\n    return `s3://${this.bucketName}/${sourceHash}`;\n  }\n\n  /**\n   * Write an asset manifest to the Cloud Assembly, return the artifact IDs written\n   */\n  private writeAssetManifest(session: ISynthesisSession): string {\n    assertBound(this.stack);\n\n    const artifactId = `${this.stack.artifactId}.assets`;\n    const manifestFile = `${artifactId}.json`;\n    const outPath = path.join(session.assembly.outdir, manifestFile);\n\n    const manifest: asset_schema.ManifestFile = {\n      version: asset_schema.AssetManifestSchema.currentVersion(),\n      files: this.files,\n      dockerImages: this.dockerImages,\n    };\n\n    fs.writeFileSync(outPath, JSON.stringify(manifest, undefined, 2));\n    session.assembly.addArtifact(artifactId, {\n      type: cxschema.ArtifactType.ASSET_MANIFEST,\n      properties: {\n        file: manifestFile,\n        requiresBootstrapStackVersion: 1,\n      },\n    });\n\n    return artifactId;\n  }\n\n  private get manifestEnvName(): string {\n    assertBound(this.stack);\n\n    return [\n      resolvedOr(this.stack.account, 'current_account'),\n      resolvedOr(this.stack.region, 'current_region'),\n    ].join('-');\n  }\n}\n\n/**\n * Return the given value if resolved or fall back to a default\n */\nfunction resolvedOr<A>(x: string, def: A): string | A {\n  return Token.isUnresolved(x) ? def : x;\n}\n\n/**\n * A \"replace-all\" function that doesn't require us escaping a literal string to a regex\n */\nfunction replaceAll(s: string, search: string, replace: string) {\n  return s.split(search).join(replace);\n}\n\n/**\n * If the string still contains placeholders, wrap it in a Fn::Sub so they will be substituted at CFN deploymen time\n *\n * (This happens to work because the placeholders we picked map directly onto CFN\n * placeholders. If they didn't we'd have to do a transformation here).\n */\nfunction cfnify(s: string): string {\n  return s.indexOf('${') > -1 ? Fn.sub(s) : s;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-synthesizer.js","sourceRoot":"","sources":["default-synthesizer.ts"],"names":[],"mappings":"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","sourcesContent":["import * as asset_schema from '@aws-cdk/cdk-assets-schema';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { DockerImageAssetLocation, DockerImageAssetSource, FileAssetLocation, FileAssetPackaging, FileAssetSource } from '../assets';\nimport { Fn } from '../cfn-fn';\nimport { ISynthesisSession } from '../construct-compat';\nimport { Stack } from '../stack';\nimport { Token } from '../token';\nimport { addStackArtifactToAssembly, assertBound, contentHash } from './_shared';\nimport { IStackSynthesizer } from './types';\n\nexport const BOOTSTRAP_QUALIFIER_CONTEXT = '@aws-cdk/core:bootstrapQualifier';\n\n/**\n * The minimum bootstrap stack version required by this app.\n */\nconst MIN_BOOTSTRAP_STACK_VERSION = 2;\n\n/**\n * Configuration properties for DefaultStackSynthesizer\n */\nexport interface DefaultStackSynthesizerProps {\n  /**\n   * Name of the S3 bucket to hold file assets\n   *\n   * You must supply this if you have given a non-standard name to the staging bucket.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_FILE_ASSETS_BUCKET_NAME\n   */\n  readonly fileAssetsBucketName?: string;\n\n  /**\n   * Name of the ECR repository to hold Docker Image assets\n   *\n   * You must supply this if you have given a non-standard name to the ECR repository.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_IMAGE_ASSETS_REPOSITORY_NAME\n   */\n  readonly imageAssetsRepositoryName?: string;\n\n  /**\n   * The role to use to publish file assets to the S3 bucket in this environment\n   *\n   * You must supply this if you have given a non-standard name to the publishing role.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_FILE_ASSET_PUBLISHING_ROLE_ARN\n   */\n  readonly fileAssetPublishingRoleArn?: string;\n\n  /**\n   * External ID to use when assuming role for file asset publishing\n   *\n   * @default - No external ID\n   */\n  readonly fileAssetPublishingExternalId?: string;\n\n  /**\n   * The role to use to publish image assets to the ECR repository in this environment\n   *\n   * You must supply this if you have given a non-standard name to the publishing role.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_IMAGE_ASSET_PUBLISHING_ROLE_ARN\n   */\n  readonly imageAssetPublishingRoleArn?: string;\n\n  /**\n   * External ID to use when assuming role for image asset publishing\n   *\n   * @default - No external ID\n   */\n  readonly imageAssetPublishingExternalId?: string;\n\n  /**\n   * The role to assume to initiate a deployment in this environment\n   *\n   * You must supply this if you have given a non-standard name to the publishing role.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_DEPLOY_ROLE_ARN\n   */\n  readonly deployRoleArn?: string;\n\n  /**\n   * The role CloudFormation will assume when deploying the Stack\n   *\n   * You must supply this if you have given a non-standard name to the execution role.\n   *\n   * The placeholders `${Qualifier}`, `${AWS::AccountId}` and `${AWS::Region}` will\n   * be replaced with the values of qualifier and the stack's account and region,\n   * respectively.\n   *\n   * @default DefaultStackSynthesizer.DEFAULT_CLOUDFORMATION_ROLE_ARN\n   */\n  readonly cloudFormationExecutionRole?: string;\n\n  /**\n   * Qualifier to disambiguate multiple environments in the same account\n   *\n   * You can use this and leave the other naming properties empty if you have deployed\n   * the bootstrap environment with standard names but only differnet qualifiers.\n   *\n   * @default - Value of context key '@aws-cdk/core:bootstrapQualifier' if set, otherwise `DefaultStackSynthesizer.DEFAULT_QUALIFIER`\n   */\n  readonly qualifier?: string;\n}\n\n/**\n * Uses conventionally named roles and reify asset storage locations\n *\n * This synthesizer is the only StackSynthesizer that generates\n * an asset manifest, and is required to deploy CDK applications using the\n * `@aws-cdk/app-delivery` CI/CD library.\n *\n * Requires the environment to have been bootstrapped with Bootstrap Stack V2.\n */\nexport class DefaultStackSynthesizer implements IStackSynthesizer {\n  /**\n   * Default ARN qualifier\n   */\n  public static readonly DEFAULT_QUALIFIER = 'hnb659fds';\n\n  /**\n   * Default CloudFormation role ARN.\n   */\n  public static readonly DEFAULT_CLOUDFORMATION_ROLE_ARN = 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-cfn-exec-role-${AWS::AccountId}-${AWS::Region}';\n\n  /**\n   * Default deploy role ARN.\n   */\n  public static readonly DEFAULT_DEPLOY_ROLE_ARN = 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-deploy-role-${AWS::AccountId}-${AWS::Region}';\n\n  /**\n   * Default asset publishing role ARN for file (S3) assets.\n   */\n  public static readonly DEFAULT_FILE_ASSET_PUBLISHING_ROLE_ARN = 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-file-publishing-role-${AWS::AccountId}-${AWS::Region}';\n\n  /**\n   * Default asset publishing role ARN for image (ECR) assets.\n   */\n  public static readonly DEFAULT_IMAGE_ASSET_PUBLISHING_ROLE_ARN = 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-${Qualifier}-image-publishing-role-${AWS::AccountId}-${AWS::Region}';\n\n  /**\n   * Default image assets repository name\n   */\n  public static readonly DEFAULT_IMAGE_ASSETS_REPOSITORY_NAME = 'cdk-${Qualifier}-container-assets-${AWS::AccountId}-${AWS::Region}';\n\n  /**\n   * Default file assets bucket name\n   */\n  public static readonly DEFAULT_FILE_ASSETS_BUCKET_NAME = 'cdk-${Qualifier}-assets-${AWS::AccountId}-${AWS::Region}';\n\n  private _stack?: Stack;\n  private bucketName?: string;\n  private repositoryName?: string;\n  private _deployRoleArn?: string;\n  private _cloudFormationExecutionRoleArn?: string;\n  private fileAssetPublishingRoleArn?: string;\n  private imageAssetPublishingRoleArn?: string;\n\n  private readonly files: NonNullable<asset_schema.ManifestFile['files']> = {};\n  private readonly dockerImages: NonNullable<asset_schema.ManifestFile['dockerImages']> = {};\n\n  constructor(private readonly props: DefaultStackSynthesizerProps = {}) {\n  }\n\n  public bind(stack: Stack): void {\n    this._stack = stack;\n\n    const qualifier = this.props.qualifier ?? stack.node.tryGetContext(BOOTSTRAP_QUALIFIER_CONTEXT) ?? DefaultStackSynthesizer.DEFAULT_QUALIFIER;\n\n    // Function to replace placeholders in the input string as much as possible\n    //\n    // We replace:\n    // - ${Qualifier}: always\n    // - ${AWS::AccountId}, ${AWS::Region}: only if we have the actual values available\n    // - ${AWS::Partition}: never, since we never have the actual partition value.\n    const specialize = (s: string) => {\n      s = replaceAll(s, '${Qualifier}', qualifier);\n      return cxapi.EnvironmentPlaceholders.replace(s, {\n        region: resolvedOr(stack.region, cxapi.EnvironmentPlaceholders.CURRENT_REGION),\n        accountId: resolvedOr(stack.account, cxapi.EnvironmentPlaceholders.CURRENT_ACCOUNT),\n        partition: cxapi.EnvironmentPlaceholders.CURRENT_PARTITION,\n      });\n    };\n\n    // tslint:disable:max-line-length\n    this.bucketName = specialize(this.props.fileAssetsBucketName ?? DefaultStackSynthesizer.DEFAULT_FILE_ASSETS_BUCKET_NAME);\n    this.repositoryName = specialize(this.props.imageAssetsRepositoryName ?? DefaultStackSynthesizer.DEFAULT_IMAGE_ASSETS_REPOSITORY_NAME);\n    this._deployRoleArn = specialize(this.props.deployRoleArn ?? DefaultStackSynthesizer.DEFAULT_DEPLOY_ROLE_ARN);\n    this._cloudFormationExecutionRoleArn = specialize(this.props.cloudFormationExecutionRole ?? DefaultStackSynthesizer.DEFAULT_CLOUDFORMATION_ROLE_ARN);\n    this.fileAssetPublishingRoleArn = specialize(this.props.fileAssetPublishingRoleArn ?? DefaultStackSynthesizer.DEFAULT_FILE_ASSET_PUBLISHING_ROLE_ARN);\n    this.imageAssetPublishingRoleArn = specialize(this.props.imageAssetPublishingRoleArn ?? DefaultStackSynthesizer.DEFAULT_IMAGE_ASSET_PUBLISHING_ROLE_ARN);\n    // tslint:enable:max-line-length\n  }\n\n  public addFileAsset(asset: FileAssetSource): FileAssetLocation {\n    assertBound(this.stack);\n    assertBound(this.bucketName);\n\n    const objectKey = asset.sourceHash + (asset.packaging === FileAssetPackaging.ZIP_DIRECTORY ? '.zip' : '');\n\n    // Add to manifest\n    this.files[asset.sourceHash] = {\n      source: {\n        path: asset.fileName,\n        packaging: asset.packaging,\n      },\n      destinations: {\n        [this.manifestEnvName]: {\n          bucketName: this.bucketName,\n          objectKey,\n          region: resolvedOr(this.stack.region, undefined),\n          assumeRoleArn: this.fileAssetPublishingRoleArn,\n          assumeRoleExternalId: this.props.fileAssetPublishingExternalId,\n        },\n      },\n    };\n\n    const httpUrl = cfnify(`https://s3.${this.stack.region}.${this.stack.urlSuffix}/${this.bucketName}/${objectKey}`);\n    const s3ObjectUrl = cfnify(`s3://${this.bucketName}/${objectKey}`);\n\n    // Return CFN expression\n    return {\n      bucketName: cfnify(this.bucketName),\n      objectKey,\n      httpUrl,\n      s3ObjectUrl,\n      s3Url: httpUrl,\n    };\n  }\n\n  public addDockerImageAsset(asset: DockerImageAssetSource): DockerImageAssetLocation {\n    assertBound(this.stack);\n    assertBound(this.repositoryName);\n\n    const imageTag = asset.sourceHash;\n\n    // Add to manifest\n    this.dockerImages[asset.sourceHash] = {\n      source: {\n        directory: asset.directoryName,\n        dockerBuildArgs: asset.dockerBuildArgs,\n        dockerBuildTarget: asset.dockerBuildTarget,\n        dockerFile: asset.dockerFile,\n      },\n      destinations: {\n        [this.manifestEnvName]: {\n          repositoryName: this.repositoryName,\n          imageTag,\n          region: resolvedOr(this.stack.region, undefined),\n          assumeRoleArn: this.imageAssetPublishingRoleArn,\n          assumeRoleExternalId: this.props.imageAssetPublishingExternalId,\n        },\n      },\n    };\n\n    // Return CFN expression\n    return {\n      repositoryName: cfnify(this.repositoryName),\n      imageUri: cfnify(`${this.stack.account}.dkr.ecr.${this.stack.region}.${this.stack.urlSuffix}/${this.repositoryName}:${imageTag}`),\n    };\n  }\n\n  public synthesizeStackArtifacts(session: ISynthesisSession): void {\n    assertBound(this.stack);\n\n    // Add the stack's template to the artifact manifest\n    const templateManifestUrl = this.addStackTemplateToAssetManifest(session);\n\n    const artifactId = this.writeAssetManifest(session);\n\n    addStackArtifactToAssembly(session, this.stack, {\n      assumeRoleArn: this._deployRoleArn,\n      cloudFormationExecutionRoleArn: this._cloudFormationExecutionRoleArn,\n      stackTemplateAssetObjectUrl: templateManifestUrl,\n      requiresBootstrapStackVersion: MIN_BOOTSTRAP_STACK_VERSION,\n    }, [artifactId]);\n  }\n\n  /**\n   * Returns the ARN of the deploy Role.\n   */\n  public get deployRoleArn(): string {\n    if (!this._deployRoleArn) {\n      throw new Error('deployRoleArn getter can only be called after the synthesizer has been bound to a Stack');\n    }\n    return this._deployRoleArn;\n  }\n\n  /**\n   * Returns the ARN of the CFN execution Role.\n   */\n  public get cloudFormationExecutionRoleArn(): string {\n    if (!this._cloudFormationExecutionRoleArn) {\n      throw new Error('cloudFormationExecutionRoleArn getter can only be called after the synthesizer has been bound to a Stack');\n    }\n    return this._cloudFormationExecutionRoleArn;\n  }\n\n  protected get stack(): Stack | undefined {\n    return this._stack;\n  }\n\n  /**\n   * Add the stack's template as one of the manifest assets\n   *\n   * This will make it get uploaded to S3 automatically by S3-assets. Return\n   * the manifest URL.\n   *\n   * (We can't return the location returned from `addFileAsset`, as that\n   * contains CloudFormation intrinsics which can't go into the manifest).\n   */\n  private addStackTemplateToAssetManifest(session: ISynthesisSession) {\n    assertBound(this.stack);\n\n    const templatePath = path.join(session.assembly.outdir, this.stack.templateFile);\n    const template = fs.readFileSync(templatePath, { encoding: 'utf-8' });\n\n    const sourceHash = contentHash(template);\n\n    this.addFileAsset({\n      fileName: this.stack.templateFile,\n      packaging: FileAssetPackaging.FILE,\n      sourceHash,\n    });\n\n    // We should technically return an 'https://s3.REGION.amazonaws.com[.cn]/name/hash' URL here,\n    // because that is what CloudFormation expects to see.\n    //\n    // However, there's no way for us to actually know the UrlSuffix a priori, so we can't construct it here.\n    //\n    // Instead, we'll have a protocol with the CLI that we put an 's3://.../...' URL here, and the CLI\n    // is going to resolve it to the correct 'https://.../' URL before it gives it to CloudFormation.\n    return `s3://${this.bucketName}/${sourceHash}`;\n  }\n\n  /**\n   * Write an asset manifest to the Cloud Assembly, return the artifact IDs written\n   */\n  private writeAssetManifest(session: ISynthesisSession): string {\n    assertBound(this.stack);\n\n    const artifactId = `${this.stack.artifactId}.assets`;\n    const manifestFile = `${artifactId}.json`;\n    const outPath = path.join(session.assembly.outdir, manifestFile);\n\n    const manifest: asset_schema.ManifestFile = {\n      version: asset_schema.AssetManifestSchema.currentVersion(),\n      files: this.files,\n      dockerImages: this.dockerImages,\n    };\n\n    fs.writeFileSync(outPath, JSON.stringify(manifest, undefined, 2));\n    session.assembly.addArtifact(artifactId, {\n      type: cxschema.ArtifactType.ASSET_MANIFEST,\n      properties: {\n        file: manifestFile,\n        requiresBootstrapStackVersion: MIN_BOOTSTRAP_STACK_VERSION,\n      },\n    });\n\n    return artifactId;\n  }\n\n  private get manifestEnvName(): string {\n    assertBound(this.stack);\n\n    return [\n      resolvedOr(this.stack.account, 'current_account'),\n      resolvedOr(this.stack.region, 'current_region'),\n    ].join('-');\n  }\n}\n\n/**\n * Return the given value if resolved or fall back to a default\n */\nfunction resolvedOr<A>(x: string, def: A): string | A {\n  return Token.isUnresolved(x) ? def : x;\n}\n\n/**\n * A \"replace-all\" function that doesn't require us escaping a literal string to a regex\n */\nfunction replaceAll(s: string, search: string, replace: string) {\n  return s.split(search).join(replace);\n}\n\n/**\n * If the string still contains placeholders, wrap it in a Fn::Sub so they will be substituted at CFN deploymen time\n *\n * (This happens to work because the placeholders we picked map directly onto CFN\n * placeholders. If they didn't we'd have to do a transformation here).\n */\nfunction cfnify(s: string): string {\n  return s.indexOf('${') > -1 ? Fn.sub(s) : s;\n}\n"]}

@@ -15,4 +15,62 @@ import * as cxapi from '@aws-cdk/cx-api';

*
* @default - The `default-account` and `default-region` context parameters will be
* used. If they are undefined, it will not be possible to deploy the stack.
* Set the `region`/`account` fields of `env` to either a concrete value to
* select the indicated environment (recommended for production stacks), or to
* the values of environment variables
* `CDK_DEFAULT_REGION`/`CDK_DEFAULT_ACCOUNT` to let the target environment
* depend on the AWS credentials/configuration that the CDK CLI is executed
* under (recommended for development stacks).
*
* If the `Stack` is instantiated inside a `Stage`, any undefined
* `region`/`account` fields from `env` will default to the same field on the
* encompassing `Stage`, if configured there.
*
* If either `region` or `account` are not set nor inherited from `Stage`, the
* Stack will be considered "*environment-agnostic*"". Environment-agnostic
* stacks can be deployed to any environment but may not be able to take
* advantage of all features of the CDK. For example, they will not be able to
* use environmental context lookups such as `ec2.Vpc.fromLookup` and will not
* automatically translate Service Principals to the right format based on the
* environment's AWS partition, and other such enhancements.
*
* @example
*
* // Use a concrete account and region to deploy this stack to:
* // `.account` and `.region` will simply return these values.
* new MyStack(app, 'Stack1', {
* env: {
* account: '123456789012',
* region: 'us-east-1'
* },
* });
*
* // Use the CLI's current credentials to determine the target environment:
* // `.account` and `.region` will reflect the account+region the CLI
* // is configured to use (based on the user CLI credentials)
* new MyStack(app, 'Stack2', {
* env: {
* account: process.env.CDK_DEFAULT_ACCOUNT,
* region: process.env.CDK_DEFAULT_REGION
* },
* });
*
* // Define multiple stacks stage associated with an environment
* const myStage = new Stage(app, 'MyStage', {
* env: {
* account: '123456789012',
* region: 'us-east-1'
* }
* });
*
* // both of these stavks will use the stage's account/region:
* // `.account` and `.region` will resolve to the concrete values as above
* new MyStack(myStage, 'Stack1');
* new YourStack(myStage, 'Stack1');
*
* // Define an environment-agnostic stack:
* // `.account` and `.region` will resolve to `{ "Ref": "AWS::AccountId" }` and `{ "Ref": "AWS::Region" }` respectively.
* // which will only resolve to actual values by CloudFormation during deployment.
* new MyStack(app, 'Stack1');
*
* @default - The environment of the containing `Stage` if available,
* otherwise create the stack will be environment-agnostic.
*/

@@ -415,10 +473,2 @@ readonly env?: Environment;

protected allocateLogicalId(cfnElement: CfnElement): string;
/**
* Prepare stack
*
* Find all CloudFormation references and tell them we're consuming them.
*
* Find all dependencies as well and add the appropriate DependsOn fields.
*/
protected prepare(): void;
protected synthesize(session: ISynthesisSession): void;

@@ -446,5 +496,32 @@ /**

/**
* Calculcate the stack name based on the construct path
* Calculate the stack name based on the construct path
*
* The stack name is the name under which we'll deploy the stack,
* and incorporates containing Stage names by default.
*
* Generally this looks a lot like how logical IDs are calculated.
* The stack name is calculated based on the construct root path,
* as follows:
*
* - Path is calculated with respect to containing App or Stage (if any)
* - If the path is one component long just use that component, otherwise
* combine them with a hash.
*
* Since the hash is quite ugly and we'd like to avoid it if possible -- but
* we can't anymore in the general case since it has been written into legacy
* stacks. The introduction of Stages makes it possible to make this nicer however.
* When a Stack is nested inside a Stage, we use the path components below the
* Stage, and prefix the path components of the Stage before it.
*/
private generateUniqueId;
private generateStackName;
/**
* The artifact ID for this stack
*
* Stack artifact ID is unique within the App's Cloud Assembly.
*/
private generateStackArtifactId;
/**
* Generate an ID with respect to the given container construct.
*/
private generateStackId;
}

@@ -481,2 +558,8 @@ /**

}
/**
* Return the construct root path of the given construct relative to the given ancestor
*
* If no ancestor is given or the ancestor is not found, return the entire root path.
*/
export declare function rootPathTo(construct: IConstruct, ancestor?: IConstruct): IConstruct[];
import { ArnComponents } from './arn';

@@ -483,0 +566,0 @@ import { CfnElement } from './cfn-element';

{
"name": "@aws-cdk/core",
"version": "1.44.0",
"version": "1.45.0",
"description": "AWS Cloud Development Kit Core Library",

@@ -155,11 +155,13 @@ "main": "lib/index.js",

"@types/lodash": "^4.14.155",
"@types/node": "^10.17.21",
"@types/node": "^10.17.25",
"@types/nodeunit": "^0.0.31",
"@types/minimatch": "^3.0.3",
"cdk-build-tools": "1.44.0",
"cfn2ts": "1.44.0",
"@types/sinon": "^9.0.4",
"cdk-build-tools": "1.45.0",
"cfn2ts": "1.45.0",
"fast-check": "^1.24.2",
"lodash": "^4.17.15",
"nodeunit": "^0.11.3",
"pkglint": "1.44.0",
"pkglint": "1.45.0",
"sinon": "^9.0.2",
"ts-mock-imports": "^1.3.0"

@@ -169,5 +171,5 @@ },

"minimatch": "^3.0.4",
"@aws-cdk/cx-api": "1.44.0",
"@aws-cdk/cdk-assets-schema": "1.44.0",
"@aws-cdk/cloud-assembly-schema": "1.44.0",
"@aws-cdk/cx-api": "1.45.0",
"@aws-cdk/cdk-assets-schema": "1.45.0",
"@aws-cdk/cloud-assembly-schema": "1.45.0",
"constructs": "^3.0.2"

@@ -180,5 +182,5 @@ },

"peerDependencies": {
"@aws-cdk/cdk-assets-schema": "1.44.0",
"@aws-cdk/cloud-assembly-schema": "1.44.0",
"@aws-cdk/cx-api": "1.44.0",
"@aws-cdk/cdk-assets-schema": "1.45.0",
"@aws-cdk/cloud-assembly-schema": "1.45.0",
"@aws-cdk/cx-api": "1.45.0",
"constructs": "^3.0.2"

@@ -185,0 +187,0 @@ },

@@ -20,2 +20,38 @@ ## AWS Cloud Development Kit Core Library

## Stacks and Stages
A `Stack` is the smallest physical unit of deployment, and maps directly onto
a CloudFormation Stack. You define a Stack by defining a subclass of `Stack`
-- let's call it `MyStack` -- and instantiating the constructs that make up
your application in `MyStack`'s constructor. You then instantiate this stack
one or more times to define different instances of your application. For example,
you can instantiate it once using few and cheap EC2 instances for testing,
and once again using more and bigger EC2 instances for production.
When your application grows, you may decide that it makes more sense to split it
out across multiple `Stack` classes. This can happen for a number of reasons:
- You could be starting to reach the maximum number of resources allowed in a single
stack (this is currently 200).
- You could decide you want to separate out stateful resources and stateless resources
into separate stacks, so that it becomes easy to tear down and recreate the stacks
that don't have stateful resources.
- There could be a single stack with resources (like a VPC) that are shared
between multiple instances of other stacks containing your applications.
As soon as your conceptual application starts to encompass multiple stacks,
it is convenient to wrap them in another construct that represents your
logical application. You can then treat that new unit the same way you used
to be able to treat a single stack: by instantiating it multiple times
for different instances of your application.
You can define a custom subclass of `Construct`, holding one or more
`Stack`s, to represent a single logical instance of your application.
As a final note: `Stack`s are not a unit of reuse. They describe physical
deployment layouts, and as such are best left to application builders to
organize their deployments with. If you want to vend a reusable construct,
define it as a subclasses of `Construct`: the consumers of your construct
will decide where to place it in their own stacks.
## Nested Stacks

@@ -40,3 +76,3 @@

new s3.Bucket(this, 'NestedBucket');
new s3.Bucket(this, 'NestedBucket');
}

@@ -241,3 +277,3 @@ }

// the ARN of the provider (SNS/Lambda) which handles
// the ARN of the provider (SNS/Lambda) which handles
// CREATE, UPDATE or DELETE events for this resource type

@@ -298,3 +334,3 @@ // see next section for details

fleet of worker hosts) and submit success/failure responses to the
CloudFormation service.
CloudFormation service.

@@ -318,3 +354,3 @@ Set `serviceToken` to `topic.topicArn` in order to use this provider:

events. The handler must take care of explicitly submitting a success/failure
response to the CloudFormation service and handle various error cases.
response to the CloudFormation service and handle various error cases.

@@ -369,3 +405,3 @@ Set `serviceToken` to `lambda.functionArn` to use this provider:

const oldProps = event.OldResourceProperties; // only for "Update"s
switch (event.RequestType) {

@@ -380,3 +416,3 @@ case "Create":

throw new Error('Failed!');
case "Delete":

@@ -413,6 +449,6 @@ // ...

exports.handler = async e => {
return {
Data: {
return {
Data: {
Result: e.ResourceProperties.lhs + e.ResourceProperties.rhs
}
}
};

@@ -474,3 +510,3 @@ };

function which is called periodically until the operation is complete. This
allows implementing providers that can take up to two hours to stabilize.
allows implementing providers that can take up to two hours to stabilize.

@@ -499,3 +535,3 @@ Set `serviceToken` to `provider.serviceToken` to use this type of provider:

fleet of worker hosts) and submit success/failure responses to the
CloudFormation service.
CloudFormation service.

@@ -519,3 +555,3 @@ Set `serviceToken` to `topic.topicArn` in order to use this provider:

events. The handler must take care of explicitly submitting a success/failure
response to the CloudFormation service and handle various error cases.
response to the CloudFormation service and handle various error cases.

@@ -546,3 +582,3 @@ Set `serviceToken` to `lambda.functionArn` to use this provider:

function which is called periodically until the operation is complete. This
allows implementing providers that can take up to two hours to stabilize.
allows implementing providers that can take up to two hours to stabilize.

@@ -842,3 +878,3 @@ Set `serviceToken` to `provider.serviceToken` to use this provider:

The following example defines an IAM role which can only be assumed by
principals that are tagged with a specific tag.
principals that are tagged with a specific tag.

@@ -845,0 +881,0 @@ ```ts

@@ -8,3 +8,4 @@ import { Test } from 'nodeunit';

synthesis(test: Test): void;
'customize publishing resources'(test: Test): void;
};
export = _default;

@@ -24,2 +24,9 @@ "use strict";

}
function readAssetManifest(asm) {
const manifestArtifact = asm.artifacts.filter(isAssetManifest)[0];
if (!manifestArtifact) {
throw new Error('no asset manifest in assembly');
}
return JSON.parse(fs.readFileSync(manifestArtifact.file, { encoding: 'utf-8' }));
}
module.exports = {

@@ -57,3 +64,3 @@ 'setUp'(cb) {

objectKey: '4bdae6e3b1b15f08c889d6c9133f24731ee14827a9a9ab9b6b6a9b42b6d34910',
assumeRoleArn: 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-publishing-role-${AWS::AccountId}-${AWS::Region}',
assumeRoleArn: 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-file-publishing-role-${AWS::AccountId}-${AWS::Region}',
},

@@ -90,2 +97,3 @@ },

'synthesis'(test) {
var _a, _b;
// GIVEN

@@ -104,16 +112,60 @@ stack.synthesizer.addFileAsset({

// THEN - we have an asset manifest with both assets and the stack template in there
const manifestArtifact = asm.artifacts.filter(isAssetManifest)[0];
test.ok(manifestArtifact);
const manifest = JSON.parse(fs.readFileSync(manifestArtifact.file, { encoding: 'utf-8' }));
const manifest = readAssetManifest(asm);
test.equals(Object.keys(manifest.files || {}).length, 2);
test.equals(Object.keys(manifest.dockerImages || {}).length, 1);
// THEN - every artifact has an assumeRoleArn
for (const file of Object.values({ ...manifest.files, ...manifest.dockerImages })) {
for (const file of Object.values((_a = manifest.files) !== null && _a !== void 0 ? _a : {})) {
for (const destination of Object.values(file.destinations)) {
test.ok(destination.assumeRoleArn);
test.deepEqual(destination.assumeRoleArn, 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-file-publishing-role-${AWS::AccountId}-${AWS::Region}');
}
}
for (const file of Object.values((_b = manifest.dockerImages) !== null && _b !== void 0 ? _b : {})) {
for (const destination of Object.values(file.destinations)) {
test.deepEqual(destination.assumeRoleArn, 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-image-publishing-role-${AWS::AccountId}-${AWS::Region}');
}
}
test.done();
},
'customize publishing resources'(test) {
var _a, _b, _c, _d, _e, _f;
// GIVEN
const myapp = new lib_1.App();
// WHEN
const mystack = new lib_1.Stack(myapp, 'mystack', {
synthesizer: new lib_1.DefaultStackSynthesizer({
fileAssetsBucketName: 'file-asset-bucket',
fileAssetPublishingRoleArn: 'file:role:arn',
fileAssetPublishingExternalId: 'file-external-id',
imageAssetsRepositoryName: 'image-ecr-repository',
imageAssetPublishingRoleArn: 'image:role:arn',
imageAssetPublishingExternalId: 'image-external-id',
}),
});
mystack.synthesizer.addFileAsset({
fileName: __filename,
packaging: lib_1.FileAssetPackaging.FILE,
sourceHash: 'file-asset-hash',
});
mystack.synthesizer.addDockerImageAsset({
directoryName: '.',
sourceHash: 'docker-asset-hash',
});
// THEN
const asm = myapp.synth();
const manifest = readAssetManifest(asm);
test.deepEqual((_c = (_b = (_a = manifest.files) === null || _a === void 0 ? void 0 : _a['file-asset-hash']) === null || _b === void 0 ? void 0 : _b.destinations) === null || _c === void 0 ? void 0 : _c['current_account-current_region'], {
bucketName: 'file-asset-bucket',
objectKey: 'file-asset-hash',
assumeRoleArn: 'file:role:arn',
assumeRoleExternalId: 'file-external-id',
});
test.deepEqual((_f = (_e = (_d = manifest.dockerImages) === null || _d === void 0 ? void 0 : _d['docker-asset-hash']) === null || _e === void 0 ? void 0 : _e.destinations) === null || _f === void 0 ? void 0 : _f['current_account-current_region'], {
repositoryName: 'image-ecr-repository',
imageTag: 'docker-asset-hash',
assumeRoleArn: 'image:role:arn',
assumeRoleExternalId: 'image-external-id',
});
test.done();
},
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.new-style-synthesis.js","sourceRoot":"","sources":["test.new-style-synthesis.ts"],"names":[],"mappings":"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","sourcesContent":["import * as asset_schema from '@aws-cdk/cdk-assets-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as fs from 'fs';\nimport { Test } from 'nodeunit';\nimport { App, CfnResource, FileAssetPackaging, Stack } from '../../lib';\nimport { evaluateCFN } from '../evaluate-cfn';\n\nconst CFN_CONTEXT = {\n  'AWS::Region': 'the_region',\n  'AWS::AccountId': 'the_account',\n  'AWS::URLSuffix': 'domain.aws',\n};\n\nlet app: App;\nlet stack: Stack;\nexport = {\n  'setUp'(cb: () => void) {\n    app = new App({\n      context: {\n        [cxapi.NEW_STYLE_STACK_SYNTHESIS_CONTEXT]: 'true',\n      },\n    });\n    stack = new Stack(app, 'Stack');\n    cb();\n  },\n\n  'stack template is in asset manifest'(test: Test) {\n    // GIVEN\n    new CfnResource(stack, 'Resource', {\n      type: 'Some::Resource',\n    });\n\n    // WHEN\n    const asm = app.synth();\n\n    // THEN -- the S3 url is advertised on the stack artifact\n    const stackArtifact = asm.getStackArtifact('Stack');\n    test.equals(stackArtifact.stackTemplateAssetObjectUrl, 's3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/4bdae6e3b1b15f08c889d6c9133f24731ee14827a9a9ab9b6b6a9b42b6d34910');\n\n    // THEN - the template is in the asset manifest\n    const manifestArtifact = asm.artifacts.filter(isAssetManifest)[0];\n    test.ok(manifestArtifact);\n    const manifest: asset_schema.ManifestFile = JSON.parse(fs.readFileSync(manifestArtifact.file, { encoding: 'utf-8' }));\n\n    const firstFile = (manifest.files ? manifest.files[Object.keys(manifest.files)[0]] : undefined) ?? {};\n\n    test.deepEqual(firstFile, {\n      source: { path: 'Stack.template.json', packaging: 'file' },\n      destinations: {\n        'current_account-current_region': {\n          bucketName: 'cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}',\n          objectKey: '4bdae6e3b1b15f08c889d6c9133f24731ee14827a9a9ab9b6b6a9b42b6d34910',\n          assumeRoleArn: 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-publishing-role-${AWS::AccountId}-${AWS::Region}',\n        },\n      },\n    });\n\n    test.done();\n  },\n\n  'add file asset'(test: Test) {\n    // WHEN\n    const location = stack.synthesizer.addFileAsset({\n      fileName: __filename,\n      packaging: FileAssetPackaging.FILE,\n      sourceHash: 'abcdef',\n    });\n\n    // THEN - we have a fixed asset location with region placeholders\n    test.equals(evalCFN(location.bucketName), 'cdk-hnb659fds-assets-the_account-the_region');\n    test.equals(evalCFN(location.s3Url), 'https://s3.the_region.domain.aws/cdk-hnb659fds-assets-the_account-the_region/abcdef');\n\n    // THEN - object key contains source hash somewhere\n    test.ok(location.objectKey.indexOf('abcdef') > -1);\n\n    test.done();\n  },\n\n  'add docker image asset'(test: Test) {\n    // WHEN\n    const location = stack.synthesizer.addDockerImageAsset({\n      directoryName: '.',\n      sourceHash: 'abcdef',\n    });\n\n    // THEN - we have a fixed asset location with region placeholders\n    test.equals(evalCFN(location.repositoryName), 'cdk-hnb659fds-container-assets-the_account-the_region');\n    test.equals(evalCFN(location.imageUri), 'the_account.dkr.ecr.the_region.domain.aws/cdk-hnb659fds-container-assets-the_account-the_region:abcdef');\n\n    test.done();\n  },\n\n  'synthesis'(test: Test) {\n    // GIVEN\n    stack.synthesizer.addFileAsset({\n      fileName: __filename,\n      packaging: FileAssetPackaging.FILE,\n      sourceHash: 'abcdef',\n    });\n    stack.synthesizer.addDockerImageAsset({\n      directoryName: '.',\n      sourceHash: 'abcdef',\n    });\n\n    // WHEN\n    const asm = app.synth();\n\n    // THEN - we have an asset manifest with both assets and the stack template in there\n    const manifestArtifact = asm.artifacts.filter(isAssetManifest)[0];\n    test.ok(manifestArtifact);\n    const manifest: asset_schema.ManifestFile = JSON.parse(fs.readFileSync(manifestArtifact.file, { encoding: 'utf-8' }));\n\n    test.equals(Object.keys(manifest.files || {}).length, 2);\n    test.equals(Object.keys(manifest.dockerImages || {}).length, 1);\n\n    // THEN - every artifact has an assumeRoleArn\n    for (const file of Object.values({...manifest.files, ...manifest.dockerImages})) {\n      for (const destination of Object.values(file.destinations)) {\n        test.ok(destination.assumeRoleArn);\n      }\n    }\n\n    test.done();\n  },\n};\n\n/**\n * Evaluate a possibly string-containing value the same way CFN would do\n *\n * (Be invariant to the specific Fn::Sub or Fn::Join we would output)\n */\nfunction evalCFN(value: any) {\n  return evaluateCFN(stack.resolve(value), CFN_CONTEXT);\n}\n\nfunction isAssetManifest(x: cxapi.CloudArtifact): x is cxapi.AssetManifestArtifact {\n  return x instanceof cxapi.AssetManifestArtifact;\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.new-style-synthesis.js","sourceRoot":"","sources":["test.new-style-synthesis.ts"],"names":[],"mappings":"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","sourcesContent":["import * as asset_schema from '@aws-cdk/cdk-assets-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as fs from 'fs';\nimport { Test } from 'nodeunit';\nimport { App, CfnResource, DefaultStackSynthesizer, FileAssetPackaging, Stack } from '../../lib';\nimport { evaluateCFN } from '../evaluate-cfn';\n\nconst CFN_CONTEXT = {\n  'AWS::Region': 'the_region',\n  'AWS::AccountId': 'the_account',\n  'AWS::URLSuffix': 'domain.aws',\n};\n\nlet app: App;\nlet stack: Stack;\nexport = {\n  'setUp'(cb: () => void) {\n    app = new App({\n      context: {\n        [cxapi.NEW_STYLE_STACK_SYNTHESIS_CONTEXT]: 'true',\n      },\n    });\n    stack = new Stack(app, 'Stack');\n    cb();\n  },\n\n  'stack template is in asset manifest'(test: Test) {\n    // GIVEN\n    new CfnResource(stack, 'Resource', {\n      type: 'Some::Resource',\n    });\n\n    // WHEN\n    const asm = app.synth();\n\n    // THEN -- the S3 url is advertised on the stack artifact\n    const stackArtifact = asm.getStackArtifact('Stack');\n    test.equals(stackArtifact.stackTemplateAssetObjectUrl, 's3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/4bdae6e3b1b15f08c889d6c9133f24731ee14827a9a9ab9b6b6a9b42b6d34910');\n\n    // THEN - the template is in the asset manifest\n    const manifestArtifact = asm.artifacts.filter(isAssetManifest)[0];\n    test.ok(manifestArtifact);\n    const manifest: asset_schema.ManifestFile = JSON.parse(fs.readFileSync(manifestArtifact.file, { encoding: 'utf-8' }));\n\n    const firstFile = (manifest.files ? manifest.files[Object.keys(manifest.files)[0]] : undefined) ?? {};\n\n    test.deepEqual(firstFile, {\n      source: { path: 'Stack.template.json', packaging: 'file' },\n      destinations: {\n        'current_account-current_region': {\n          bucketName: 'cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}',\n          objectKey: '4bdae6e3b1b15f08c889d6c9133f24731ee14827a9a9ab9b6b6a9b42b6d34910',\n          assumeRoleArn: 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-file-publishing-role-${AWS::AccountId}-${AWS::Region}',\n        },\n      },\n    });\n\n    test.done();\n  },\n\n  'add file asset'(test: Test) {\n    // WHEN\n    const location = stack.synthesizer.addFileAsset({\n      fileName: __filename,\n      packaging: FileAssetPackaging.FILE,\n      sourceHash: 'abcdef',\n    });\n\n    // THEN - we have a fixed asset location with region placeholders\n    test.equals(evalCFN(location.bucketName), 'cdk-hnb659fds-assets-the_account-the_region');\n    test.equals(evalCFN(location.s3Url), 'https://s3.the_region.domain.aws/cdk-hnb659fds-assets-the_account-the_region/abcdef');\n\n    // THEN - object key contains source hash somewhere\n    test.ok(location.objectKey.indexOf('abcdef') > -1);\n\n    test.done();\n  },\n\n  'add docker image asset'(test: Test) {\n    // WHEN\n    const location = stack.synthesizer.addDockerImageAsset({\n      directoryName: '.',\n      sourceHash: 'abcdef',\n    });\n\n    // THEN - we have a fixed asset location with region placeholders\n    test.equals(evalCFN(location.repositoryName), 'cdk-hnb659fds-container-assets-the_account-the_region');\n    test.equals(evalCFN(location.imageUri), 'the_account.dkr.ecr.the_region.domain.aws/cdk-hnb659fds-container-assets-the_account-the_region:abcdef');\n\n    test.done();\n  },\n\n  'synthesis'(test: Test) {\n    // GIVEN\n    stack.synthesizer.addFileAsset({\n      fileName: __filename,\n      packaging: FileAssetPackaging.FILE,\n      sourceHash: 'abcdef',\n    });\n    stack.synthesizer.addDockerImageAsset({\n      directoryName: '.',\n      sourceHash: 'abcdef',\n    });\n\n    // WHEN\n    const asm = app.synth();\n\n    // THEN - we have an asset manifest with both assets and the stack template in there\n    const manifest = readAssetManifest(asm);\n\n    test.equals(Object.keys(manifest.files || {}).length, 2);\n    test.equals(Object.keys(manifest.dockerImages || {}).length, 1);\n\n    // THEN - every artifact has an assumeRoleArn\n    for (const file of Object.values(manifest.files ?? {})) {\n      for (const destination of Object.values(file.destinations)) {\n        test.deepEqual(destination.assumeRoleArn, 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-file-publishing-role-${AWS::AccountId}-${AWS::Region}');\n      }\n    }\n\n    for (const file of Object.values(manifest.dockerImages ?? {})) {\n      for (const destination of Object.values(file.destinations)) {\n        test.deepEqual(destination.assumeRoleArn, 'arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-image-publishing-role-${AWS::AccountId}-${AWS::Region}');\n      }\n    }\n\n    test.done();\n  },\n\n  'customize publishing resources'(test: Test) {\n    // GIVEN\n    const myapp = new App();\n\n    // WHEN\n    const mystack = new Stack(myapp, 'mystack', {\n      synthesizer: new DefaultStackSynthesizer({\n        fileAssetsBucketName: 'file-asset-bucket',\n        fileAssetPublishingRoleArn: 'file:role:arn',\n        fileAssetPublishingExternalId: 'file-external-id',\n\n        imageAssetsRepositoryName: 'image-ecr-repository',\n        imageAssetPublishingRoleArn: 'image:role:arn',\n        imageAssetPublishingExternalId: 'image-external-id',\n      }),\n    });\n\n    mystack.synthesizer.addFileAsset({\n      fileName: __filename,\n      packaging: FileAssetPackaging.FILE,\n      sourceHash: 'file-asset-hash',\n    });\n\n    mystack.synthesizer.addDockerImageAsset({\n      directoryName: '.',\n      sourceHash: 'docker-asset-hash',\n    });\n\n    // THEN\n    const asm = myapp.synth();\n    const manifest = readAssetManifest(asm);\n\n    test.deepEqual(manifest.files?.['file-asset-hash']?.destinations?.['current_account-current_region'], {\n      bucketName: 'file-asset-bucket',\n      objectKey: 'file-asset-hash',\n      assumeRoleArn: 'file:role:arn',\n      assumeRoleExternalId: 'file-external-id',\n    });\n\n    test.deepEqual(manifest.dockerImages?.['docker-asset-hash']?.destinations?.['current_account-current_region'] , {\n      repositoryName: 'image-ecr-repository',\n      imageTag: 'docker-asset-hash',\n      assumeRoleArn: 'image:role:arn',\n      assumeRoleExternalId: 'image-external-id',\n    });\n\n    test.done();\n  },\n};\n\n/**\n * Evaluate a possibly string-containing value the same way CFN would do\n *\n * (Be invariant to the specific Fn::Sub or Fn::Join we would output)\n */\nfunction evalCFN(value: any) {\n  return evaluateCFN(stack.resolve(value), CFN_CONTEXT);\n}\n\nfunction isAssetManifest(x: cxapi.CloudArtifact): x is cxapi.AssetManifestArtifact {\n  return x instanceof cxapi.AssetManifestArtifact;\n}\n\nfunction readAssetManifest(asm: cxapi.CloudAssembly): asset_schema.ManifestFile {\n  const manifestArtifact = asm.artifacts.filter(isAssetManifest)[0];\n  if (!manifestArtifact) { throw new Error('no asset manifest in assembly'); }\n\n  return JSON.parse(fs.readFileSync(manifestArtifact.file, { encoding: 'utf-8' }));\n}"]}

@@ -7,3 +7,11 @@ import { Test } from 'nodeunit';

'allow specifying extra data to include in the source hash'(test: Test): void;
'with bundling'(test: Test): void;
'bundling throws when /asset-ouput is empty'(test: Test): void;
'bundling with BUNDLE asset hash type'(test: Test): void;
'custom hash'(test: Test): void;
'throws with assetHash and not CUSTOM hash type'(test: Test): void;
'throws with BUNDLE hash type and no bundling'(test: Test): void;
'throws with CUSTOM and no hash'(test: Test): void;
'throws when bundling fails'(test: Test): void;
};
export = _default;

@@ -65,3 +65,126 @@ "use strict";

},
'with bundling'(test) {
// GIVEN
const app = new lib_1.App();
const stack = new lib_1.Stack(app, 'stack');
const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');
// WHEN
new lib_1.AssetStaging(stack, 'Asset', {
sourcePath: directory,
bundling: {
image: lib_1.BundlingDockerImage.fromRegistry('alpine'),
command: ['touch', '/asset-output/test.txt'],
},
});
// THEN
const assembly = app.synth();
test.deepEqual(fs.readdirSync(assembly.directory), [
'asset.2f37f937c51e2c191af66acf9b09f548926008ec68c575bd2ee54b6e997c0e00',
'cdk.out',
'manifest.json',
'stack.template.json',
'tree.json',
]);
test.done();
},
'bundling throws when /asset-ouput is empty'(test) {
// GIVEN
const app = new lib_1.App();
const stack = new lib_1.Stack(app, 'stack');
const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');
// THEN
test.throws(() => new lib_1.AssetStaging(stack, 'Asset', {
sourcePath: directory,
bundling: {
image: lib_1.BundlingDockerImage.fromRegistry('alpine'),
},
}), /Bundling did not produce any output/);
test.done();
},
'bundling with BUNDLE asset hash type'(test) {
// GIVEN
const app = new lib_1.App();
const stack = new lib_1.Stack(app, 'stack');
const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');
// WHEN
const asset = new lib_1.AssetStaging(stack, 'Asset', {
sourcePath: directory,
bundling: {
image: lib_1.BundlingDockerImage.fromRegistry('alpine'),
command: ['touch', '/asset-output/test.txt'],
},
assetHashType: lib_1.AssetHashType.BUNDLE,
});
test.equal(asset.assetHash, '33cbf2cae5432438e0f046bc45ba8c3cef7b6afcf47b59d1c183775c1918fb1f');
test.done();
},
'custom hash'(test) {
// GIVEN
const app = new lib_1.App();
const stack = new lib_1.Stack(app, 'stack');
const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');
// WHEN
const asset = new lib_1.AssetStaging(stack, 'Asset', {
sourcePath: directory,
assetHash: 'my-custom-hash',
});
test.equal(asset.assetHash, 'my-custom-hash');
test.done();
},
'throws with assetHash and not CUSTOM hash type'(test) {
// GIVEN
const app = new lib_1.App();
const stack = new lib_1.Stack(app, 'stack');
const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');
// THEN
test.throws(() => new lib_1.AssetStaging(stack, 'Asset', {
sourcePath: directory,
bundling: {
image: lib_1.BundlingDockerImage.fromRegistry('alpine'),
command: ['touch', '/asset-output/test.txt'],
},
assetHash: 'my-custom-hash',
assetHashType: lib_1.AssetHashType.BUNDLE,
}), /Cannot specify `bundle` for `assetHashType`/);
test.done();
},
'throws with BUNDLE hash type and no bundling'(test) {
// GIVEN
const app = new lib_1.App();
const stack = new lib_1.Stack(app, 'stack');
const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');
// THEN
test.throws(() => new lib_1.AssetStaging(stack, 'Asset', {
sourcePath: directory,
assetHashType: lib_1.AssetHashType.BUNDLE,
}), /Cannot use `AssetHashType.BUNDLE` when `bundling` is not specified/);
test.done();
},
'throws with CUSTOM and no hash'(test) {
// GIVEN
const app = new lib_1.App();
const stack = new lib_1.Stack(app, 'stack');
const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');
// THEN
test.throws(() => new lib_1.AssetStaging(stack, 'Asset', {
sourcePath: directory,
assetHashType: lib_1.AssetHashType.CUSTOM,
}), /`assetHash` must be specified when `assetHashType` is set to `AssetHashType.CUSTOM`/);
test.done();
},
'throws when bundling fails'(test) {
// GIVEN
const app = new lib_1.App();
const stack = new lib_1.Stack(app, 'stack');
const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');
// THEN
test.throws(() => new lib_1.AssetStaging(stack, 'Asset', {
sourcePath: directory,
bundling: {
image: lib_1.BundlingDockerImage.fromRegistry('this-is-an-invalid-docker-image'),
},
}), /Failed to run bundling Docker image for asset stack\/Asset/);
test.done();
},
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5zdGFnaW5nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGVzdC5zdGFnaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSx5Q0FBeUM7QUFDekMseUJBQXlCO0FBRXpCLDZCQUE2QjtBQUM3QixnQ0FBa0Q7QUFFbEQsaUJBQVM7SUFDUCxXQUFXLENBQUMsSUFBVTtRQUNwQixRQUFRO1FBQ1IsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLEVBQUUsQ0FBQztRQUMxQixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBRW5FLE9BQU87UUFDUCxNQUFNLE9BQU8sR0FBRyxJQUFJLGtCQUFZLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7UUFFOUQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsVUFBVSxFQUFFLGtFQUFrRSxDQUFDLENBQUM7UUFDdkcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsVUFBVSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQy9DLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLEVBQUUsd0VBQXdFLENBQUMsQ0FBQztRQUM1SCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO0lBRUQseUNBQXlDLENBQUMsSUFBVTtRQUNsRCxRQUFRO1FBQ1IsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLEVBQUUsQ0FBQztRQUMxQixLQUFLLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsNkJBQTZCLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDakUsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxPQUFPLENBQUMs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d3MtY2RrL2N4LWFwaSc7XG5pbXBvcnQgKiBhcyBmcyBmcm9tICdmcyc7XG5pbXBvcnQgeyBUZXN0IH0gZnJvbSAnbm9kZXVuaXQnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IEFwcCwgQXNzZXRTdGFnaW5nLCBTdGFjayB9IGZyb20gJy4uL2xpYic7XG5cbmV4cG9ydCA9IHtcbiAgJ2Jhc2UgY2FzZScodGVzdDogVGVzdCkge1xuICAgIC8vIEdJVkVOXG4gICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soKTtcbiAgICBjb25zdCBzb3VyY2VQYXRoID0gcGF0aC5qb2luKF9fZGlybmFtZSwgJ2ZzJywgJ2ZpeHR1cmVzJywgJ3Rlc3QxJyk7XG5cbiAgICAvLyBXSEVOXG4gICAgY29uc3Qgc3RhZ2luZyA9IG5ldyBBc3NldFN0YWdpbmcoc3RhY2ssICdzMScsIHsgc291cmNlUGF0aCB9KTtcblxuICAgIHRlc3QuZGVlcEVxdWFsKHN0YWdpbmcuc291cmNlSGFzaCwgJzJmMzdmOTM3YzUxZTJjMTkxYWY2NmFjZjliMDlmNTQ4OTI2MDA4ZWM2OGM1NzViZDJlZTU0YjZlOTk3YzBlMDAnKTtcbiAgICB0ZXN0LmRlZXBFcXVhbChzdGFnaW5nLnNvdXJjZVBhdGgsIHNvdXJjZVBhdGgpO1xuICAgIHRlc3QuZGVlcEVxdWFsKHN0YWNrLnJlc29sdmUoc3RhZ2luZy5zdGFnZWRQYXRoKSwgJ2Fzc2V0LjJmMzdmOTM3YzUxZTJjMTkxYWY2NmFjZjliMDlmNTQ4OTI2MDA4ZWM2OGM1NzViZDJlZTU0YjZlOTk3YzBlMDAnKTtcbiAgICB0ZXN0LmRvbmUoKTtcbiAgfSxcblxuICAnc3RhZ2luZyBjYW4gYmUgZGlzYWJsZWQgdGhyb3VnaCBjb250ZXh0Jyh0ZXN0OiBUZXN0KSB7XG4gICAgLy8gR0lWRU5cbiAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuICAgIHN0YWNrLm5vZGUuc2V0Q29udGV4dChjeGFwaS5ESVNBQkxFX0FTU0VUX1NUQUdJTkdfQ09OVEVYVCwgdHJ1ZSk7XG4gICAgY29uc3Qgc291cmNlUGF0aCA9IHBhdGguam9pbihfX2Rpcm5hbWUsICdmcycsICdmaXh0dXJlcycsICd0ZXN0MScpO1xuXG4gICAgLy8gV0hFTlxuICAgIGNvbnN0IHN0YWdpbmcgPSBuZXcgQXNzZXRTdGFnaW5nKHN0YWNrLCAnczEnLCB7IHNvdXJjZVBhdGggfSk7XG5cbiAgICB0ZXN0LmRlZXBFcXVhbChzdGFnaW5nLnNvdXJjZUhhc2gsICcyZjM3ZjkzN2M1MWUyYzE5MWFmNjZhY2Y5YjA5ZjU0ODkyNjAwOGVjNjhjNTc1YmQyZWU1NGI2ZTk5N2MwZTAwJyk7XG4gICAgdGVzdC5kZWVwRXF1YWwoc3RhZ2luZy5zb3VyY2VQYXRoLCBzb3VyY2VQYXRoKTtcbiAgICB0ZXN0LmRlZXBFcXVhbChzdGFjay5yZXNvbHZlKHN0YWdpbmcuc3RhZ2VkUGF0aCksIHNvdXJjZVBhdGgpO1xuICAgIHRlc3QuZG9uZSgpO1xuICB9LFxuXG4gICdmaWxlcyBhcmUgY29waWVkIHRvIHRoZSBvdXRwdXQgZGlyZWN0b3J5IGR1cmluZyBzeW50aCcodGVzdDogVGVzdCkge1xuICAgIC8vIEdJVkVOXG4gICAgY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ3N0YWNrJyk7XG4gICAgY29uc3QgZGlyZWN0b3J5ID0gcGF0aC5qb2luKF9fZGlybmFtZSwgJ2ZzJywgJ2ZpeHR1cmVzJywgJ3Rlc3QxJyk7XG4gICAgY29uc3QgZmlsZSA9IHBhdGguam9pbihfX2Rpcm5hbWUsICdmcycsICdmaXh0dXJlcy50YXIuZ3onKTtcblxuICAgIC8vIFdIRU5cbiAgICBuZXcgQXNzZXRTdGFnaW5nKHN0YWNrLCAnczEnLCB7IHNvdXJjZVBhdGg6IGRpcmVjdG9yeSB9KTtcbiAgICBuZXcgQXNzZXRTdGFnaW5nKHN0YWNrLCAnZmlsZScsIHsgc291cmNlUGF0aDogZmlsZSB9KTtcblxuICAgIC8vIFRIRU5cbiAgICBjb25zdCBhc3NlbWJseSA9IGFwcC5zeW50aCgpO1xuICAgIHRlc3QuZGVlcEVxdWFsKGZzLnJlYWRkaXJTeW5jKGFzc2VtYmx5LmRpcmVjdG9yeSksIFtcbiAgICAgICdhc3NldC4yZjM3ZjkzN2M1MWUyYzE5MWFmNjZhY2Y5YjA5ZjU0ODkyNjAwOGVjNjhjNTc1YmQyZWU1NGI2ZTk5N2MwZTAwJyxcbiAgICAgICdhc3NldC5hZjEwYWMwNGIzYjYwN2IwZjg2NTljOGYwY2VlOGMzNDMwMjVlZTc1YmFmMGIxNDZmMTBmMGU1MzExZDJjNDZiLmd6JyxcbiAgICAgICdjZGsub3V0JyxcbiAgICAgICdtYW5pZmVzdC5qc29uJyxcbiAgICAgICdzdGFjay50ZW1wbGF0ZS5qc29uJyxcbiAgICAgICd0cmVlLmpzb24nLFxuICAgIF0pO1xuICAgIHRlc3QuZG9uZSgpO1xuICB9LFxuXG4gICdhbGxvdyBzcGVjaWZ5aW5nIGV4dHJhIGRhdGEgdG8gaW5jbHVkZSBpbiB0aGUgc291cmNlIGhhc2gnKHRlc3Q6IFRlc3QpIHtcbiAgICAvLyBHSVZFTlxuICAgIGNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbiAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdzdGFjaycpO1xuICAgIGNvbnN0IGRpcmVjdG9yeSA9IHBhdGguam9pbihfX2Rpcm5hbWUsICdmcycsICdmaXh0dXJlcycsICd0ZXN0MScpO1xuXG4gICAgLy8gV0hFTlxuICAgIGNvbnN0IHdpdGhvdXRFeHRyYSA9IG5ldyBBc3NldFN0YWdpbmcoc3RhY2ssICd3aXRob3V0RXh0cmEnLCB7IHNvdXJjZVBhdGg6IGRpcmVjdG9yeSB9KTtcbiAgICBjb25zdCB3aXRoRXh0cmEgPSBuZXcgQXNzZXRTdGFnaW5nKHN0YWNrLCAnd2l0aEV4dHJhJywgeyBzb3VyY2VQYXRoOiBkaXJlY3RvcnksIGV4dHJhSGFzaDogJ2Jvb20nIH0pO1xuXG4gICAgLy8gVEhFTlxuICAgIHRlc3Qubm90RXF1YWwod2l0aG91dEV4dHJhLnNvdXJjZUhhc2gsIHdpdGhFeHRyYS5zb3VyY2VIYXNoKTtcbiAgICB0ZXN0LmRlZXBFcXVhbCh3aXRob3V0RXh0cmEuc291cmNlSGFzaCwgJzJmMzdmOTM3YzUxZTJjMTkxYWY2NmFjZjliMDlmNTQ4OTI2MDA4ZWM2OGM1NzViZDJlZTU0YjZlOTk3YzBlMDAnKTtcbiAgICB0ZXN0LmRlZXBFcXVhbCh3aXRoRXh0cmEuc291cmNlSGFzaCwgJ2M5NWM5MTVhNTcyMmJiOTAxOWUyYzcyNWQxMTg2OGU1YTYxOWI1NWYzNjE3MmY3NmJjYmNhYThiYjJkMTBjNWYnKTtcbiAgICB0ZXN0LmRvbmUoKTtcbiAgfSxcbn07XG4iXX0=
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.staging.js","sourceRoot":"","sources":["test.staging.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cxapi from '@aws-cdk/cx-api';\nimport * as fs from 'fs';\nimport { Test } from 'nodeunit';\nimport * as path from 'path';\nimport { App, AssetHashType, AssetStaging, BundlingDockerImage, Stack } from '../lib';\n\nexport = {\n  'base case'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    const sourcePath = path.join(__dirname, 'fs', 'fixtures', 'test1');\n\n    // WHEN\n    const staging = new AssetStaging(stack, 's1', { sourcePath });\n\n    test.deepEqual(staging.sourceHash, '2f37f937c51e2c191af66acf9b09f548926008ec68c575bd2ee54b6e997c0e00');\n    test.deepEqual(staging.sourcePath, sourcePath);\n    test.deepEqual(stack.resolve(staging.stagedPath), 'asset.2f37f937c51e2c191af66acf9b09f548926008ec68c575bd2ee54b6e997c0e00');\n    test.done();\n  },\n\n  'staging can be disabled through context'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    stack.node.setContext(cxapi.DISABLE_ASSET_STAGING_CONTEXT, true);\n    const sourcePath = path.join(__dirname, 'fs', 'fixtures', 'test1');\n\n    // WHEN\n    const staging = new AssetStaging(stack, 's1', { sourcePath });\n\n    test.deepEqual(staging.sourceHash, '2f37f937c51e2c191af66acf9b09f548926008ec68c575bd2ee54b6e997c0e00');\n    test.deepEqual(staging.sourcePath, sourcePath);\n    test.deepEqual(stack.resolve(staging.stagedPath), sourcePath);\n    test.done();\n  },\n\n  'files are copied to the output directory during synth'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'stack');\n    const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');\n    const file = path.join(__dirname, 'fs', 'fixtures.tar.gz');\n\n    // WHEN\n    new AssetStaging(stack, 's1', { sourcePath: directory });\n    new AssetStaging(stack, 'file', { sourcePath: file });\n\n    // THEN\n    const assembly = app.synth();\n    test.deepEqual(fs.readdirSync(assembly.directory), [\n      'asset.2f37f937c51e2c191af66acf9b09f548926008ec68c575bd2ee54b6e997c0e00',\n      'asset.af10ac04b3b607b0f8659c8f0cee8c343025ee75baf0b146f10f0e5311d2c46b.gz',\n      'cdk.out',\n      'manifest.json',\n      'stack.template.json',\n      'tree.json',\n    ]);\n    test.done();\n  },\n\n  'allow specifying extra data to include in the source hash'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'stack');\n    const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');\n\n    // WHEN\n    const withoutExtra = new AssetStaging(stack, 'withoutExtra', { sourcePath: directory });\n    const withExtra = new AssetStaging(stack, 'withExtra', { sourcePath: directory, extraHash: 'boom' });\n\n    // THEN\n    test.notEqual(withoutExtra.sourceHash, withExtra.sourceHash);\n    test.deepEqual(withoutExtra.sourceHash, '2f37f937c51e2c191af66acf9b09f548926008ec68c575bd2ee54b6e997c0e00');\n    test.deepEqual(withExtra.sourceHash, 'c95c915a5722bb9019e2c725d11868e5a619b55f36172f76bcbcaa8bb2d10c5f');\n    test.done();\n  },\n\n  'with bundling'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'stack');\n    const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');\n\n    // WHEN\n    new AssetStaging(stack, 'Asset', {\n      sourcePath: directory,\n      bundling: {\n        image: BundlingDockerImage.fromRegistry('alpine'),\n        command: ['touch', '/asset-output/test.txt'],\n      },\n    });\n\n    // THEN\n    const assembly = app.synth();\n    test.deepEqual(fs.readdirSync(assembly.directory), [\n      'asset.2f37f937c51e2c191af66acf9b09f548926008ec68c575bd2ee54b6e997c0e00',\n      'cdk.out',\n      'manifest.json',\n      'stack.template.json',\n      'tree.json',\n    ]);\n\n    test.done();\n  },\n\n  'bundling throws when /asset-ouput is empty'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'stack');\n    const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');\n\n    // THEN\n    test.throws(() => new AssetStaging(stack, 'Asset', {\n      sourcePath: directory,\n      bundling: {\n        image: BundlingDockerImage.fromRegistry('alpine'),\n      },\n    }), /Bundling did not produce any output/);\n\n    test.done();\n  },\n\n  'bundling with BUNDLE asset hash type'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'stack');\n    const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');\n\n    // WHEN\n    const asset = new AssetStaging(stack, 'Asset', {\n      sourcePath: directory,\n      bundling: {\n        image: BundlingDockerImage.fromRegistry('alpine'),\n        command: ['touch', '/asset-output/test.txt'],\n      },\n      assetHashType: AssetHashType.BUNDLE,\n    });\n\n    test.equal(asset.assetHash, '33cbf2cae5432438e0f046bc45ba8c3cef7b6afcf47b59d1c183775c1918fb1f');\n\n    test.done();\n  },\n\n  'custom hash'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'stack');\n    const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');\n\n    // WHEN\n    const asset = new AssetStaging(stack, 'Asset', {\n      sourcePath: directory,\n      assetHash: 'my-custom-hash',\n    });\n\n    test.equal(asset.assetHash, 'my-custom-hash');\n\n    test.done();\n  },\n\n  'throws with assetHash and not CUSTOM hash type'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'stack');\n    const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');\n\n    // THEN\n    test.throws(() => new AssetStaging(stack, 'Asset', {\n      sourcePath: directory,\n      bundling: {\n        image: BundlingDockerImage.fromRegistry('alpine'),\n        command: ['touch', '/asset-output/test.txt'],\n      },\n      assetHash: 'my-custom-hash',\n      assetHashType: AssetHashType.BUNDLE,\n    }), /Cannot specify `bundle` for `assetHashType`/);\n\n    test.done();\n  },\n\n  'throws with BUNDLE hash type and no bundling'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'stack');\n    const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');\n\n    // THEN\n    test.throws(() => new AssetStaging(stack, 'Asset', {\n      sourcePath: directory,\n      assetHashType: AssetHashType.BUNDLE,\n    }), /Cannot use `AssetHashType.BUNDLE` when `bundling` is not specified/);\n\n    test.done();\n  },\n\n  'throws with CUSTOM and no hash'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'stack');\n    const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');\n\n    // THEN\n    test.throws(() => new AssetStaging(stack, 'Asset', {\n      sourcePath: directory,\n      assetHashType: AssetHashType.CUSTOM,\n    }), /`assetHash` must be specified when `assetHashType` is set to `AssetHashType.CUSTOM`/);\n\n    test.done();\n  },\n\n  'throws when bundling fails'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'stack');\n    const directory = path.join(__dirname, 'fs', 'fixtures', 'test1');\n\n    // THEN\n    test.throws(() => new AssetStaging(stack, 'Asset', {\n      sourcePath: directory,\n      bundling: {\n        image: BundlingDockerImage.fromRegistry('this-is-an-invalid-docker-image'),\n      },\n    }), /Failed to run bundling Docker image for asset stack\\/Asset/);\n\n    test.done();\n  },\n};\n"]}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc