@cdktn/cli-core 0.23.0-pre.8 → 0.24.0-pre.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/ambient.d.ts +0 -1
- package/build/lib/cdktf-config.d.ts.map +1 -0
- package/build/lib/cdktf-config.js +108 -0
- package/build/lib/cdktf-project-io-handler.d.ts.map +1 -0
- package/build/lib/cdktf-project-io-handler.js +84 -0
- package/build/lib/cdktf-project.d.ts.map +1 -0
- package/build/lib/cdktf-project.js +370 -0
- package/{src → build}/lib/cdktf-stack.d.ts +1 -0
- package/build/lib/cdktf-stack.d.ts.map +1 -0
- package/build/lib/cdktf-stack.js +386 -0
- package/build/lib/convert.d.ts.map +1 -0
- package/build/lib/convert.js +51 -0
- package/build/lib/dependencies/cdktf-config-manager.d.ts.map +1 -0
- package/build/lib/dependencies/cdktf-config-manager.js +36 -0
- package/build/lib/dependencies/dependency-manager.d.ts.map +1 -0
- package/build/lib/dependencies/dependency-manager.js +393 -0
- package/build/lib/dependencies/package-manager.d.ts.map +1 -0
- package/build/lib/dependencies/package-manager.js +581 -0
- package/build/lib/dependencies/prebuilt-providers.d.ts.map +1 -0
- package/build/lib/dependencies/prebuilt-providers.js +221 -0
- package/build/lib/dependencies/registry-api.d.ts.map +1 -0
- package/build/lib/dependencies/registry-api.js +77 -0
- package/build/lib/dependencies/version-constraints.d.ts.map +1 -0
- package/build/lib/dependencies/version-constraints.js +95 -0
- package/build/lib/error-reporting.d.ts.map +1 -0
- package/build/lib/error-reporting.js +133 -0
- package/build/lib/errors.d.ts.map +1 -0
- package/build/lib/errors.js +10 -0
- package/build/lib/execution-logs.d.ts.map +1 -0
- package/build/lib/execution-logs.js +47 -0
- package/build/lib/get.d.ts.map +1 -0
- package/build/lib/get.js +90 -0
- package/build/lib/helpers/stack-helpers.d.ts.map +1 -0
- package/build/lib/helpers/stack-helpers.js +155 -0
- package/build/lib/index.d.ts.map +1 -0
- package/{src → build}/lib/index.js +1 -2
- package/build/lib/init.d.ts.map +1 -0
- package/build/lib/init.js +131 -0
- package/build/lib/local-provider-constraints.d.ts.map +1 -0
- package/build/lib/local-provider-constraints.js +95 -0
- package/build/lib/local-provider-versions.d.ts.map +1 -0
- package/build/lib/local-provider-versions.js +73 -0
- package/{src → build}/lib/models/deploy-machine.d.ts +3 -11
- package/build/lib/models/deploy-machine.d.ts.map +1 -0
- package/build/lib/models/deploy-machine.js +283 -0
- package/build/lib/models/interactive-process.d.ts +28 -0
- package/build/lib/models/interactive-process.d.ts.map +1 -0
- package/build/lib/models/interactive-process.js +59 -0
- package/{src → build}/lib/models/schema.d.ts.map +1 -1
- package/build/lib/models/schema.js +181 -0
- package/{src → build}/lib/models/terraform-cli.d.ts +1 -0
- package/build/lib/models/terraform-cli.d.ts.map +1 -0
- package/build/lib/models/terraform-cli.js +355 -0
- package/build/lib/models/terraform.d.ts.map +1 -0
- package/build/lib/models/terraform.js +72 -0
- package/build/lib/output.d.ts.map +1 -0
- package/build/lib/output.js +211 -0
- package/build/lib/provider-add.d.ts.map +1 -0
- package/build/lib/provider-add.js +30 -0
- package/build/lib/server/terraform-logs.d.ts.map +1 -0
- package/build/lib/server/terraform-logs.js +19 -0
- package/{src → build}/lib/synth-stack.d.ts +1 -0
- package/build/lib/synth-stack.d.ts.map +1 -0
- package/build/lib/synth-stack.js +251 -0
- package/build/lib/synth.d.ts.map +1 -0
- package/build/lib/synth.js +67 -0
- package/{src → build}/lib/terraform-json.d.ts.map +1 -1
- package/build/lib/terraform-json.js +82 -0
- package/build/lib/terraform-provider-lock.d.ts.map +1 -0
- package/{src → build}/lib/terraform-provider-lock.js +2 -2
- package/{src → build}/lib/watch.d.ts +1 -0
- package/build/lib/watch.d.ts.map +1 -0
- package/build/lib/watch.js +155 -0
- package/eslint.config.mjs +2 -70
- package/package.json +22 -33
- package/templates/go/go.mod +1 -1
- package/templates/python/Pipfile +1 -1
- package/templates/typescript/.hooks.sscaff.js +1 -1
- package/templates/typescript/jest.config.js +1 -1
- package/src/lib/cdktf-config.d.ts.map +0 -1
- package/src/lib/cdktf-config.js +0 -108
- package/src/lib/cdktf-project-io-handler.d.ts.map +0 -1
- package/src/lib/cdktf-project-io-handler.js +0 -84
- package/src/lib/cdktf-project.d.ts.map +0 -1
- package/src/lib/cdktf-project.js +0 -371
- package/src/lib/cdktf-stack.d.ts.map +0 -1
- package/src/lib/cdktf-stack.js +0 -386
- package/src/lib/convert.d.ts.map +0 -1
- package/src/lib/convert.js +0 -51
- package/src/lib/dependencies/cdktf-config-manager.d.ts.map +0 -1
- package/src/lib/dependencies/cdktf-config-manager.js +0 -36
- package/src/lib/dependencies/dependency-manager.d.ts.map +0 -1
- package/src/lib/dependencies/dependency-manager.js +0 -393
- package/src/lib/dependencies/package-manager.d.ts.map +0 -1
- package/src/lib/dependencies/package-manager.js +0 -581
- package/src/lib/dependencies/prebuilt-providers.d.ts.map +0 -1
- package/src/lib/dependencies/prebuilt-providers.js +0 -220
- package/src/lib/dependencies/registry-api.d.ts.map +0 -1
- package/src/lib/dependencies/registry-api.js +0 -77
- package/src/lib/dependencies/version-constraints.d.ts.map +0 -1
- package/src/lib/dependencies/version-constraints.js +0 -95
- package/src/lib/error-reporting.d.ts.map +0 -1
- package/src/lib/error-reporting.js +0 -133
- package/src/lib/errors.d.ts.map +0 -1
- package/src/lib/errors.js +0 -10
- package/src/lib/execution-logs.d.ts.map +0 -1
- package/src/lib/execution-logs.js +0 -47
- package/src/lib/get.d.ts.map +0 -1
- package/src/lib/get.js +0 -90
- package/src/lib/helpers/stack-helpers.d.ts.map +0 -1
- package/src/lib/helpers/stack-helpers.js +0 -155
- package/src/lib/index.d.ts.map +0 -1
- package/src/lib/init.d.ts.map +0 -1
- package/src/lib/init.js +0 -131
- package/src/lib/local-provider-constraints.d.ts.map +0 -1
- package/src/lib/local-provider-constraints.js +0 -95
- package/src/lib/local-provider-versions.d.ts.map +0 -1
- package/src/lib/local-provider-versions.js +0 -73
- package/src/lib/models/deploy-machine.d.ts.map +0 -1
- package/src/lib/models/deploy-machine.js +0 -280
- package/src/lib/models/pty-process.d.ts +0 -29
- package/src/lib/models/pty-process.d.ts.map +0 -1
- package/src/lib/models/pty-process.js +0 -132
- package/src/lib/models/schema.js +0 -181
- package/src/lib/models/terraform-cli.d.ts.map +0 -1
- package/src/lib/models/terraform-cli.js +0 -357
- package/src/lib/models/terraform.d.ts.map +0 -1
- package/src/lib/models/terraform.js +0 -72
- package/src/lib/output.d.ts.map +0 -1
- package/src/lib/output.js +0 -211
- package/src/lib/provider-add.d.ts.map +0 -1
- package/src/lib/provider-add.js +0 -30
- package/src/lib/server/terraform-logs.d.ts.map +0 -1
- package/src/lib/server/terraform-logs.js +0 -19
- package/src/lib/synth-stack.d.ts.map +0 -1
- package/src/lib/synth-stack.js +0 -251
- package/src/lib/synth.d.ts.map +0 -1
- package/src/lib/synth.js +0 -67
- package/src/lib/terraform-json.js +0 -82
- package/src/lib/terraform-provider-lock.d.ts.map +0 -1
- package/src/lib/watch.d.ts.map +0 -1
- package/src/lib/watch.js +0 -155
- /package/{src → build}/lib/cdktf-config.d.ts +0 -0
- /package/{src → build}/lib/cdktf-project-io-handler.d.ts +0 -0
- /package/{src → build}/lib/cdktf-project.d.ts +0 -0
- /package/{src → build}/lib/convert.d.ts +0 -0
- /package/{src → build}/lib/dependencies/cdktf-config-manager.d.ts +0 -0
- /package/{src → build}/lib/dependencies/dependency-manager.d.ts +0 -0
- /package/{src → build}/lib/dependencies/package-manager.d.ts +0 -0
- /package/{src → build}/lib/dependencies/prebuilt-providers.d.ts +0 -0
- /package/{src → build}/lib/dependencies/registry-api.d.ts +0 -0
- /package/{src → build}/lib/dependencies/version-constraints.d.ts +0 -0
- /package/{src → build}/lib/error-reporting.d.ts +0 -0
- /package/{src → build}/lib/errors.d.ts +0 -0
- /package/{src → build}/lib/execution-logs.d.ts +0 -0
- /package/{src → build}/lib/get.d.ts +0 -0
- /package/{src → build}/lib/helpers/stack-helpers.d.ts +0 -0
- /package/{src → build}/lib/index.d.ts +0 -0
- /package/{src → build}/lib/init.d.ts +0 -0
- /package/{src → build}/lib/local-provider-constraints.d.ts +0 -0
- /package/{src → build}/lib/local-provider-versions.d.ts +0 -0
- /package/{src → build}/lib/models/schema.d.ts +0 -0
- /package/{src → build}/lib/models/terraform.d.ts +0 -0
- /package/{src → build}/lib/output.d.ts +0 -0
- /package/{src → build}/lib/provider-add.d.ts +0 -0
- /package/{src → build}/lib/server/terraform-logs.d.ts +0 -0
- /package/{src → build}/lib/synth.d.ts +0 -0
- /package/{src → build}/lib/terraform-json.d.ts +0 -0
- /package/{src → build}/lib/terraform-provider-lock.d.ts +0 -0
|
@@ -0,0 +1,370 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CdktfProject = exports.isWaitingForUserInputUpdate = void 0;
|
|
4
|
+
// Copyright (c) HashiCorp, Inc
|
|
5
|
+
// SPDX-License-Identifier: MPL-2.0
|
|
6
|
+
const commons_1 = require("@cdktn/commons");
|
|
7
|
+
const synth_stack_1 = require("./synth-stack");
|
|
8
|
+
const synth_1 = require("./synth");
|
|
9
|
+
const cdktf_stack_1 = require("./cdktf-stack");
|
|
10
|
+
const execution_logs_1 = require("./execution-logs");
|
|
11
|
+
const stack_helpers_1 = require("./helpers/stack-helpers");
|
|
12
|
+
const cdktf_project_io_handler_1 = require("./cdktf-project-io-handler");
|
|
13
|
+
function isWaitingForUserInputUpdate(update) {
|
|
14
|
+
return ["waiting for approval", "waiting for sentinel override"].includes(update.type);
|
|
15
|
+
}
|
|
16
|
+
exports.isWaitingForUserInputUpdate = isWaitingForUserInputUpdate;
|
|
17
|
+
class CdktfProject {
|
|
18
|
+
constructor({ synthCommand, outDir, onUpdate, onLog, workingDirectory = process.cwd(), synthOrigin, hcl = false, }) {
|
|
19
|
+
// Set during deploy / destroy
|
|
20
|
+
this.stacksToRun = [];
|
|
21
|
+
// This means sth different in deploy / destroy
|
|
22
|
+
this.stopAllStacksThatCanNotRunWithout = () => { };
|
|
23
|
+
this.synthCommand = synthCommand;
|
|
24
|
+
this.outDir = outDir;
|
|
25
|
+
this.workingDirectory = workingDirectory;
|
|
26
|
+
this.onUpdate = onUpdate;
|
|
27
|
+
this.onLog = onLog;
|
|
28
|
+
const ac = new AbortController();
|
|
29
|
+
this.abortSignal = ac.signal;
|
|
30
|
+
this.synthOrigin = synthOrigin;
|
|
31
|
+
this.hcl =
|
|
32
|
+
process.env.SYNTH_HCL_OUTPUT === "true" ||
|
|
33
|
+
process.env.SYNTH_HCL_OUTPUT === "1" ||
|
|
34
|
+
hcl;
|
|
35
|
+
this.hardAbort = ac.abort.bind(ac);
|
|
36
|
+
this.ioHandler = new cdktf_project_io_handler_1.CdktfProjectIOHandler();
|
|
37
|
+
}
|
|
38
|
+
stopAllStacks() {
|
|
39
|
+
this.stacksToRun.forEach((stack) => stack.stop());
|
|
40
|
+
this.ioHandler.filterUserInputEventsFromBuffer();
|
|
41
|
+
}
|
|
42
|
+
handleUserUpdate(update, operations, originalCallback, eventType) {
|
|
43
|
+
const callbacks = (update) => Object.fromEntries(Object.entries(operations).map(([key, value]) => {
|
|
44
|
+
return [
|
|
45
|
+
key,
|
|
46
|
+
// This is passed in to make typescript happy only
|
|
47
|
+
(_) => {
|
|
48
|
+
value(update);
|
|
49
|
+
// We need to defer these calls for the case that approve() is instantly invoked
|
|
50
|
+
// in the listener that receives these callbacks as it otherwise would already
|
|
51
|
+
// remove the "waiting for stack approval" event from the buffer before we even
|
|
52
|
+
// set waitingForApproval to true (at the end of this if statement) which results
|
|
53
|
+
// in buffered updates which will never unblock
|
|
54
|
+
setTimeout(() => this.ioHandler.resumeAfterUserInput(update.stackName), 0);
|
|
55
|
+
},
|
|
56
|
+
];
|
|
57
|
+
}));
|
|
58
|
+
// always send to buffer, as resumeAfterUserInput() always expects a matching event
|
|
59
|
+
this.ioHandler.pushEvent({
|
|
60
|
+
cb: originalCallback,
|
|
61
|
+
value: {
|
|
62
|
+
type: eventType,
|
|
63
|
+
stackName: update.stackName,
|
|
64
|
+
...callbacks(update),
|
|
65
|
+
},
|
|
66
|
+
type: "projectUpdate",
|
|
67
|
+
});
|
|
68
|
+
// if we aren't already waiting, this needs to go to cb() too to arrive at the UI
|
|
69
|
+
if (!this.ioHandler.isWaitingForUserInput()) {
|
|
70
|
+
originalCallback({
|
|
71
|
+
type: eventType,
|
|
72
|
+
stackName: update.stackName,
|
|
73
|
+
...callbacks(update),
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
handleUserInputProcess(cb) {
|
|
78
|
+
return (update) => {
|
|
79
|
+
if (update.type === "external stack approval reply") {
|
|
80
|
+
if (!update.approved) {
|
|
81
|
+
this.stopAllStacksThatCanNotRunWithout(update.stackName);
|
|
82
|
+
}
|
|
83
|
+
this.ioHandler.resumeAfterUserInput(update.stackName);
|
|
84
|
+
return; // aka don't send this event to any buffer
|
|
85
|
+
}
|
|
86
|
+
if (update.type === "external stack sentinel override reply") {
|
|
87
|
+
if (!update.overridden) {
|
|
88
|
+
this.stopAllStacksThatCanNotRunWithout(update.stackName);
|
|
89
|
+
}
|
|
90
|
+
this.ioHandler.resumeAfterUserInput(update.stackName);
|
|
91
|
+
return; // aka don't send this event to any buffer
|
|
92
|
+
}
|
|
93
|
+
if (update.type === "waiting for stack approval" ||
|
|
94
|
+
update.type === "waiting for stack sentinel override") {
|
|
95
|
+
if (update.type === "waiting for stack approval") {
|
|
96
|
+
this.handleUserUpdate(update, {
|
|
97
|
+
approve: (update) => update.approve(),
|
|
98
|
+
dismiss: (update) => {
|
|
99
|
+
update.reject();
|
|
100
|
+
this.stopAllStacksThatCanNotRunWithout(update.stackName);
|
|
101
|
+
},
|
|
102
|
+
stop: (update) => {
|
|
103
|
+
update.reject();
|
|
104
|
+
this.stopAllStacks();
|
|
105
|
+
},
|
|
106
|
+
}, cb, "waiting for approval");
|
|
107
|
+
}
|
|
108
|
+
else if (update.type === "waiting for stack sentinel override") {
|
|
109
|
+
this.handleUserUpdate(update, {
|
|
110
|
+
override: (update) => {
|
|
111
|
+
update.override();
|
|
112
|
+
},
|
|
113
|
+
reject: (update) => {
|
|
114
|
+
update.reject();
|
|
115
|
+
this.stopAllStacksThatCanNotRunWithout(update.stackName);
|
|
116
|
+
},
|
|
117
|
+
}, cb, "waiting for sentinel override");
|
|
118
|
+
}
|
|
119
|
+
this.ioHandler.awaitUserInput();
|
|
120
|
+
}
|
|
121
|
+
else {
|
|
122
|
+
if (this.ioHandler.isWaitingForUserInput()) {
|
|
123
|
+
this.ioHandler.pushEvent({
|
|
124
|
+
cb,
|
|
125
|
+
value: update,
|
|
126
|
+
type: "projectUpdate",
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
cb(update);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
getStackExecutor(stack, opts = {}) {
|
|
136
|
+
const enhanceLogMessage = (0, execution_logs_1.createEnhanceLogMessage)(stack);
|
|
137
|
+
const onLog = this.ioHandler.bufferWhileAwaitingUserInput(this.onLog);
|
|
138
|
+
return new cdktf_stack_1.CdktfStack({
|
|
139
|
+
...opts,
|
|
140
|
+
stack,
|
|
141
|
+
onUpdate: this.handleUserInputProcess(this.onUpdate),
|
|
142
|
+
onLog: onLog
|
|
143
|
+
? ({ message }) => onLog({
|
|
144
|
+
stackName: stack.name,
|
|
145
|
+
message,
|
|
146
|
+
messageWithConstructPath: enhanceLogMessage(message),
|
|
147
|
+
})
|
|
148
|
+
: undefined,
|
|
149
|
+
abortSignal: this.abortSignal,
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
get outputsByConstructId() {
|
|
153
|
+
return this.stacksToRun.reduce((acc, stack) => ({
|
|
154
|
+
...acc,
|
|
155
|
+
...stack.outputsByConstructId,
|
|
156
|
+
}), {});
|
|
157
|
+
}
|
|
158
|
+
async synth(noColor) {
|
|
159
|
+
this.onUpdate({
|
|
160
|
+
type: "synthesizing",
|
|
161
|
+
});
|
|
162
|
+
const stacks = await synth_stack_1.SynthStack.synth(this.abortSignal, this.synthCommand, this.outDir, this.workingDirectory, false, noColor, this.synthOrigin, this.hcl);
|
|
163
|
+
(0, synth_1.printAnnotations)(stacks);
|
|
164
|
+
this.onUpdate({
|
|
165
|
+
type: "synthesized",
|
|
166
|
+
stacks,
|
|
167
|
+
});
|
|
168
|
+
return stacks;
|
|
169
|
+
}
|
|
170
|
+
async readSynthesizedStacks() {
|
|
171
|
+
const stacks = await synth_stack_1.SynthStack.readSynthesizedStacks(this.outDir);
|
|
172
|
+
(0, synth_1.printAnnotations)(stacks);
|
|
173
|
+
this.onUpdate({
|
|
174
|
+
type: "synthesized",
|
|
175
|
+
stacks,
|
|
176
|
+
});
|
|
177
|
+
return stacks;
|
|
178
|
+
}
|
|
179
|
+
async diff(opts = {}) {
|
|
180
|
+
const stacks = opts.skipSynth
|
|
181
|
+
? await this.readSynthesizedStacks()
|
|
182
|
+
: await this.synth(opts.noColor);
|
|
183
|
+
const stack = this.getStackExecutor((0, stack_helpers_1.getSingleStack)(stacks, opts === null || opts === void 0 ? void 0 : opts.stackName, "diff"));
|
|
184
|
+
await stack.initalizeTerraform(opts.noColor, opts.skipProviderLock, opts.migrateState);
|
|
185
|
+
try {
|
|
186
|
+
await stack.diff(opts);
|
|
187
|
+
}
|
|
188
|
+
catch (e) {
|
|
189
|
+
throw commons_1.Errors.External(`Stack failed to plan: ${stack.stack.name}. Please check the logs for more information.`, e);
|
|
190
|
+
}
|
|
191
|
+
if (stack.error) {
|
|
192
|
+
throw commons_1.Errors.External(`Stack failed to plan: ${stack.stack.name}. Please check the logs for more information.`, new Error(stack.error));
|
|
193
|
+
}
|
|
194
|
+
try {
|
|
195
|
+
await this.projectTelemetry("diff", {
|
|
196
|
+
stackMetadata: stacks.map((stack) => JSON.parse(stack.content)["//"]
|
|
197
|
+
? JSON.parse(stack.content)["//"].metadata
|
|
198
|
+
: {}),
|
|
199
|
+
errors: stack.error,
|
|
200
|
+
requiredProviders: stacks.map((stack) => JSON.parse(stack.content)["terraform"]
|
|
201
|
+
? JSON.parse(stack.content)["terraform"].required_providers
|
|
202
|
+
: {}),
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
catch (e) {
|
|
206
|
+
commons_1.logger.debug("Failed to send telemetry", e);
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
async execute(method, next, opts) {
|
|
210
|
+
// We only support refresh only on deploy, a bit of a leaky abstraction here
|
|
211
|
+
if (opts.refreshOnly && method !== "deploy") {
|
|
212
|
+
throw commons_1.Errors.Internal(`Refresh only is only supported on deploy`);
|
|
213
|
+
}
|
|
214
|
+
const maxParallelRuns = !opts.parallelism || opts.parallelism < 0 ? Infinity : opts.parallelism;
|
|
215
|
+
const allExecutions = [];
|
|
216
|
+
await this.initializeStacksToRunInSerial(opts.noColor, opts.skipProviderLock, opts.migrateState);
|
|
217
|
+
while (this.stacksToRun.filter((stack) => stack.isPending).length > 0) {
|
|
218
|
+
const runningStacks = this.stacksToRun.filter((stack) => stack.isRunning);
|
|
219
|
+
if (runningStacks.length >= maxParallelRuns) {
|
|
220
|
+
await Promise.race(runningStacks.map((s) => s.currentWorkPromise));
|
|
221
|
+
continue;
|
|
222
|
+
}
|
|
223
|
+
try {
|
|
224
|
+
const nextRunningExecutor = await next();
|
|
225
|
+
if (!nextRunningExecutor) {
|
|
226
|
+
// In this case we have no pending stacks, but we also can not find a new executor
|
|
227
|
+
break;
|
|
228
|
+
}
|
|
229
|
+
const promise = method === "deploy"
|
|
230
|
+
? nextRunningExecutor.deploy(opts)
|
|
231
|
+
: nextRunningExecutor.destroy(opts);
|
|
232
|
+
allExecutions.push(promise);
|
|
233
|
+
}
|
|
234
|
+
catch (e) {
|
|
235
|
+
// await next() threw an error because a stack failed to apply/destroy
|
|
236
|
+
// wait for all other currently running stacks to complete before propagating that error
|
|
237
|
+
commons_1.logger.debug("Encountered an error while awaiting stack to finish", e);
|
|
238
|
+
const openStacks = this.stacksToRun.filter((ex) => ex.currentWorkPromise);
|
|
239
|
+
commons_1.logger.debug("Waiting for still running stacks to finish:", openStacks);
|
|
240
|
+
await Promise.allSettled(openStacks.map((ex) => ex.currentWorkPromise));
|
|
241
|
+
commons_1.logger.debug("Done waiting for still running stacks. All pending work finished");
|
|
242
|
+
throw e;
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
// We end the loop when all stacks are started, now we need to wait for them to be done
|
|
246
|
+
// We wait for all work to finish even if one of the promises threw an error.
|
|
247
|
+
await (0, commons_1.ensureAllSettledBeforeThrowing)(Promise.all(allExecutions), allExecutions);
|
|
248
|
+
}
|
|
249
|
+
async deploy(opts = {}) {
|
|
250
|
+
const stacks = opts.skipSynth
|
|
251
|
+
? await this.readSynthesizedStacks()
|
|
252
|
+
: await this.synth(opts.noColor);
|
|
253
|
+
const stacksToRun = (0, stack_helpers_1.getMultipleStacks)(stacks, opts.stackNames, "deploy");
|
|
254
|
+
if (!opts.ignoreMissingStackDependencies) {
|
|
255
|
+
(0, stack_helpers_1.checkIfAllDependenciesAreIncluded)(stacksToRun);
|
|
256
|
+
}
|
|
257
|
+
this.stopAllStacksThatCanNotRunWithout = (stackName) => {
|
|
258
|
+
(0, stack_helpers_1.findAllNestedDependantStacks)(this.stacksToRun, stackName).forEach((stack) => stack.stop());
|
|
259
|
+
};
|
|
260
|
+
this.stacksToRun = stacksToRun.map((stack) => this.getStackExecutor(stack, opts));
|
|
261
|
+
const next = opts.ignoreMissingStackDependencies
|
|
262
|
+
? () => Promise.resolve(this.stacksToRun.filter((stack) => stack.isPending)[0])
|
|
263
|
+
: () => (0, stack_helpers_1.getStackWithNoUnmetDependencies)(this.stacksToRun);
|
|
264
|
+
await this.execute("deploy", next, opts);
|
|
265
|
+
const unprocessedStacks = this.stacksToRun.filter((executor) => executor.isPending);
|
|
266
|
+
if (unprocessedStacks.length > 0) {
|
|
267
|
+
throw commons_1.Errors.External(`Some stacks failed to deploy: ${unprocessedStacks
|
|
268
|
+
.map((s) => s.stack.name)
|
|
269
|
+
.join(", ")}. Please check the logs for more information.`);
|
|
270
|
+
}
|
|
271
|
+
try {
|
|
272
|
+
await this.projectTelemetry("deploy", {
|
|
273
|
+
stackMetadata: stacksToRun.map((stack) => JSON.parse(stack.content)["//"]
|
|
274
|
+
? JSON.parse(stack.content)["//"].metadata
|
|
275
|
+
: {}),
|
|
276
|
+
failedStacks: unprocessedStacks.map((stack) => stack.error),
|
|
277
|
+
requiredProviders: stacksToRun.map((stack) => JSON.parse(stack.content)["terraform"]
|
|
278
|
+
? JSON.parse(stack.content)["terraform"].required_providers
|
|
279
|
+
: {}),
|
|
280
|
+
});
|
|
281
|
+
}
|
|
282
|
+
catch (e) {
|
|
283
|
+
commons_1.logger.debug("Failed to send telemetry", e);
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
async destroy(opts = {}) {
|
|
287
|
+
const stacks = opts.skipSynth
|
|
288
|
+
? await this.readSynthesizedStacks()
|
|
289
|
+
: await this.synth(opts.noColor);
|
|
290
|
+
const stacksToRun = (0, stack_helpers_1.getMultipleStacks)(stacks, opts.stackNames, "destroy");
|
|
291
|
+
if (!opts.ignoreMissingStackDependencies) {
|
|
292
|
+
(0, stack_helpers_1.checkIfAllDependantsAreIncluded)(stacksToRun, stacks);
|
|
293
|
+
}
|
|
294
|
+
this.stopAllStacksThatCanNotRunWithout = (stackName) => {
|
|
295
|
+
const stackExecutor = this.stacksToRun.find((s) => s.stack.name === stackName);
|
|
296
|
+
if (!stackExecutor) {
|
|
297
|
+
throw commons_1.Errors.Internal(`Could not find stack "${stackName}" that was stopped`);
|
|
298
|
+
}
|
|
299
|
+
stackExecutor.stack.dependencies.forEach((dependant) => {
|
|
300
|
+
this.stopAllStacksThatCanNotRunWithout(dependant);
|
|
301
|
+
const dependantStack = this.stacksToRun.find((s) => s.stack.name === dependant);
|
|
302
|
+
if (!dependantStack) {
|
|
303
|
+
throw commons_1.Errors.Internal(`Could not find stack "${dependant}" that was stopped`);
|
|
304
|
+
}
|
|
305
|
+
dependantStack.stop();
|
|
306
|
+
});
|
|
307
|
+
};
|
|
308
|
+
this.stacksToRun = stacksToRun.map((stack) => this.getStackExecutor(stack, opts));
|
|
309
|
+
const next = opts.ignoreMissingStackDependencies
|
|
310
|
+
? () => Promise.resolve(this.stacksToRun.filter((stack) => stack.currentState !== "done")[0])
|
|
311
|
+
: () => (0, stack_helpers_1.getStackWithNoUnmetDependants)(this.stacksToRun);
|
|
312
|
+
await this.execute("destroy", next, opts);
|
|
313
|
+
const unprocessedStacks = this.stacksToRun.filter((executor) => executor.isPending);
|
|
314
|
+
if (unprocessedStacks.length > 0) {
|
|
315
|
+
throw commons_1.Errors.External(`Some stacks failed to destroy: ${unprocessedStacks
|
|
316
|
+
.map((s) => s.stack.name)
|
|
317
|
+
.join(", ")}. Please check the logs for more information.`);
|
|
318
|
+
}
|
|
319
|
+
try {
|
|
320
|
+
await this.projectTelemetry("destroy", {
|
|
321
|
+
stackMetadata: stacksToRun.map((stack) => JSON.parse(stack.content)["//"]
|
|
322
|
+
? JSON.parse(stack.content)["//"].metadata
|
|
323
|
+
: {}),
|
|
324
|
+
failedStacks: unprocessedStacks.map((stack) => stack.error),
|
|
325
|
+
requiredProviders: stacksToRun.map((stack) => JSON.parse(stack.content)["terraform"]
|
|
326
|
+
? JSON.parse(stack.content)["terraform"].required_providers
|
|
327
|
+
: {}),
|
|
328
|
+
});
|
|
329
|
+
}
|
|
330
|
+
catch (e) {
|
|
331
|
+
commons_1.logger.debug("Failed to send telemetry", e);
|
|
332
|
+
}
|
|
333
|
+
}
|
|
334
|
+
async projectTelemetry(command, payload) {
|
|
335
|
+
const config = (0, commons_1.readConfigSync)();
|
|
336
|
+
await (0, commons_1.sendTelemetry)(command, {
|
|
337
|
+
...payload,
|
|
338
|
+
language: config.language,
|
|
339
|
+
});
|
|
340
|
+
}
|
|
341
|
+
async fetchOutputs(opts) {
|
|
342
|
+
const stacks = opts.skipSynth
|
|
343
|
+
? await this.readSynthesizedStacks()
|
|
344
|
+
: await this.synth();
|
|
345
|
+
const stacksToRun = (0, stack_helpers_1.getMultipleStacks)(stacks, opts.stackNames || [], "deploy");
|
|
346
|
+
if (stacksToRun.length === 0) {
|
|
347
|
+
throw new Error("No stacks to fetch outputs for specified");
|
|
348
|
+
}
|
|
349
|
+
this.stacksToRun = stacksToRun.map((stack) =>
|
|
350
|
+
// Options are empty, because MultipleStackOptions doesn't have any relevant
|
|
351
|
+
// options for `getStackExecutor`, hence defaults are fine
|
|
352
|
+
this.getStackExecutor(stack, {}));
|
|
353
|
+
await this.initializeStacksToRunInSerial(undefined, opts.skipProviderLock);
|
|
354
|
+
const outputs = await Promise.all(this.stacksToRun.map(async (s) => {
|
|
355
|
+
const output = await s.fetchOutputs();
|
|
356
|
+
return {
|
|
357
|
+
[s.stack.name]: output,
|
|
358
|
+
};
|
|
359
|
+
}));
|
|
360
|
+
return outputs.reduce((acc, curr) => ({ ...acc, ...curr }), {});
|
|
361
|
+
}
|
|
362
|
+
// Serially run terraform init to prohibit text file busy errors for the cache files
|
|
363
|
+
async initializeStacksToRunInSerial(noColor, skipProviderLock, migrateState) {
|
|
364
|
+
for (const stack of this.stacksToRun) {
|
|
365
|
+
await stack.initalizeTerraform(noColor, skipProviderLock, migrateState);
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
exports.CdktfProject = CdktfProject;
|
|
370
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdktf-project.js","sourceRoot":"","sources":["../../src/lib/cdktf-project.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\nimport {\n  Errors,\n  ensureAllSettledBeforeThrowing,\n  logger,\n  readConfigSync,\n  sendTelemetry,\n} from \"@cdktn/commons\";\nimport { SynthesizedStack, SynthOrigin, SynthStack } from \"./synth-stack\";\nimport { printAnnotations } from \"./synth\";\nimport {\n  CdktfStack,\n  ExternalStackApprovalUpdate,\n  ExternalStackSentinelOverrideUpdate,\n  StackApprovalUpdate,\n  StackSentinelOverrideUpdate,\n  StackUpdate,\n  StackUserInputUpdate,\n} from \"./cdktf-stack\";\nimport { NestedTerraformOutputs } from \"./output\";\nimport { createEnhanceLogMessage } from \"./execution-logs\";\nimport {\n  checkIfAllDependantsAreIncluded,\n  checkIfAllDependenciesAreIncluded,\n  findAllNestedDependantStacks,\n  getMultipleStacks,\n  getSingleStack,\n  getStackWithNoUnmetDependants,\n  getStackWithNoUnmetDependencies,\n} from \"./helpers/stack-helpers\";\nimport { CdktfProjectIOHandler } from \"./cdktf-project-io-handler\";\n\ntype MultiStackApprovalUpdate = {\n  type: \"waiting for approval\";\n  stackName: string;\n  approve: () => void;\n  dismiss: () => void;\n  stop: () => void;\n};\n\ntype MultiStackSentinelOverrideUpdate = {\n  type: \"waiting for sentinel override\";\n  stackName: string;\n  override: () => void;\n  reject: () => void;\n};\n\nexport type MultiStackUpdate =\n  | MultiStackApprovalUpdate\n  | MultiStackSentinelOverrideUpdate;\n\nexport type ProjectUpdate =\n  | {\n      type: \"synthesizing\";\n    }\n  | {\n      type: \"synthesized\";\n      stacks: SynthesizedStack[];\n      errorMessage?: string;\n    }\n  | StackUpdate\n  | MultiStackUpdate;\n\nexport type SingleStackOptions = {\n  stackName?: string;\n};\n\nexport type MultipleStackOptions = {\n  stackNames?: string[];\n};\n\nexport type SkipSynthOptions = {\n  skipSynth?: boolean;\n};\n\nexport type SkipProviderLockOptions = {\n  skipProviderLock?: boolean;\n};\n\nexport type FetchOutputOptions = SkipSynthOptions &\n  SkipProviderLockOptions &\n  MultipleStackOptions;\n\nexport type AutoApproveOptions = {\n  autoApprove?: boolean;\n};\n\nexport type DiffOptions = SingleStackOptions &\n  SkipProviderLockOptions &\n  SkipSynthOptions & {\n    refreshOnly?: boolean;\n    terraformParallelism?: number;\n    vars?: string[];\n    varFiles?: string[];\n    noColor?: boolean;\n    migrateState?: boolean;\n  };\n\nexport type MutationOptions = MultipleStackOptions &\n  SkipProviderLockOptions &\n  SkipSynthOptions &\n  AutoApproveOptions & {\n    refreshOnly?: boolean;\n    ignoreMissingStackDependencies?: boolean;\n    parallelism?: number;\n    terraformParallelism?: number;\n    vars?: string[];\n    varFiles?: string[];\n    noColor?: boolean;\n    migrateState?: boolean;\n  };\n\nexport type LogMessage = {\n  stackName: string;\n  messageWithConstructPath?: string;\n  message: string;\n};\n\n// Stores a log value of a certain type until it can be sent\ntype Buffered<T, V> = {\n  cb: (item: T) => void;\n  value: T;\n  type: V;\n};\n\nexport function isWaitingForUserInputUpdate(\n  update: ProjectUpdate | StackUpdate,\n) {\n  return [\"waiting for approval\", \"waiting for sentinel override\"].includes(\n    update.type,\n  );\n}\n\nexport type ProjectEvent =\n  | Buffered<ProjectUpdate, \"projectUpdate\">\n  | Buffered<LogMessage, \"logMessage\">;\nexport type CdktfProjectOptions = {\n  synthCommand: string;\n  outDir: string;\n  onUpdate: (update: ProjectUpdate) => void;\n  onLog?: (log: LogMessage) => void;\n  workingDirectory?: string;\n  synthOrigin?: SynthOrigin;\n  hcl?: boolean;\n};\nexport class CdktfProject {\n  public stacks?: SynthesizedStack[];\n  public hardAbort: () => void;\n\n  private synthCommand: string;\n  private outDir: string;\n  private workingDirectory: string;\n  private onUpdate: (update: ProjectUpdate) => void;\n  private onLog?: (log: LogMessage) => void;\n  private abortSignal: AbortSignal;\n  private synthOrigin?: SynthOrigin;\n  private hcl?: boolean;\n\n  // Set during deploy / destroy\n  public stacksToRun: CdktfStack[] = [];\n  // This means sth different in deploy / destroy\n  private stopAllStacksThatCanNotRunWithout: (stackName: string) => void =\n    () => {};\n\n  private ioHandler: CdktfProjectIOHandler;\n\n  constructor({\n    synthCommand,\n    outDir,\n    onUpdate,\n    onLog,\n    workingDirectory = process.cwd(),\n    synthOrigin,\n    hcl = false,\n  }: CdktfProjectOptions) {\n    this.synthCommand = synthCommand;\n    this.outDir = outDir;\n    this.workingDirectory = workingDirectory;\n    this.onUpdate = onUpdate;\n    this.onLog = onLog;\n    const ac = new AbortController();\n    this.abortSignal = ac.signal;\n    this.synthOrigin = synthOrigin;\n    this.hcl =\n      process.env.SYNTH_HCL_OUTPUT === \"true\" ||\n      process.env.SYNTH_HCL_OUTPUT === \"1\" ||\n      hcl;\n\n    this.hardAbort = ac.abort.bind(ac);\n    this.ioHandler = new CdktfProjectIOHandler();\n  }\n\n  private stopAllStacks() {\n    this.stacksToRun.forEach((stack) => stack.stop());\n    this.ioHandler.filterUserInputEventsFromBuffer();\n  }\n\n  private handleUserUpdate<\n    T extends MultiStackUpdate,\n    V extends StackUserInputUpdate,\n  >(\n    update: StackUserInputUpdate,\n    operations: Record<string, (update: V) => void>,\n    originalCallback: (updateToSend: ProjectUpdate) => void,\n    eventType: T[\"type\"],\n  ) {\n    const callbacks = (update: V) =>\n      Object.fromEntries(\n        Object.entries(operations).map(([key, value]) => {\n          return [\n            key,\n            // This is passed in to make typescript happy only\n            (_: V) => {\n              value(update);\n\n              // We need to defer these calls for the case that approve() is instantly invoked\n              // in the listener that receives these callbacks as it otherwise would already\n              // remove the \"waiting for stack approval\" event from the buffer before we even\n              // set waitingForApproval to true (at the end of this if statement) which results\n              // in buffered updates which will never unblock\n              setTimeout(\n                () => this.ioHandler.resumeAfterUserInput(update.stackName),\n                0,\n              );\n            },\n          ];\n        }),\n      );\n\n    // always send to buffer, as resumeAfterUserInput() always expects a matching event\n    this.ioHandler.pushEvent({\n      cb: originalCallback,\n      value: {\n        type: eventType,\n        stackName: update.stackName,\n        ...callbacks(update as V),\n      } as T,\n      type: \"projectUpdate\",\n    });\n\n    // if we aren't already waiting, this needs to go to cb() too to arrive at the UI\n    if (!this.ioHandler.isWaitingForUserInput()) {\n      originalCallback({\n        type: eventType,\n        stackName: update.stackName,\n        ...callbacks(update as V),\n      } as T);\n    }\n  }\n\n  private handleUserInputProcess(cb: (updateToSend: ProjectUpdate) => void) {\n    return (\n      update:\n        | StackUpdate\n        | StackApprovalUpdate\n        | ExternalStackApprovalUpdate\n        | StackSentinelOverrideUpdate\n        | ExternalStackSentinelOverrideUpdate,\n    ) => {\n      if (update.type === \"external stack approval reply\") {\n        if (!update.approved) {\n          this.stopAllStacksThatCanNotRunWithout(update.stackName);\n        }\n        this.ioHandler.resumeAfterUserInput(update.stackName);\n        return; // aka don't send this event to any buffer\n      }\n      if (update.type === \"external stack sentinel override reply\") {\n        if (!update.overridden) {\n          this.stopAllStacksThatCanNotRunWithout(update.stackName);\n        }\n        this.ioHandler.resumeAfterUserInput(update.stackName);\n        return; // aka don't send this event to any buffer\n      }\n\n      if (\n        update.type === \"waiting for stack approval\" ||\n        update.type === \"waiting for stack sentinel override\"\n      ) {\n        if (update.type === \"waiting for stack approval\") {\n          this.handleUserUpdate<MultiStackApprovalUpdate, StackApprovalUpdate>(\n            update,\n            {\n              approve: (update) => update.approve(),\n              dismiss: (update) => {\n                update.reject();\n                this.stopAllStacksThatCanNotRunWithout(update.stackName);\n              },\n              stop: (update) => {\n                update.reject();\n                this.stopAllStacks();\n              },\n            },\n            cb,\n            \"waiting for approval\",\n          );\n        } else if (update.type === \"waiting for stack sentinel override\") {\n          this.handleUserUpdate<\n            MultiStackSentinelOverrideUpdate,\n            StackSentinelOverrideUpdate\n          >(\n            update,\n            {\n              override: (update) => {\n                update.override();\n              },\n              reject: (update) => {\n                update.reject();\n                this.stopAllStacksThatCanNotRunWithout(update.stackName);\n              },\n            },\n            cb,\n            \"waiting for sentinel override\",\n          );\n        }\n\n        this.ioHandler.awaitUserInput();\n      } else {\n        if (this.ioHandler.isWaitingForUserInput()) {\n          this.ioHandler.pushEvent({\n            cb,\n            value: update,\n            type: \"projectUpdate\",\n          });\n        } else {\n          cb(update as ProjectUpdate);\n        }\n      }\n    };\n  }\n\n  public getStackExecutor(\n    stack: SynthesizedStack,\n    opts: AutoApproveOptions = {},\n  ) {\n    const enhanceLogMessage = createEnhanceLogMessage(stack);\n    const onLog = this.ioHandler.bufferWhileAwaitingUserInput(this.onLog);\n    return new CdktfStack({\n      ...opts,\n      stack,\n      onUpdate: this.handleUserInputProcess(this.onUpdate),\n      onLog: onLog\n        ? ({ message }) =>\n            onLog({\n              stackName: stack.name,\n              message,\n              messageWithConstructPath: enhanceLogMessage(message),\n            })\n        : undefined,\n      abortSignal: this.abortSignal,\n    });\n  }\n\n  public get outputsByConstructId() {\n    return this.stacksToRun.reduce(\n      (acc, stack) => ({\n        ...acc,\n        ...stack.outputsByConstructId,\n      }),\n      {} as NestedTerraformOutputs,\n    );\n  }\n\n  public async synth(noColor?: boolean) {\n    this.onUpdate({\n      type: \"synthesizing\",\n    });\n\n    const stacks = await SynthStack.synth(\n      this.abortSignal as any,\n      this.synthCommand,\n      this.outDir,\n      this.workingDirectory,\n      false,\n      noColor,\n      this.synthOrigin,\n      this.hcl,\n    );\n\n    printAnnotations(stacks);\n\n    this.onUpdate({\n      type: \"synthesized\",\n      stacks,\n    });\n\n    return stacks;\n  }\n\n  public async readSynthesizedStacks() {\n    const stacks = await SynthStack.readSynthesizedStacks(this.outDir);\n\n    printAnnotations(stacks);\n\n    this.onUpdate({\n      type: \"synthesized\",\n      stacks,\n    });\n    return stacks;\n  }\n\n  public async diff(opts: DiffOptions = {}) {\n    const stacks = opts.skipSynth\n      ? await this.readSynthesizedStacks()\n      : await this.synth(opts.noColor);\n    const stack = this.getStackExecutor(\n      getSingleStack(stacks, opts?.stackName, \"diff\"),\n    );\n    await stack.initalizeTerraform(\n      opts.noColor,\n      opts.skipProviderLock,\n      opts.migrateState,\n    );\n\n    try {\n      await stack.diff(opts);\n    } catch (e: any) {\n      throw Errors.External(\n        `Stack failed to plan: ${stack.stack.name}. Please check the logs for more information.`,\n        e,\n      );\n    }\n    if (stack.error) {\n      throw Errors.External(\n        `Stack failed to plan: ${stack.stack.name}. Please check the logs for more information.`,\n        new Error(stack.error),\n      );\n    }\n\n    try {\n      await this.projectTelemetry(\"diff\", {\n        stackMetadata: stacks.map((stack) =>\n          JSON.parse(stack.content)[\"//\"]\n            ? JSON.parse(stack.content)[\"//\"].metadata\n            : {},\n        ),\n        errors: stack.error,\n        requiredProviders: stacks.map((stack: any) =>\n          JSON.parse(stack.content)[\"terraform\"]\n            ? JSON.parse(stack.content)[\"terraform\"].required_providers\n            : {},\n        ),\n      });\n    } catch (e) {\n      logger.debug(\"Failed to send telemetry\", e);\n    }\n  }\n\n  private async execute(\n    method: \"deploy\" | \"destroy\",\n    next: () => Promise<CdktfStack | undefined>,\n    opts: MutationOptions,\n  ) {\n    // We only support refresh only on deploy, a bit of a leaky abstraction here\n    if (opts.refreshOnly && method !== \"deploy\") {\n      throw Errors.Internal(`Refresh only is only supported on deploy`);\n    }\n    const maxParallelRuns =\n      !opts.parallelism || opts.parallelism < 0 ? Infinity : opts.parallelism;\n    const allExecutions = [];\n\n    await this.initializeStacksToRunInSerial(\n      opts.noColor,\n      opts.skipProviderLock,\n      opts.migrateState,\n    );\n    while (this.stacksToRun.filter((stack) => stack.isPending).length > 0) {\n      const runningStacks = this.stacksToRun.filter((stack) => stack.isRunning);\n      if (runningStacks.length >= maxParallelRuns) {\n        await Promise.race(runningStacks.map((s) => s.currentWorkPromise));\n        continue;\n      }\n      try {\n        const nextRunningExecutor = await next();\n        if (!nextRunningExecutor) {\n          // In this case we have no pending stacks, but we also can not find a new executor\n          break;\n        }\n        const promise =\n          method === \"deploy\"\n            ? nextRunningExecutor.deploy(opts)\n            : nextRunningExecutor.destroy(opts);\n\n        allExecutions.push(promise);\n      } catch (e) {\n        // await next() threw an error because a stack failed to apply/destroy\n        // wait for all other currently running stacks to complete before propagating that error\n        logger.debug(\"Encountered an error while awaiting stack to finish\", e);\n        const openStacks = this.stacksToRun.filter(\n          (ex) => ex.currentWorkPromise,\n        );\n        logger.debug(\"Waiting for still running stacks to finish:\", openStacks);\n        await Promise.allSettled(openStacks.map((ex) => ex.currentWorkPromise));\n        logger.debug(\n          \"Done waiting for still running stacks. All pending work finished\",\n        );\n        throw e;\n      }\n    }\n    // We end the loop when all stacks are started, now we need to wait for them to be done\n    // We wait for all work to finish even if one of the promises threw an error.\n    await ensureAllSettledBeforeThrowing(\n      Promise.all(allExecutions),\n      allExecutions,\n    );\n  }\n\n  public async deploy(opts: MutationOptions = {}) {\n    const stacks = opts.skipSynth\n      ? await this.readSynthesizedStacks()\n      : await this.synth(opts.noColor);\n    const stacksToRun = getMultipleStacks(stacks, opts.stackNames, \"deploy\");\n    if (!opts.ignoreMissingStackDependencies) {\n      checkIfAllDependenciesAreIncluded(stacksToRun);\n    }\n\n    this.stopAllStacksThatCanNotRunWithout = (stackName: string) => {\n      findAllNestedDependantStacks(this.stacksToRun, stackName).forEach(\n        (stack) => stack.stop(),\n      );\n    };\n\n    this.stacksToRun = stacksToRun.map((stack) =>\n      this.getStackExecutor(stack, opts),\n    );\n\n    const next = opts.ignoreMissingStackDependencies\n      ? () =>\n          Promise.resolve(\n            this.stacksToRun.filter((stack) => stack.isPending)[0],\n          )\n      : () => getStackWithNoUnmetDependencies(this.stacksToRun);\n\n    await this.execute(\"deploy\", next, opts);\n\n    const unprocessedStacks = this.stacksToRun.filter(\n      (executor) => executor.isPending,\n    );\n    if (unprocessedStacks.length > 0) {\n      throw Errors.External(\n        `Some stacks failed to deploy: ${unprocessedStacks\n          .map((s) => s.stack.name)\n          .join(\", \")}. Please check the logs for more information.`,\n      );\n    }\n\n    try {\n      await this.projectTelemetry(\"deploy\", {\n        stackMetadata: stacksToRun.map((stack) =>\n          JSON.parse(stack.content)[\"//\"]\n            ? JSON.parse(stack.content)[\"//\"].metadata\n            : {},\n        ),\n        failedStacks: unprocessedStacks.map((stack) => stack.error),\n        requiredProviders: stacksToRun.map((stack: any) =>\n          JSON.parse(stack.content)[\"terraform\"]\n            ? JSON.parse(stack.content)[\"terraform\"].required_providers\n            : {},\n        ),\n      });\n    } catch (e) {\n      logger.debug(\"Failed to send telemetry\", e);\n    }\n  }\n\n  public async destroy(opts: MutationOptions = {}) {\n    const stacks = opts.skipSynth\n      ? await this.readSynthesizedStacks()\n      : await this.synth(opts.noColor);\n    const stacksToRun = getMultipleStacks(stacks, opts.stackNames, \"destroy\");\n\n    if (!opts.ignoreMissingStackDependencies) {\n      checkIfAllDependantsAreIncluded(stacksToRun, stacks);\n    }\n\n    this.stopAllStacksThatCanNotRunWithout = (stackName: string) => {\n      const stackExecutor = this.stacksToRun.find(\n        (s) => s.stack.name === stackName,\n      );\n      if (!stackExecutor) {\n        throw Errors.Internal(\n          `Could not find stack \"${stackName}\" that was stopped`,\n        );\n      }\n\n      stackExecutor.stack.dependencies.forEach((dependant) => {\n        this.stopAllStacksThatCanNotRunWithout(dependant);\n\n        const dependantStack = this.stacksToRun.find(\n          (s) => s.stack.name === dependant,\n        );\n        if (!dependantStack) {\n          throw Errors.Internal(\n            `Could not find stack \"${dependant}\" that was stopped`,\n          );\n        }\n\n        dependantStack.stop();\n      });\n    };\n    this.stacksToRun = stacksToRun.map((stack) =>\n      this.getStackExecutor(stack, opts),\n    );\n    const next = opts.ignoreMissingStackDependencies\n      ? () =>\n          Promise.resolve(\n            this.stacksToRun.filter(\n              (stack) => stack.currentState !== \"done\",\n            )[0],\n          )\n      : () => getStackWithNoUnmetDependants(this.stacksToRun);\n\n    await this.execute(\"destroy\", next, opts);\n\n    const unprocessedStacks = this.stacksToRun.filter(\n      (executor) => executor.isPending,\n    );\n    if (unprocessedStacks.length > 0) {\n      throw Errors.External(\n        `Some stacks failed to destroy: ${unprocessedStacks\n          .map((s) => s.stack.name)\n          .join(\", \")}. Please check the logs for more information.`,\n      );\n    }\n\n    try {\n      await this.projectTelemetry(\"destroy\", {\n        stackMetadata: stacksToRun.map((stack) =>\n          JSON.parse(stack.content)[\"//\"]\n            ? JSON.parse(stack.content)[\"//\"].metadata\n            : {},\n        ),\n        failedStacks: unprocessedStacks.map((stack) => stack.error),\n        requiredProviders: stacksToRun.map((stack: any) =>\n          JSON.parse(stack.content)[\"terraform\"]\n            ? JSON.parse(stack.content)[\"terraform\"].required_providers\n            : {},\n        ),\n      });\n    } catch (e) {\n      logger.debug(\"Failed to send telemetry\", e);\n    }\n  }\n\n  public async projectTelemetry(command: string, payload: any): Promise<void> {\n    const config = readConfigSync();\n    await sendTelemetry(command, {\n      ...payload,\n      language: config.language,\n    });\n  }\n\n  public async fetchOutputs(opts: FetchOutputOptions) {\n    const stacks = opts.skipSynth\n      ? await this.readSynthesizedStacks()\n      : await this.synth();\n\n    const stacksToRun = getMultipleStacks(\n      stacks,\n      opts.stackNames || [],\n      \"deploy\",\n    );\n\n    if (stacksToRun.length === 0) {\n      throw new Error(\"No stacks to fetch outputs for specified\");\n    }\n\n    this.stacksToRun = stacksToRun.map((stack) =>\n      // Options are empty, because MultipleStackOptions doesn't have any relevant\n      // options for `getStackExecutor`, hence defaults are fine\n      this.getStackExecutor(stack, {}),\n    );\n\n    await this.initializeStacksToRunInSerial(undefined, opts.skipProviderLock);\n    const outputs = await Promise.all(\n      this.stacksToRun.map(async (s) => {\n        const output = await s.fetchOutputs();\n        return {\n          [s.stack.name]: output,\n        };\n      }),\n    );\n\n    return outputs.reduce(\n      (acc, curr) => ({ ...acc, ...curr }),\n      {},\n    ) as NestedTerraformOutputs;\n  }\n\n  // Serially run terraform init to prohibit text file busy errors for the cache files\n  private async initializeStacksToRunInSerial(\n    noColor?: boolean,\n    skipProviderLock?: boolean,\n    migrateState?: boolean,\n  ): Promise<void> {\n    for (const stack of this.stacksToRun) {\n      await stack.initalizeTerraform(noColor, skipProviderLock, migrateState);\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cdktf-stack.d.ts","sourceRoot":"","sources":["../../src/lib/cdktf-stack.ts"],"names":[],"mappings":"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"}
|