@aws-cdk/cloud-assembly-api 0.0.1 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +202 -0
- package/README.md +15 -41
- package/design/NESTED_ASSEMBLIES.md +93 -0
- package/lib/artifacts/asset-manifest-artifact.d.ts +46 -0
- package/lib/artifacts/asset-manifest-artifact.js +66 -0
- package/lib/artifacts/cloudformation-artifact.d.ts +147 -0
- package/lib/artifacts/cloudformation-artifact.js +94 -0
- package/lib/artifacts/nested-cloud-assembly-artifact-aug.d.ts +1 -0
- package/lib/artifacts/nested-cloud-assembly-artifact-aug.js +19 -0
- package/lib/artifacts/nested-cloud-assembly-artifact.d.ts +45 -0
- package/lib/artifacts/nested-cloud-assembly-artifact.js +56 -0
- package/lib/artifacts/tree-cloud-artifact.d.ts +25 -0
- package/lib/artifacts/tree-cloud-artifact.js +49 -0
- package/lib/assets.d.ts +33 -0
- package/lib/assets.js +37 -0
- package/lib/bootstrap.d.ts +7 -0
- package/lib/bootstrap.js +12 -0
- package/lib/cloud-artifact-aug.d.ts +1 -0
- package/lib/cloud-artifact-aug.js +29 -0
- package/lib/cloud-artifact.d.ts +73 -0
- package/lib/cloud-artifact.js +94 -0
- package/lib/cloud-assembly.d.ts +266 -0
- package/lib/cloud-assembly.js +374 -0
- package/lib/context/ami.d.ts +4 -0
- package/lib/context/ami.js +3 -0
- package/lib/context/availability-zones.d.ts +12 -0
- package/lib/context/availability-zones.js +12 -0
- package/lib/context/endpoint-service-availability-zones.d.ts +22 -0
- package/lib/context/endpoint-service-availability-zones.js +5 -0
- package/lib/context/generic.d.ts +4 -0
- package/lib/context/generic.js +8 -0
- package/lib/context/key.d.ts +9 -0
- package/lib/context/key.js +3 -0
- package/lib/context/load-balancer.d.ts +63 -0
- package/lib/context/load-balancer.js +22 -0
- package/lib/context/security-group.d.ts +15 -0
- package/lib/context/security-group.js +3 -0
- package/lib/context/vpc.d.ts +152 -0
- package/lib/context/vpc.js +18 -0
- package/lib/environment.d.ts +24 -0
- package/lib/environment.js +40 -0
- package/lib/index.d.ts +21 -0
- package/lib/index.js +38 -0
- package/lib/metadata.d.ts +27 -0
- package/lib/metadata.js +14 -0
- package/lib/placeholders.d.ts +66 -0
- package/lib/placeholders.js +90 -0
- package/lib/private/error.d.ts +1 -0
- package/lib/private/error.js +47 -0
- package/lib/private/toposort.d.ts +11 -0
- package/lib/private/toposort.js +35 -0
- package/node_modules/jsonschema/.editorconfig +10 -0
- package/node_modules/jsonschema/LICENSE +21 -0
- package/node_modules/jsonschema/README.md +421 -0
- package/node_modules/jsonschema/lib/attribute.js +978 -0
- package/node_modules/jsonschema/lib/helpers.js +390 -0
- package/node_modules/jsonschema/lib/index.d.ts +142 -0
- package/node_modules/jsonschema/lib/index.js +15 -0
- package/node_modules/jsonschema/lib/scan.js +75 -0
- package/node_modules/jsonschema/lib/validator.js +336 -0
- package/node_modules/jsonschema/package.json +42 -0
- package/node_modules/semver/LICENSE +15 -0
- package/node_modules/semver/README.md +664 -0
- package/node_modules/semver/bin/semver.js +191 -0
- package/node_modules/semver/classes/comparator.js +143 -0
- package/node_modules/semver/classes/index.js +7 -0
- package/node_modules/semver/classes/range.js +557 -0
- package/node_modules/semver/classes/semver.js +333 -0
- package/node_modules/semver/functions/clean.js +8 -0
- package/node_modules/semver/functions/cmp.js +54 -0
- package/node_modules/semver/functions/coerce.js +62 -0
- package/node_modules/semver/functions/compare-build.js +9 -0
- package/node_modules/semver/functions/compare-loose.js +5 -0
- package/node_modules/semver/functions/compare.js +7 -0
- package/node_modules/semver/functions/diff.js +60 -0
- package/node_modules/semver/functions/eq.js +5 -0
- package/node_modules/semver/functions/gt.js +5 -0
- package/node_modules/semver/functions/gte.js +5 -0
- package/node_modules/semver/functions/inc.js +21 -0
- package/node_modules/semver/functions/lt.js +5 -0
- package/node_modules/semver/functions/lte.js +5 -0
- package/node_modules/semver/functions/major.js +5 -0
- package/node_modules/semver/functions/minor.js +5 -0
- package/node_modules/semver/functions/neq.js +5 -0
- package/node_modules/semver/functions/parse.js +18 -0
- package/node_modules/semver/functions/patch.js +5 -0
- package/node_modules/semver/functions/prerelease.js +8 -0
- package/node_modules/semver/functions/rcompare.js +5 -0
- package/node_modules/semver/functions/rsort.js +5 -0
- package/node_modules/semver/functions/satisfies.js +12 -0
- package/node_modules/semver/functions/sort.js +5 -0
- package/node_modules/semver/functions/valid.js +8 -0
- package/node_modules/semver/index.js +91 -0
- package/node_modules/semver/internal/constants.js +37 -0
- package/node_modules/semver/internal/debug.js +11 -0
- package/node_modules/semver/internal/identifiers.js +29 -0
- package/node_modules/semver/internal/lrucache.js +42 -0
- package/node_modules/semver/internal/parse-options.js +17 -0
- package/node_modules/semver/internal/re.js +223 -0
- package/node_modules/semver/package.json +78 -0
- package/node_modules/semver/preload.js +4 -0
- package/node_modules/semver/range.bnf +16 -0
- package/node_modules/semver/ranges/gtr.js +6 -0
- package/node_modules/semver/ranges/intersects.js +9 -0
- package/node_modules/semver/ranges/ltr.js +6 -0
- package/node_modules/semver/ranges/max-satisfying.js +27 -0
- package/node_modules/semver/ranges/min-satisfying.js +26 -0
- package/node_modules/semver/ranges/min-version.js +63 -0
- package/node_modules/semver/ranges/outside.js +82 -0
- package/node_modules/semver/ranges/simplify.js +49 -0
- package/node_modules/semver/ranges/subset.js +249 -0
- package/node_modules/semver/ranges/to-comparators.js +10 -0
- package/node_modules/semver/ranges/valid.js +13 -0
- package/package.json +80 -6
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CloudFormationStackArtifact = void 0;
|
|
4
|
+
const fs = require("fs");
|
|
5
|
+
const path = require("path");
|
|
6
|
+
const cxschema = require("@aws-cdk/cloud-assembly-schema");
|
|
7
|
+
const cloud_artifact_1 = require("../cloud-artifact");
|
|
8
|
+
const environment_1 = require("../environment");
|
|
9
|
+
const error_1 = require("../private/error");
|
|
10
|
+
const CLOUDFORMATION_STACK_ARTIFACT_SYM = Symbol.for('@aws-cdk/cx-api.CloudFormationStackArtifact');
|
|
11
|
+
class CloudFormationStackArtifact extends cloud_artifact_1.CloudArtifact {
|
|
12
|
+
/**
|
|
13
|
+
* Checks if `art` is an instance of this class.
|
|
14
|
+
*
|
|
15
|
+
* Use this method instead of `instanceof` to properly detect `CloudFormationStackArtifact`
|
|
16
|
+
* instances, even when the construct library is symlinked.
|
|
17
|
+
*
|
|
18
|
+
* Explanation: in JavaScript, multiple copies of the `cx-api` library on
|
|
19
|
+
* disk are seen as independent, completely different libraries. As a
|
|
20
|
+
* consequence, the class `CloudFormationStackArtifact` in each copy of the `cx-api` library
|
|
21
|
+
* is seen as a different class, and an instance of one class will not test as
|
|
22
|
+
* `instanceof` the other class. `npm install` will not create installations
|
|
23
|
+
* like this, but users may manually symlink construct libraries together or
|
|
24
|
+
* use a monorepo tool: in those cases, multiple copies of the `cx-api`
|
|
25
|
+
* library can be accidentally installed, and `instanceof` will behave
|
|
26
|
+
* unpredictably. It is safest to avoid using `instanceof`, and using
|
|
27
|
+
* this type-testing method instead.
|
|
28
|
+
*/
|
|
29
|
+
static isCloudFormationStackArtifact(art) {
|
|
30
|
+
return art && typeof art === 'object' && CLOUDFORMATION_STACK_ARTIFACT_SYM in art;
|
|
31
|
+
}
|
|
32
|
+
constructor(assembly, artifactId, artifact) {
|
|
33
|
+
super(assembly, artifactId, artifact);
|
|
34
|
+
const properties = (this.manifest.properties || {});
|
|
35
|
+
if (!properties.templateFile) {
|
|
36
|
+
throw new error_1.CloudAssemblyError('Invalid CloudFormation stack artifact. Missing "templateFile" property in cloud assembly manifest');
|
|
37
|
+
}
|
|
38
|
+
if (!artifact.environment) {
|
|
39
|
+
throw new error_1.CloudAssemblyError('Invalid CloudFormation stack artifact. Missing environment');
|
|
40
|
+
}
|
|
41
|
+
this.environment = environment_1.EnvironmentUtils.parse(artifact.environment);
|
|
42
|
+
this.templateFile = properties.templateFile;
|
|
43
|
+
this.parameters = properties.parameters ?? {};
|
|
44
|
+
// We get the tags from 'properties' if available (cloud assembly format >= 6.0.0), otherwise
|
|
45
|
+
// from the stack metadata
|
|
46
|
+
this.tags = properties.tags ?? {};
|
|
47
|
+
this.notificationArns = properties.notificationArns;
|
|
48
|
+
this.assumeRoleArn = properties.assumeRoleArn;
|
|
49
|
+
this.assumeRoleExternalId = properties.assumeRoleExternalId;
|
|
50
|
+
this.assumeRoleAdditionalOptions = properties.assumeRoleAdditionalOptions;
|
|
51
|
+
this.cloudFormationExecutionRoleArn = properties.cloudFormationExecutionRoleArn;
|
|
52
|
+
this.stackTemplateAssetObjectUrl = properties.stackTemplateAssetObjectUrl;
|
|
53
|
+
this.requiresBootstrapStackVersion = properties.requiresBootstrapStackVersion;
|
|
54
|
+
this.bootstrapStackVersionSsmParameter = properties.bootstrapStackVersionSsmParameter;
|
|
55
|
+
this.terminationProtection = properties.terminationProtection;
|
|
56
|
+
this.validateOnSynth = properties.validateOnSynth;
|
|
57
|
+
this.lookupRole = properties.lookupRole;
|
|
58
|
+
this.stackName = properties.stackName || artifactId;
|
|
59
|
+
this.assets = this.findMetadataByType(cxschema.ArtifactMetadataEntryType.ASSET).map(e => e.data);
|
|
60
|
+
this.displayName = this.stackName === artifactId
|
|
61
|
+
? this.hierarchicalId
|
|
62
|
+
: `${this.hierarchicalId} (${this.stackName})`;
|
|
63
|
+
this.name = this.stackName; // backwards compat
|
|
64
|
+
this.originalName = this.stackName;
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Full path to the template file
|
|
68
|
+
*/
|
|
69
|
+
get templateFullPath() {
|
|
70
|
+
return path.join(this.assembly.directory, this.templateFile);
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* The CloudFormation template for this stack.
|
|
74
|
+
*/
|
|
75
|
+
get template() {
|
|
76
|
+
if (this._template === undefined) {
|
|
77
|
+
this._template = JSON.parse(fs.readFileSync(this.templateFullPath, 'utf-8'));
|
|
78
|
+
}
|
|
79
|
+
return this._template;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
exports.CloudFormationStackArtifact = CloudFormationStackArtifact;
|
|
83
|
+
/**
|
|
84
|
+
* Mark all instances of 'CloudFormationStackArtifact'
|
|
85
|
+
*
|
|
86
|
+
* Why not put this in the constructor? Because this is a class property,
|
|
87
|
+
* not an instance property. It applies to all instances of the class.
|
|
88
|
+
*/
|
|
89
|
+
Object.defineProperty(CloudFormationStackArtifact.prototype, CLOUDFORMATION_STACK_ARTIFACT_SYM, {
|
|
90
|
+
value: true,
|
|
91
|
+
enumerable: false,
|
|
92
|
+
writable: false,
|
|
93
|
+
});
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloudformation-artifact.js","sourceRoot":"","sources":["cloudformation-artifact.ts"],"names":[],"mappings":";;;AAAA,yBAAyB;AACzB,6BAA6B;AAC7B,2DAA2D;AAC3D,sDAAkD;AAGlD,gDAAkD;AAClD,4CAAsD;AACtD,MAAM,iCAAiC,GAAG,MAAM,CAAC,GAAG,CAAC,6CAA6C,CAAC,CAAC;AAEpG,MAAa,2BAA4B,SAAQ,8BAAa;IAC5D;;;;;;;;;;;;;;;;OAgBG;IACI,MAAM,CAAC,6BAA6B,CAAC,GAAQ;QAClD,OAAO,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,iCAAiC,IAAI,GAAG,CAAC;IACpF,CAAC;IAmID,YAAY,QAAuB,EAAE,UAAkB,EAAE,QAAmC;QAC1F,KAAK,CAAC,QAAQ,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;QAEtC,MAAM,UAAU,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,IAAI,EAAE,CAA8C,CAAC;QACjG,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC;YAC7B,MAAM,IAAI,0BAAkB,CAAC,mGAAmG,CAAC,CAAC;QACpI,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;YAC1B,MAAM,IAAI,0BAAkB,CAAC,4DAA4D,CAAC,CAAC;QAC7F,CAAC;QACD,IAAI,CAAC,WAAW,GAAG,8BAAgB,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;QAChE,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,YAAY,CAAC;QAC5C,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,UAAU,IAAI,EAAE,CAAC;QAE9C,6FAA6F;QAC7F,0BAA0B;QAC1B,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,IAAI,EAAE,CAAC;QAClC,IAAI,CAAC,gBAAgB,GAAG,UAAU,CAAC,gBAAgB,CAAC;QACpD,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC,aAAa,CAAC;QAC9C,IAAI,CAAC,oBAAoB,GAAG,UAAU,CAAC,oBAAoB,CAAC;QAC5D,IAAI,CAAC,2BAA2B,GAAG,UAAU,CAAC,2BAA2B,CAAC;QAC1E,IAAI,CAAC,8BAA8B,GAAG,UAAU,CAAC,8BAA8B,CAAC;QAChF,IAAI,CAAC,2BAA2B,GAAG,UAAU,CAAC,2BAA2B,CAAC;QAC1E,IAAI,CAAC,6BAA6B,GAAG,UAAU,CAAC,6BAA6B,CAAC;QAC9E,IAAI,CAAC,iCAAiC,GAAG,UAAU,CAAC,iCAAiC,CAAC;QACtF,IAAI,CAAC,qBAAqB,GAAG,UAAU,CAAC,qBAAqB,CAAC;QAC9D,IAAI,CAAC,eAAe,GAAG,UAAU,CAAC,eAAe,CAAC;QAClD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC;QAExC,IAAI,CAAC,SAAS,GAAG,UAAU,CAAC,SAAS,IAAI,UAAU,CAAC;QACpD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,yBAAyB,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAmC,CAAC,CAAC;QAEhI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,KAAK,UAAU;YAC9C,CAAC,CAAC,IAAI,CAAC,cAAc;YACrB,CAAC,CAAC,GAAG,IAAI,CAAC,cAAc,KAAK,IAAI,CAAC,SAAS,GAAG,CAAC;QAEjD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,mBAAmB;QAC/C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC;IACrC,CAAC;IAED;;OAEG;IACH,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IAC/D,CAAC;IAED;;OAEG;IACH,IAAW,QAAQ;QACjB,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YACjC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAC,CAAC;QAC/E,CAAC;QACD,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;CACF;AA/MD,kEA+MC;AAED;;;;;GAKG;AACH,MAAM,CAAC,cAAc,CAAC,2BAA2B,CAAC,SAAS,EAAE,iCAAiC,EAAE;IAC9F,KAAK,EAAE,IAAI;IACX,UAAU,EAAE,KAAK;IACjB,QAAQ,EAAE,KAAK;CAChB,CAAC,CAAC","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { CloudArtifact } from '../cloud-artifact';\nimport type { CloudAssembly } from '../cloud-assembly';\nimport type { Environment } from '../environment';\nimport { EnvironmentUtils } from '../environment';\nimport { CloudAssemblyError } from '../private/error';\nconst CLOUDFORMATION_STACK_ARTIFACT_SYM = Symbol.for('@aws-cdk/cx-api.CloudFormationStackArtifact');\n\nexport class CloudFormationStackArtifact extends CloudArtifact {\n  /**\n   * Checks if `art` is an instance of this class.\n   *\n   * Use this method instead of `instanceof` to properly detect `CloudFormationStackArtifact`\n   * instances, even when the construct library is symlinked.\n   *\n   * Explanation: in JavaScript, multiple copies of the `cx-api` library on\n   * disk are seen as independent, completely different libraries. As a\n   * consequence, the class `CloudFormationStackArtifact` in each copy of the `cx-api` library\n   * is seen as a different class, and an instance of one class will not test as\n   * `instanceof` the other class. `npm install` will not create installations\n   * like this, but users may manually symlink construct libraries together or\n   * use a monorepo tool: in those cases, multiple copies of the `cx-api`\n   * library can be accidentally installed, and `instanceof` will behave\n   * unpredictably. It is safest to avoid using `instanceof`, and using\n   * this type-testing method instead.\n   */\n  public static isCloudFormationStackArtifact(art: any): art is CloudFormationStackArtifact {\n    return art && typeof art === 'object' && CLOUDFORMATION_STACK_ARTIFACT_SYM in art;\n  }\n\n  /**\n   * The file name of the template.\n   */\n  public readonly templateFile: string;\n\n  /**\n   * The original name as defined in the CDK app.\n   */\n  public readonly originalName: string;\n\n  /**\n   * Any assets associated with this stack.\n   */\n  public readonly assets: cxschema.AssetMetadataEntry[];\n\n  /**\n   * CloudFormation parameters to pass to the stack.\n   */\n  public readonly parameters: { [id: string]: string };\n\n  /**\n   * CloudFormation tags to pass to the stack.\n   */\n  public readonly tags: { [id: string]: string };\n\n  /**\n   * SNS Topics that will receive stack events.\n   */\n  public readonly notificationArns?: string[];\n\n  /**\n   * The physical name of this stack.\n   */\n  public readonly stackName: string;\n\n  /**\n   * A string that represents this stack. Should only be used in user\n   * interfaces. If the stackName has not been set explicitly, or has been set\n   * to artifactId, it will return the hierarchicalId of the stack. Otherwise,\n   * it will return something like \"<hierarchicalId> (<stackName>)\"\n   */\n  public readonly displayName: string;\n\n  /**\n   * The physical name of this stack.\n   * @deprecated renamed to `stackName`\n   */\n  public readonly name: string;\n\n  /**\n   * The environment into which to deploy this artifact.\n   */\n  public readonly environment: Environment;\n\n  /**\n   * The role that needs to be assumed to deploy the stack\n   *\n   * @default - No role is assumed (current credentials are used)\n   */\n  public readonly assumeRoleArn?: string;\n\n  /**\n   * External ID to use when assuming role for cloudformation deployments\n   *\n   * @default - No external ID\n   */\n  readonly assumeRoleExternalId?: string;\n\n  /**\n   * Additional options to pass to STS when assuming the role for cloudformation deployments.\n   *\n   * - `RoleArn` should not be used. Use the dedicated `assumeRoleArn` property instead.\n   * - `ExternalId` should not be used. Use the dedicated `assumeRoleExternalId` instead.\n   * - `TransitiveTagKeys` defaults to use all keys (if any) specified in `Tags`. E.g, all tags are transitive by default.\n   *\n   * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property\n   * @default - No additional options.\n   */\n  readonly assumeRoleAdditionalOptions?: { [key: string]: any };\n\n  /**\n   * The role that is passed to CloudFormation to execute the change set\n   *\n   * @default - No role is passed (currently assumed role/credentials are used)\n   */\n  public readonly cloudFormationExecutionRoleArn?: string;\n\n  /**\n   * The role to use to look up values from the target AWS account\n   *\n   * @default - No role is assumed (current credentials are used)\n   */\n  public readonly lookupRole?: cxschema.BootstrapRole;\n\n  /**\n   * If the stack template has already been included in the asset manifest, its asset URL\n   *\n   * @default - Not uploaded yet, upload just before deploying\n   */\n  public readonly stackTemplateAssetObjectUrl?: string;\n\n  /**\n   * Version of bootstrap stack required to deploy this stack\n   *\n   * @default - No bootstrap stack required\n   */\n  public readonly requiresBootstrapStackVersion?: number;\n\n  /**\n   * Name of SSM parameter with bootstrap stack version\n   *\n   * @default - Discover SSM parameter by reading stack\n   */\n  public readonly bootstrapStackVersionSsmParameter?: string;\n\n  /**\n   * Whether termination protection is enabled for this stack.\n   */\n  public readonly terminationProtection?: boolean;\n\n  /**\n   * Whether this stack should be validated by the CLI after synthesis\n   *\n   * @default - false\n   */\n  public readonly validateOnSynth?: boolean;\n\n  private _template: any | undefined;\n\n  constructor(assembly: CloudAssembly, artifactId: string, artifact: cxschema.ArtifactManifest) {\n    super(assembly, artifactId, artifact);\n\n    const properties = (this.manifest.properties || {}) as cxschema.AwsCloudFormationStackProperties;\n    if (!properties.templateFile) {\n      throw new CloudAssemblyError('Invalid CloudFormation stack artifact. Missing \"templateFile\" property in cloud assembly manifest');\n    }\n    if (!artifact.environment) {\n      throw new CloudAssemblyError('Invalid CloudFormation stack artifact. Missing environment');\n    }\n    this.environment = EnvironmentUtils.parse(artifact.environment);\n    this.templateFile = properties.templateFile;\n    this.parameters = properties.parameters ?? {};\n\n    // We get the tags from 'properties' if available (cloud assembly format >= 6.0.0), otherwise\n    // from the stack metadata\n    this.tags = properties.tags ?? {};\n    this.notificationArns = properties.notificationArns;\n    this.assumeRoleArn = properties.assumeRoleArn;\n    this.assumeRoleExternalId = properties.assumeRoleExternalId;\n    this.assumeRoleAdditionalOptions = properties.assumeRoleAdditionalOptions;\n    this.cloudFormationExecutionRoleArn = properties.cloudFormationExecutionRoleArn;\n    this.stackTemplateAssetObjectUrl = properties.stackTemplateAssetObjectUrl;\n    this.requiresBootstrapStackVersion = properties.requiresBootstrapStackVersion;\n    this.bootstrapStackVersionSsmParameter = properties.bootstrapStackVersionSsmParameter;\n    this.terminationProtection = properties.terminationProtection;\n    this.validateOnSynth = properties.validateOnSynth;\n    this.lookupRole = properties.lookupRole;\n\n    this.stackName = properties.stackName || artifactId;\n    this.assets = this.findMetadataByType(cxschema.ArtifactMetadataEntryType.ASSET).map(e => e.data as cxschema.AssetMetadataEntry);\n\n    this.displayName = this.stackName === artifactId\n      ? this.hierarchicalId\n      : `${this.hierarchicalId} (${this.stackName})`;\n\n    this.name = this.stackName; // backwards compat\n    this.originalName = this.stackName;\n  }\n\n  /**\n   * Full path to the template file\n   */\n  public get templateFullPath() {\n    return path.join(this.assembly.directory, this.templateFile);\n  }\n\n  /**\n   * The CloudFormation template for this stack.\n   */\n  public get template(): any {\n    if (this._template === undefined) {\n      this._template = JSON.parse(fs.readFileSync(this.templateFullPath, 'utf-8'));\n    }\n    return this._template;\n  }\n}\n\n/**\n * Mark all instances of 'CloudFormationStackArtifact'\n *\n * Why not put this in the constructor? Because this is a class property,\n * not an instance property. It applies to all instances of the class.\n */\nObject.defineProperty(CloudFormationStackArtifact.prototype, CLOUDFORMATION_STACK_ARTIFACT_SYM, {\n  value: true,\n  enumerable: false,\n  writable: false,\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const nested_cloud_assembly_artifact_1 = require("./nested-cloud-assembly-artifact");
|
|
4
|
+
const cloud_assembly_1 = require("../cloud-assembly");
|
|
5
|
+
const cacheSym = Symbol();
|
|
6
|
+
/**
|
|
7
|
+
* The nested Assembly
|
|
8
|
+
*
|
|
9
|
+
* Declared in a different file to break circular dep between CloudAssembly and NestedCloudAssemblyArtifact
|
|
10
|
+
*/
|
|
11
|
+
Object.defineProperty(nested_cloud_assembly_artifact_1.NestedCloudAssemblyArtifact.prototype, 'nestedAssembly', {
|
|
12
|
+
get() {
|
|
13
|
+
if (!this[cacheSym]) {
|
|
14
|
+
this[cacheSym] = new cloud_assembly_1.CloudAssembly(this.fullPath);
|
|
15
|
+
}
|
|
16
|
+
return this[cacheSym];
|
|
17
|
+
},
|
|
18
|
+
});
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmVzdGVkLWNsb3VkLWFzc2VtYmx5LWFydGlmYWN0LWF1Zy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIm5lc3RlZC1jbG91ZC1hc3NlbWJseS1hcnRpZmFjdC1hdWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxxRkFBK0U7QUFDL0Usc0RBQWtEO0FBRWxELE1BQU0sUUFBUSxHQUFHLE1BQU0sRUFBRSxDQUFDO0FBRTFCOzs7O0dBSUc7QUFDSCxNQUFNLENBQUMsY0FBYyxDQUFDLDREQUEyQixDQUFDLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtJQUM3RSxHQUFHO1FBQ0QsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1lBQ3BCLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxJQUFJLDhCQUFhLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ3BELENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUN4QixDQUFDO0NBQ0YsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmVzdGVkQ2xvdWRBc3NlbWJseUFydGlmYWN0IH0gZnJvbSAnLi9uZXN0ZWQtY2xvdWQtYXNzZW1ibHktYXJ0aWZhY3QnO1xuaW1wb3J0IHsgQ2xvdWRBc3NlbWJseSB9IGZyb20gJy4uL2Nsb3VkLWFzc2VtYmx5JztcblxuY29uc3QgY2FjaGVTeW0gPSBTeW1ib2woKTtcblxuLyoqXG4gKiBUaGUgbmVzdGVkIEFzc2VtYmx5XG4gKlxuICogRGVjbGFyZWQgaW4gYSBkaWZmZXJlbnQgZmlsZSB0byBicmVhayBjaXJjdWxhciBkZXAgYmV0d2VlbiBDbG91ZEFzc2VtYmx5IGFuZCBOZXN0ZWRDbG91ZEFzc2VtYmx5QXJ0aWZhY3RcbiAqL1xuT2JqZWN0LmRlZmluZVByb3BlcnR5KE5lc3RlZENsb3VkQXNzZW1ibHlBcnRpZmFjdC5wcm90b3R5cGUsICduZXN0ZWRBc3NlbWJseScsIHtcbiAgZ2V0KCkge1xuICAgIGlmICghdGhpc1tjYWNoZVN5bV0pIHtcbiAgICAgIHRoaXNbY2FjaGVTeW1dID0gbmV3IENsb3VkQXNzZW1ibHkodGhpcy5mdWxsUGF0aCk7XG4gICAgfVxuICAgIHJldHVybiB0aGlzW2NhY2hlU3ltXTtcbiAgfSxcbn0pO1xuIl19
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import type * as cxschema from '@aws-cdk/cloud-assembly-schema';
|
|
2
|
+
import { CloudArtifact } from '../cloud-artifact';
|
|
3
|
+
import type { CloudAssembly } from '../cloud-assembly';
|
|
4
|
+
/**
|
|
5
|
+
* Asset manifest is a description of a set of assets which need to be built and published
|
|
6
|
+
*/
|
|
7
|
+
export declare class NestedCloudAssemblyArtifact extends CloudArtifact {
|
|
8
|
+
/**
|
|
9
|
+
* Checks if `art` is an instance of this class.
|
|
10
|
+
*
|
|
11
|
+
* Use this method instead of `instanceof` to properly detect `NestedCloudAssemblyArtifact`
|
|
12
|
+
* instances, even when the construct library is symlinked.
|
|
13
|
+
*
|
|
14
|
+
* Explanation: in JavaScript, multiple copies of the `cx-api` library on
|
|
15
|
+
* disk are seen as independent, completely different libraries. As a
|
|
16
|
+
* consequence, the class `NestedCloudAssemblyArtifact` in each copy of the `cx-api` library
|
|
17
|
+
* is seen as a different class, and an instance of one class will not test as
|
|
18
|
+
* `instanceof` the other class. `npm install` will not create installations
|
|
19
|
+
* like this, but users may manually symlink construct libraries together or
|
|
20
|
+
* use a monorepo tool: in those cases, multiple copies of the `cx-api`
|
|
21
|
+
* library can be accidentally installed, and `instanceof` will behave
|
|
22
|
+
* unpredictably. It is safest to avoid using `instanceof`, and using
|
|
23
|
+
* this type-testing method instead.
|
|
24
|
+
*/
|
|
25
|
+
static isNestedCloudAssemblyArtifact(art: any): art is NestedCloudAssemblyArtifact;
|
|
26
|
+
/**
|
|
27
|
+
* The relative directory name of the asset manifest
|
|
28
|
+
*/
|
|
29
|
+
readonly directoryName: string;
|
|
30
|
+
/**
|
|
31
|
+
* Display name
|
|
32
|
+
*/
|
|
33
|
+
readonly displayName: string;
|
|
34
|
+
constructor(assembly: CloudAssembly, name: string, artifact: cxschema.ArtifactManifest);
|
|
35
|
+
/**
|
|
36
|
+
* Full path to the nested assembly directory
|
|
37
|
+
*/
|
|
38
|
+
get fullPath(): string;
|
|
39
|
+
}
|
|
40
|
+
export interface NestedCloudAssemblyArtifact {
|
|
41
|
+
/**
|
|
42
|
+
* The nested Assembly
|
|
43
|
+
*/
|
|
44
|
+
readonly nestedAssembly: CloudAssembly;
|
|
45
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NestedCloudAssemblyArtifact = void 0;
|
|
4
|
+
const path = require("path");
|
|
5
|
+
const cloud_artifact_1 = require("../cloud-artifact");
|
|
6
|
+
const NESTED_CLOUD_ASSEMBLY_SYM = Symbol.for('@aws-cdk/cx-api.NestedCloudAssemblyArtifact');
|
|
7
|
+
/**
|
|
8
|
+
* Asset manifest is a description of a set of assets which need to be built and published
|
|
9
|
+
*/
|
|
10
|
+
class NestedCloudAssemblyArtifact extends cloud_artifact_1.CloudArtifact {
|
|
11
|
+
/**
|
|
12
|
+
* Checks if `art` is an instance of this class.
|
|
13
|
+
*
|
|
14
|
+
* Use this method instead of `instanceof` to properly detect `NestedCloudAssemblyArtifact`
|
|
15
|
+
* instances, even when the construct library is symlinked.
|
|
16
|
+
*
|
|
17
|
+
* Explanation: in JavaScript, multiple copies of the `cx-api` library on
|
|
18
|
+
* disk are seen as independent, completely different libraries. As a
|
|
19
|
+
* consequence, the class `NestedCloudAssemblyArtifact` in each copy of the `cx-api` library
|
|
20
|
+
* is seen as a different class, and an instance of one class will not test as
|
|
21
|
+
* `instanceof` the other class. `npm install` will not create installations
|
|
22
|
+
* like this, but users may manually symlink construct libraries together or
|
|
23
|
+
* use a monorepo tool: in those cases, multiple copies of the `cx-api`
|
|
24
|
+
* library can be accidentally installed, and `instanceof` will behave
|
|
25
|
+
* unpredictably. It is safest to avoid using `instanceof`, and using
|
|
26
|
+
* this type-testing method instead.
|
|
27
|
+
*/
|
|
28
|
+
static isNestedCloudAssemblyArtifact(art) {
|
|
29
|
+
return art && typeof art === 'object' && NESTED_CLOUD_ASSEMBLY_SYM in art;
|
|
30
|
+
}
|
|
31
|
+
constructor(assembly, name, artifact) {
|
|
32
|
+
super(assembly, name, artifact);
|
|
33
|
+
const properties = (this.manifest.properties || {});
|
|
34
|
+
this.directoryName = properties.directoryName;
|
|
35
|
+
this.displayName = properties.displayName ?? name;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Full path to the nested assembly directory
|
|
39
|
+
*/
|
|
40
|
+
get fullPath() {
|
|
41
|
+
return path.join(this.assembly.directory, this.directoryName);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
exports.NestedCloudAssemblyArtifact = NestedCloudAssemblyArtifact;
|
|
45
|
+
/**
|
|
46
|
+
* Mark all instances of 'NestedCloudAssemblyArtifact'
|
|
47
|
+
*
|
|
48
|
+
* Why not put this in the constructor? Because this is a class property,
|
|
49
|
+
* not an instance property. It applies to all instances of the class.
|
|
50
|
+
*/
|
|
51
|
+
Object.defineProperty(NestedCloudAssemblyArtifact.prototype, NESTED_CLOUD_ASSEMBLY_SYM, {
|
|
52
|
+
value: true,
|
|
53
|
+
enumerable: false,
|
|
54
|
+
writable: false,
|
|
55
|
+
});
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmVzdGVkLWNsb3VkLWFzc2VtYmx5LWFydGlmYWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibmVzdGVkLWNsb3VkLWFzc2VtYmx5LWFydGlmYWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZCQUE2QjtBQUU3QixzREFBa0Q7QUFHbEQsTUFBTSx5QkFBeUIsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLDZDQUE2QyxDQUFDLENBQUM7QUFFNUY7O0dBRUc7QUFDSCxNQUFhLDJCQUE0QixTQUFRLDhCQUFhO0lBQzVEOzs7Ozs7Ozs7Ozs7Ozs7O09BZ0JHO0lBQ0ksTUFBTSxDQUFDLDZCQUE2QixDQUFDLEdBQVE7UUFDbEQsT0FBTyxHQUFHLElBQUksT0FBTyxHQUFHLEtBQUssUUFBUSxJQUFJLHlCQUF5QixJQUFJLEdBQUcsQ0FBQztJQUM1RSxDQUFDO0lBWUQsWUFBWSxRQUF1QixFQUFFLElBQVksRUFBRSxRQUFtQztRQUNwRixLQUFLLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQztRQUVoQyxNQUFNLFVBQVUsR0FBRyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsVUFBVSxJQUFJLEVBQUUsQ0FBMkMsQ0FBQztRQUM5RixJQUFJLENBQUMsYUFBYSxHQUFHLFVBQVUsQ0FBQyxhQUFhLENBQUM7UUFDOUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxVQUFVLENBQUMsV0FBVyxJQUFJLElBQUksQ0FBQztJQUNwRCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLFFBQVE7UUFDakIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUNoRSxDQUFDO0NBQ0Y7QUE5Q0Qsa0VBOENDO0FBV0Q7Ozs7O0dBS0c7QUFDSCxNQUFNLENBQUMsY0FBYyxDQUFDLDJCQUEyQixDQUFDLFNBQVMsRUFBRSx5QkFBeUIsRUFBRTtJQUN0RixLQUFLLEVBQUUsSUFBSTtJQUNYLFVBQVUsRUFBRSxLQUFLO0lBQ2pCLFFBQVEsRUFBRSxLQUFLO0NBQ2hCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgdHlwZSAqIGFzIGN4c2NoZW1hIGZyb20gJ0Bhd3MtY2RrL2Nsb3VkLWFzc2VtYmx5LXNjaGVtYSc7XG5pbXBvcnQgeyBDbG91ZEFydGlmYWN0IH0gZnJvbSAnLi4vY2xvdWQtYXJ0aWZhY3QnO1xuaW1wb3J0IHR5cGUgeyBDbG91ZEFzc2VtYmx5IH0gZnJvbSAnLi4vY2xvdWQtYXNzZW1ibHknO1xuXG5jb25zdCBORVNURURfQ0xPVURfQVNTRU1CTFlfU1lNID0gU3ltYm9sLmZvcignQGF3cy1jZGsvY3gtYXBpLk5lc3RlZENsb3VkQXNzZW1ibHlBcnRpZmFjdCcpO1xuXG4vKipcbiAqIEFzc2V0IG1hbmlmZXN0IGlzIGEgZGVzY3JpcHRpb24gb2YgYSBzZXQgb2YgYXNzZXRzIHdoaWNoIG5lZWQgdG8gYmUgYnVpbHQgYW5kIHB1Ymxpc2hlZFxuICovXG5leHBvcnQgY2xhc3MgTmVzdGVkQ2xvdWRBc3NlbWJseUFydGlmYWN0IGV4dGVuZHMgQ2xvdWRBcnRpZmFjdCB7XG4gIC8qKlxuICAgKiBDaGVja3MgaWYgYGFydGAgaXMgYW4gaW5zdGFuY2Ugb2YgdGhpcyBjbGFzcy5cbiAgICpcbiAgICogVXNlIHRoaXMgbWV0aG9kIGluc3RlYWQgb2YgYGluc3RhbmNlb2ZgIHRvIHByb3Blcmx5IGRldGVjdCBgTmVzdGVkQ2xvdWRBc3NlbWJseUFydGlmYWN0YFxuICAgKiBpbnN0YW5jZXMsIGV2ZW4gd2hlbiB0aGUgY29uc3RydWN0IGxpYnJhcnkgaXMgc3ltbGlua2VkLlxuICAgKlxuICAgKiBFeHBsYW5hdGlvbjogaW4gSmF2YVNjcmlwdCwgbXVsdGlwbGUgY29waWVzIG9mIHRoZSBgY3gtYXBpYCBsaWJyYXJ5IG9uXG4gICAqIGRpc2sgYXJlIHNlZW4gYXMgaW5kZXBlbmRlbnQsIGNvbXBsZXRlbHkgZGlmZmVyZW50IGxpYnJhcmllcy4gQXMgYVxuICAgKiBjb25zZXF1ZW5jZSwgdGhlIGNsYXNzIGBOZXN0ZWRDbG91ZEFzc2VtYmx5QXJ0aWZhY3RgIGluIGVhY2ggY29weSBvZiB0aGUgYGN4LWFwaWAgbGlicmFyeVxuICAgKiBpcyBzZWVuIGFzIGEgZGlmZmVyZW50IGNsYXNzLCBhbmQgYW4gaW5zdGFuY2Ugb2Ygb25lIGNsYXNzIHdpbGwgbm90IHRlc3QgYXNcbiAgICogYGluc3RhbmNlb2ZgIHRoZSBvdGhlciBjbGFzcy4gYG5wbSBpbnN0YWxsYCB3aWxsIG5vdCBjcmVhdGUgaW5zdGFsbGF0aW9uc1xuICAgKiBsaWtlIHRoaXMsIGJ1dCB1c2VycyBtYXkgbWFudWFsbHkgc3ltbGluayBjb25zdHJ1Y3QgbGlicmFyaWVzIHRvZ2V0aGVyIG9yXG4gICAqIHVzZSBhIG1vbm9yZXBvIHRvb2w6IGluIHRob3NlIGNhc2VzLCBtdWx0aXBsZSBjb3BpZXMgb2YgdGhlIGBjeC1hcGlgXG4gICAqIGxpYnJhcnkgY2FuIGJlIGFjY2lkZW50YWxseSBpbnN0YWxsZWQsIGFuZCBgaW5zdGFuY2VvZmAgd2lsbCBiZWhhdmVcbiAgICogdW5wcmVkaWN0YWJseS4gSXQgaXMgc2FmZXN0IHRvIGF2b2lkIHVzaW5nIGBpbnN0YW5jZW9mYCwgYW5kIHVzaW5nXG4gICAqIHRoaXMgdHlwZS10ZXN0aW5nIG1ldGhvZCBpbnN0ZWFkLlxuICAgKi9cbiAgcHVibGljIHN0YXRpYyBpc05lc3RlZENsb3VkQXNzZW1ibHlBcnRpZmFjdChhcnQ6IGFueSk6IGFydCBpcyBOZXN0ZWRDbG91ZEFzc2VtYmx5QXJ0aWZhY3Qge1xuICAgIHJldHVybiBhcnQgJiYgdHlwZW9mIGFydCA9PT0gJ29iamVjdCcgJiYgTkVTVEVEX0NMT1VEX0FTU0VNQkxZX1NZTSBpbiBhcnQ7XG4gIH1cblxuICAvKipcbiAgICogVGhlIHJlbGF0aXZlIGRpcmVjdG9yeSBuYW1lIG9mIHRoZSBhc3NldCBtYW5pZmVzdFxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IGRpcmVjdG9yeU5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogRGlzcGxheSBuYW1lXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgZGlzcGxheU5hbWU6IHN0cmluZztcblxuICBjb25zdHJ1Y3Rvcihhc3NlbWJseTogQ2xvdWRBc3NlbWJseSwgbmFtZTogc3RyaW5nLCBhcnRpZmFjdDogY3hzY2hlbWEuQXJ0aWZhY3RNYW5pZmVzdCkge1xuICAgIHN1cGVyKGFzc2VtYmx5LCBuYW1lLCBhcnRpZmFjdCk7XG5cbiAgICBjb25zdCBwcm9wZXJ0aWVzID0gKHRoaXMubWFuaWZlc3QucHJvcGVydGllcyB8fCB7fSkgYXMgY3hzY2hlbWEuTmVzdGVkQ2xvdWRBc3NlbWJseVByb3BlcnRpZXM7XG4gICAgdGhpcy5kaXJlY3RvcnlOYW1lID0gcHJvcGVydGllcy5kaXJlY3RvcnlOYW1lO1xuICAgIHRoaXMuZGlzcGxheU5hbWUgPSBwcm9wZXJ0aWVzLmRpc3BsYXlOYW1lID8/IG5hbWU7XG4gIH1cblxuICAvKipcbiAgICogRnVsbCBwYXRoIHRvIHRoZSBuZXN0ZWQgYXNzZW1ibHkgZGlyZWN0b3J5XG4gICAqL1xuICBwdWJsaWMgZ2V0IGZ1bGxQYXRoKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHBhdGguam9pbih0aGlzLmFzc2VtYmx5LmRpcmVjdG9yeSwgdGhpcy5kaXJlY3RvcnlOYW1lKTtcbiAgfVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIE5lc3RlZENsb3VkQXNzZW1ibHlBcnRpZmFjdCB7XG4gIC8qKlxuICAgKiBUaGUgbmVzdGVkIEFzc2VtYmx5XG4gICAqL1xuICByZWFkb25seSBuZXN0ZWRBc3NlbWJseTogQ2xvdWRBc3NlbWJseTtcblxuICAvLyBEZWNsYXJlZCBpbiBhIGRpZmZlcmVudCBmaWxlXG59XG5cbi8qKlxuICogTWFyayBhbGwgaW5zdGFuY2VzIG9mICdOZXN0ZWRDbG91ZEFzc2VtYmx5QXJ0aWZhY3QnXG4gKlxuICogV2h5IG5vdCBwdXQgdGhpcyBpbiB0aGUgY29uc3RydWN0b3I/IEJlY2F1c2UgdGhpcyBpcyBhIGNsYXNzIHByb3BlcnR5LFxuICogbm90IGFuIGluc3RhbmNlIHByb3BlcnR5LiBJdCBhcHBsaWVzIHRvIGFsbCBpbnN0YW5jZXMgb2YgdGhlIGNsYXNzLlxuICovXG5PYmplY3QuZGVmaW5lUHJvcGVydHkoTmVzdGVkQ2xvdWRBc3NlbWJseUFydGlmYWN0LnByb3RvdHlwZSwgTkVTVEVEX0NMT1VEX0FTU0VNQkxZX1NZTSwge1xuICB2YWx1ZTogdHJ1ZSxcbiAgZW51bWVyYWJsZTogZmFsc2UsXG4gIHdyaXRhYmxlOiBmYWxzZSxcbn0pO1xuIl19
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type * as cxschema from '@aws-cdk/cloud-assembly-schema';
|
|
2
|
+
import { CloudArtifact } from '../cloud-artifact';
|
|
3
|
+
import type { CloudAssembly } from '../cloud-assembly';
|
|
4
|
+
export declare class TreeCloudArtifact extends CloudArtifact {
|
|
5
|
+
/**
|
|
6
|
+
* Checks if `art` is an instance of this class.
|
|
7
|
+
*
|
|
8
|
+
* Use this method instead of `instanceof` to properly detect `TreeCloudArtifact`
|
|
9
|
+
* instances, even when the construct library is symlinked.
|
|
10
|
+
*
|
|
11
|
+
* Explanation: in JavaScript, multiple copies of the `cx-api` library on
|
|
12
|
+
* disk are seen as independent, completely different libraries. As a
|
|
13
|
+
* consequence, the class `TreeCloudArtifact` in each copy of the `cx-api` library
|
|
14
|
+
* is seen as a different class, and an instance of one class will not test as
|
|
15
|
+
* `instanceof` the other class. `npm install` will not create installations
|
|
16
|
+
* like this, but users may manually symlink construct libraries together or
|
|
17
|
+
* use a monorepo tool: in those cases, multiple copies of the `cx-api`
|
|
18
|
+
* library can be accidentally installed, and `instanceof` will behave
|
|
19
|
+
* unpredictably. It is safest to avoid using `instanceof`, and using
|
|
20
|
+
* this type-testing method instead.
|
|
21
|
+
*/
|
|
22
|
+
static isTreeCloudArtifact(art: any): art is TreeCloudArtifact;
|
|
23
|
+
readonly file: string;
|
|
24
|
+
constructor(assembly: CloudAssembly, name: string, artifact: cxschema.ArtifactManifest);
|
|
25
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TreeCloudArtifact = void 0;
|
|
4
|
+
const cloud_artifact_1 = require("../cloud-artifact");
|
|
5
|
+
const error_1 = require("../private/error");
|
|
6
|
+
const TREE_CLOUD_ARTIFACT_SYM = Symbol.for('@aws-cdk/cx-api.TreeCloudArtifact');
|
|
7
|
+
class TreeCloudArtifact extends cloud_artifact_1.CloudArtifact {
|
|
8
|
+
/**
|
|
9
|
+
* Checks if `art` is an instance of this class.
|
|
10
|
+
*
|
|
11
|
+
* Use this method instead of `instanceof` to properly detect `TreeCloudArtifact`
|
|
12
|
+
* instances, even when the construct library is symlinked.
|
|
13
|
+
*
|
|
14
|
+
* Explanation: in JavaScript, multiple copies of the `cx-api` library on
|
|
15
|
+
* disk are seen as independent, completely different libraries. As a
|
|
16
|
+
* consequence, the class `TreeCloudArtifact` in each copy of the `cx-api` library
|
|
17
|
+
* is seen as a different class, and an instance of one class will not test as
|
|
18
|
+
* `instanceof` the other class. `npm install` will not create installations
|
|
19
|
+
* like this, but users may manually symlink construct libraries together or
|
|
20
|
+
* use a monorepo tool: in those cases, multiple copies of the `cx-api`
|
|
21
|
+
* library can be accidentally installed, and `instanceof` will behave
|
|
22
|
+
* unpredictably. It is safest to avoid using `instanceof`, and using
|
|
23
|
+
* this type-testing method instead.
|
|
24
|
+
*/
|
|
25
|
+
static isTreeCloudArtifact(art) {
|
|
26
|
+
return art && typeof art === 'object' && TREE_CLOUD_ARTIFACT_SYM in art;
|
|
27
|
+
}
|
|
28
|
+
constructor(assembly, name, artifact) {
|
|
29
|
+
super(assembly, name, artifact);
|
|
30
|
+
const properties = (this.manifest.properties || {});
|
|
31
|
+
if (!properties.file) {
|
|
32
|
+
throw new error_1.CloudAssemblyError('Invalid TreeCloudArtifact. Missing "file" property');
|
|
33
|
+
}
|
|
34
|
+
this.file = properties.file;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
exports.TreeCloudArtifact = TreeCloudArtifact;
|
|
38
|
+
/**
|
|
39
|
+
* Mark all instances of 'TreeCloudArtifact'
|
|
40
|
+
*
|
|
41
|
+
* Why not put this in the constructor? Because this is a class property,
|
|
42
|
+
* not an instance property. It applies to all instances of the class.
|
|
43
|
+
*/
|
|
44
|
+
Object.defineProperty(TreeCloudArtifact.prototype, TREE_CLOUD_ARTIFACT_SYM, {
|
|
45
|
+
value: true,
|
|
46
|
+
enumerable: false,
|
|
47
|
+
writable: false,
|
|
48
|
+
});
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS1jbG91ZC1hcnRpZmFjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRyZWUtY2xvdWQtYXJ0aWZhY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0Esc0RBQWtEO0FBRWxELDRDQUFzRDtBQUV0RCxNQUFNLHVCQUF1QixHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsbUNBQW1DLENBQUMsQ0FBQztBQUVoRixNQUFhLGlCQUFrQixTQUFRLDhCQUFhO0lBQ2xEOzs7Ozs7Ozs7Ozs7Ozs7O09BZ0JHO0lBQ0ksTUFBTSxDQUFDLG1CQUFtQixDQUFDLEdBQVE7UUFDeEMsT0FBTyxHQUFHLElBQUksT0FBTyxHQUFHLEtBQUssUUFBUSxJQUFJLHVCQUF1QixJQUFJLEdBQUcsQ0FBQztJQUMxRSxDQUFDO0lBSUQsWUFBWSxRQUF1QixFQUFFLElBQVksRUFBRSxRQUFtQztRQUNwRixLQUFLLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQztRQUVoQyxNQUFNLFVBQVUsR0FBRyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsVUFBVSxJQUFJLEVBQUUsQ0FBb0MsQ0FBQztRQUN2RixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3JCLE1BQU0sSUFBSSwwQkFBa0IsQ0FBQyxvREFBb0QsQ0FBQyxDQUFDO1FBQ3JGLENBQUM7UUFDRCxJQUFJLENBQUMsSUFBSSxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUM7SUFDOUIsQ0FBQztDQUNGO0FBakNELDhDQWlDQztBQUVEOzs7OztHQUtHO0FBQ0gsTUFBTSxDQUFDLGNBQWMsQ0FBQyxpQkFBaUIsQ0FBQyxTQUFTLEVBQUUsdUJBQXVCLEVBQUU7SUFDMUUsS0FBSyxFQUFFLElBQUk7SUFDWCxVQUFVLEVBQUUsS0FBSztJQUNqQixRQUFRLEVBQUUsS0FBSztDQUNoQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSAqIGFzIGN4c2NoZW1hIGZyb20gJ0Bhd3MtY2RrL2Nsb3VkLWFzc2VtYmx5LXNjaGVtYSc7XG5pbXBvcnQgeyBDbG91ZEFydGlmYWN0IH0gZnJvbSAnLi4vY2xvdWQtYXJ0aWZhY3QnO1xuaW1wb3J0IHR5cGUgeyBDbG91ZEFzc2VtYmx5IH0gZnJvbSAnLi4vY2xvdWQtYXNzZW1ibHknO1xuaW1wb3J0IHsgQ2xvdWRBc3NlbWJseUVycm9yIH0gZnJvbSAnLi4vcHJpdmF0ZS9lcnJvcic7XG5cbmNvbnN0IFRSRUVfQ0xPVURfQVJUSUZBQ1RfU1lNID0gU3ltYm9sLmZvcignQGF3cy1jZGsvY3gtYXBpLlRyZWVDbG91ZEFydGlmYWN0Jyk7XG5cbmV4cG9ydCBjbGFzcyBUcmVlQ2xvdWRBcnRpZmFjdCBleHRlbmRzIENsb3VkQXJ0aWZhY3Qge1xuICAvKipcbiAgICogQ2hlY2tzIGlmIGBhcnRgIGlzIGFuIGluc3RhbmNlIG9mIHRoaXMgY2xhc3MuXG4gICAqXG4gICAqIFVzZSB0aGlzIG1ldGhvZCBpbnN0ZWFkIG9mIGBpbnN0YW5jZW9mYCB0byBwcm9wZXJseSBkZXRlY3QgYFRyZWVDbG91ZEFydGlmYWN0YFxuICAgKiBpbnN0YW5jZXMsIGV2ZW4gd2hlbiB0aGUgY29uc3RydWN0IGxpYnJhcnkgaXMgc3ltbGlua2VkLlxuICAgKlxuICAgKiBFeHBsYW5hdGlvbjogaW4gSmF2YVNjcmlwdCwgbXVsdGlwbGUgY29waWVzIG9mIHRoZSBgY3gtYXBpYCBsaWJyYXJ5IG9uXG4gICAqIGRpc2sgYXJlIHNlZW4gYXMgaW5kZXBlbmRlbnQsIGNvbXBsZXRlbHkgZGlmZmVyZW50IGxpYnJhcmllcy4gQXMgYVxuICAgKiBjb25zZXF1ZW5jZSwgdGhlIGNsYXNzIGBUcmVlQ2xvdWRBcnRpZmFjdGAgaW4gZWFjaCBjb3B5IG9mIHRoZSBgY3gtYXBpYCBsaWJyYXJ5XG4gICAqIGlzIHNlZW4gYXMgYSBkaWZmZXJlbnQgY2xhc3MsIGFuZCBhbiBpbnN0YW5jZSBvZiBvbmUgY2xhc3Mgd2lsbCBub3QgdGVzdCBhc1xuICAgKiBgaW5zdGFuY2VvZmAgdGhlIG90aGVyIGNsYXNzLiBgbnBtIGluc3RhbGxgIHdpbGwgbm90IGNyZWF0ZSBpbnN0YWxsYXRpb25zXG4gICAqIGxpa2UgdGhpcywgYnV0IHVzZXJzIG1heSBtYW51YWxseSBzeW1saW5rIGNvbnN0cnVjdCBsaWJyYXJpZXMgdG9nZXRoZXIgb3JcbiAgICogdXNlIGEgbW9ub3JlcG8gdG9vbDogaW4gdGhvc2UgY2FzZXMsIG11bHRpcGxlIGNvcGllcyBvZiB0aGUgYGN4LWFwaWBcbiAgICogbGlicmFyeSBjYW4gYmUgYWNjaWRlbnRhbGx5IGluc3RhbGxlZCwgYW5kIGBpbnN0YW5jZW9mYCB3aWxsIGJlaGF2ZVxuICAgKiB1bnByZWRpY3RhYmx5LiBJdCBpcyBzYWZlc3QgdG8gYXZvaWQgdXNpbmcgYGluc3RhbmNlb2ZgLCBhbmQgdXNpbmdcbiAgICogdGhpcyB0eXBlLXRlc3RpbmcgbWV0aG9kIGluc3RlYWQuXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGlzVHJlZUNsb3VkQXJ0aWZhY3QoYXJ0OiBhbnkpOiBhcnQgaXMgVHJlZUNsb3VkQXJ0aWZhY3Qge1xuICAgIHJldHVybiBhcnQgJiYgdHlwZW9mIGFydCA9PT0gJ29iamVjdCcgJiYgVFJFRV9DTE9VRF9BUlRJRkFDVF9TWU0gaW4gYXJ0O1xuICB9XG5cbiAgcHVibGljIHJlYWRvbmx5IGZpbGU6IHN0cmluZztcblxuICBjb25zdHJ1Y3Rvcihhc3NlbWJseTogQ2xvdWRBc3NlbWJseSwgbmFtZTogc3RyaW5nLCBhcnRpZmFjdDogY3hzY2hlbWEuQXJ0aWZhY3RNYW5pZmVzdCkge1xuICAgIHN1cGVyKGFzc2VtYmx5LCBuYW1lLCBhcnRpZmFjdCk7XG5cbiAgICBjb25zdCBwcm9wZXJ0aWVzID0gKHRoaXMubWFuaWZlc3QucHJvcGVydGllcyB8fCB7fSkgYXMgY3hzY2hlbWEuVHJlZUFydGlmYWN0UHJvcGVydGllcztcbiAgICBpZiAoIXByb3BlcnRpZXMuZmlsZSkge1xuICAgICAgdGhyb3cgbmV3IENsb3VkQXNzZW1ibHlFcnJvcignSW52YWxpZCBUcmVlQ2xvdWRBcnRpZmFjdC4gTWlzc2luZyBcImZpbGVcIiBwcm9wZXJ0eScpO1xuICAgIH1cbiAgICB0aGlzLmZpbGUgPSBwcm9wZXJ0aWVzLmZpbGU7XG4gIH1cbn1cblxuLyoqXG4gKiBNYXJrIGFsbCBpbnN0YW5jZXMgb2YgJ1RyZWVDbG91ZEFydGlmYWN0J1xuICpcbiAqIFdoeSBub3QgcHV0IHRoaXMgaW4gdGhlIGNvbnN0cnVjdG9yPyBCZWNhdXNlIHRoaXMgaXMgYSBjbGFzcyBwcm9wZXJ0eSxcbiAqIG5vdCBhbiBpbnN0YW5jZSBwcm9wZXJ0eS4gSXQgYXBwbGllcyB0byBhbGwgaW5zdGFuY2VzIG9mIHRoZSBjbGFzcy5cbiAqL1xuT2JqZWN0LmRlZmluZVByb3BlcnR5KFRyZWVDbG91ZEFydGlmYWN0LnByb3RvdHlwZSwgVFJFRV9DTE9VRF9BUlRJRkFDVF9TWU0sIHtcbiAgdmFsdWU6IHRydWUsXG4gIGVudW1lcmFibGU6IGZhbHNlLFxuICB3cml0YWJsZTogZmFsc2UsXG59KTtcbiJdfQ==
|
package/lib/assets.d.ts
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* If this is set in the context, the aws:asset:xxx metadata entries will not be
|
|
3
|
+
* added to the template. This is used, for example, when we run integrationt
|
|
4
|
+
* tests.
|
|
5
|
+
*/
|
|
6
|
+
export declare const ASSET_RESOURCE_METADATA_ENABLED_CONTEXT = "aws:cdk:enable-asset-metadata";
|
|
7
|
+
/**
|
|
8
|
+
* Metadata added to the CloudFormation template entries that map local assets
|
|
9
|
+
* to resources.
|
|
10
|
+
*/
|
|
11
|
+
export declare const ASSET_RESOURCE_METADATA_PATH_KEY = "aws:asset:path";
|
|
12
|
+
export declare const ASSET_RESOURCE_METADATA_DOCKERFILE_PATH_KEY = "aws:asset:dockerfile-path";
|
|
13
|
+
export declare const ASSET_RESOURCE_METADATA_DOCKER_BUILD_ARGS_KEY = "aws:asset:docker-build-args";
|
|
14
|
+
export declare const ASSET_RESOURCE_METADATA_DOCKER_BUILD_SECRETS_KEY = "aws:asset:docker-build-secrets";
|
|
15
|
+
export declare const ASSET_RESOURCE_METADATA_DOCKER_BUILD_SSH_KEY = "aws:asset:docker-build-ssh";
|
|
16
|
+
export declare const ASSET_RESOURCE_METADATA_DOCKER_BUILD_TARGET_KEY = "aws:asset:docker-build-target";
|
|
17
|
+
export declare const ASSET_RESOURCE_METADATA_PROPERTY_KEY = "aws:asset:property";
|
|
18
|
+
export declare const ASSET_RESOURCE_METADATA_IS_BUNDLED_KEY = "aws:asset:is-bundled";
|
|
19
|
+
export declare const ASSET_RESOURCE_METADATA_DOCKER_OUTPUTS_KEY = "aws:asset:docker-outputs";
|
|
20
|
+
export declare const ASSET_RESOURCE_METADATA_DOCKER_CACHE_FROM_KEY = "aws:asset:docker-cache-from";
|
|
21
|
+
export declare const ASSET_RESOURCE_METADATA_DOCKER_CACHE_TO_KEY = "aws:asset:docker-cache-to";
|
|
22
|
+
export declare const ASSET_RESOURCE_METADATA_DOCKER_CACHE_DISABLED_KEY = "aws:asset:docker-cache-disabled";
|
|
23
|
+
/**
|
|
24
|
+
* Separator string that separates the prefix separator from the object key separator.
|
|
25
|
+
*
|
|
26
|
+
* Asset keys will look like:
|
|
27
|
+
*
|
|
28
|
+
* /assets/MyConstruct12345678/||abcdef12345.zip
|
|
29
|
+
*
|
|
30
|
+
* This allows us to encode both the prefix and the full location in a single
|
|
31
|
+
* CloudFormation Template Parameter.
|
|
32
|
+
*/
|
|
33
|
+
export declare const ASSET_PREFIX_SEPARATOR = "||";
|
package/lib/assets.js
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ASSET_PREFIX_SEPARATOR = exports.ASSET_RESOURCE_METADATA_DOCKER_CACHE_DISABLED_KEY = exports.ASSET_RESOURCE_METADATA_DOCKER_CACHE_TO_KEY = exports.ASSET_RESOURCE_METADATA_DOCKER_CACHE_FROM_KEY = exports.ASSET_RESOURCE_METADATA_DOCKER_OUTPUTS_KEY = exports.ASSET_RESOURCE_METADATA_IS_BUNDLED_KEY = exports.ASSET_RESOURCE_METADATA_PROPERTY_KEY = exports.ASSET_RESOURCE_METADATA_DOCKER_BUILD_TARGET_KEY = exports.ASSET_RESOURCE_METADATA_DOCKER_BUILD_SSH_KEY = exports.ASSET_RESOURCE_METADATA_DOCKER_BUILD_SECRETS_KEY = exports.ASSET_RESOURCE_METADATA_DOCKER_BUILD_ARGS_KEY = exports.ASSET_RESOURCE_METADATA_DOCKERFILE_PATH_KEY = exports.ASSET_RESOURCE_METADATA_PATH_KEY = exports.ASSET_RESOURCE_METADATA_ENABLED_CONTEXT = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* If this is set in the context, the aws:asset:xxx metadata entries will not be
|
|
6
|
+
* added to the template. This is used, for example, when we run integrationt
|
|
7
|
+
* tests.
|
|
8
|
+
*/
|
|
9
|
+
exports.ASSET_RESOURCE_METADATA_ENABLED_CONTEXT = 'aws:cdk:enable-asset-metadata';
|
|
10
|
+
/**
|
|
11
|
+
* Metadata added to the CloudFormation template entries that map local assets
|
|
12
|
+
* to resources.
|
|
13
|
+
*/
|
|
14
|
+
exports.ASSET_RESOURCE_METADATA_PATH_KEY = 'aws:asset:path';
|
|
15
|
+
exports.ASSET_RESOURCE_METADATA_DOCKERFILE_PATH_KEY = 'aws:asset:dockerfile-path';
|
|
16
|
+
exports.ASSET_RESOURCE_METADATA_DOCKER_BUILD_ARGS_KEY = 'aws:asset:docker-build-args';
|
|
17
|
+
exports.ASSET_RESOURCE_METADATA_DOCKER_BUILD_SECRETS_KEY = 'aws:asset:docker-build-secrets';
|
|
18
|
+
exports.ASSET_RESOURCE_METADATA_DOCKER_BUILD_SSH_KEY = 'aws:asset:docker-build-ssh';
|
|
19
|
+
exports.ASSET_RESOURCE_METADATA_DOCKER_BUILD_TARGET_KEY = 'aws:asset:docker-build-target';
|
|
20
|
+
exports.ASSET_RESOURCE_METADATA_PROPERTY_KEY = 'aws:asset:property';
|
|
21
|
+
exports.ASSET_RESOURCE_METADATA_IS_BUNDLED_KEY = 'aws:asset:is-bundled';
|
|
22
|
+
exports.ASSET_RESOURCE_METADATA_DOCKER_OUTPUTS_KEY = 'aws:asset:docker-outputs';
|
|
23
|
+
exports.ASSET_RESOURCE_METADATA_DOCKER_CACHE_FROM_KEY = 'aws:asset:docker-cache-from';
|
|
24
|
+
exports.ASSET_RESOURCE_METADATA_DOCKER_CACHE_TO_KEY = 'aws:asset:docker-cache-to';
|
|
25
|
+
exports.ASSET_RESOURCE_METADATA_DOCKER_CACHE_DISABLED_KEY = 'aws:asset:docker-cache-disabled';
|
|
26
|
+
/**
|
|
27
|
+
* Separator string that separates the prefix separator from the object key separator.
|
|
28
|
+
*
|
|
29
|
+
* Asset keys will look like:
|
|
30
|
+
*
|
|
31
|
+
* /assets/MyConstruct12345678/||abcdef12345.zip
|
|
32
|
+
*
|
|
33
|
+
* This allows us to encode both the prefix and the full location in a single
|
|
34
|
+
* CloudFormation Template Parameter.
|
|
35
|
+
*/
|
|
36
|
+
exports.ASSET_PREFIX_SEPARATOR = '||';
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXNzZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOzs7O0dBSUc7QUFDVSxRQUFBLHVDQUF1QyxHQUFHLCtCQUErQixDQUFDO0FBRXZGOzs7R0FHRztBQUNVLFFBQUEsZ0NBQWdDLEdBQUcsZ0JBQWdCLENBQUM7QUFDcEQsUUFBQSwyQ0FBMkMsR0FBRywyQkFBMkIsQ0FBQztBQUMxRSxRQUFBLDZDQUE2QyxHQUFHLDZCQUE2QixDQUFDO0FBQzlFLFFBQUEsZ0RBQWdELEdBQUcsZ0NBQWdDLENBQUM7QUFDcEYsUUFBQSw0Q0FBNEMsR0FBRyw0QkFBNEIsQ0FBQztBQUM1RSxRQUFBLCtDQUErQyxHQUFHLCtCQUErQixDQUFDO0FBQ2xGLFFBQUEsb0NBQW9DLEdBQUcsb0JBQW9CLENBQUM7QUFDNUQsUUFBQSxzQ0FBc0MsR0FBRyxzQkFBc0IsQ0FBQztBQUNoRSxRQUFBLDBDQUEwQyxHQUFHLDBCQUEwQixDQUFDO0FBQ3hFLFFBQUEsNkNBQTZDLEdBQUcsNkJBQTZCLENBQUM7QUFDOUUsUUFBQSwyQ0FBMkMsR0FBRywyQkFBMkIsQ0FBQztBQUMxRSxRQUFBLGlEQUFpRCxHQUFHLGlDQUFpQyxDQUFDO0FBRW5HOzs7Ozs7Ozs7R0FTRztBQUNVLFFBQUEsc0JBQXNCLEdBQUcsSUFBSSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBJZiB0aGlzIGlzIHNldCBpbiB0aGUgY29udGV4dCwgdGhlIGF3czphc3NldDp4eHggbWV0YWRhdGEgZW50cmllcyB3aWxsIG5vdCBiZVxuICogYWRkZWQgdG8gdGhlIHRlbXBsYXRlLiBUaGlzIGlzIHVzZWQsIGZvciBleGFtcGxlLCB3aGVuIHdlIHJ1biBpbnRlZ3JhdGlvbnRcbiAqIHRlc3RzLlxuICovXG5leHBvcnQgY29uc3QgQVNTRVRfUkVTT1VSQ0VfTUVUQURBVEFfRU5BQkxFRF9DT05URVhUID0gJ2F3czpjZGs6ZW5hYmxlLWFzc2V0LW1ldGFkYXRhJztcblxuLyoqXG4gKiBNZXRhZGF0YSBhZGRlZCB0byB0aGUgQ2xvdWRGb3JtYXRpb24gdGVtcGxhdGUgZW50cmllcyB0aGF0IG1hcCBsb2NhbCBhc3NldHNcbiAqIHRvIHJlc291cmNlcy5cbiAqL1xuZXhwb3J0IGNvbnN0IEFTU0VUX1JFU09VUkNFX01FVEFEQVRBX1BBVEhfS0VZID0gJ2F3czphc3NldDpwYXRoJztcbmV4cG9ydCBjb25zdCBBU1NFVF9SRVNPVVJDRV9NRVRBREFUQV9ET0NLRVJGSUxFX1BBVEhfS0VZID0gJ2F3czphc3NldDpkb2NrZXJmaWxlLXBhdGgnO1xuZXhwb3J0IGNvbnN0IEFTU0VUX1JFU09VUkNFX01FVEFEQVRBX0RPQ0tFUl9CVUlMRF9BUkdTX0tFWSA9ICdhd3M6YXNzZXQ6ZG9ja2VyLWJ1aWxkLWFyZ3MnO1xuZXhwb3J0IGNvbnN0IEFTU0VUX1JFU09VUkNFX01FVEFEQVRBX0RPQ0tFUl9CVUlMRF9TRUNSRVRTX0tFWSA9ICdhd3M6YXNzZXQ6ZG9ja2VyLWJ1aWxkLXNlY3JldHMnO1xuZXhwb3J0IGNvbnN0IEFTU0VUX1JFU09VUkNFX01FVEFEQVRBX0RPQ0tFUl9CVUlMRF9TU0hfS0VZID0gJ2F3czphc3NldDpkb2NrZXItYnVpbGQtc3NoJztcbmV4cG9ydCBjb25zdCBBU1NFVF9SRVNPVVJDRV9NRVRBREFUQV9ET0NLRVJfQlVJTERfVEFSR0VUX0tFWSA9ICdhd3M6YXNzZXQ6ZG9ja2VyLWJ1aWxkLXRhcmdldCc7XG5leHBvcnQgY29uc3QgQVNTRVRfUkVTT1VSQ0VfTUVUQURBVEFfUFJPUEVSVFlfS0VZID0gJ2F3czphc3NldDpwcm9wZXJ0eSc7XG5leHBvcnQgY29uc3QgQVNTRVRfUkVTT1VSQ0VfTUVUQURBVEFfSVNfQlVORExFRF9LRVkgPSAnYXdzOmFzc2V0OmlzLWJ1bmRsZWQnO1xuZXhwb3J0IGNvbnN0IEFTU0VUX1JFU09VUkNFX01FVEFEQVRBX0RPQ0tFUl9PVVRQVVRTX0tFWSA9ICdhd3M6YXNzZXQ6ZG9ja2VyLW91dHB1dHMnO1xuZXhwb3J0IGNvbnN0IEFTU0VUX1JFU09VUkNFX01FVEFEQVRBX0RPQ0tFUl9DQUNIRV9GUk9NX0tFWSA9ICdhd3M6YXNzZXQ6ZG9ja2VyLWNhY2hlLWZyb20nO1xuZXhwb3J0IGNvbnN0IEFTU0VUX1JFU09VUkNFX01FVEFEQVRBX0RPQ0tFUl9DQUNIRV9UT19LRVkgPSAnYXdzOmFzc2V0OmRvY2tlci1jYWNoZS10byc7XG5leHBvcnQgY29uc3QgQVNTRVRfUkVTT1VSQ0VfTUVUQURBVEFfRE9DS0VSX0NBQ0hFX0RJU0FCTEVEX0tFWSA9ICdhd3M6YXNzZXQ6ZG9ja2VyLWNhY2hlLWRpc2FibGVkJztcblxuLyoqXG4gKiBTZXBhcmF0b3Igc3RyaW5nIHRoYXQgc2VwYXJhdGVzIHRoZSBwcmVmaXggc2VwYXJhdG9yIGZyb20gdGhlIG9iamVjdCBrZXkgc2VwYXJhdG9yLlxuICpcbiAqIEFzc2V0IGtleXMgd2lsbCBsb29rIGxpa2U6XG4gKlxuICogICAgL2Fzc2V0cy9NeUNvbnN0cnVjdDEyMzQ1Njc4L3x8YWJjZGVmMTIzNDUuemlwXG4gKlxuICogVGhpcyBhbGxvd3MgdXMgdG8gZW5jb2RlIGJvdGggdGhlIHByZWZpeCBhbmQgdGhlIGZ1bGwgbG9jYXRpb24gaW4gYSBzaW5nbGVcbiAqIENsb3VkRm9ybWF0aW9uIFRlbXBsYXRlIFBhcmFtZXRlci5cbiAqL1xuZXhwb3J0IGNvbnN0IEFTU0VUX1BSRUZJWF9TRVBBUkFUT1IgPSAnfHwnO1xuIl19
|
package/lib/bootstrap.js
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SSMPARAM_NO_INVALIDATE = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* This SSM parameter does not invalidate the template
|
|
6
|
+
*
|
|
7
|
+
* If this string occurs in the description of an SSM parameter, the CLI
|
|
8
|
+
* will not assume that the stack must always be redeployed.
|
|
9
|
+
*/
|
|
10
|
+
exports.SSMPARAM_NO_INVALIDATE = '[cdk:skip]';
|
|
11
|
+
// Not strictly part of the cloud-assembly-api, but it definitely belongs here more than in cx-api.
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9vdHN0cmFwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYm9vdHN0cmFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOzs7OztHQUtHO0FBQ1UsUUFBQSxzQkFBc0IsR0FBRyxZQUFZLENBQUM7QUFFbkQsbUdBQW1HIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUaGlzIFNTTSBwYXJhbWV0ZXIgZG9lcyBub3QgaW52YWxpZGF0ZSB0aGUgdGVtcGxhdGVcbiAqXG4gKiBJZiB0aGlzIHN0cmluZyBvY2N1cnMgaW4gdGhlIGRlc2NyaXB0aW9uIG9mIGFuIFNTTSBwYXJhbWV0ZXIsIHRoZSBDTElcbiAqIHdpbGwgbm90IGFzc3VtZSB0aGF0IHRoZSBzdGFjayBtdXN0IGFsd2F5cyBiZSByZWRlcGxveWVkLlxuICovXG5leHBvcnQgY29uc3QgU1NNUEFSQU1fTk9fSU5WQUxJREFURSA9ICdbY2RrOnNraXBdJztcblxuLy8gTm90IHN0cmljdGx5IHBhcnQgb2YgdGhlIGNsb3VkLWFzc2VtYmx5LWFwaSwgYnV0IGl0IGRlZmluaXRlbHkgYmVsb25ncyBoZXJlIG1vcmUgdGhhbiBpbiBjeC1hcGkuXG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const cxschema = require("@aws-cdk/cloud-assembly-schema");
|
|
4
|
+
const asset_manifest_artifact_1 = require("./artifacts/asset-manifest-artifact");
|
|
5
|
+
const cloudformation_artifact_1 = require("./artifacts/cloudformation-artifact");
|
|
6
|
+
const nested_cloud_assembly_artifact_1 = require("./artifacts/nested-cloud-assembly-artifact");
|
|
7
|
+
const tree_cloud_artifact_1 = require("./artifacts/tree-cloud-artifact");
|
|
8
|
+
const cloud_artifact_1 = require("./cloud-artifact");
|
|
9
|
+
/**
|
|
10
|
+
* Add the 'fromManifest' factory function
|
|
11
|
+
*
|
|
12
|
+
* It is defined in a separate file to avoid circular dependencies between 'cloud-artifact.ts'
|
|
13
|
+
* and all of its subclass files.
|
|
14
|
+
*/
|
|
15
|
+
cloud_artifact_1.CloudArtifact.fromManifest = function fromManifest(assembly, id, artifact) {
|
|
16
|
+
switch (artifact.type) {
|
|
17
|
+
case cxschema.ArtifactType.AWS_CLOUDFORMATION_STACK:
|
|
18
|
+
return new cloudformation_artifact_1.CloudFormationStackArtifact(assembly, id, artifact);
|
|
19
|
+
case cxschema.ArtifactType.CDK_TREE:
|
|
20
|
+
return new tree_cloud_artifact_1.TreeCloudArtifact(assembly, id, artifact);
|
|
21
|
+
case cxschema.ArtifactType.ASSET_MANIFEST:
|
|
22
|
+
return new asset_manifest_artifact_1.AssetManifestArtifact(assembly, id, artifact);
|
|
23
|
+
case cxschema.ArtifactType.NESTED_CLOUD_ASSEMBLY:
|
|
24
|
+
return new nested_cloud_assembly_artifact_1.NestedCloudAssemblyArtifact(assembly, id, artifact);
|
|
25
|
+
default:
|
|
26
|
+
return undefined;
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xvdWQtYXJ0aWZhY3QtYXVnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY2xvdWQtYXJ0aWZhY3QtYXVnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsMkRBQTJEO0FBQzNELGlGQUE0RTtBQUM1RSxpRkFBa0Y7QUFDbEYsK0ZBQXlGO0FBQ3pGLHlFQUFvRTtBQUNwRSxxREFBaUQ7QUFHakQ7Ozs7O0dBS0c7QUFDSCw4QkFBYSxDQUFDLFlBQVksR0FBRyxTQUFTLFlBQVksQ0FDaEQsUUFBdUIsRUFDdkIsRUFBVSxFQUNWLFFBQW1DO0lBRW5DLFFBQVEsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3RCLEtBQUssUUFBUSxDQUFDLFlBQVksQ0FBQyx3QkFBd0I7WUFDakQsT0FBTyxJQUFJLHFEQUEyQixDQUFDLFFBQVEsRUFBRSxFQUFFLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDakUsS0FBSyxRQUFRLENBQUMsWUFBWSxDQUFDLFFBQVE7WUFDakMsT0FBTyxJQUFJLHVDQUFpQixDQUFDLFFBQVEsRUFBRSxFQUFFLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDdkQsS0FBSyxRQUFRLENBQUMsWUFBWSxDQUFDLGNBQWM7WUFDdkMsT0FBTyxJQUFJLCtDQUFxQixDQUFDLFFBQVEsRUFBRSxFQUFFLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDM0QsS0FBSyxRQUFRLENBQUMsWUFBWSxDQUFDLHFCQUFxQjtZQUM5QyxPQUFPLElBQUksNERBQTJCLENBQUMsUUFBUSxFQUFFLEVBQUUsRUFBRSxRQUFRLENBQUMsQ0FBQztRQUNqRTtZQUNFLE9BQU8sU0FBUyxDQUFDO0lBQ3JCLENBQUM7QUFDSCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjeHNjaGVtYSBmcm9tICdAYXdzLWNkay9jbG91ZC1hc3NlbWJseS1zY2hlbWEnO1xuaW1wb3J0IHsgQXNzZXRNYW5pZmVzdEFydGlmYWN0IH0gZnJvbSAnLi9hcnRpZmFjdHMvYXNzZXQtbWFuaWZlc3QtYXJ0aWZhY3QnO1xuaW1wb3J0IHsgQ2xvdWRGb3JtYXRpb25TdGFja0FydGlmYWN0IH0gZnJvbSAnLi9hcnRpZmFjdHMvY2xvdWRmb3JtYXRpb24tYXJ0aWZhY3QnO1xuaW1wb3J0IHsgTmVzdGVkQ2xvdWRBc3NlbWJseUFydGlmYWN0IH0gZnJvbSAnLi9hcnRpZmFjdHMvbmVzdGVkLWNsb3VkLWFzc2VtYmx5LWFydGlmYWN0JztcbmltcG9ydCB7IFRyZWVDbG91ZEFydGlmYWN0IH0gZnJvbSAnLi9hcnRpZmFjdHMvdHJlZS1jbG91ZC1hcnRpZmFjdCc7XG5pbXBvcnQgeyBDbG91ZEFydGlmYWN0IH0gZnJvbSAnLi9jbG91ZC1hcnRpZmFjdCc7XG5pbXBvcnQgdHlwZSB7IENsb3VkQXNzZW1ibHkgfSBmcm9tICcuL2Nsb3VkLWFzc2VtYmx5JztcblxuLyoqXG4gKiBBZGQgdGhlICdmcm9tTWFuaWZlc3QnIGZhY3RvcnkgZnVuY3Rpb25cbiAqXG4gKiBJdCBpcyBkZWZpbmVkIGluIGEgc2VwYXJhdGUgZmlsZSB0byBhdm9pZCBjaXJjdWxhciBkZXBlbmRlbmNpZXMgYmV0d2VlbiAnY2xvdWQtYXJ0aWZhY3QudHMnXG4gKiBhbmQgYWxsIG9mIGl0cyBzdWJjbGFzcyBmaWxlcy5cbiAqL1xuQ2xvdWRBcnRpZmFjdC5mcm9tTWFuaWZlc3QgPSBmdW5jdGlvbiBmcm9tTWFuaWZlc3QoXG4gIGFzc2VtYmx5OiBDbG91ZEFzc2VtYmx5LFxuICBpZDogc3RyaW5nLFxuICBhcnRpZmFjdDogY3hzY2hlbWEuQXJ0aWZhY3RNYW5pZmVzdCxcbik6IENsb3VkQXJ0aWZhY3QgfCB1bmRlZmluZWQge1xuICBzd2l0Y2ggKGFydGlmYWN0LnR5cGUpIHtcbiAgICBjYXNlIGN4c2NoZW1hLkFydGlmYWN0VHlwZS5BV1NfQ0xPVURGT1JNQVRJT05fU1RBQ0s6XG4gICAgICByZXR1cm4gbmV3IENsb3VkRm9ybWF0aW9uU3RhY2tBcnRpZmFjdChhc3NlbWJseSwgaWQsIGFydGlmYWN0KTtcbiAgICBjYXNlIGN4c2NoZW1hLkFydGlmYWN0VHlwZS5DREtfVFJFRTpcbiAgICAgIHJldHVybiBuZXcgVHJlZUNsb3VkQXJ0aWZhY3QoYXNzZW1ibHksIGlkLCBhcnRpZmFjdCk7XG4gICAgY2FzZSBjeHNjaGVtYS5BcnRpZmFjdFR5cGUuQVNTRVRfTUFOSUZFU1Q6XG4gICAgICByZXR1cm4gbmV3IEFzc2V0TWFuaWZlc3RBcnRpZmFjdChhc3NlbWJseSwgaWQsIGFydGlmYWN0KTtcbiAgICBjYXNlIGN4c2NoZW1hLkFydGlmYWN0VHlwZS5ORVNURURfQ0xPVURfQVNTRU1CTFk6XG4gICAgICByZXR1cm4gbmV3IE5lc3RlZENsb3VkQXNzZW1ibHlBcnRpZmFjdChhc3NlbWJseSwgaWQsIGFydGlmYWN0KTtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxufTtcbiJdfQ==
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import * as cxschema from '@aws-cdk/cloud-assembly-schema';
|
|
2
|
+
import type { CloudAssembly } from './cloud-assembly';
|
|
3
|
+
import type { MetadataEntryResult, SynthesisMessage } from './metadata';
|
|
4
|
+
/**
|
|
5
|
+
* Artifact properties for CloudFormation stacks.
|
|
6
|
+
*/
|
|
7
|
+
export interface AwsCloudFormationStackProperties {
|
|
8
|
+
/**
|
|
9
|
+
* A file relative to the assembly root which contains the CloudFormation template for this stack.
|
|
10
|
+
*/
|
|
11
|
+
readonly templateFile: string;
|
|
12
|
+
/**
|
|
13
|
+
* Values for CloudFormation stack parameters that should be passed when the stack is deployed.
|
|
14
|
+
*/
|
|
15
|
+
readonly parameters?: {
|
|
16
|
+
[id: string]: string;
|
|
17
|
+
};
|
|
18
|
+
/**
|
|
19
|
+
* The name to use for the CloudFormation stack.
|
|
20
|
+
* @default - name derived from artifact ID
|
|
21
|
+
*/
|
|
22
|
+
readonly stackName?: string;
|
|
23
|
+
/**
|
|
24
|
+
* Whether to enable termination protection for this stack.
|
|
25
|
+
*
|
|
26
|
+
* @default false
|
|
27
|
+
*/
|
|
28
|
+
readonly terminationProtection?: boolean;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Represents an artifact within a cloud assembly.
|
|
32
|
+
*/
|
|
33
|
+
export declare class CloudArtifact {
|
|
34
|
+
readonly assembly: CloudAssembly;
|
|
35
|
+
readonly id: string;
|
|
36
|
+
/**
|
|
37
|
+
* Returns a subclass of `CloudArtifact` based on the artifact type defined in the artifact manifest.
|
|
38
|
+
*
|
|
39
|
+
* @param assembly - The cloud assembly from which to load the artifact
|
|
40
|
+
* @param id - The artifact ID
|
|
41
|
+
* @param artifact - The artifact manifest
|
|
42
|
+
* @returns the `CloudArtifact` that matches the artifact type or `undefined` if it's an artifact type that is unrecognized by this module.
|
|
43
|
+
*/
|
|
44
|
+
static fromManifest(assembly: CloudAssembly, id: string, artifact: cxschema.ArtifactManifest): CloudArtifact | undefined;
|
|
45
|
+
/**
|
|
46
|
+
* The artifact's manifest
|
|
47
|
+
*/
|
|
48
|
+
readonly manifest: cxschema.ArtifactManifest;
|
|
49
|
+
/**
|
|
50
|
+
* The set of messages extracted from the artifact's metadata.
|
|
51
|
+
*/
|
|
52
|
+
readonly messages: SynthesisMessage[];
|
|
53
|
+
/**
|
|
54
|
+
* Cache of resolved dependencies.
|
|
55
|
+
*/
|
|
56
|
+
private _deps?;
|
|
57
|
+
protected constructor(assembly: CloudAssembly, id: string, manifest: cxschema.ArtifactManifest);
|
|
58
|
+
/**
|
|
59
|
+
* Returns all the artifacts that this artifact depends on.
|
|
60
|
+
*/
|
|
61
|
+
get dependencies(): CloudArtifact[];
|
|
62
|
+
/**
|
|
63
|
+
* @returns all the metadata entries of a specific type in this artifact.
|
|
64
|
+
*/
|
|
65
|
+
findMetadataByType(type: string): MetadataEntryResult[];
|
|
66
|
+
private renderMessages;
|
|
67
|
+
/**
|
|
68
|
+
* An identifier that shows where this artifact is located in the tree
|
|
69
|
+
* of nested assemblies, based on their manifests. Defaults to the normal
|
|
70
|
+
* id. Should only be used in user interfaces.
|
|
71
|
+
*/
|
|
72
|
+
get hierarchicalId(): string;
|
|
73
|
+
}
|