@cdktn/cli-core 0.21.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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 +95 -0
  25. package/src/lib/dependencies/dependency-manager.d.ts.map +1 -0
  26. package/src/lib/dependencies/dependency-manager.js +393 -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 +581 -0
  30. package/src/lib/dependencies/prebuilt-providers.d.ts +23 -0
  31. package/src/lib/dependencies/prebuilt-providers.d.ts.map +1 -0
  32. package/src/lib/dependencies/prebuilt-providers.js +220 -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,251 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.SynthStack = exports.StackDependencies = void 0;
30
+ // Copyright (c) HashiCorp, Inc
31
+ // SPDX-License-Identifier: MPL-2.0
32
+ const fs = __importStar(require("fs-extra"));
33
+ const path = __importStar(require("path"));
34
+ const chalk = __importStar(require("chalk"));
35
+ const indent_string_1 = __importDefault(require("indent-string"));
36
+ const cdktn_1 = require("cdktn");
37
+ const perf_hooks_1 = require("perf_hooks");
38
+ const commons_1 = require("@cdktn/commons");
39
+ const cdktf_config_1 = require("./cdktf-config");
40
+ const hcl_tools_1 = require("@cdktn/hcl-tools");
41
+ const chalkColour = new chalk.Instance();
42
+ class StackDependencies {
43
+ constructor(stacks) {
44
+ this.stacks = stacks;
45
+ this.pendingStacks = [];
46
+ this.inflightStacks = [];
47
+ this.deployedStacks = [];
48
+ this.pendingStacks = [...this.stacks];
49
+ }
50
+ startRun(stack) {
51
+ this.pendingStacks = this.pendingStacks.filter((item) => item.name !== stack.name);
52
+ this.inflightStacks.push(stack);
53
+ }
54
+ finishRun(stack) {
55
+ this.inflightStacks = this.inflightStacks.filter((item) => item.name !== stack.name);
56
+ this.deployedStacks.push(stack);
57
+ }
58
+ get pendingDeployableStacks() {
59
+ return this.pendingStacks.filter((pendingStack) => {
60
+ const unmetDependencies = pendingStack.dependencies.filter((dependency) => {
61
+ return !this.deployedStacks.some((deployedStack) => {
62
+ return deployedStack.name === dependency;
63
+ });
64
+ });
65
+ return unmetDependencies.length === 0;
66
+ });
67
+ }
68
+ }
69
+ exports.StackDependencies = StackDependencies;
70
+ class SynthStack {
71
+ static async synth(abortSignal, command, outdir, workingDirectory = process.cwd(), graceful = false, // will not exit the process but rethrow the error instead
72
+ noColor = false, synthOrigin, hcl = false) {
73
+ // start performance timer
74
+ const startTime = perf_hooks_1.performance.now();
75
+ const isDirectory = (source) => fs.lstatSync(source).isDirectory();
76
+ const getDirectories = (source) => {
77
+ if (!fs.existsSync(source))
78
+ return [];
79
+ return fs
80
+ .readdirSync(source)
81
+ .map((name) => path.join(source, name))
82
+ .filter(isDirectory);
83
+ };
84
+ const existingDirectories = getDirectories(path.join(outdir, cdktn_1.Manifest.stacksFolder));
85
+ const env = Object.fromEntries(Object.entries(process.env).filter(
86
+ // We don't want to pass Terraform variables to the synth command since they should only be used at execution time
87
+ ([key]) => !key.startsWith("TF_VAR_")));
88
+ // Increases the default memory available to Node.js when synthesizing a TypeScript CDK project.
89
+ const nodeOptsSwitch = "--max-old-space-size";
90
+ const nodeOptsSetting = `${nodeOptsSwitch}=4096`;
91
+ if (env.NODE_OPTIONS && !env.NODE_OPTIONS.includes(nodeOptsSwitch)) {
92
+ commons_1.logger.warn(`WARNING: Found NODE_OPTIONS environment variable without a setting for ${nodeOptsSwitch}
93
+ The synthesizing step for TypeScript may need an increased amount of memory if multiple large providers
94
+ are used with locally generated bindings. You can ignore this if you don't use CDKTN with TypeScript.
95
+ If not present, the cdktn-cli sets it to NODE_OPTIONS="${nodeOptsSetting}" by default. But as
96
+ your environment already contains a NODE_OPTIONS variable, we won't override it. Hence, the app command
97
+ might fail while synthesizing with an out of memory error.`);
98
+ }
99
+ else if (!env.NODE_OPTIONS) {
100
+ // increase memory to allow ts-node (when using TypeScript) to handle large amounts of generated code in memory
101
+ env.NODE_OPTIONS = `${env.NODE_OPTIONS || ""} ${nodeOptsSetting}`.trim();
102
+ }
103
+ const currentContext = process.env[cdktn_1.CONTEXT_ENV]
104
+ ? JSON.parse(process.env.CDKTF_CONTEXT_JSON)
105
+ : {};
106
+ const relativeModules = getRelativeTerraformModules();
107
+ try {
108
+ await (0, commons_1.shell)(command, [], {
109
+ shell: true,
110
+ env: {
111
+ ...env,
112
+ CDKTF_OUTDIR: outdir,
113
+ CDKTF_CONTINUE_SYNTH_ON_ERROR_ANNOTATIONS: "true", // we want to display the errors ourselves
114
+ [cdktn_1.CONTEXT_ENV]: JSON.stringify({
115
+ ...currentContext,
116
+ cdktfRelativeModules: relativeModules,
117
+ }),
118
+ SYNTH_HCL_OUTPUT: hcl.toString(),
119
+ },
120
+ cwd: workingDirectory,
121
+ signal: abortSignal,
122
+ noColor: noColor,
123
+ });
124
+ }
125
+ catch (e) {
126
+ const errorOutput = chalkColour `{redBright cdktn encountered an error while synthesizing}
127
+
128
+ Synth command: {blue ${command}}
129
+ Error: {redBright ${e.message}}
130
+ ${e.stderr
131
+ ? chalkColour `
132
+ Command output on stderr:
133
+
134
+ {dim ${(0, indent_string_1.default)(e.stderr, 4)}}
135
+ `
136
+ : ""}
137
+ ${e.stdout
138
+ ? chalkColour `
139
+ Command output on stdout:
140
+
141
+ {dim ${(0, indent_string_1.default)(e.stdout, 4)}}
142
+ `
143
+ : ""}`;
144
+ await this.synthErrorTelemetry(synthOrigin);
145
+ if (graceful) {
146
+ e.errorOutput = errorOutput;
147
+ throw e;
148
+ }
149
+ console.error(`ERROR: ${errorOutput}`);
150
+ process.exit(1);
151
+ }
152
+ // Apply formatting to HCL files if hcl output was selected
153
+ if (hcl) {
154
+ await SynthStack.formatHclFiles(outdir);
155
+ }
156
+ // end performance timer
157
+ const endTime = perf_hooks_1.performance.now();
158
+ let stacks = [];
159
+ try {
160
+ stacks = await SynthStack.readSynthesizedStacks(outdir);
161
+ }
162
+ catch (e) {
163
+ const errorMessage = `ERROR: synthesis failed, because app was expected to call 'synth()', but didn't. Thus "${outdir}/${cdktn_1.Manifest.fileName}" was not created: ${e}`;
164
+ if (graceful) {
165
+ throw new Error(errorMessage);
166
+ }
167
+ commons_1.logger.error(errorMessage);
168
+ process.exit(1);
169
+ }
170
+ await this.synthTelemetry(endTime - startTime, stacks, synthOrigin);
171
+ if (stacks.length === 0) {
172
+ commons_1.logger.error("ERROR: No Terraform code synthesized.");
173
+ }
174
+ const stackNames = stacks.map((s) => s.name);
175
+ const orphanedDirectories = existingDirectories.filter((e) => !stackNames.includes(path.basename(e)));
176
+ for (const orphanedDirectory of orphanedDirectories) {
177
+ fs.rmSync(orphanedDirectory, { recursive: true });
178
+ }
179
+ return stacks;
180
+ }
181
+ static async formatHclFiles(outDir) {
182
+ const manifestPath = path.join(outDir, cdktn_1.Manifest.fileName);
183
+ if (!(await fs.pathExists(manifestPath))) {
184
+ throw new Error(`Could not find manifest file at ${manifestPath}. In case --skip-synth was passed, please try again without the flag.`);
185
+ }
186
+ const manifest = JSON.parse(fs.readFileSync(manifestPath).toString());
187
+ for (const stackName in manifest.stacks) {
188
+ const stack = manifest.stacks[stackName];
189
+ const filePath = path.join(outDir, stack.synthesizedStackPath);
190
+ const hclContent = fs.readFileSync(filePath).toString();
191
+ const formattedHcl = await (0, hcl_tools_1.format)(hclContent);
192
+ fs.writeFileSync(filePath, formattedHcl);
193
+ }
194
+ }
195
+ static async readSynthesizedStacks(outdir) {
196
+ const manifestPath = path.join(outdir, cdktn_1.Manifest.fileName);
197
+ if (!(await fs.pathExists(manifestPath))) {
198
+ throw new Error(`Could not find manifest file at ${manifestPath}. In case --skip-synth was passed, please try again without the flag.`);
199
+ }
200
+ const stacks = [];
201
+ const manifest = JSON.parse(fs.readFileSync(manifestPath).toString());
202
+ for (const stackName in manifest.stacks) {
203
+ const stack = manifest.stacks[stackName];
204
+ const filePath = path.join(outdir, stack.synthesizedStackPath);
205
+ let jsonContent = {};
206
+ if (filePath.endsWith(".tf.json")) {
207
+ jsonContent = JSON.parse(fs.readFileSync(filePath).toString());
208
+ }
209
+ else {
210
+ const metadataPath = path.join(outdir, stack.stackMetadataPath);
211
+ jsonContent = JSON.parse(fs.readFileSync(metadataPath).toString());
212
+ }
213
+ stacks.push({
214
+ ...stack,
215
+ workingDirectory: path.join(outdir, stack.workingDirectory),
216
+ content: JSON.stringify(jsonContent, null, 2),
217
+ });
218
+ }
219
+ return stacks;
220
+ }
221
+ static async synthTelemetry(totalTime, stacks, synthOrigin) {
222
+ const config = (0, commons_1.readConfigSync)();
223
+ await (0, commons_1.sendTelemetry)("synth", {
224
+ totalTime: totalTime,
225
+ language: config.language,
226
+ synthOrigin,
227
+ stackMetadata: stacks.map((stack) => JSON.parse(stack.content)["//"].metadata),
228
+ requiredProviders: stacks.map((stack) => JSON.parse(stack.content)["terraform"].required_providers),
229
+ });
230
+ }
231
+ static async synthErrorTelemetry(synthOrigin) {
232
+ await (0, commons_1.sendTelemetry)("synth", { error: true, synthOrigin });
233
+ }
234
+ }
235
+ exports.SynthStack = SynthStack;
236
+ function getRelativeTerraformModules() {
237
+ let cfg;
238
+ try {
239
+ cfg = cdktf_config_1.CdktfConfig.read();
240
+ }
241
+ catch (e) {
242
+ commons_1.logger.trace("Could not read cdktf.json: " + e);
243
+ return [];
244
+ }
245
+ return cfg.terraformModules.filter((mod) => {
246
+ return typeof mod === "string"
247
+ ? mod.startsWith("./") || mod.startsWith("../")
248
+ : mod.source.startsWith("./") || mod.source.startsWith("../");
249
+ });
250
+ }
251
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"synth-stack.js","sourceRoot":"","sources":["synth-stack.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+BAA+B;AAC/B,mCAAmC;AACnC,6CAA+B;AAC/B,2CAA6B;AAC7B,6CAA+B;AAC/B,kEAAyC;AACzC,iCAKe;AACf,2CAAyC;AACzC,4CAA8E;AAC9E,iDAA6C;AAC7C,gDAA0C;AAE1C,MAAM,WAAW,GAAG,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;AAUzC,MAAa,iBAAiB;IAK5B,YAA6B,MAA0B;QAA1B,WAAM,GAAN,MAAM,CAAoB;QAJhD,kBAAa,GAAuB,EAAE,CAAC;QACvC,mBAAc,GAAuB,EAAE,CAAC;QACxC,mBAAc,GAAuB,EAAE,CAAC;QAG7C,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;IACxC,CAAC;IAEM,QAAQ,CAAC,KAAuB;QACrC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAC5C,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,CACnC,CAAC;QACF,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAEM,SAAS,CAAC,KAAuB;QACtC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAC9C,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,CACnC,CAAC;QACF,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAED,IAAW,uBAAuB;QAChC,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,YAAY,EAAE,EAAE;YAChD,MAAM,iBAAiB,GAAG,YAAY,CAAC,YAAY,CAAC,MAAM,CACxD,CAAC,UAAU,EAAE,EAAE;gBACb,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,EAAE;oBACjD,OAAO,aAAa,CAAC,IAAI,KAAK,UAAU,CAAC;gBAC3C,CAAC,CAAC,CAAC;YACL,CAAC,CACF,CAAC;YAEF,OAAO,iBAAiB,CAAC,MAAM,KAAK,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AApCD,8CAoCC;AASD,MAAa,UAAU;IACd,MAAM,CAAC,KAAK,CAAC,KAAK,CACvB,WAAwB,EACxB,OAAe,EACf,MAAc,EACd,gBAAgB,GAAG,OAAO,CAAC,GAAG,EAAE,EAChC,QAAQ,GAAG,KAAK,EAAE,0DAA0D;IAC5E,OAAO,GAAG,KAAK,EACf,WAAyB,EACzB,GAAG,GAAG,KAAK;QAEX,0BAA0B;QAC1B,MAAM,SAAS,GAAG,wBAAW,CAAC,GAAG,EAAE,CAAC;QAEpC,MAAM,WAAW,GAAG,CAAC,MAAc,EAAE,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAC;QAC3E,MAAM,cAAc,GAAG,CAAC,MAAc,EAAE,EAAE;YACxC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC;gBAAE,OAAO,EAAE,CAAC;YACtC,OAAO,EAAE;iBACN,WAAW,CAAC,MAAM,CAAC;iBACnB,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;iBACtC,MAAM,CAAC,WAAW,CAAC,CAAC;QACzB,CAAC,CAAC;QAEF,MAAM,mBAAmB,GAAG,cAAc,CACxC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,gBAAQ,CAAC,YAAY,CAAC,CACzC,CAAC;QAEF,MAAM,GAAG,GAAG,MAAM,CAAC,WAAW,CAC5B,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM;QAChC,kHAAkH;QAClH,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,SAAS,CAAC,CACtC,CACF,CAAC;QAEF,gGAAgG;QAChG,MAAM,cAAc,GAAG,sBAAsB,CAAC;QAC9C,MAAM,eAAe,GAAG,GAAG,cAAc,OAAO,CAAC;QACjD,IAAI,GAAG,CAAC,YAAY,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC;YACnE,gBAAM,CAAC,IAAI,CAAC,0EAA0E,cAAc;;;yDAGjD,eAAe;;2DAEb,CAAC,CAAC;QACzD,CAAC;aAAM,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC7B,+GAA+G;YAC/G,GAAG,CAAC,YAAY,GAAG,GAAG,GAAG,CAAC,YAAY,IAAI,EAAE,IAAI,eAAe,EAAE,CAAC,IAAI,EAAE,CAAC;QAC3E,CAAC;QAED,MAAM,cAAc,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAW,CAAC;YAC7C,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC;YAC5C,CAAC,CAAC,EAAE,CAAC;QACP,MAAM,eAAe,GAAG,2BAA2B,EAAE,CAAC;QAEtD,IAAI,CAAC;YACH,MAAM,IAAA,eAAK,EAAC,OAAO,EAAE,EAAE,EAAE;gBACvB,KAAK,EAAE,IAAI;gBACX,GAAG,EAAE;oBACH,GAAG,GAAG;oBACN,YAAY,EAAE,MAAM;oBACpB,yCAAyC,EAAE,MAAM,EAAE,0CAA0C;oBAC7F,CAAC,mBAAW,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC;wBAC5B,GAAG,cAAc;wBACjB,oBAAoB,EAAE,eAAe;qBACtC,CAAC;oBACF,gBAAgB,EAAE,GAAG,CAAC,QAAQ,EAAE;iBACjC;gBACD,GAAG,EAAE,gBAAgB;gBACrB,MAAM,EAAE,WAAW;gBACnB,OAAO,EAAE,OAAO;aACjB,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,WAAW,GAAG,WAAW,CAAA;;uBAEd,OAAO;4BACF,CAAC,CAAC,OAAO;EAEnC,CAAC,CAAC,MAAM;gBACN,CAAC,CAAC,WAAW,CAAA;;;OAGV,IAAA,uBAAY,EAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;CAC/B;gBACG,CAAC,CAAC,EACN;EAEE,CAAC,CAAC,MAAM;gBACN,CAAC,CAAC,WAAW,CAAA;;;OAGV,IAAA,uBAAY,EAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;CAC/B;gBACG,CAAC,CAAC,EACN,EAAE,CAAC;YACG,MAAM,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAC;YAC5C,IAAI,QAAQ,EAAE,CAAC;gBACb,CAAC,CAAC,WAAW,GAAG,WAAW,CAAC;gBAC5B,MAAM,CAAC,CAAC;YACV,CAAC;YACD,OAAO,CAAC,KAAK,CAAC,UAAU,WAAW,EAAE,CAAC,CAAC;YACvC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;QAED,2DAA2D;QAC3D,IAAI,GAAG,EAAE,CAAC;YACR,MAAM,UAAU,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAC1C,CAAC;QAED,wBAAwB;QACxB,MAAM,OAAO,GAAG,wBAAW,CAAC,GAAG,EAAE,CAAC;QAElC,IAAI,MAAM,GAAuB,EAAE,CAAC;QACpC,IAAI,CAAC;YACH,MAAM,GAAG,MAAM,UAAU,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAC1D,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,YAAY,GAAG,0FAA0F,MAAM,IAAI,gBAAQ,CAAC,QAAQ,uBAAuB,CAAC,EAAE,CAAC;YACrK,IAAI,QAAQ,EAAE,CAAC;gBACb,MAAM,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC;YAChC,CAAC;YACD,gBAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YAC3B,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;QAED,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,GAAG,SAAS,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;QAEpE,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxB,gBAAM,CAAC,KAAK,CAAC,uCAAuC,CAAC,CAAC;QACxD,CAAC;QAED,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAC7C,MAAM,mBAAmB,GAAG,mBAAmB,CAAC,MAAM,CACpD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAC9C,CAAC;QAEF,KAAK,MAAM,iBAAiB,IAAI,mBAAmB,EAAE,CAAC;YACpD,EAAE,CAAC,MAAM,CAAC,iBAAiB,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACpD,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,MAAc;QAC/C,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,gBAAQ,CAAC,QAAQ,CAAC,CAAC;QAC1D,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC;YACzC,MAAM,IAAI,KAAK,CACb,mCAAmC,YAAY,uEAAuE,CACvH,CAAC;QACJ,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CACzB,EAAE,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,CACzB,CAAC;QAElB,KAAK,MAAM,SAAS,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACxC,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YACzC,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,oBAAoB,CAAC,CAAC;YAE/D,MAAM,UAAU,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC;YACxD,MAAM,YAAY,GAAG,MAAM,IAAA,kBAAM,EAAC,UAAU,CAAC,CAAC;YAC9C,EAAE,CAAC,aAAa,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,qBAAqB,CACvC,MAAc;QAEd,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,gBAAQ,CAAC,QAAQ,CAAC,CAAC;QAC1D,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC;YACzC,MAAM,IAAI,KAAK,CACb,mCAAmC,YAAY,uEAAuE,CACvH,CAAC;QACJ,CAAC;QAED,MAAM,MAAM,GAAuB,EAAE,CAAC;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CACzB,EAAE,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,CACzB,CAAC;QAElB,KAAK,MAAM,SAAS,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACxC,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YACzC,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,oBAAoB,CAAC,CAAC;YAC/D,IAAI,WAAW,GAA6B,EAAE,CAAC;YAC/C,IAAI,QAAQ,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;gBAClC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;YACjE,CAAC;iBAAM,CAAC;gBACN,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,iBAAkB,CAAC,CAAC;gBACjE,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;YACrE,CAAC;YAED,MAAM,CAAC,IAAI,CAAC;gBACV,GAAG,KAAK;gBACR,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,gBAAgB,CAAC;gBAC3D,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC;aAC9C,CAAC,CAAC;QACL,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,cAAc,CAChC,SAAiB,EACjB,MAA0B,EAC1B,WAAyB;QAEzB,MAAM,MAAM,GAAG,IAAA,wBAAc,GAAE,CAAC;QAEhC,MAAM,IAAA,uBAAa,EAAC,OAAO,EAAE;YAC3B,SAAS,EAAE,SAAS;YACpB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,WAAW;YACX,aAAa,EAAE,MAAM,CAAC,GAAG,CACvB,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,CACpD;YACD,iBAAiB,EAAE,MAAM,CAAC,GAAG,CAC3B,CAAC,KAAU,EAAE,EAAE,CACb,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,CAAC,kBAAkB,CAC5D;SACF,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,WAAyB;QAC/D,MAAM,IAAA,uBAAa,EAAC,OAAO,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC,CAAC;IAC7D,CAAC;CACF;AA/ND,gCA+NC;AAED,SAAS,2BAA2B;IAClC,IAAI,GAAG,CAAC;IAER,IAAI,CAAC;QACH,GAAG,GAAG,0BAAW,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,gBAAM,CAAC,KAAK,CAAC,6BAA6B,GAAG,CAAC,CAAC,CAAC;QAChD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,OAAO,GAAG,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;QACzC,OAAO,OAAO,GAAG,KAAK,QAAQ;YAC5B,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC;YAC/C,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\nimport * as fs from \"fs-extra\";\nimport * as path from \"path\";\nimport * as chalk from \"chalk\";\nimport indentString from \"indent-string\";\nimport {\n  CONTEXT_ENV,\n  Manifest,\n  StackManifest,\n  TerraformStackMetadata,\n} from \"cdktn\";\nimport { performance } from \"perf_hooks\";\nimport { logger, readConfigSync, sendTelemetry, shell } from \"@cdktn/commons\";\nimport { CdktfConfig } from \"./cdktf-config\";\nimport { format } from \"@cdktn/hcl-tools\";\n\nconst chalkColour = new chalk.Instance();\n\nexport interface SynthesizedStackMetadata {\n  \"//\"?: { [key: string]: TerraformStackMetadata };\n}\n\nexport interface SynthesizedStack extends StackManifest {\n  content: string;\n}\n\nexport class StackDependencies {\n  public pendingStacks: SynthesizedStack[] = [];\n  public inflightStacks: SynthesizedStack[] = [];\n  public deployedStacks: SynthesizedStack[] = [];\n\n  constructor(private readonly stacks: SynthesizedStack[]) {\n    this.pendingStacks = [...this.stacks];\n  }\n\n  public startRun(stack: SynthesizedStack): void {\n    this.pendingStacks = this.pendingStacks.filter(\n      (item) => item.name !== stack.name,\n    );\n    this.inflightStacks.push(stack);\n  }\n\n  public finishRun(stack: SynthesizedStack): void {\n    this.inflightStacks = this.inflightStacks.filter(\n      (item) => item.name !== stack.name,\n    );\n    this.deployedStacks.push(stack);\n  }\n\n  public get pendingDeployableStacks(): SynthesizedStack[] {\n    return this.pendingStacks.filter((pendingStack) => {\n      const unmetDependencies = pendingStack.dependencies.filter(\n        (dependency) => {\n          return !this.deployedStacks.some((deployedStack) => {\n            return deployedStack.name === dependency;\n          });\n        },\n      );\n\n      return unmetDependencies.length === 0;\n    });\n  }\n}\n\ninterface ManifestJson {\n  version: string;\n  stacks: StackManifest[];\n}\n\nexport type SynthOrigin = \"watch\";\n\nexport class SynthStack {\n  public static async synth(\n    abortSignal: AbortSignal,\n    command: string,\n    outdir: string,\n    workingDirectory = process.cwd(),\n    graceful = false, // will not exit the process but rethrow the error instead\n    noColor = false,\n    synthOrigin?: SynthOrigin,\n    hcl = false,\n  ): Promise<SynthesizedStack[]> {\n    // start performance timer\n    const startTime = performance.now();\n\n    const isDirectory = (source: string) => fs.lstatSync(source).isDirectory();\n    const getDirectories = (source: string) => {\n      if (!fs.existsSync(source)) return [];\n      return fs\n        .readdirSync(source)\n        .map((name) => path.join(source, name))\n        .filter(isDirectory);\n    };\n\n    const existingDirectories = getDirectories(\n      path.join(outdir, Manifest.stacksFolder),\n    );\n\n    const env = Object.fromEntries(\n      Object.entries(process.env).filter(\n        // We don't want to pass Terraform variables to the synth command since they should only be used at execution time\n        ([key]) => !key.startsWith(\"TF_VAR_\"),\n      ),\n    );\n\n    // Increases the default memory available to Node.js when synthesizing a TypeScript CDK project.\n    const nodeOptsSwitch = \"--max-old-space-size\";\n    const nodeOptsSetting = `${nodeOptsSwitch}=4096`;\n    if (env.NODE_OPTIONS && !env.NODE_OPTIONS.includes(nodeOptsSwitch)) {\n      logger.warn(`WARNING: Found NODE_OPTIONS environment variable without a setting for ${nodeOptsSwitch}\nThe synthesizing step for TypeScript may need an increased amount of memory if multiple large providers\nare used with locally generated bindings. You can ignore this if you don't use CDKTN with TypeScript.\nIf not present, the cdktn-cli sets it to NODE_OPTIONS=\"${nodeOptsSetting}\" by default. But as\nyour environment already contains a NODE_OPTIONS variable, we won't override it. Hence, the app command\nmight fail while synthesizing with an out of memory error.`);\n    } else if (!env.NODE_OPTIONS) {\n      // increase memory to allow ts-node (when using TypeScript) to handle large amounts of generated code in memory\n      env.NODE_OPTIONS = `${env.NODE_OPTIONS || \"\"} ${nodeOptsSetting}`.trim();\n    }\n\n    const currentContext = process.env[CONTEXT_ENV]\n      ? JSON.parse(process.env.CDKTF_CONTEXT_JSON)\n      : {};\n    const relativeModules = getRelativeTerraformModules();\n\n    try {\n      await shell(command, [], {\n        shell: true,\n        env: {\n          ...env,\n          CDKTF_OUTDIR: outdir,\n          CDKTF_CONTINUE_SYNTH_ON_ERROR_ANNOTATIONS: \"true\", // we want to display the errors ourselves\n          [CONTEXT_ENV]: JSON.stringify({\n            ...currentContext,\n            cdktfRelativeModules: relativeModules,\n          }),\n          SYNTH_HCL_OUTPUT: hcl.toString(),\n        },\n        cwd: workingDirectory,\n        signal: abortSignal,\n        noColor: noColor,\n      });\n    } catch (e: any) {\n      const errorOutput = chalkColour`{redBright cdktn encountered an error while synthesizing}\n\nSynth command: {blue ${command}}\nError:         {redBright ${e.message}}\n${\n  e.stderr\n    ? chalkColour`\nCommand output on stderr:\n\n{dim ${indentString(e.stderr, 4)}}\n`\n    : \"\"\n}\n${\n  e.stdout\n    ? chalkColour`\nCommand output on stdout:\n\n{dim ${indentString(e.stdout, 4)}}\n`\n    : \"\"\n}`;\n      await this.synthErrorTelemetry(synthOrigin);\n      if (graceful) {\n        e.errorOutput = errorOutput;\n        throw e;\n      }\n      console.error(`ERROR: ${errorOutput}`);\n      process.exit(1);\n    }\n\n    // Apply formatting to HCL files if hcl output was selected\n    if (hcl) {\n      await SynthStack.formatHclFiles(outdir);\n    }\n\n    // end performance timer\n    const endTime = performance.now();\n\n    let stacks: SynthesizedStack[] = [];\n    try {\n      stacks = await SynthStack.readSynthesizedStacks(outdir);\n    } catch (e: any) {\n      const errorMessage = `ERROR: synthesis failed, because app was expected to call 'synth()', but didn't. Thus \"${outdir}/${Manifest.fileName}\"  was not created: ${e}`;\n      if (graceful) {\n        throw new Error(errorMessage);\n      }\n      logger.error(errorMessage);\n      process.exit(1);\n    }\n\n    await this.synthTelemetry(endTime - startTime, stacks, synthOrigin);\n\n    if (stacks.length === 0) {\n      logger.error(\"ERROR: No Terraform code synthesized.\");\n    }\n\n    const stackNames = stacks.map((s) => s.name);\n    const orphanedDirectories = existingDirectories.filter(\n      (e) => !stackNames.includes(path.basename(e)),\n    );\n\n    for (const orphanedDirectory of orphanedDirectories) {\n      fs.rmSync(orphanedDirectory, { recursive: true });\n    }\n\n    return stacks;\n  }\n\n  public static async formatHclFiles(outDir: string) {\n    const manifestPath = path.join(outDir, Manifest.fileName);\n    if (!(await fs.pathExists(manifestPath))) {\n      throw new Error(\n        `Could not find manifest file at ${manifestPath}. In case --skip-synth was passed, please try again without the flag.`,\n      );\n    }\n\n    const manifest = JSON.parse(\n      fs.readFileSync(manifestPath).toString(),\n    ) as ManifestJson;\n\n    for (const stackName in manifest.stacks) {\n      const stack = manifest.stacks[stackName];\n      const filePath = path.join(outDir, stack.synthesizedStackPath);\n\n      const hclContent = fs.readFileSync(filePath).toString();\n      const formattedHcl = await format(hclContent);\n      fs.writeFileSync(filePath, formattedHcl);\n    }\n  }\n\n  public static async readSynthesizedStacks(\n    outdir: string,\n  ): Promise<SynthesizedStack[]> {\n    const manifestPath = path.join(outdir, Manifest.fileName);\n    if (!(await fs.pathExists(manifestPath))) {\n      throw new Error(\n        `Could not find manifest file at ${manifestPath}. In case --skip-synth was passed, please try again without the flag.`,\n      );\n    }\n\n    const stacks: SynthesizedStack[] = [];\n    const manifest = JSON.parse(\n      fs.readFileSync(manifestPath).toString(),\n    ) as ManifestJson;\n\n    for (const stackName in manifest.stacks) {\n      const stack = manifest.stacks[stackName];\n      const filePath = path.join(outdir, stack.synthesizedStackPath);\n      let jsonContent: SynthesizedStackMetadata = {};\n      if (filePath.endsWith(\".tf.json\")) {\n        jsonContent = JSON.parse(fs.readFileSync(filePath).toString());\n      } else {\n        const metadataPath = path.join(outdir, stack.stackMetadataPath!);\n        jsonContent = JSON.parse(fs.readFileSync(metadataPath).toString());\n      }\n\n      stacks.push({\n        ...stack,\n        workingDirectory: path.join(outdir, stack.workingDirectory),\n        content: JSON.stringify(jsonContent, null, 2),\n      });\n    }\n\n    return stacks;\n  }\n\n  public static async synthTelemetry(\n    totalTime: number,\n    stacks: SynthesizedStack[],\n    synthOrigin?: SynthOrigin,\n  ): Promise<void> {\n    const config = readConfigSync();\n\n    await sendTelemetry(\"synth\", {\n      totalTime: totalTime,\n      language: config.language,\n      synthOrigin,\n      stackMetadata: stacks.map(\n        (stack) => JSON.parse(stack.content)[\"//\"].metadata,\n      ),\n      requiredProviders: stacks.map(\n        (stack: any) =>\n          JSON.parse(stack.content)[\"terraform\"].required_providers,\n      ),\n    });\n  }\n\n  public static async synthErrorTelemetry(synthOrigin?: SynthOrigin) {\n    await sendTelemetry(\"synth\", { error: true, synthOrigin });\n  }\n}\n\nfunction getRelativeTerraformModules() {\n  let cfg;\n\n  try {\n    cfg = CdktfConfig.read();\n  } catch (e) {\n    logger.trace(\"Could not read cdktf.json: \" + e);\n    return [];\n  }\n\n  return cfg.terraformModules.filter((mod) => {\n    return typeof mod === \"string\"\n      ? mod.startsWith(\"./\") || mod.startsWith(\"../\")\n      : mod.source.startsWith(\"./\") || mod.source.startsWith(\"../\");\n  });\n}\n"]}
@@ -0,0 +1,7 @@
1
+ import { SynthesizedStack } from "./synth-stack";
2
+ /**
3
+ * prints annotations via console
4
+ * @throws Error if an Annotation with level === ERROR has been encountered
5
+ */
6
+ export declare function printAnnotations(stacks: SynthesizedStack[]): void;
7
+ //# sourceMappingURL=synth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"synth.d.ts","sourceRoot":"","sources":["synth.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAMjD;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,gBAAgB,EAAE,QA0C1D"}
@@ -0,0 +1,67 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.printAnnotations = void 0;
27
+ const cdktn_1 = require("cdktn");
28
+ const chalk = __importStar(require("chalk"));
29
+ const chalkColour = new chalk.Instance();
30
+ /**
31
+ * prints annotations via console
32
+ * @throws Error if an Annotation with level === ERROR has been encountered
33
+ */
34
+ function printAnnotations(stacks) {
35
+ let encounteredAnnotationError = false;
36
+ stacks.forEach((stack) => (stack.annotations || []).forEach((annotation) => {
37
+ if (annotation.level === cdktn_1.AnnotationMetadataEntryType.ERROR)
38
+ encounteredAnnotationError = true;
39
+ let color = chalkColour.whiteBright;
40
+ let level = annotation.level;
41
+ switch (annotation.level) {
42
+ case cdktn_1.AnnotationMetadataEntryType.INFO: {
43
+ level = "INFO";
44
+ break;
45
+ }
46
+ case cdktn_1.AnnotationMetadataEntryType.WARN: {
47
+ color = chalkColour.hex("#FFA500"); // orange
48
+ level = "WARN";
49
+ break;
50
+ }
51
+ case cdktn_1.AnnotationMetadataEntryType.ERROR: {
52
+ color = chalkColour.redBright;
53
+ level = "ERROR";
54
+ break;
55
+ }
56
+ }
57
+ console.log(color(`${level} [${annotation.constructPath}]: ${annotation.message}`));
58
+ if (annotation.level === cdktn_1.AnnotationMetadataEntryType.ERROR &&
59
+ annotation.stacktrace)
60
+ console.log(chalkColour.gray(annotation.stacktrace.join("\n")));
61
+ }));
62
+ if (encounteredAnnotationError) {
63
+ throw new Error("While synthesizing one or more error annotations have been encountered. Please check the log output above.");
64
+ }
65
+ }
66
+ exports.printAnnotations = printAnnotations;
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ludGguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJzeW50aC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUdBLGlDQUFvRDtBQUNwRCw2Q0FBK0I7QUFFL0IsTUFBTSxXQUFXLEdBQUcsSUFBSSxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7QUFFekM7OztHQUdHO0FBQ0gsU0FBZ0IsZ0JBQWdCLENBQUMsTUFBMEI7SUFDekQsSUFBSSwwQkFBMEIsR0FBRyxLQUFLLENBQUM7SUFFdkMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQ3ZCLENBQUMsS0FBSyxDQUFDLFdBQVcsSUFBSSxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxVQUFVLEVBQUUsRUFBRTtRQUMvQyxJQUFJLFVBQVUsQ0FBQyxLQUFLLEtBQUssbUNBQTJCLENBQUMsS0FBSztZQUN4RCwwQkFBMEIsR0FBRyxJQUFJLENBQUM7UUFFcEMsSUFBSSxLQUFLLEdBQUcsV0FBVyxDQUFDLFdBQVcsQ0FBQztRQUNwQyxJQUFJLEtBQUssR0FBVyxVQUFVLENBQUMsS0FBSyxDQUFDO1FBQ3JDLFFBQVEsVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ3pCLEtBQUssbUNBQTJCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztnQkFDdEMsS0FBSyxHQUFHLE1BQU0sQ0FBQztnQkFDZixNQUFNO1lBQ1IsQ0FBQztZQUNELEtBQUssbUNBQTJCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztnQkFDdEMsS0FBSyxHQUFHLFdBQVcsQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxTQUFTO2dCQUM3QyxLQUFLLEdBQUcsTUFBTSxDQUFDO2dCQUNmLE1BQU07WUFDUixDQUFDO1lBQ0QsS0FBSyxtQ0FBMkIsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO2dCQUN2QyxLQUFLLEdBQUcsV0FBVyxDQUFDLFNBQVMsQ0FBQztnQkFDOUIsS0FBSyxHQUFHLE9BQU8sQ0FBQztnQkFDaEIsTUFBTTtZQUNSLENBQUM7UUFDSCxDQUFDO1FBQ0QsT0FBTyxDQUFDLEdBQUcsQ0FDVCxLQUFLLENBQUMsR0FBRyxLQUFLLEtBQUssVUFBVSxDQUFDLGFBQWEsTUFBTSxVQUFVLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FDdkUsQ0FBQztRQUNGLElBQ0UsVUFBVSxDQUFDLEtBQUssS0FBSyxtQ0FBMkIsQ0FBQyxLQUFLO1lBQ3RELFVBQVUsQ0FBQyxVQUFVO1lBRXJCLE9BQU8sQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDcEUsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUVGLElBQUksMEJBQTBCLEVBQUUsQ0FBQztRQUMvQixNQUFNLElBQUksS0FBSyxDQUNiLDRHQUE0RyxDQUM3RyxDQUFDO0lBQ0osQ0FBQztBQUNILENBQUM7QUExQ0QsNENBMENDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IChjKSBIYXNoaUNvcnAsIEluY1xuLy8gU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IE1QTC0yLjBcbmltcG9ydCB7IFN5bnRoZXNpemVkU3RhY2sgfSBmcm9tIFwiLi9zeW50aC1zdGFja1wiO1xuaW1wb3J0IHsgQW5ub3RhdGlvbk1ldGFkYXRhRW50cnlUeXBlIH0gZnJvbSBcImNka3RuXCI7XG5pbXBvcnQgKiBhcyBjaGFsayBmcm9tIFwiY2hhbGtcIjtcblxuY29uc3QgY2hhbGtDb2xvdXIgPSBuZXcgY2hhbGsuSW5zdGFuY2UoKTtcblxuLyoqXG4gKiBwcmludHMgYW5ub3RhdGlvbnMgdmlhIGNvbnNvbGVcbiAqIEB0aHJvd3MgRXJyb3IgaWYgYW4gQW5ub3RhdGlvbiB3aXRoIGxldmVsID09PSBFUlJPUiBoYXMgYmVlbiBlbmNvdW50ZXJlZFxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJpbnRBbm5vdGF0aW9ucyhzdGFja3M6IFN5bnRoZXNpemVkU3RhY2tbXSkge1xuICBsZXQgZW5jb3VudGVyZWRBbm5vdGF0aW9uRXJyb3IgPSBmYWxzZTtcblxuICBzdGFja3MuZm9yRWFjaCgoc3RhY2spID0+XG4gICAgKHN0YWNrLmFubm90YXRpb25zIHx8IFtdKS5mb3JFYWNoKChhbm5vdGF0aW9uKSA9PiB7XG4gICAgICBpZiAoYW5ub3RhdGlvbi5sZXZlbCA9PT0gQW5ub3RhdGlvbk1ldGFkYXRhRW50cnlUeXBlLkVSUk9SKVxuICAgICAgICBlbmNvdW50ZXJlZEFubm90YXRpb25FcnJvciA9IHRydWU7XG5cbiAgICAgIGxldCBjb2xvciA9IGNoYWxrQ29sb3VyLndoaXRlQnJpZ2h0O1xuICAgICAgbGV0IGxldmVsOiBzdHJpbmcgPSBhbm5vdGF0aW9uLmxldmVsO1xuICAgICAgc3dpdGNoIChhbm5vdGF0aW9uLmxldmVsKSB7XG4gICAgICAgIGNhc2UgQW5ub3RhdGlvbk1ldGFkYXRhRW50cnlUeXBlLklORk86IHtcbiAgICAgICAgICBsZXZlbCA9IFwiSU5GT1wiO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICB9XG4gICAgICAgIGNhc2UgQW5ub3RhdGlvbk1ldGFkYXRhRW50cnlUeXBlLldBUk46IHtcbiAgICAgICAgICBjb2xvciA9IGNoYWxrQ29sb3VyLmhleChcIiNGRkE1MDBcIik7IC8vIG9yYW5nZVxuICAgICAgICAgIGxldmVsID0gXCJXQVJOXCI7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICAgICAgY2FzZSBBbm5vdGF0aW9uTWV0YWRhdGFFbnRyeVR5cGUuRVJST1I6IHtcbiAgICAgICAgICBjb2xvciA9IGNoYWxrQ29sb3VyLnJlZEJyaWdodDtcbiAgICAgICAgICBsZXZlbCA9IFwiRVJST1JcIjtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgY29uc29sZS5sb2coXG4gICAgICAgIGNvbG9yKGAke2xldmVsfSBbJHthbm5vdGF0aW9uLmNvbnN0cnVjdFBhdGh9XTogJHthbm5vdGF0aW9uLm1lc3NhZ2V9YCksXG4gICAgICApO1xuICAgICAgaWYgKFxuICAgICAgICBhbm5vdGF0aW9uLmxldmVsID09PSBBbm5vdGF0aW9uTWV0YWRhdGFFbnRyeVR5cGUuRVJST1IgJiZcbiAgICAgICAgYW5ub3RhdGlvbi5zdGFja3RyYWNlXG4gICAgICApXG4gICAgICAgIGNvbnNvbGUubG9nKGNoYWxrQ29sb3VyLmdyYXkoYW5ub3RhdGlvbi5zdGFja3RyYWNlLmpvaW4oXCJcXG5cIikpKTtcbiAgICB9KSxcbiAgKTtcblxuICBpZiAoZW5jb3VudGVyZWRBbm5vdGF0aW9uRXJyb3IpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIldoaWxlIHN5bnRoZXNpemluZyBvbmUgb3IgbW9yZSBlcnJvciBhbm5vdGF0aW9ucyBoYXZlIGJlZW4gZW5jb3VudGVyZWQuIFBsZWFzZSBjaGVjayB0aGUgbG9nIG91dHB1dCBhYm92ZS5cIixcbiAgICApO1xuICB9XG59XG4iXX0=