@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,374 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CloudAssemblyBuilder = exports.CloudAssembly = void 0;
4
+ const fs = require("fs");
5
+ const os = require("os");
6
+ const path = require("path");
7
+ const cxschema = require("@aws-cdk/cloud-assembly-schema/lib");
8
+ const cloudformation_artifact_1 = require("./artifacts/cloudformation-artifact");
9
+ const nested_cloud_assembly_artifact_1 = require("./artifacts/nested-cloud-assembly-artifact");
10
+ const tree_cloud_artifact_1 = require("./artifacts/tree-cloud-artifact");
11
+ const cloud_artifact_1 = require("./cloud-artifact");
12
+ const error_1 = require("./private/error");
13
+ const toposort_1 = require("./private/toposort");
14
+ const CLOUD_ASSEMBLY_SYMBOL = Symbol.for('@aws-cdk/cx-api.CloudAssembly');
15
+ /**
16
+ * The name of the root manifest file of the assembly.
17
+ */
18
+ const MANIFEST_FILE = 'manifest.json';
19
+ /**
20
+ * Represents a deployable cloud application.
21
+ */
22
+ class CloudAssembly {
23
+ /**
24
+ * Return whether the given object is a CloudAssembly.
25
+ *
26
+ * We do attribute detection since we can't reliably use 'instanceof'.
27
+ */
28
+ static isCloudAssembly(x) {
29
+ return x !== null && typeof (x) === 'object' && CLOUD_ASSEMBLY_SYMBOL in x;
30
+ }
31
+ /**
32
+ * Cleans up any temporary assembly directories that got created in this process
33
+ *
34
+ * If a Cloud Assembly is emitted to a temporary directory, its directory gets
35
+ * added to a list. This function iterates over that list and deletes each
36
+ * directory in it, to free up disk space.
37
+ *
38
+ * This function will normally be called automatically during Node process
39
+ * exit and so you don't need to call this. However, some test environments do
40
+ * not properly trigger Node's `exit` event. Notably: Jest does not trigger
41
+ * the `exit` event (<https://github.com/jestjs/jest/issues/10927>).
42
+ *
43
+ * ## Cleaning up temporary directories in jest
44
+ *
45
+ * For Jest, you have to make sure this function is called at the end of the
46
+ * test suite instead:
47
+ *
48
+ * ```js
49
+ * import { CloudAssembly } from 'aws-cdk-lib/cx-api';
50
+ *
51
+ * afterAll(CloudAssembly.cleanupTemporaryDirectories);
52
+ * ```
53
+ *
54
+ * Alternatively, you can use the `setupFilesAfterEnv` feature and use a
55
+ * provided helper script to automatically inject the above into every
56
+ * test file, so you don't have to do it by hand.
57
+ *
58
+ * ```
59
+ * $ npx jest --setupFilesAfterEnv aws-cdk-lib/testhelpers/jest-autoclean
60
+ * ```
61
+ *
62
+ * Or put the following into `jest.config.js`:
63
+ *
64
+ * ```js
65
+ * module.exports = {
66
+ * // ...
67
+ * setupFilesAfterEnv: ['aws-cdk-lib/testhelpers/jest-cleanup'],
68
+ * };
69
+ * ```
70
+ */
71
+ static cleanupTemporaryDirectories() {
72
+ for (const dir of TEMPORARY_ASSEMBLY_DIRS) {
73
+ fs.rmSync(dir, { recursive: true, force: true });
74
+ }
75
+ TEMPORARY_ASSEMBLY_DIRS.splice(0, TEMPORARY_ASSEMBLY_DIRS.length);
76
+ }
77
+ /**
78
+ * Reads a cloud assembly from the specified directory.
79
+ * @param directory - The root directory of the assembly.
80
+ */
81
+ constructor(directory, loadOptions) {
82
+ this.directory = directory;
83
+ this.manifest = cxschema.Manifest.loadAssemblyManifest(path.join(directory, MANIFEST_FILE), loadOptions);
84
+ this.version = this.manifest.version;
85
+ this.artifacts = this.renderArtifacts(loadOptions?.topoSort ?? true);
86
+ this.runtime = this.manifest.runtime || { libraries: {} };
87
+ Object.defineProperty(this, CLOUD_ASSEMBLY_SYMBOL, { value: true });
88
+ // force validation of deps by accessing 'depends' on all artifacts
89
+ this.validateDeps();
90
+ }
91
+ /**
92
+ * Attempts to find an artifact with a specific identity.
93
+ * @returns A `CloudArtifact` object or `undefined` if the artifact does not exist in this assembly.
94
+ * @param id - The artifact ID
95
+ */
96
+ tryGetArtifact(id) {
97
+ return this.artifacts.find(a => a.id === id);
98
+ }
99
+ /**
100
+ * Returns a CloudFormation stack artifact from this assembly.
101
+ *
102
+ * Will only search the current assembly.
103
+ *
104
+ * @param stackName - the name of the CloudFormation stack.
105
+ * @throws if there is no stack artifact by that name
106
+ * @throws if there is more than one stack with the same stack name. You can
107
+ * use `getStackArtifact(stack.artifactId)` instead.
108
+ * @returns a `CloudFormationStackArtifact` object.
109
+ */
110
+ getStackByName(stackName) {
111
+ const artifacts = this.artifacts.filter(a => a instanceof cloudformation_artifact_1.CloudFormationStackArtifact && a.stackName === stackName);
112
+ if (!artifacts || artifacts.length === 0) {
113
+ throw new error_1.CloudAssemblyError(`Unable to find stack with stack name "${stackName}"`);
114
+ }
115
+ if (artifacts.length > 1) {
116
+ throw new error_1.CloudAssemblyError(`There are multiple stacks with the stack name "${stackName}" (${artifacts.map(a => a.id).join(',')}). Use "getStackArtifact(id)" instead`);
117
+ }
118
+ return artifacts[0];
119
+ }
120
+ /**
121
+ * Returns a CloudFormation stack artifact by name from this assembly.
122
+ * @deprecated renamed to `getStackByName` (or `getStackArtifact(id)`)
123
+ */
124
+ getStack(stackName) {
125
+ return this.getStackByName(stackName);
126
+ }
127
+ /**
128
+ * Returns a CloudFormation stack artifact from this assembly.
129
+ *
130
+ * @param artifactId - the artifact id of the stack (can be obtained through `stack.artifactId`).
131
+ * @throws if there is no stack artifact with that id
132
+ * @returns a `CloudFormationStackArtifact` object.
133
+ */
134
+ getStackArtifact(artifactId) {
135
+ const artifact = this.tryGetArtifactRecursively(artifactId);
136
+ if (!artifact) {
137
+ throw new error_1.CloudAssemblyError(`Unable to find artifact with id "${artifactId}"`);
138
+ }
139
+ if (!(artifact instanceof cloudformation_artifact_1.CloudFormationStackArtifact)) {
140
+ throw new error_1.CloudAssemblyError(`Artifact ${artifactId} is not a CloudFormation stack`);
141
+ }
142
+ return artifact;
143
+ }
144
+ tryGetArtifactRecursively(artifactId) {
145
+ return this.stacksRecursively.find(a => a.id === artifactId);
146
+ }
147
+ /**
148
+ * Returns all the stacks, including the ones in nested assemblies
149
+ */
150
+ get stacksRecursively() {
151
+ function search(stackArtifacts, assemblies) {
152
+ if (assemblies.length === 0) {
153
+ return stackArtifacts;
154
+ }
155
+ const [head, ...tail] = assemblies;
156
+ const nestedAssemblies = head.nestedAssemblies.map(asm => asm.nestedAssembly);
157
+ return search(stackArtifacts.concat(head.stacks), tail.concat(nestedAssemblies));
158
+ }
159
+ return search([], [this]);
160
+ }
161
+ /**
162
+ * Returns a nested assembly artifact.
163
+ *
164
+ * @param artifactId - The artifact ID of the nested assembly
165
+ */
166
+ getNestedAssemblyArtifact(artifactId) {
167
+ const artifact = this.tryGetArtifact(artifactId);
168
+ if (!artifact) {
169
+ throw new error_1.CloudAssemblyError(`Unable to find artifact with id "${artifactId}"`);
170
+ }
171
+ if (!(artifact instanceof nested_cloud_assembly_artifact_1.NestedCloudAssemblyArtifact)) {
172
+ throw new error_1.CloudAssemblyError(`Found artifact '${artifactId}' but it's not a nested cloud assembly`);
173
+ }
174
+ return artifact;
175
+ }
176
+ /**
177
+ * Returns a nested assembly.
178
+ *
179
+ * @param artifactId - The artifact ID of the nested assembly
180
+ */
181
+ getNestedAssembly(artifactId) {
182
+ return this.getNestedAssemblyArtifact(artifactId).nestedAssembly;
183
+ }
184
+ /**
185
+ * Returns the tree metadata artifact from this assembly.
186
+ * @throws if there is no metadata artifact by that name
187
+ * @returns a `TreeCloudArtifact` object if there is one defined in the manifest, `undefined` otherwise.
188
+ */
189
+ tree() {
190
+ const trees = this.artifacts.filter(a => a.manifest.type === cxschema.ArtifactType.CDK_TREE);
191
+ if (trees.length === 0) {
192
+ return undefined;
193
+ }
194
+ else if (trees.length > 1) {
195
+ throw new error_1.CloudAssemblyError(`Multiple artifacts of type ${cxschema.ArtifactType.CDK_TREE} found in manifest`);
196
+ }
197
+ const tree = trees[0];
198
+ if (!(tree instanceof tree_cloud_artifact_1.TreeCloudArtifact)) {
199
+ throw new error_1.CloudAssemblyError('"Tree" artifact is not of expected type');
200
+ }
201
+ return tree;
202
+ }
203
+ /**
204
+ * @returns all the CloudFormation stack artifacts that are included in this assembly.
205
+ */
206
+ get stacks() {
207
+ return this.artifacts.filter(isCloudFormationStackArtifact);
208
+ function isCloudFormationStackArtifact(x) {
209
+ return x instanceof cloudformation_artifact_1.CloudFormationStackArtifact;
210
+ }
211
+ }
212
+ /**
213
+ * The nested assembly artifacts in this assembly
214
+ */
215
+ get nestedAssemblies() {
216
+ return this.artifacts.filter(isNestedCloudAssemblyArtifact);
217
+ function isNestedCloudAssemblyArtifact(x) {
218
+ return x instanceof nested_cloud_assembly_artifact_1.NestedCloudAssemblyArtifact;
219
+ }
220
+ }
221
+ validateDeps() {
222
+ for (const artifact of this.artifacts) {
223
+ ignore(artifact.dependencies);
224
+ }
225
+ }
226
+ renderArtifacts(topoSort) {
227
+ const result = new Array();
228
+ for (const [name, artifact] of Object.entries(this.manifest.artifacts || {})) {
229
+ const cloudartifact = cloud_artifact_1.CloudArtifact.fromManifest(this, name, artifact);
230
+ if (cloudartifact) {
231
+ result.push(cloudartifact);
232
+ }
233
+ }
234
+ return topoSort ? (0, toposort_1.topologicalSort)(result, x => x.id, x => x._dependencyIDs) : result;
235
+ }
236
+ }
237
+ exports.CloudAssembly = CloudAssembly;
238
+ /**
239
+ * Can be used to build a cloud assembly.
240
+ */
241
+ class CloudAssemblyBuilder {
242
+ /**
243
+ * Initializes a cloud assembly builder.
244
+ * @param outdir - The output directory, uses temporary directory if undefined
245
+ */
246
+ constructor(outdir, props = {}) {
247
+ this.artifacts = {};
248
+ this.missing = new Array();
249
+ this.outdir = determineOutputDirectory(outdir);
250
+ this.assetOutdir = props.assetOutdir ?? this.outdir;
251
+ this.parentBuilder = props.parentBuilder;
252
+ // we leverage the fact that outdir is long-lived to avoid staging assets into it
253
+ // that were already staged (copying can be expensive). this is achieved by the fact
254
+ // that assets use a source hash as their name. other artifacts, and the manifest itself,
255
+ // will overwrite existing files as needed.
256
+ ensureDirSync(this.outdir);
257
+ }
258
+ /**
259
+ * Adds an artifact into the cloud assembly.
260
+ * @param id - The ID of the artifact.
261
+ * @param manifest - The artifact manifest
262
+ */
263
+ addArtifact(id, manifest) {
264
+ this.artifacts[id] = filterUndefined(manifest);
265
+ }
266
+ /**
267
+ * Reports that some context is missing in order for this cloud assembly to be fully synthesized.
268
+ * @param missing - Missing context information.
269
+ */
270
+ addMissing(missing) {
271
+ if (this.missing.every(m => m.key !== missing.key)) {
272
+ this.missing.push(missing);
273
+ }
274
+ // Also report in parent
275
+ this.parentBuilder?.addMissing(missing);
276
+ }
277
+ /**
278
+ * Finalizes the cloud assembly into the output directory returns a
279
+ * `CloudAssembly` object that can be used to inspect the assembly.
280
+ */
281
+ buildAssembly(options = {}) {
282
+ // explicitly initializing this type will help us detect
283
+ // breaking changes. (For example adding a required property will break compilation).
284
+ let manifest = {
285
+ version: cxschema.Manifest.version(),
286
+ artifacts: this.artifacts,
287
+ runtime: options.runtimeInfo,
288
+ missing: this.missing.length > 0 ? this.missing : undefined,
289
+ };
290
+ // now we can filter
291
+ manifest = filterUndefined(manifest);
292
+ const manifestFilePath = path.join(this.outdir, MANIFEST_FILE);
293
+ cxschema.Manifest.saveAssemblyManifest(manifest, manifestFilePath);
294
+ // "backwards compatibility": in order for the old CLI to tell the user they
295
+ // need a new version, we'll emit the legacy manifest with only "version".
296
+ // this will result in an error "CDK Toolkit >= CLOUD_ASSEMBLY_VERSION is required in order to interact with this program."
297
+ fs.writeFileSync(path.join(this.outdir, 'cdk.out'), JSON.stringify({ version: manifest.version }));
298
+ return new CloudAssembly(this.outdir);
299
+ }
300
+ /**
301
+ * Creates a nested cloud assembly
302
+ */
303
+ createNestedAssembly(artifactId, displayName) {
304
+ const directoryName = artifactId;
305
+ const innerAsmDir = path.join(this.outdir, directoryName);
306
+ this.addArtifact(artifactId, {
307
+ type: cxschema.ArtifactType.NESTED_CLOUD_ASSEMBLY,
308
+ properties: {
309
+ directoryName,
310
+ displayName,
311
+ },
312
+ });
313
+ return new CloudAssemblyBuilder(innerAsmDir, {
314
+ // Reuse the same asset output directory as the current Casm builder
315
+ assetOutdir: this.assetOutdir,
316
+ parentBuilder: this,
317
+ });
318
+ }
319
+ /**
320
+ * Delete the cloud assembly directory
321
+ */
322
+ delete() {
323
+ fs.rmSync(this.outdir, { recursive: true, force: true });
324
+ }
325
+ }
326
+ exports.CloudAssemblyBuilder = CloudAssemblyBuilder;
327
+ /**
328
+ * Returns a copy of `obj` without undefined values in maps or arrays.
329
+ */
330
+ function filterUndefined(obj) {
331
+ if (Array.isArray(obj)) {
332
+ return obj.filter(x => x !== undefined).map(x => filterUndefined(x));
333
+ }
334
+ if (typeof (obj) === 'object') {
335
+ const ret = {};
336
+ for (const [key, value] of Object.entries(obj)) {
337
+ if (value === undefined) {
338
+ continue;
339
+ }
340
+ ret[key] = filterUndefined(value);
341
+ }
342
+ return ret;
343
+ }
344
+ return obj;
345
+ }
346
+ function ignore(_x) {
347
+ return;
348
+ }
349
+ /**
350
+ * Turn the given optional output directory into a fixed output directory
351
+ */
352
+ function determineOutputDirectory(outdir) {
353
+ if (outdir) {
354
+ return outdir;
355
+ }
356
+ // Make a temporary directory; clean it up automatically if this is done for testing.
357
+ const tmpDir = fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), 'cdk.out'));
358
+ TEMPORARY_ASSEMBLY_DIRS.push(tmpDir);
359
+ return outdir ?? tmpDir;
360
+ }
361
+ function ensureDirSync(dir) {
362
+ if (fs.existsSync(dir)) {
363
+ if (!fs.statSync(dir).isDirectory()) {
364
+ throw new error_1.CloudAssemblyError(`${dir} must be a directory`);
365
+ }
366
+ }
367
+ else {
368
+ fs.mkdirSync(dir, { recursive: true });
369
+ }
370
+ }
371
+ // On process exit, delete all temporary assembly directories
372
+ const TEMPORARY_ASSEMBLY_DIRS = [];
373
+ process.on('exit', () => CloudAssembly.cleanupTemporaryDirectories());
374
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-assembly.js","sourceRoot":"","sources":["cloud-assembly.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as os from 'os';\nimport * as path from 'path';\nimport type { ICloudAssembly } from '@aws-cdk/cloud-assembly-schema';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema/lib';\nimport { CloudFormationStackArtifact } from './artifacts/cloudformation-artifact';\nimport { NestedCloudAssemblyArtifact } from './artifacts/nested-cloud-assembly-artifact';\nimport { TreeCloudArtifact } from './artifacts/tree-cloud-artifact';\nimport { CloudArtifact } from './cloud-artifact';\nimport { CloudAssemblyError } from './private/error';\nimport { topologicalSort } from './private/toposort';\n\nconst CLOUD_ASSEMBLY_SYMBOL = Symbol.for('@aws-cdk/cx-api.CloudAssembly');\n\n/**\n * The name of the root manifest file of the assembly.\n */\nconst MANIFEST_FILE = 'manifest.json';\n\n/**\n * Represents a deployable cloud application.\n */\nexport class CloudAssembly implements ICloudAssembly {\n  /**\n   * Return whether the given object is a CloudAssembly.\n   *\n   * We do attribute detection since we can't reliably use 'instanceof'.\n   */\n  public static isCloudAssembly(x: any): x is CloudAssembly {\n    return x !== null && typeof(x) === 'object' && CLOUD_ASSEMBLY_SYMBOL in x;\n  }\n\n  /**\n   * Cleans up any temporary assembly directories that got created in this process\n   *\n   * If a Cloud Assembly is emitted to a temporary directory, its directory gets\n   * added to a list. This function iterates over that list and deletes each\n   * directory in it, to free up disk space.\n   *\n   * This function will normally be called automatically during Node process\n   * exit and so you don't need to call this. However, some test environments do\n   * not properly trigger Node's `exit` event. Notably: Jest does not trigger\n   * the `exit` event (<https://github.com/jestjs/jest/issues/10927>).\n   *\n   * ## Cleaning up temporary directories in jest\n   *\n   * For Jest, you have to make sure this function is called at the end of the\n   * test suite instead:\n   *\n   * ```js\n   * import { CloudAssembly } from 'aws-cdk-lib/cx-api';\n   *\n   * afterAll(CloudAssembly.cleanupTemporaryDirectories);\n   * ```\n   *\n   * Alternatively, you can use the `setupFilesAfterEnv` feature and use a\n   * provided helper script to automatically inject the above into every\n   * test file, so you don't have to do it by hand.\n   *\n   * ```\n   * $ npx jest --setupFilesAfterEnv aws-cdk-lib/testhelpers/jest-autoclean\n   * ```\n   *\n   * Or put the following into `jest.config.js`:\n   *\n   * ```js\n   * module.exports = {\n   *   // ...\n   *   setupFilesAfterEnv: ['aws-cdk-lib/testhelpers/jest-cleanup'],\n   * };\n   * ```\n   */\n  public static cleanupTemporaryDirectories() {\n    for (const dir of TEMPORARY_ASSEMBLY_DIRS) {\n      fs.rmSync(dir, { recursive: true, force: true });\n    }\n    TEMPORARY_ASSEMBLY_DIRS.splice(0, TEMPORARY_ASSEMBLY_DIRS.length);\n  }\n\n  /**\n   * The root directory of the cloud assembly.\n   */\n  public readonly directory: string;\n\n  /**\n   * The schema version of the assembly manifest.\n   */\n  public readonly version: string;\n\n  /**\n   * All artifacts included in this assembly.\n   */\n  public readonly artifacts: CloudArtifact[];\n\n  /**\n   * Runtime information such as module versions used to synthesize this assembly.\n   */\n  public readonly runtime: cxschema.RuntimeInfo;\n\n  /**\n   * The raw assembly manifest.\n   */\n  public readonly manifest: cxschema.AssemblyManifest;\n\n  /**\n   * Reads a cloud assembly from the specified directory.\n   * @param directory - The root directory of the assembly.\n   */\n  constructor(directory: string, loadOptions?: cxschema.LoadManifestOptions) {\n    this.directory = directory;\n\n    this.manifest = cxschema.Manifest.loadAssemblyManifest(path.join(directory, MANIFEST_FILE), loadOptions);\n    this.version = this.manifest.version;\n    this.artifacts = this.renderArtifacts(loadOptions?.topoSort ?? true);\n    this.runtime = this.manifest.runtime || { libraries: { } };\n\n    Object.defineProperty(this, CLOUD_ASSEMBLY_SYMBOL, { value: true });\n\n    // force validation of deps by accessing 'depends' on all artifacts\n    this.validateDeps();\n  }\n\n  /**\n   * Attempts to find an artifact with a specific identity.\n   * @returns A `CloudArtifact` object or `undefined` if the artifact does not exist in this assembly.\n   * @param id - The artifact ID\n   */\n  public tryGetArtifact(id: string): CloudArtifact | undefined {\n    return this.artifacts.find(a => a.id === id);\n  }\n\n  /**\n   * Returns a CloudFormation stack artifact from this assembly.\n   *\n   * Will only search the current assembly.\n   *\n   * @param stackName - the name of the CloudFormation stack.\n   * @throws if there is no stack artifact by that name\n   * @throws if there is more than one stack with the same stack name. You can\n   * use `getStackArtifact(stack.artifactId)` instead.\n   * @returns a `CloudFormationStackArtifact` object.\n   */\n  public getStackByName(stackName: string): CloudFormationStackArtifact {\n    const artifacts = this.artifacts.filter(a => a instanceof CloudFormationStackArtifact && a.stackName === stackName);\n    if (!artifacts || artifacts.length === 0) {\n      throw new CloudAssemblyError(`Unable to find stack with stack name \"${stackName}\"`);\n    }\n\n    if (artifacts.length > 1) {\n      throw new CloudAssemblyError(`There are multiple stacks with the stack name \"${stackName}\" (${artifacts.map(a => a.id).join(',')}). Use \"getStackArtifact(id)\" instead`);\n    }\n\n    return artifacts[0] as CloudFormationStackArtifact;\n  }\n\n  /**\n   * Returns a CloudFormation stack artifact by name from this assembly.\n   * @deprecated renamed to `getStackByName` (or `getStackArtifact(id)`)\n   */\n  public getStack(stackName: string) {\n    return this.getStackByName(stackName);\n  }\n\n  /**\n   * Returns a CloudFormation stack artifact from this assembly.\n   *\n   * @param artifactId - the artifact id of the stack (can be obtained through `stack.artifactId`).\n   * @throws if there is no stack artifact with that id\n   * @returns a `CloudFormationStackArtifact` object.\n   */\n  public getStackArtifact(artifactId: string): CloudFormationStackArtifact {\n    const artifact = this.tryGetArtifactRecursively(artifactId);\n\n    if (!artifact) {\n      throw new CloudAssemblyError(`Unable to find artifact with id \"${artifactId}\"`);\n    }\n\n    if (!(artifact instanceof CloudFormationStackArtifact)) {\n      throw new CloudAssemblyError(`Artifact ${artifactId} is not a CloudFormation stack`);\n    }\n\n    return artifact;\n  }\n\n  private tryGetArtifactRecursively(artifactId: string): CloudArtifact | undefined {\n    return this.stacksRecursively.find(a => a.id === artifactId);\n  }\n\n  /**\n   * Returns all the stacks, including the ones in nested assemblies\n   */\n  public get stacksRecursively(): CloudFormationStackArtifact[] {\n    function search(stackArtifacts: CloudFormationStackArtifact[], assemblies: CloudAssembly[]): CloudFormationStackArtifact[] {\n      if (assemblies.length === 0) {\n        return stackArtifacts;\n      }\n\n      const [head, ...tail] = assemblies;\n      const nestedAssemblies = head.nestedAssemblies.map(asm => asm.nestedAssembly);\n      return search(stackArtifacts.concat(head.stacks), tail.concat(nestedAssemblies));\n    }\n\n    return search([], [this]);\n  }\n\n  /**\n   * Returns a nested assembly artifact.\n   *\n   * @param artifactId - The artifact ID of the nested assembly\n   */\n  public getNestedAssemblyArtifact(artifactId: string): NestedCloudAssemblyArtifact {\n    const artifact = this.tryGetArtifact(artifactId);\n    if (!artifact) {\n      throw new CloudAssemblyError(`Unable to find artifact with id \"${artifactId}\"`);\n    }\n\n    if (!(artifact instanceof NestedCloudAssemblyArtifact)) {\n      throw new CloudAssemblyError(`Found artifact '${artifactId}' but it's not a nested cloud assembly`);\n    }\n\n    return artifact;\n  }\n\n  /**\n   * Returns a nested assembly.\n   *\n   * @param artifactId - The artifact ID of the nested assembly\n   */\n  public getNestedAssembly(artifactId: string): CloudAssembly {\n    return this.getNestedAssemblyArtifact(artifactId).nestedAssembly;\n  }\n\n  /**\n   * Returns the tree metadata artifact from this assembly.\n   * @throws if there is no metadata artifact by that name\n   * @returns a `TreeCloudArtifact` object if there is one defined in the manifest, `undefined` otherwise.\n   */\n  public tree(): TreeCloudArtifact | undefined {\n    const trees = this.artifacts.filter(a => a.manifest.type === cxschema.ArtifactType.CDK_TREE);\n    if (trees.length === 0) {\n      return undefined;\n    } else if (trees.length > 1) {\n      throw new CloudAssemblyError(`Multiple artifacts of type ${cxschema.ArtifactType.CDK_TREE} found in manifest`);\n    }\n    const tree = trees[0];\n\n    if (!(tree instanceof TreeCloudArtifact)) {\n      throw new CloudAssemblyError('\"Tree\" artifact is not of expected type');\n    }\n\n    return tree;\n  }\n\n  /**\n   * @returns all the CloudFormation stack artifacts that are included in this assembly.\n   */\n  public get stacks(): CloudFormationStackArtifact[] {\n    return this.artifacts.filter(isCloudFormationStackArtifact);\n\n    function isCloudFormationStackArtifact(x: any): x is CloudFormationStackArtifact {\n      return x instanceof CloudFormationStackArtifact;\n    }\n  }\n\n  /**\n   * The nested assembly artifacts in this assembly\n   */\n  public get nestedAssemblies(): NestedCloudAssemblyArtifact[] {\n    return this.artifacts.filter(isNestedCloudAssemblyArtifact);\n\n    function isNestedCloudAssemblyArtifact(x: any): x is NestedCloudAssemblyArtifact {\n      return x instanceof NestedCloudAssemblyArtifact;\n    }\n  }\n\n  private validateDeps() {\n    for (const artifact of this.artifacts) {\n      ignore(artifact.dependencies);\n    }\n  }\n\n  private renderArtifacts(topoSort: boolean) {\n    const result = new Array<CloudArtifact>();\n    for (const [name, artifact] of Object.entries(this.manifest.artifacts || { })) {\n      const cloudartifact = CloudArtifact.fromManifest(this, name, artifact);\n      if (cloudartifact) {\n        result.push(cloudartifact);\n      }\n    }\n\n    return topoSort ? topologicalSort(result, x => x.id, x => x._dependencyIDs) : result;\n  }\n}\n\n/**\n * Construction properties for CloudAssemblyBuilder\n */\nexport interface CloudAssemblyBuilderProps {\n  /**\n   * Use the given asset output directory\n   *\n   * @default - Same as the manifest outdir\n   */\n  readonly assetOutdir?: string;\n\n  /**\n   * If this builder is for a nested assembly, the parent assembly builder\n   *\n   * @default - This is a root assembly\n   */\n  readonly parentBuilder?: CloudAssemblyBuilder;\n}\n\n/**\n * Can be used to build a cloud assembly.\n */\nexport class CloudAssemblyBuilder {\n  /**\n   * The root directory of the resulting cloud assembly.\n   */\n  public readonly outdir: string;\n\n  /**\n   * The directory where assets of this Cloud Assembly should be stored\n   */\n  public readonly assetOutdir: string;\n\n  private readonly artifacts: { [id: string]: cxschema.ArtifactManifest } = { };\n  private readonly missing = new Array<cxschema.MissingContext>();\n  private readonly parentBuilder?: CloudAssemblyBuilder;\n\n  /**\n   * Initializes a cloud assembly builder.\n   * @param outdir - The output directory, uses temporary directory if undefined\n   */\n  constructor(outdir?: string, props: CloudAssemblyBuilderProps = {}) {\n    this.outdir = determineOutputDirectory(outdir);\n    this.assetOutdir = props.assetOutdir ?? this.outdir;\n    this.parentBuilder = props.parentBuilder;\n\n    // we leverage the fact that outdir is long-lived to avoid staging assets into it\n    // that were already staged (copying can be expensive). this is achieved by the fact\n    // that assets use a source hash as their name. other artifacts, and the manifest itself,\n    // will overwrite existing files as needed.\n    ensureDirSync(this.outdir);\n  }\n\n  /**\n   * Adds an artifact into the cloud assembly.\n   * @param id - The ID of the artifact.\n   * @param manifest - The artifact manifest\n   */\n  public addArtifact(id: string, manifest: cxschema.ArtifactManifest) {\n    this.artifacts[id] = filterUndefined(manifest);\n  }\n\n  /**\n   * Reports that some context is missing in order for this cloud assembly to be fully synthesized.\n   * @param missing - Missing context information.\n   */\n  public addMissing(missing: cxschema.MissingContext) {\n    if (this.missing.every(m => m.key !== missing.key)) {\n      this.missing.push(missing);\n    }\n    // Also report in parent\n    this.parentBuilder?.addMissing(missing);\n  }\n\n  /**\n   * Finalizes the cloud assembly into the output directory returns a\n   * `CloudAssembly` object that can be used to inspect the assembly.\n   */\n  public buildAssembly(options: AssemblyBuildOptions = { }): CloudAssembly {\n    // explicitly initializing this type will help us detect\n    // breaking changes. (For example adding a required property will break compilation).\n    let manifest: cxschema.AssemblyManifest = {\n      version: cxschema.Manifest.version(),\n      artifacts: this.artifacts,\n      runtime: options.runtimeInfo,\n      missing: this.missing.length > 0 ? this.missing : undefined,\n    };\n\n    // now we can filter\n    manifest = filterUndefined(manifest);\n\n    const manifestFilePath = path.join(this.outdir, MANIFEST_FILE);\n    cxschema.Manifest.saveAssemblyManifest(manifest, manifestFilePath);\n\n    // \"backwards compatibility\": in order for the old CLI to tell the user they\n    // need a new version, we'll emit the legacy manifest with only \"version\".\n    // this will result in an error \"CDK Toolkit >= CLOUD_ASSEMBLY_VERSION is required in order to interact with this program.\"\n    fs.writeFileSync(path.join(this.outdir, 'cdk.out'), JSON.stringify({ version: manifest.version }));\n\n    return new CloudAssembly(this.outdir);\n  }\n\n  /**\n   * Creates a nested cloud assembly\n   */\n  public createNestedAssembly(artifactId: string, displayName: string) {\n    const directoryName = artifactId;\n    const innerAsmDir = path.join(this.outdir, directoryName);\n\n    this.addArtifact(artifactId, {\n      type: cxschema.ArtifactType.NESTED_CLOUD_ASSEMBLY,\n      properties: {\n        directoryName,\n        displayName,\n      } as cxschema.NestedCloudAssemblyProperties,\n    });\n\n    return new CloudAssemblyBuilder(innerAsmDir, {\n      // Reuse the same asset output directory as the current Casm builder\n      assetOutdir: this.assetOutdir,\n      parentBuilder: this,\n    });\n  }\n\n  /**\n   * Delete the cloud assembly directory\n   */\n  public delete() {\n    fs.rmSync(this.outdir, { recursive: true, force: true });\n  }\n}\n\n/**\n * Backwards compatibility for when `RuntimeInfo`\n * was defined here. This is necessary because its used as an input in the stable\n * @aws-cdk/core library.\n *\n * @deprecated moved to package 'cloud-assembly-schema'\n * @see core.ConstructNode.synth\n */\nexport interface RuntimeInfo extends cxschema.RuntimeInfo {\n\n}\n\n/**\n * Backwards compatibility for when `MetadataEntry`\n * was defined here. This is necessary because its used as an input in the stable\n * @aws-cdk/core library.\n *\n * @deprecated moved to package 'cloud-assembly-schema'\n * @see core.ConstructNode.metadata\n */\nexport interface MetadataEntry extends cxschema.MetadataEntry {\n\n}\n\n/**\n * Backwards compatibility for when `MissingContext`\n * was defined here. This is necessary because its used as an input in the stable\n * @aws-cdk/core library.\n *\n * @deprecated moved to package 'cloud-assembly-schema'\n * @see core.Stack.reportMissingContext\n */\nexport interface MissingContext {\n  /**\n   * The missing context key.\n   */\n  readonly key: string;\n\n  /**\n   * The provider from which we expect this context key to be obtained.\n   *\n   * (This is the old untyped definition, which is necessary for backwards compatibility.\n   * See cxschema for a type definition.)\n   */\n  readonly provider: string;\n\n  /**\n   * A set of provider-specific options.\n   *\n   * (This is the old untyped definition, which is necessary for backwards compatibility.\n   * See cxschema for a type definition.)\n   */\n  readonly props: Record<string, any>;\n}\n\nexport interface AssemblyBuildOptions {\n  /**\n   * Include the specified runtime information (module versions) in manifest.\n   * @default - if this option is not specified, runtime info will not be included\n   * @deprecated All template modifications that should result from this should\n   * have already been inserted into the template.\n   */\n  readonly runtimeInfo?: RuntimeInfo;\n}\n\n/**\n * Returns a copy of `obj` without undefined values in maps or arrays.\n */\nfunction filterUndefined(obj: any): any {\n  if (Array.isArray(obj)) {\n    return obj.filter(x => x !== undefined).map(x => filterUndefined(x));\n  }\n\n  if (typeof(obj) === 'object') {\n    const ret: any = { };\n    for (const [key, value] of Object.entries(obj)) {\n      if (value === undefined) {\n        continue;\n      }\n      ret[key] = filterUndefined(value);\n    }\n    return ret;\n  }\n\n  return obj;\n}\n\nfunction ignore(_x: any) {\n  return;\n}\n\n/**\n * Turn the given optional output directory into a fixed output directory\n */\nfunction determineOutputDirectory(outdir?: string) {\n  if (outdir) {\n    return outdir;\n  }\n\n  // Make a temporary directory; clean it up automatically if this is done for testing.\n  const tmpDir = fs.mkdtempSync(path.join(fs.realpathSync(os.tmpdir()), 'cdk.out'));\n  TEMPORARY_ASSEMBLY_DIRS.push(tmpDir);\n  return outdir ?? tmpDir;\n}\n\nfunction ensureDirSync(dir: string) {\n  if (fs.existsSync(dir)) {\n    if (!fs.statSync(dir).isDirectory()) {\n      throw new CloudAssemblyError(`${dir} must be a directory`);\n    }\n  } else {\n    fs.mkdirSync(dir, { recursive: true });\n  }\n}\n\n// On process exit, delete all temporary assembly directories\nconst TEMPORARY_ASSEMBLY_DIRS: string[] = [];\nprocess.on('exit', () => CloudAssembly.cleanupTemporaryDirectories());\n"]}
@@ -0,0 +1,4 @@
1
+ /**
2
+ * Returns just an AMI ID
3
+ */
4
+ export type AmiContextResponse = string;
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW1pLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYW1pLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFJldHVybnMganVzdCBhbiBBTUkgSURcbiAqL1xuZXhwb3J0IHR5cGUgQW1pQ29udGV4dFJlc3BvbnNlID0gc3RyaW5nO1xuIl19
@@ -0,0 +1,12 @@
1
+ /**
2
+ * This context key is used to determine the value of `stack.availabilityZones`
3
+ * when a stack is not associated with a specific account/region (env-agnostic).
4
+ *
5
+ * If this key is passed in the context, the values will be used. Otherwise, a
6
+ * system-fallback which uses `Fn::GetAZs` will be used.
7
+ */
8
+ export declare const AVAILABILITY_ZONE_FALLBACK_CONTEXT_KEY = "aws:cdk:availability-zones:fallback";
9
+ /**
10
+ * Response of the AZ provider looks like this
11
+ */
12
+ export type AvailabilityZonesContextResponse = string[];
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AVAILABILITY_ZONE_FALLBACK_CONTEXT_KEY = void 0;
4
+ /**
5
+ * This context key is used to determine the value of `stack.availabilityZones`
6
+ * when a stack is not associated with a specific account/region (env-agnostic).
7
+ *
8
+ * If this key is passed in the context, the values will be used. Otherwise, a
9
+ * system-fallback which uses `Fn::GetAZs` will be used.
10
+ */
11
+ exports.AVAILABILITY_ZONE_FALLBACK_CONTEXT_KEY = 'aws:cdk:availability-zones:fallback';
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhaWxhYmlsaXR5LXpvbmVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXZhaWxhYmlsaXR5LXpvbmVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOzs7Ozs7R0FNRztBQUNVLFFBQUEsc0NBQXNDLEdBQUcscUNBQXFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoaXMgY29udGV4dCBrZXkgaXMgdXNlZCB0byBkZXRlcm1pbmUgdGhlIHZhbHVlIG9mIGBzdGFjay5hdmFpbGFiaWxpdHlab25lc2BcbiAqIHdoZW4gYSBzdGFjayBpcyBub3QgYXNzb2NpYXRlZCB3aXRoIGEgc3BlY2lmaWMgYWNjb3VudC9yZWdpb24gKGVudi1hZ25vc3RpYykuXG4gKlxuICogSWYgdGhpcyBrZXkgaXMgcGFzc2VkIGluIHRoZSBjb250ZXh0LCB0aGUgdmFsdWVzIHdpbGwgYmUgdXNlZC4gT3RoZXJ3aXNlLCBhXG4gKiBzeXN0ZW0tZmFsbGJhY2sgd2hpY2ggdXNlcyBgRm46OkdldEFac2Agd2lsbCBiZSB1c2VkLlxuICovXG5leHBvcnQgY29uc3QgQVZBSUxBQklMSVRZX1pPTkVfRkFMTEJBQ0tfQ09OVEVYVF9LRVkgPSAnYXdzOmNkazphdmFpbGFiaWxpdHktem9uZXM6ZmFsbGJhY2snO1xuXG4vKipcbiAqIFJlc3BvbnNlIG9mIHRoZSBBWiBwcm92aWRlciBsb29rcyBsaWtlIHRoaXNcbiAqL1xuZXhwb3J0IHR5cGUgQXZhaWxhYmlsaXR5Wm9uZXNDb250ZXh0UmVzcG9uc2UgPSBzdHJpbmdbXTtcbiJdfQ==
@@ -0,0 +1,22 @@
1
+ export declare const ENDPOINT_SERVICE_AVAILABILITY_ZONE_PROVIDER = "endpoint-service-availability-zones";
2
+ /**
3
+ * Query to hosted zone context provider
4
+ */
5
+ export interface EndpointServiceAvailabilityZonesContextQuery {
6
+ /**
7
+ * Query account
8
+ */
9
+ readonly account?: string;
10
+ /**
11
+ * Query region
12
+ */
13
+ readonly region?: string;
14
+ /**
15
+ * Query service name
16
+ */
17
+ readonly serviceName?: string;
18
+ }
19
+ /**
20
+ * Response of the AZ provider looks like this
21
+ */
22
+ export type EndpointServiceAvailabilityZonesContextResponse = string[];
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ENDPOINT_SERVICE_AVAILABILITY_ZONE_PROVIDER = void 0;
4
+ exports.ENDPOINT_SERVICE_AVAILABILITY_ZONE_PROVIDER = 'endpoint-service-availability-zones';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5kcG9pbnQtc2VydmljZS1hdmFpbGFiaWxpdHktem9uZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJlbmRwb2ludC1zZXJ2aWNlLWF2YWlsYWJpbGl0eS16b25lcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBYSxRQUFBLDJDQUEyQyxHQUFHLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IEVORFBPSU5UX1NFUlZJQ0VfQVZBSUxBQklMSVRZX1pPTkVfUFJPVklERVIgPSAnZW5kcG9pbnQtc2VydmljZS1hdmFpbGFiaWxpdHktem9uZXMnO1xuXG4vKipcbiAqIFF1ZXJ5IHRvIGhvc3RlZCB6b25lIGNvbnRleHQgcHJvdmlkZXJcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFbmRwb2ludFNlcnZpY2VBdmFpbGFiaWxpdHlab25lc0NvbnRleHRRdWVyeSB7XG4gIC8qKlxuICAgKiBRdWVyeSBhY2NvdW50XG4gICAqL1xuICByZWFkb25seSBhY2NvdW50Pzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBRdWVyeSByZWdpb25cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbj86IHN0cmluZztcblxuICAvKipcbiAgICogUXVlcnkgc2VydmljZSBuYW1lXG4gICAqL1xuICByZWFkb25seSBzZXJ2aWNlTmFtZT86IHN0cmluZztcbn1cblxuLyoqXG4gKiBSZXNwb25zZSBvZiB0aGUgQVogcHJvdmlkZXIgbG9va3MgbGlrZSB0aGlzXG4gKi9cbmV4cG9ydCB0eXBlIEVuZHBvaW50U2VydmljZUF2YWlsYWJpbGl0eVpvbmVzQ29udGV4dFJlc3BvbnNlID0gc3RyaW5nW107XG4iXX0=
@@ -0,0 +1,4 @@
1
+ /**
2
+ * If a context value is an object with this key, it indicates an error
3
+ */
4
+ export declare const PROVIDER_ERROR_KEY = "$providerError";
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PROVIDER_ERROR_KEY = void 0;
4
+ /**
5
+ * If a context value is an object with this key, it indicates an error
6
+ */
7
+ exports.PROVIDER_ERROR_KEY = '$providerError';
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJpYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImdlbmVyaWMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUE7O0dBRUc7QUFDVSxRQUFBLGtCQUFrQixHQUFHLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBJZiBhIGNvbnRleHQgdmFsdWUgaXMgYW4gb2JqZWN0IHdpdGggdGhpcyBrZXksIGl0IGluZGljYXRlcyBhbiBlcnJvclxuICovXG5leHBvcnQgY29uc3QgUFJPVklERVJfRVJST1JfS0VZID0gJyRwcm92aWRlckVycm9yJztcbiJdfQ==
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Properties of a discovered key
3
+ */
4
+ export interface KeyContextResponse {
5
+ /**
6
+ * Id of the key
7
+ */
8
+ readonly keyId: string;
9
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsia2V5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFByb3BlcnRpZXMgb2YgYSBkaXNjb3ZlcmVkIGtleVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEtleUNvbnRleHRSZXNwb25zZSB7XG5cbiAgLyoqXG4gICAqIElkIG9mIHRoZSBrZXlcbiAgICovXG4gIHJlYWRvbmx5IGtleUlkOiBzdHJpbmc7XG5cbn1cbiJdfQ==
@@ -0,0 +1,63 @@
1
+ /**
2
+ * Load balancer ip address type.
3
+ */
4
+ export declare enum LoadBalancerIpAddressType {
5
+ /**
6
+ * IPV4 ip address
7
+ */
8
+ IPV4 = "ipv4",
9
+ /**
10
+ * Dual stack address
11
+ */
12
+ DUAL_STACK = "dualstack",
13
+ /**
14
+ * IPv6 only public addresses, with private IPv4 and IPv6 addresses
15
+ */
16
+ DUAL_STACK_WITHOUT_PUBLIC_IPV4 = "dualstack-without-public-ipv4"
17
+ }
18
+ /**
19
+ * Properties of a discovered load balancer
20
+ */
21
+ export interface LoadBalancerContextResponse {
22
+ /**
23
+ * The ARN of the load balancer.
24
+ */
25
+ readonly loadBalancerArn: string;
26
+ /**
27
+ * The hosted zone ID of the load balancer's name.
28
+ */
29
+ readonly loadBalancerCanonicalHostedZoneId: string;
30
+ /**
31
+ * Load balancer's DNS name
32
+ */
33
+ readonly loadBalancerDnsName: string;
34
+ /**
35
+ * Type of IP address
36
+ */
37
+ readonly ipAddressType: LoadBalancerIpAddressType;
38
+ /**
39
+ * Load balancer's security groups
40
+ */
41
+ readonly securityGroupIds: string[];
42
+ /**
43
+ * Load balancer's VPC
44
+ */
45
+ readonly vpcId: string;
46
+ }
47
+ /**
48
+ * Properties of a discovered load balancer listener.
49
+ */
50
+ export interface LoadBalancerListenerContextResponse {
51
+ /**
52
+ * The ARN of the listener.
53
+ */
54
+ readonly listenerArn: string;
55
+ /**
56
+ * The port the listener is listening on.
57
+ */
58
+ readonly listenerPort: number;
59
+ /**
60
+ * The security groups of the load balancer.
61
+ */
62
+ readonly securityGroupIds: string[];
63
+ }
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LoadBalancerIpAddressType = void 0;
4
+ /**
5
+ * Load balancer ip address type.
6
+ */
7
+ var LoadBalancerIpAddressType;
8
+ (function (LoadBalancerIpAddressType) {
9
+ /**
10
+ * IPV4 ip address
11
+ */
12
+ LoadBalancerIpAddressType["IPV4"] = "ipv4";
13
+ /**
14
+ * Dual stack address
15
+ */
16
+ LoadBalancerIpAddressType["DUAL_STACK"] = "dualstack";
17
+ /**
18
+ * IPv6 only public addresses, with private IPv4 and IPv6 addresses
19
+ */
20
+ LoadBalancerIpAddressType["DUAL_STACK_WITHOUT_PUBLIC_IPV4"] = "dualstack-without-public-ipv4";
21
+ })(LoadBalancerIpAddressType || (exports.LoadBalancerIpAddressType = LoadBalancerIpAddressType = {}));
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZC1iYWxhbmNlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImxvYWQtYmFsYW5jZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUE7O0dBRUc7QUFDSCxJQUFZLHlCQWVYO0FBZkQsV0FBWSx5QkFBeUI7SUFDbkM7O09BRUc7SUFDSCwwQ0FBYSxDQUFBO0lBRWI7O09BRUc7SUFDSCxxREFBd0IsQ0FBQTtJQUV4Qjs7T0FFRztJQUNILDZGQUFnRSxDQUFBO0FBQ2xFLENBQUMsRUFmVyx5QkFBeUIseUNBQXpCLHlCQUF5QixRQWVwQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTG9hZCBiYWxhbmNlciBpcCBhZGRyZXNzIHR5cGUuXG4gKi9cbmV4cG9ydCBlbnVtIExvYWRCYWxhbmNlcklwQWRkcmVzc1R5cGUge1xuICAvKipcbiAgICogSVBWNCBpcCBhZGRyZXNzXG4gICAqL1xuICBJUFY0ID0gJ2lwdjQnLFxuXG4gIC8qKlxuICAgKiBEdWFsIHN0YWNrIGFkZHJlc3NcbiAgICovXG4gIERVQUxfU1RBQ0sgPSAnZHVhbHN0YWNrJyxcblxuICAvKipcbiAgICogSVB2NiBvbmx5IHB1YmxpYyBhZGRyZXNzZXMsIHdpdGggcHJpdmF0ZSBJUHY0IGFuZCBJUHY2IGFkZHJlc3Nlc1xuICAgKi9cbiAgRFVBTF9TVEFDS19XSVRIT1VUX1BVQkxJQ19JUFY0ID0gJ2R1YWxzdGFjay13aXRob3V0LXB1YmxpYy1pcHY0Jyxcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIG9mIGEgZGlzY292ZXJlZCBsb2FkIGJhbGFuY2VyXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTG9hZEJhbGFuY2VyQ29udGV4dFJlc3BvbnNlIHtcbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIGxvYWQgYmFsYW5jZXIuXG4gICAqL1xuICByZWFkb25seSBsb2FkQmFsYW5jZXJBcm46IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIGhvc3RlZCB6b25lIElEIG9mIHRoZSBsb2FkIGJhbGFuY2VyJ3MgbmFtZS5cbiAgICovXG4gIHJlYWRvbmx5IGxvYWRCYWxhbmNlckNhbm9uaWNhbEhvc3RlZFpvbmVJZDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBMb2FkIGJhbGFuY2VyJ3MgRE5TIG5hbWVcbiAgICovXG4gIHJlYWRvbmx5IGxvYWRCYWxhbmNlckRuc05hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogVHlwZSBvZiBJUCBhZGRyZXNzXG4gICAqL1xuICByZWFkb25seSBpcEFkZHJlc3NUeXBlOiBMb2FkQmFsYW5jZXJJcEFkZHJlc3NUeXBlO1xuXG4gIC8qKlxuICAgKiBMb2FkIGJhbGFuY2VyJ3Mgc2VjdXJpdHkgZ3JvdXBzXG4gICAqL1xuICByZWFkb25seSBzZWN1cml0eUdyb3VwSWRzOiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogTG9hZCBiYWxhbmNlcidzIFZQQ1xuICAgKi9cbiAgcmVhZG9ubHkgdnBjSWQ6IHN0cmluZztcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIG9mIGEgZGlzY292ZXJlZCBsb2FkIGJhbGFuY2VyIGxpc3RlbmVyLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIExvYWRCYWxhbmNlckxpc3RlbmVyQ29udGV4dFJlc3BvbnNlIHtcbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIGxpc3RlbmVyLlxuICAgKi9cbiAgcmVhZG9ubHkgbGlzdGVuZXJBcm46IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHBvcnQgdGhlIGxpc3RlbmVyIGlzIGxpc3RlbmluZyBvbi5cbiAgICovXG4gIHJlYWRvbmx5IGxpc3RlbmVyUG9ydDogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBUaGUgc2VjdXJpdHkgZ3JvdXBzIG9mIHRoZSBsb2FkIGJhbGFuY2VyLlxuICAgKi9cbiAgcmVhZG9ubHkgc2VjdXJpdHlHcm91cElkczogc3RyaW5nW107XG59XG4iXX0=
@@ -0,0 +1,15 @@
1
+ /**
2
+ * Properties of a discovered SecurityGroup.
3
+ */
4
+ export interface SecurityGroupContextResponse {
5
+ /**
6
+ * The security group's id.
7
+ */
8
+ readonly securityGroupId: string;
9
+ /**
10
+ * Whether the security group allows all outbound traffic. This will be true
11
+ * when the security group has all-protocol egress permissions to access both
12
+ * `0.0.0.0/0` and `::/0`.
13
+ */
14
+ readonly allowAllOutbound: boolean;
15
+ }