@cdktn/cli-core 0.22.0-pre.2

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