@aws-cdk/cloud-assembly-api 0.0.1 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +202 -0
- package/README.md +15 -41
- package/design/NESTED_ASSEMBLIES.md +93 -0
- package/lib/artifacts/asset-manifest-artifact.d.ts +46 -0
- package/lib/artifacts/asset-manifest-artifact.js +66 -0
- package/lib/artifacts/cloudformation-artifact.d.ts +147 -0
- package/lib/artifacts/cloudformation-artifact.js +94 -0
- package/lib/artifacts/nested-cloud-assembly-artifact-aug.d.ts +1 -0
- package/lib/artifacts/nested-cloud-assembly-artifact-aug.js +19 -0
- package/lib/artifacts/nested-cloud-assembly-artifact.d.ts +45 -0
- package/lib/artifacts/nested-cloud-assembly-artifact.js +56 -0
- package/lib/artifacts/tree-cloud-artifact.d.ts +25 -0
- package/lib/artifacts/tree-cloud-artifact.js +49 -0
- package/lib/assets.d.ts +33 -0
- package/lib/assets.js +37 -0
- package/lib/bootstrap.d.ts +7 -0
- package/lib/bootstrap.js +12 -0
- package/lib/cloud-artifact-aug.d.ts +1 -0
- package/lib/cloud-artifact-aug.js +29 -0
- package/lib/cloud-artifact.d.ts +73 -0
- package/lib/cloud-artifact.js +94 -0
- package/lib/cloud-assembly.d.ts +266 -0
- package/lib/cloud-assembly.js +374 -0
- package/lib/context/ami.d.ts +4 -0
- package/lib/context/ami.js +3 -0
- package/lib/context/availability-zones.d.ts +12 -0
- package/lib/context/availability-zones.js +12 -0
- package/lib/context/endpoint-service-availability-zones.d.ts +22 -0
- package/lib/context/endpoint-service-availability-zones.js +5 -0
- package/lib/context/generic.d.ts +4 -0
- package/lib/context/generic.js +8 -0
- package/lib/context/key.d.ts +9 -0
- package/lib/context/key.js +3 -0
- package/lib/context/load-balancer.d.ts +63 -0
- package/lib/context/load-balancer.js +22 -0
- package/lib/context/security-group.d.ts +15 -0
- package/lib/context/security-group.js +3 -0
- package/lib/context/vpc.d.ts +152 -0
- package/lib/context/vpc.js +18 -0
- package/lib/environment.d.ts +24 -0
- package/lib/environment.js +40 -0
- package/lib/index.d.ts +21 -0
- package/lib/index.js +38 -0
- package/lib/metadata.d.ts +27 -0
- package/lib/metadata.js +14 -0
- package/lib/placeholders.d.ts +66 -0
- package/lib/placeholders.js +90 -0
- package/lib/private/error.d.ts +1 -0
- package/lib/private/error.js +47 -0
- package/lib/private/toposort.d.ts +11 -0
- package/lib/private/toposort.js +35 -0
- package/node_modules/jsonschema/.editorconfig +10 -0
- package/node_modules/jsonschema/LICENSE +21 -0
- package/node_modules/jsonschema/README.md +421 -0
- package/node_modules/jsonschema/lib/attribute.js +978 -0
- package/node_modules/jsonschema/lib/helpers.js +390 -0
- package/node_modules/jsonschema/lib/index.d.ts +142 -0
- package/node_modules/jsonschema/lib/index.js +15 -0
- package/node_modules/jsonschema/lib/scan.js +75 -0
- package/node_modules/jsonschema/lib/validator.js +336 -0
- package/node_modules/jsonschema/package.json +42 -0
- package/node_modules/semver/LICENSE +15 -0
- package/node_modules/semver/README.md +664 -0
- package/node_modules/semver/bin/semver.js +191 -0
- package/node_modules/semver/classes/comparator.js +143 -0
- package/node_modules/semver/classes/index.js +7 -0
- package/node_modules/semver/classes/range.js +557 -0
- package/node_modules/semver/classes/semver.js +333 -0
- package/node_modules/semver/functions/clean.js +8 -0
- package/node_modules/semver/functions/cmp.js +54 -0
- package/node_modules/semver/functions/coerce.js +62 -0
- package/node_modules/semver/functions/compare-build.js +9 -0
- package/node_modules/semver/functions/compare-loose.js +5 -0
- package/node_modules/semver/functions/compare.js +7 -0
- package/node_modules/semver/functions/diff.js +60 -0
- package/node_modules/semver/functions/eq.js +5 -0
- package/node_modules/semver/functions/gt.js +5 -0
- package/node_modules/semver/functions/gte.js +5 -0
- package/node_modules/semver/functions/inc.js +21 -0
- package/node_modules/semver/functions/lt.js +5 -0
- package/node_modules/semver/functions/lte.js +5 -0
- package/node_modules/semver/functions/major.js +5 -0
- package/node_modules/semver/functions/minor.js +5 -0
- package/node_modules/semver/functions/neq.js +5 -0
- package/node_modules/semver/functions/parse.js +18 -0
- package/node_modules/semver/functions/patch.js +5 -0
- package/node_modules/semver/functions/prerelease.js +8 -0
- package/node_modules/semver/functions/rcompare.js +5 -0
- package/node_modules/semver/functions/rsort.js +5 -0
- package/node_modules/semver/functions/satisfies.js +12 -0
- package/node_modules/semver/functions/sort.js +5 -0
- package/node_modules/semver/functions/valid.js +8 -0
- package/node_modules/semver/index.js +91 -0
- package/node_modules/semver/internal/constants.js +37 -0
- package/node_modules/semver/internal/debug.js +11 -0
- package/node_modules/semver/internal/identifiers.js +29 -0
- package/node_modules/semver/internal/lrucache.js +42 -0
- package/node_modules/semver/internal/parse-options.js +17 -0
- package/node_modules/semver/internal/re.js +223 -0
- package/node_modules/semver/package.json +78 -0
- package/node_modules/semver/preload.js +4 -0
- package/node_modules/semver/range.bnf +16 -0
- package/node_modules/semver/ranges/gtr.js +6 -0
- package/node_modules/semver/ranges/intersects.js +9 -0
- package/node_modules/semver/ranges/ltr.js +6 -0
- package/node_modules/semver/ranges/max-satisfying.js +27 -0
- package/node_modules/semver/ranges/min-satisfying.js +26 -0
- package/node_modules/semver/ranges/min-version.js +63 -0
- package/node_modules/semver/ranges/outside.js +82 -0
- package/node_modules/semver/ranges/simplify.js +49 -0
- package/node_modules/semver/ranges/subset.js +249 -0
- package/node_modules/semver/ranges/to-comparators.js +10 -0
- package/node_modules/semver/ranges/valid.js +13 -0
- package/package.json +80 -6
|
@@ -0,0 +1,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,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,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,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
|
+
}
|