@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.
Files changed (114) hide show
  1. package/LICENSE +202 -0
  2. package/README.md +15 -41
  3. package/design/NESTED_ASSEMBLIES.md +93 -0
  4. package/lib/artifacts/asset-manifest-artifact.d.ts +46 -0
  5. package/lib/artifacts/asset-manifest-artifact.js +66 -0
  6. package/lib/artifacts/cloudformation-artifact.d.ts +147 -0
  7. package/lib/artifacts/cloudformation-artifact.js +94 -0
  8. package/lib/artifacts/nested-cloud-assembly-artifact-aug.d.ts +1 -0
  9. package/lib/artifacts/nested-cloud-assembly-artifact-aug.js +19 -0
  10. package/lib/artifacts/nested-cloud-assembly-artifact.d.ts +45 -0
  11. package/lib/artifacts/nested-cloud-assembly-artifact.js +56 -0
  12. package/lib/artifacts/tree-cloud-artifact.d.ts +25 -0
  13. package/lib/artifacts/tree-cloud-artifact.js +49 -0
  14. package/lib/assets.d.ts +33 -0
  15. package/lib/assets.js +37 -0
  16. package/lib/bootstrap.d.ts +7 -0
  17. package/lib/bootstrap.js +12 -0
  18. package/lib/cloud-artifact-aug.d.ts +1 -0
  19. package/lib/cloud-artifact-aug.js +29 -0
  20. package/lib/cloud-artifact.d.ts +73 -0
  21. package/lib/cloud-artifact.js +94 -0
  22. package/lib/cloud-assembly.d.ts +266 -0
  23. package/lib/cloud-assembly.js +374 -0
  24. package/lib/context/ami.d.ts +4 -0
  25. package/lib/context/ami.js +3 -0
  26. package/lib/context/availability-zones.d.ts +12 -0
  27. package/lib/context/availability-zones.js +12 -0
  28. package/lib/context/endpoint-service-availability-zones.d.ts +22 -0
  29. package/lib/context/endpoint-service-availability-zones.js +5 -0
  30. package/lib/context/generic.d.ts +4 -0
  31. package/lib/context/generic.js +8 -0
  32. package/lib/context/key.d.ts +9 -0
  33. package/lib/context/key.js +3 -0
  34. package/lib/context/load-balancer.d.ts +63 -0
  35. package/lib/context/load-balancer.js +22 -0
  36. package/lib/context/security-group.d.ts +15 -0
  37. package/lib/context/security-group.js +3 -0
  38. package/lib/context/vpc.d.ts +152 -0
  39. package/lib/context/vpc.js +18 -0
  40. package/lib/environment.d.ts +24 -0
  41. package/lib/environment.js +40 -0
  42. package/lib/index.d.ts +21 -0
  43. package/lib/index.js +38 -0
  44. package/lib/metadata.d.ts +27 -0
  45. package/lib/metadata.js +14 -0
  46. package/lib/placeholders.d.ts +66 -0
  47. package/lib/placeholders.js +90 -0
  48. package/lib/private/error.d.ts +1 -0
  49. package/lib/private/error.js +47 -0
  50. package/lib/private/toposort.d.ts +11 -0
  51. package/lib/private/toposort.js +35 -0
  52. package/node_modules/jsonschema/.editorconfig +10 -0
  53. package/node_modules/jsonschema/LICENSE +21 -0
  54. package/node_modules/jsonschema/README.md +421 -0
  55. package/node_modules/jsonschema/lib/attribute.js +978 -0
  56. package/node_modules/jsonschema/lib/helpers.js +390 -0
  57. package/node_modules/jsonschema/lib/index.d.ts +142 -0
  58. package/node_modules/jsonschema/lib/index.js +15 -0
  59. package/node_modules/jsonschema/lib/scan.js +75 -0
  60. package/node_modules/jsonschema/lib/validator.js +336 -0
  61. package/node_modules/jsonschema/package.json +42 -0
  62. package/node_modules/semver/LICENSE +15 -0
  63. package/node_modules/semver/README.md +664 -0
  64. package/node_modules/semver/bin/semver.js +191 -0
  65. package/node_modules/semver/classes/comparator.js +143 -0
  66. package/node_modules/semver/classes/index.js +7 -0
  67. package/node_modules/semver/classes/range.js +557 -0
  68. package/node_modules/semver/classes/semver.js +333 -0
  69. package/node_modules/semver/functions/clean.js +8 -0
  70. package/node_modules/semver/functions/cmp.js +54 -0
  71. package/node_modules/semver/functions/coerce.js +62 -0
  72. package/node_modules/semver/functions/compare-build.js +9 -0
  73. package/node_modules/semver/functions/compare-loose.js +5 -0
  74. package/node_modules/semver/functions/compare.js +7 -0
  75. package/node_modules/semver/functions/diff.js +60 -0
  76. package/node_modules/semver/functions/eq.js +5 -0
  77. package/node_modules/semver/functions/gt.js +5 -0
  78. package/node_modules/semver/functions/gte.js +5 -0
  79. package/node_modules/semver/functions/inc.js +21 -0
  80. package/node_modules/semver/functions/lt.js +5 -0
  81. package/node_modules/semver/functions/lte.js +5 -0
  82. package/node_modules/semver/functions/major.js +5 -0
  83. package/node_modules/semver/functions/minor.js +5 -0
  84. package/node_modules/semver/functions/neq.js +5 -0
  85. package/node_modules/semver/functions/parse.js +18 -0
  86. package/node_modules/semver/functions/patch.js +5 -0
  87. package/node_modules/semver/functions/prerelease.js +8 -0
  88. package/node_modules/semver/functions/rcompare.js +5 -0
  89. package/node_modules/semver/functions/rsort.js +5 -0
  90. package/node_modules/semver/functions/satisfies.js +12 -0
  91. package/node_modules/semver/functions/sort.js +5 -0
  92. package/node_modules/semver/functions/valid.js +8 -0
  93. package/node_modules/semver/index.js +91 -0
  94. package/node_modules/semver/internal/constants.js +37 -0
  95. package/node_modules/semver/internal/debug.js +11 -0
  96. package/node_modules/semver/internal/identifiers.js +29 -0
  97. package/node_modules/semver/internal/lrucache.js +42 -0
  98. package/node_modules/semver/internal/parse-options.js +17 -0
  99. package/node_modules/semver/internal/re.js +223 -0
  100. package/node_modules/semver/package.json +78 -0
  101. package/node_modules/semver/preload.js +4 -0
  102. package/node_modules/semver/range.bnf +16 -0
  103. package/node_modules/semver/ranges/gtr.js +6 -0
  104. package/node_modules/semver/ranges/intersects.js +9 -0
  105. package/node_modules/semver/ranges/ltr.js +6 -0
  106. package/node_modules/semver/ranges/max-satisfying.js +27 -0
  107. package/node_modules/semver/ranges/min-satisfying.js +26 -0
  108. package/node_modules/semver/ranges/min-version.js +63 -0
  109. package/node_modules/semver/ranges/outside.js +82 -0
  110. package/node_modules/semver/ranges/simplify.js +49 -0
  111. package/node_modules/semver/ranges/subset.js +249 -0
  112. package/node_modules/semver/ranges/to-comparators.js +10 -0
  113. package/node_modules/semver/ranges/valid.js +13 -0
  114. 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":"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","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,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==
@@ -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
@@ -0,0 +1,7 @@
1
+ /**
2
+ * This SSM parameter does not invalidate the template
3
+ *
4
+ * If this string occurs in the description of an SSM parameter, the CLI
5
+ * will not assume that the stack must always be redeployed.
6
+ */
7
+ export declare const SSMPARAM_NO_INVALIDATE = "[cdk:skip]";
@@ -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
+ }