@cdktn/cli-core 0.23.0-pre.8 → 0.24.0-pre.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (169) hide show
  1. package/ambient.d.ts +0 -1
  2. package/build/lib/cdktf-config.d.ts.map +1 -0
  3. package/build/lib/cdktf-config.js +108 -0
  4. package/build/lib/cdktf-project-io-handler.d.ts.map +1 -0
  5. package/build/lib/cdktf-project-io-handler.js +84 -0
  6. package/build/lib/cdktf-project.d.ts.map +1 -0
  7. package/build/lib/cdktf-project.js +370 -0
  8. package/{src → build}/lib/cdktf-stack.d.ts +1 -0
  9. package/build/lib/cdktf-stack.d.ts.map +1 -0
  10. package/build/lib/cdktf-stack.js +386 -0
  11. package/build/lib/convert.d.ts.map +1 -0
  12. package/build/lib/convert.js +51 -0
  13. package/build/lib/dependencies/cdktf-config-manager.d.ts.map +1 -0
  14. package/build/lib/dependencies/cdktf-config-manager.js +36 -0
  15. package/build/lib/dependencies/dependency-manager.d.ts.map +1 -0
  16. package/build/lib/dependencies/dependency-manager.js +393 -0
  17. package/build/lib/dependencies/package-manager.d.ts.map +1 -0
  18. package/build/lib/dependencies/package-manager.js +581 -0
  19. package/build/lib/dependencies/prebuilt-providers.d.ts.map +1 -0
  20. package/build/lib/dependencies/prebuilt-providers.js +221 -0
  21. package/build/lib/dependencies/registry-api.d.ts.map +1 -0
  22. package/build/lib/dependencies/registry-api.js +77 -0
  23. package/build/lib/dependencies/version-constraints.d.ts.map +1 -0
  24. package/build/lib/dependencies/version-constraints.js +95 -0
  25. package/build/lib/error-reporting.d.ts.map +1 -0
  26. package/build/lib/error-reporting.js +133 -0
  27. package/build/lib/errors.d.ts.map +1 -0
  28. package/build/lib/errors.js +10 -0
  29. package/build/lib/execution-logs.d.ts.map +1 -0
  30. package/build/lib/execution-logs.js +47 -0
  31. package/build/lib/get.d.ts.map +1 -0
  32. package/build/lib/get.js +90 -0
  33. package/build/lib/helpers/stack-helpers.d.ts.map +1 -0
  34. package/build/lib/helpers/stack-helpers.js +155 -0
  35. package/build/lib/index.d.ts.map +1 -0
  36. package/{src → build}/lib/index.js +1 -2
  37. package/build/lib/init.d.ts.map +1 -0
  38. package/build/lib/init.js +131 -0
  39. package/build/lib/local-provider-constraints.d.ts.map +1 -0
  40. package/build/lib/local-provider-constraints.js +95 -0
  41. package/build/lib/local-provider-versions.d.ts.map +1 -0
  42. package/build/lib/local-provider-versions.js +73 -0
  43. package/{src → build}/lib/models/deploy-machine.d.ts +3 -11
  44. package/build/lib/models/deploy-machine.d.ts.map +1 -0
  45. package/build/lib/models/deploy-machine.js +283 -0
  46. package/build/lib/models/interactive-process.d.ts +28 -0
  47. package/build/lib/models/interactive-process.d.ts.map +1 -0
  48. package/build/lib/models/interactive-process.js +59 -0
  49. package/{src → build}/lib/models/schema.d.ts.map +1 -1
  50. package/build/lib/models/schema.js +181 -0
  51. package/{src → build}/lib/models/terraform-cli.d.ts +1 -0
  52. package/build/lib/models/terraform-cli.d.ts.map +1 -0
  53. package/build/lib/models/terraform-cli.js +355 -0
  54. package/build/lib/models/terraform.d.ts.map +1 -0
  55. package/build/lib/models/terraform.js +72 -0
  56. package/build/lib/output.d.ts.map +1 -0
  57. package/build/lib/output.js +211 -0
  58. package/build/lib/provider-add.d.ts.map +1 -0
  59. package/build/lib/provider-add.js +30 -0
  60. package/build/lib/server/terraform-logs.d.ts.map +1 -0
  61. package/build/lib/server/terraform-logs.js +19 -0
  62. package/{src → build}/lib/synth-stack.d.ts +1 -0
  63. package/build/lib/synth-stack.d.ts.map +1 -0
  64. package/build/lib/synth-stack.js +251 -0
  65. package/build/lib/synth.d.ts.map +1 -0
  66. package/build/lib/synth.js +67 -0
  67. package/{src → build}/lib/terraform-json.d.ts.map +1 -1
  68. package/build/lib/terraform-json.js +82 -0
  69. package/build/lib/terraform-provider-lock.d.ts.map +1 -0
  70. package/{src → build}/lib/terraform-provider-lock.js +2 -2
  71. package/{src → build}/lib/watch.d.ts +1 -0
  72. package/build/lib/watch.d.ts.map +1 -0
  73. package/build/lib/watch.js +155 -0
  74. package/eslint.config.mjs +2 -70
  75. package/package.json +22 -33
  76. package/templates/go/go.mod +1 -1
  77. package/templates/python/Pipfile +1 -1
  78. package/templates/typescript/.hooks.sscaff.js +1 -1
  79. package/templates/typescript/jest.config.js +1 -1
  80. package/src/lib/cdktf-config.d.ts.map +0 -1
  81. package/src/lib/cdktf-config.js +0 -108
  82. package/src/lib/cdktf-project-io-handler.d.ts.map +0 -1
  83. package/src/lib/cdktf-project-io-handler.js +0 -84
  84. package/src/lib/cdktf-project.d.ts.map +0 -1
  85. package/src/lib/cdktf-project.js +0 -371
  86. package/src/lib/cdktf-stack.d.ts.map +0 -1
  87. package/src/lib/cdktf-stack.js +0 -386
  88. package/src/lib/convert.d.ts.map +0 -1
  89. package/src/lib/convert.js +0 -51
  90. package/src/lib/dependencies/cdktf-config-manager.d.ts.map +0 -1
  91. package/src/lib/dependencies/cdktf-config-manager.js +0 -36
  92. package/src/lib/dependencies/dependency-manager.d.ts.map +0 -1
  93. package/src/lib/dependencies/dependency-manager.js +0 -393
  94. package/src/lib/dependencies/package-manager.d.ts.map +0 -1
  95. package/src/lib/dependencies/package-manager.js +0 -581
  96. package/src/lib/dependencies/prebuilt-providers.d.ts.map +0 -1
  97. package/src/lib/dependencies/prebuilt-providers.js +0 -220
  98. package/src/lib/dependencies/registry-api.d.ts.map +0 -1
  99. package/src/lib/dependencies/registry-api.js +0 -77
  100. package/src/lib/dependencies/version-constraints.d.ts.map +0 -1
  101. package/src/lib/dependencies/version-constraints.js +0 -95
  102. package/src/lib/error-reporting.d.ts.map +0 -1
  103. package/src/lib/error-reporting.js +0 -133
  104. package/src/lib/errors.d.ts.map +0 -1
  105. package/src/lib/errors.js +0 -10
  106. package/src/lib/execution-logs.d.ts.map +0 -1
  107. package/src/lib/execution-logs.js +0 -47
  108. package/src/lib/get.d.ts.map +0 -1
  109. package/src/lib/get.js +0 -90
  110. package/src/lib/helpers/stack-helpers.d.ts.map +0 -1
  111. package/src/lib/helpers/stack-helpers.js +0 -155
  112. package/src/lib/index.d.ts.map +0 -1
  113. package/src/lib/init.d.ts.map +0 -1
  114. package/src/lib/init.js +0 -131
  115. package/src/lib/local-provider-constraints.d.ts.map +0 -1
  116. package/src/lib/local-provider-constraints.js +0 -95
  117. package/src/lib/local-provider-versions.d.ts.map +0 -1
  118. package/src/lib/local-provider-versions.js +0 -73
  119. package/src/lib/models/deploy-machine.d.ts.map +0 -1
  120. package/src/lib/models/deploy-machine.js +0 -280
  121. package/src/lib/models/pty-process.d.ts +0 -29
  122. package/src/lib/models/pty-process.d.ts.map +0 -1
  123. package/src/lib/models/pty-process.js +0 -132
  124. package/src/lib/models/schema.js +0 -181
  125. package/src/lib/models/terraform-cli.d.ts.map +0 -1
  126. package/src/lib/models/terraform-cli.js +0 -357
  127. package/src/lib/models/terraform.d.ts.map +0 -1
  128. package/src/lib/models/terraform.js +0 -72
  129. package/src/lib/output.d.ts.map +0 -1
  130. package/src/lib/output.js +0 -211
  131. package/src/lib/provider-add.d.ts.map +0 -1
  132. package/src/lib/provider-add.js +0 -30
  133. package/src/lib/server/terraform-logs.d.ts.map +0 -1
  134. package/src/lib/server/terraform-logs.js +0 -19
  135. package/src/lib/synth-stack.d.ts.map +0 -1
  136. package/src/lib/synth-stack.js +0 -251
  137. package/src/lib/synth.d.ts.map +0 -1
  138. package/src/lib/synth.js +0 -67
  139. package/src/lib/terraform-json.js +0 -82
  140. package/src/lib/terraform-provider-lock.d.ts.map +0 -1
  141. package/src/lib/watch.d.ts.map +0 -1
  142. package/src/lib/watch.js +0 -155
  143. /package/{src → build}/lib/cdktf-config.d.ts +0 -0
  144. /package/{src → build}/lib/cdktf-project-io-handler.d.ts +0 -0
  145. /package/{src → build}/lib/cdktf-project.d.ts +0 -0
  146. /package/{src → build}/lib/convert.d.ts +0 -0
  147. /package/{src → build}/lib/dependencies/cdktf-config-manager.d.ts +0 -0
  148. /package/{src → build}/lib/dependencies/dependency-manager.d.ts +0 -0
  149. /package/{src → build}/lib/dependencies/package-manager.d.ts +0 -0
  150. /package/{src → build}/lib/dependencies/prebuilt-providers.d.ts +0 -0
  151. /package/{src → build}/lib/dependencies/registry-api.d.ts +0 -0
  152. /package/{src → build}/lib/dependencies/version-constraints.d.ts +0 -0
  153. /package/{src → build}/lib/error-reporting.d.ts +0 -0
  154. /package/{src → build}/lib/errors.d.ts +0 -0
  155. /package/{src → build}/lib/execution-logs.d.ts +0 -0
  156. /package/{src → build}/lib/get.d.ts +0 -0
  157. /package/{src → build}/lib/helpers/stack-helpers.d.ts +0 -0
  158. /package/{src → build}/lib/index.d.ts +0 -0
  159. /package/{src → build}/lib/init.d.ts +0 -0
  160. /package/{src → build}/lib/local-provider-constraints.d.ts +0 -0
  161. /package/{src → build}/lib/local-provider-versions.d.ts +0 -0
  162. /package/{src → build}/lib/models/schema.d.ts +0 -0
  163. /package/{src → build}/lib/models/terraform.d.ts +0 -0
  164. /package/{src → build}/lib/output.d.ts +0 -0
  165. /package/{src → build}/lib/provider-add.d.ts +0 -0
  166. /package/{src → build}/lib/server/terraform-logs.d.ts +0 -0
  167. /package/{src → build}/lib/synth.d.ts +0 -0
  168. /package/{src → build}/lib/terraform-json.d.ts +0 -0
  169. /package/{src → build}/lib/terraform-provider-lock.d.ts +0 -0
@@ -0,0 +1,211 @@
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.getConstructIdsForOutputs = exports.parseOutput = exports.normalizeOutputPath = exports.saveOutputs = void 0;
30
+ // Copyright (c) HashiCorp, Inc
31
+ // SPDX-License-Identifier: MPL-2.0
32
+ const z = __importStar(require("zod"));
33
+ const fs = __importStar(require("fs"));
34
+ const path = __importStar(require("path"));
35
+ const strip_ansi_1 = __importDefault(require("strip-ansi"));
36
+ const commons_1 = require("@cdktn/commons");
37
+ const schema_1 = require("./models/schema");
38
+ const terraform_1 = require("./models/terraform");
39
+ function unpackTerraformOutput(outputs, includeSensitiveOutputs) {
40
+ return Object.entries(outputs).reduce((acc, [key, entry]) => ({
41
+ ...acc,
42
+ [key]: (0, terraform_1.isTerraformOutput)(entry)
43
+ ? !entry.sensitive || includeSensitiveOutputs
44
+ ? entry.value
45
+ : undefined
46
+ : unpackTerraformOutput(entry, includeSensitiveOutputs),
47
+ }), {});
48
+ }
49
+ async function saveOutputs(filePath, outputs, includeSensitiveOutputs) {
50
+ fs.writeFileSync(filePath, JSON.stringify(unpackTerraformOutput(outputs, includeSensitiveOutputs), null, 2));
51
+ }
52
+ exports.saveOutputs = saveOutputs;
53
+ function normalizeOutputPath(filePath) {
54
+ return path.isAbsolute(filePath)
55
+ ? filePath
56
+ : path.join(process.cwd(), filePath);
57
+ }
58
+ exports.normalizeOutputPath = normalizeOutputPath;
59
+ const mapActionToState = (action, done) => {
60
+ switch (action) {
61
+ case "create":
62
+ case "update":
63
+ return done
64
+ ? terraform_1.DeployingResourceApplyState.CREATED
65
+ : terraform_1.DeployingResourceApplyState.CREATING;
66
+ case "delete":
67
+ return done
68
+ ? terraform_1.DeployingResourceApplyState.DESTROYED
69
+ : terraform_1.DeployingResourceApplyState.DESTROYING;
70
+ default:
71
+ return terraform_1.DeployingResourceApplyState.WAITING;
72
+ }
73
+ };
74
+ // This is deprecated and will be removed in a future version.
75
+ const parseJsonOutputLine = (line) => {
76
+ let json, message;
77
+ try {
78
+ json = JSON.parse(line);
79
+ }
80
+ catch (_a) {
81
+ commons_1.logger.trace(`Could not parse line as JSON: ${line}`);
82
+ return;
83
+ }
84
+ try {
85
+ message = schema_1.schema.parse(json);
86
+ }
87
+ catch (err) {
88
+ if (err instanceof z.ZodError) {
89
+ commons_1.logger.trace(`Error parsing line into schema: ${JSON.stringify(err.errors)} => ${line}`);
90
+ }
91
+ return;
92
+ }
93
+ switch (message.type) {
94
+ case "apply_start":
95
+ case "apply_progress":
96
+ return {
97
+ id: message.hook.resource.resource,
98
+ applyState: mapActionToState(message.hook.action, false),
99
+ };
100
+ case "apply_complete":
101
+ return {
102
+ id: message.hook.resource.resource,
103
+ applyState: mapActionToState(message.hook.action, true),
104
+ };
105
+ default:
106
+ return;
107
+ }
108
+ };
109
+ const parseTextOutputLine = (line) => {
110
+ if (/^Outputs:/.test(line)) {
111
+ return;
112
+ }
113
+ if (/^Plan:/.test(line)) {
114
+ return;
115
+ }
116
+ if (/^data\..*/.test(line)) {
117
+ return;
118
+ }
119
+ const resourceMatch = line.match(/^([a-zA-Z_][a-zA-Z\d_\-.]*):/);
120
+ let applyState;
121
+ switch (true) {
122
+ case /Creating.../.test(line):
123
+ case /Still creating.../.test(line):
124
+ applyState = terraform_1.DeployingResourceApplyState.CREATING;
125
+ break;
126
+ case /Creation complete/.test(line):
127
+ applyState = terraform_1.DeployingResourceApplyState.CREATED;
128
+ break;
129
+ case /Modifying.../.test(line):
130
+ applyState = terraform_1.DeployingResourceApplyState.UPDATING;
131
+ break;
132
+ case /Modifications complete/.test(line):
133
+ applyState = terraform_1.DeployingResourceApplyState.UPDATED;
134
+ break;
135
+ case /Destroying.../.test(line):
136
+ case /Still destroying.../.test(line):
137
+ applyState = terraform_1.DeployingResourceApplyState.DESTROYING;
138
+ break;
139
+ case /Destruction complete/.test(line):
140
+ applyState = terraform_1.DeployingResourceApplyState.DESTROYED;
141
+ break;
142
+ default:
143
+ return;
144
+ }
145
+ if (resourceMatch &&
146
+ resourceMatch.length >= 0 &&
147
+ resourceMatch[1] != "Warning") {
148
+ return {
149
+ id: resourceMatch[1],
150
+ applyState,
151
+ };
152
+ }
153
+ else {
154
+ return;
155
+ }
156
+ };
157
+ const parseOutput = (str) => {
158
+ const lines = (0, strip_ansi_1.default)(str.toString()).split("\n");
159
+ const resources = lines.map((line) => {
160
+ const parsed = parseJsonOutputLine(line) || parseTextOutputLine(line);
161
+ if (parsed === undefined) {
162
+ return;
163
+ }
164
+ const { id, applyState } = parsed;
165
+ return {
166
+ id,
167
+ applyState,
168
+ action: terraform_1.PlannedResourceAction.CREATE,
169
+ };
170
+ });
171
+ return resources.reduce((acc, resource) => {
172
+ if (resource) {
173
+ acc.push(resource);
174
+ }
175
+ return acc;
176
+ // eslint-disable-next-line @typescript-eslint/no-array-constructor
177
+ }, new Array());
178
+ };
179
+ exports.parseOutput = parseOutput;
180
+ const isObjectEmpty = (obj) => {
181
+ if (typeof obj !== "object") {
182
+ return false;
183
+ }
184
+ return (Object.keys(obj).length === 0 ||
185
+ Object.values(obj).every((v) => v === undefined || v === null || isObjectEmpty(v)));
186
+ };
187
+ const getConstructIdsForOutputs = (stackContent, outputs) => {
188
+ // Older cdktf versions might not have the output metadata
189
+ if (!("//" in stackContent) || !("outputs" in stackContent["//"])) {
190
+ return outputs;
191
+ }
192
+ const outputsMapping = stackContent["//"].outputs;
193
+ const mapOutputs = (value) => {
194
+ return Object.entries(value).reduce((acc, [key, value]) => {
195
+ if (typeof value === "string") {
196
+ return { ...acc, [key]: outputs[value] };
197
+ }
198
+ const mapped = mapOutputs(value);
199
+ if (isObjectEmpty(mapped)) {
200
+ return acc;
201
+ }
202
+ return {
203
+ ...acc,
204
+ [key]: mapped,
205
+ };
206
+ }, {});
207
+ };
208
+ return mapOutputs(outputsMapping);
209
+ };
210
+ exports.getConstructIdsForOutputs = getConstructIdsForOutputs;
211
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"output.js","sourceRoot":"","sources":["../../src/lib/output.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+BAA+B;AAC/B,mCAAmC;AACnC,uCAAyB;AACzB,uCAAyB;AACzB,2CAA6B;AAC7B,4DAAmC;AAEnC,4CAAwC;AACxC,4CAAsD;AACtD,kDAM4B;AAO5B,SAAS,qBAAqB,CAC5B,OAA+B,EAC/B,uBAAgC;IAEhC,OAAO,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,CACnC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;QACtB,GAAG,GAAG;QACN,CAAC,GAAG,CAAC,EAAE,IAAA,6BAAiB,EAAC,KAAK,CAAC;YAC7B,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,IAAI,uBAAuB;gBAC3C,CAAC,CAAC,KAAK,CAAC,KAAK;gBACb,CAAC,CAAC,SAAS;YACb,CAAC,CAAC,qBAAqB,CAAC,KAAK,EAAE,uBAAuB,CAAC;KAC1D,CAAC,EACF,EAAE,CACH,CAAC;AACJ,CAAC;AAEM,KAAK,UAAU,WAAW,CAC/B,QAAgB,EAChB,OAA+B,EAC/B,uBAAgC;IAEhC,EAAE,CAAC,aAAa,CACd,QAAQ,EACR,IAAI,CAAC,SAAS,CACZ,qBAAqB,CAAC,OAAO,EAAE,uBAAuB,CAAC,EACvD,IAAI,EACJ,CAAC,CACF,CACF,CAAC;AACJ,CAAC;AAbD,kCAaC;AAED,SAAgB,mBAAmB,CAAC,QAAgB;IAClD,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;QAC9B,CAAC,CAAC,QAAQ;QACV,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;AACzC,CAAC;AAJD,kDAIC;AAMD,MAAM,gBAAgB,GAAG,CAAC,MAAmB,EAAE,IAAa,EAAE,EAAE;IAC9D,QAAQ,MAAM,EAAE,CAAC;QACf,KAAK,QAAQ,CAAC;QACd,KAAK,QAAQ;YACX,OAAO,IAAI;gBACT,CAAC,CAAC,uCAA2B,CAAC,OAAO;gBACrC,CAAC,CAAC,uCAA2B,CAAC,QAAQ,CAAC;QAC3C,KAAK,QAAQ;YACX,OAAO,IAAI;gBACT,CAAC,CAAC,uCAA2B,CAAC,SAAS;gBACvC,CAAC,CAAC,uCAA2B,CAAC,UAAU,CAAC;QAC7C;YACE,OAAO,uCAA2B,CAAC,OAAO,CAAC;IAC/C,CAAC;AACH,CAAC,CAAC;AACF,8DAA8D;AAC9D,MAAM,mBAAmB,GAAG,CAC1B,IAAY,EACmC,EAAE;IACjD,IAAI,IAAI,EAAE,OAAO,CAAC;IAClB,IAAI,CAAC;QACH,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAAC,WAAM,CAAC;QACP,gBAAM,CAAC,KAAK,CAAC,iCAAiC,IAAI,EAAE,CAAC,CAAC;QACtD,OAAO;IACT,CAAC;IAED,IAAI,CAAC;QACH,OAAO,GAAG,eAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,IAAI,GAAG,YAAY,CAAC,CAAC,QAAQ,EAAE,CAAC;YAC9B,gBAAM,CAAC,KAAK,CACV,mCAAmC,IAAI,CAAC,SAAS,CAC/C,GAAG,CAAC,MAAM,CACX,OAAO,IAAI,EAAE,CACf,CAAC;QACJ,CAAC;QAED,OAAO;IACT,CAAC;IAED,QAAQ,OAAO,CAAC,IAAI,EAAE,CAAC;QACrB,KAAK,aAAa,CAAC;QACnB,KAAK,gBAAgB;YACnB,OAAO;gBACL,EAAE,EAAE,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ;gBAClC,UAAU,EAAE,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC;aACzD,CAAC;QAEJ,KAAK,gBAAgB;YACnB,OAAO;gBACL,EAAE,EAAE,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ;gBAClC,UAAU,EAAE,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC;aACxD,CAAC;QACJ;YACE,OAAO;IACX,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,mBAAmB,GAAG,CAC1B,IAAY,EACmC,EAAE;IACjD,IAAI,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QAC3B,OAAO;IACT,CAAC;IACD,IAAI,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACxB,OAAO;IACT,CAAC;IACD,IAAI,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QAC3B,OAAO;IACT,CAAC;IAED,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,8BAA8B,CAAC,CAAC;IACjE,IAAI,UAAuC,CAAC;IAE5C,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,KAAK,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC;YACjC,UAAU,GAAG,uCAA2B,CAAC,QAAQ,CAAC;YAClD,MAAM;QACR,KAAK,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC;YACjC,UAAU,GAAG,uCAA2B,CAAC,OAAO,CAAC;YACjD,MAAM;QACR,KAAK,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC;YAC5B,UAAU,GAAG,uCAA2B,CAAC,QAAQ,CAAC;YAClD,MAAM;QACR,KAAK,wBAAwB,CAAC,IAAI,CAAC,IAAI,CAAC;YACtC,UAAU,GAAG,uCAA2B,CAAC,OAAO,CAAC;YACjD,MAAM;QACR,KAAK,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChC,KAAK,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC;YACnC,UAAU,GAAG,uCAA2B,CAAC,UAAU,CAAC;YACpD,MAAM;QACR,KAAK,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC;YACpC,UAAU,GAAG,uCAA2B,CAAC,SAAS,CAAC;YACnD,MAAM;QACR;YACE,OAAO;IACX,CAAC;IAED,IACE,aAAa;QACb,aAAa,CAAC,MAAM,IAAI,CAAC;QACzB,aAAa,CAAC,CAAC,CAAC,IAAI,SAAS,EAC7B,CAAC;QACD,OAAO;YACL,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC;YACpB,UAAU;SACX,CAAC;IACJ,CAAC;SAAM,CAAC;QACN,OAAO;IACT,CAAC;AACH,CAAC,CAAC;AAEK,MAAM,WAAW,GAAG,CAAC,GAAW,EAAuB,EAAE;IAC9D,MAAM,KAAK,GAAG,IAAA,oBAAS,EAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAEpD,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACnC,MAAM,MAAM,GAAG,mBAAmB,CAAC,IAAI,CAAC,IAAI,mBAAmB,CAAC,IAAI,CAAC,CAAC;QACtE,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;YACzB,OAAO;QACT,CAAC;QAED,MAAM,EAAE,EAAE,EAAE,UAAU,EAAE,GAAG,MAAM,CAAC;QAClC,OAAO;YACL,EAAE;YACF,UAAU;YACV,MAAM,EAAE,iCAAqB,CAAC,MAAM;SACrC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,QAAQ,EAAE,EAAE;QACxC,IAAI,QAAQ,EAAE,CAAC;YACb,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrB,CAAC;QACD,OAAO,GAAG,CAAC;QACX,mEAAmE;IACrE,CAAC,EAAE,IAAI,KAAK,EAAE,CAAC,CAAC;AAClB,CAAC,CAAC;AAxBW,QAAA,WAAW,eAwBtB;AAEF,MAAM,aAAa,GAAG,CAAC,GAAwB,EAAW,EAAE;IAC1D,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC5B,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,CACL,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,KAAK,CAAC;QAC7B,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,CACtB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,IAAI,CAAC,KAAK,IAAI,IAAI,aAAa,CAAC,CAAC,CAAC,CACzD,CACF,CAAC;AACJ,CAAC,CAAC;AAEK,MAAM,yBAAyB,GAAG,CACvC,YAAiC,EACjC,OAA2C,EACnB,EAAE;IAC1B,0DAA0D;IAC1D,IAAI,CAAC,CAAC,IAAI,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,SAAS,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;QAClE,OAAO,OAAO,CAAC;IACjB,CAAC;IACD,MAAM,cAAc,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC;IAElD,MAAM,UAAU,GAAG,CAAC,KAAkB,EAA0B,EAAE;QAChE,OAAO,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;YACxD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;gBAC9B,OAAO,EAAE,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAC3C,CAAC;YAED,MAAM,MAAM,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC;YACjC,IAAI,aAAa,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC1B,OAAO,GAAG,CAAC;YACb,CAAC;YAED,OAAO;gBACL,GAAG,GAAG;gBACN,CAAC,GAAG,CAAC,EAAE,MAAM;aACd,CAAC;QACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC,CAAC;IAEF,OAAO,UAAU,CAAC,cAAc,CAAC,CAAC;AACpC,CAAC,CAAC;AA7BW,QAAA,yBAAyB,6BA6BpC","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\nimport * as z from \"zod\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport stripAnsi from \"strip-ansi\";\n\nimport { logger } from \"@cdktn/commons\";\nimport { ActionTypes, schema } from \"./models/schema\";\nimport {\n  DeployingResource,\n  DeployingResourceApplyState,\n  PlannedResourceAction,\n  TerraformOutput,\n  isTerraformOutput,\n} from \"./models/terraform\";\n\nexport type Outputs = { [key: string]: TerraformOutput };\nexport type OutputIdMapLeaf = { [constructId: string]: string };\nexport type OutputIdMapNode = { [stackOrConstructId: string]: OutputIdMap };\nexport type OutputIdMap = OutputIdMapLeaf | OutputIdMapNode;\n\nfunction unpackTerraformOutput(\n  outputs: NestedTerraformOutputs,\n  includeSensitiveOutputs: boolean,\n): Record<string, string> {\n  return Object.entries(outputs).reduce(\n    (acc, [key, entry]) => ({\n      ...acc,\n      [key]: isTerraformOutput(entry)\n        ? !entry.sensitive || includeSensitiveOutputs\n          ? entry.value\n          : undefined\n        : unpackTerraformOutput(entry, includeSensitiveOutputs),\n    }),\n    {},\n  );\n}\n\nexport async function saveOutputs(\n  filePath: string,\n  outputs: NestedTerraformOutputs,\n  includeSensitiveOutputs: boolean,\n) {\n  fs.writeFileSync(\n    filePath,\n    JSON.stringify(\n      unpackTerraformOutput(outputs, includeSensitiveOutputs),\n      null,\n      2,\n    ),\n  );\n}\n\nexport function normalizeOutputPath(filePath: string) {\n  return path.isAbsolute(filePath)\n    ? filePath\n    : path.join(process.cwd(), filePath);\n}\n\nexport type NestedTerraformOutputs =\n  | { [key: string]: TerraformOutput }\n  | { [key: string]: NestedTerraformOutputs };\n\nconst mapActionToState = (action: ActionTypes, done: boolean) => {\n  switch (action) {\n    case \"create\":\n    case \"update\":\n      return done\n        ? DeployingResourceApplyState.CREATED\n        : DeployingResourceApplyState.CREATING;\n    case \"delete\":\n      return done\n        ? DeployingResourceApplyState.DESTROYED\n        : DeployingResourceApplyState.DESTROYING;\n    default:\n      return DeployingResourceApplyState.WAITING;\n  }\n};\n// This is deprecated and will be removed in a future version.\nconst parseJsonOutputLine = (\n  line: string,\n): Omit<DeployingResource, \"action\"> | undefined => {\n  let json, message;\n  try {\n    json = JSON.parse(line);\n  } catch {\n    logger.trace(`Could not parse line as JSON: ${line}`);\n    return;\n  }\n\n  try {\n    message = schema.parse(json);\n  } catch (err) {\n    if (err instanceof z.ZodError) {\n      logger.trace(\n        `Error parsing line into schema: ${JSON.stringify(\n          err.errors,\n        )} => ${line}`,\n      );\n    }\n\n    return;\n  }\n\n  switch (message.type) {\n    case \"apply_start\":\n    case \"apply_progress\":\n      return {\n        id: message.hook.resource.resource,\n        applyState: mapActionToState(message.hook.action, false),\n      };\n\n    case \"apply_complete\":\n      return {\n        id: message.hook.resource.resource,\n        applyState: mapActionToState(message.hook.action, true),\n      };\n    default:\n      return;\n  }\n};\n\nconst parseTextOutputLine = (\n  line: string,\n): Omit<DeployingResource, \"action\"> | undefined => {\n  if (/^Outputs:/.test(line)) {\n    return;\n  }\n  if (/^Plan:/.test(line)) {\n    return;\n  }\n  if (/^data\\..*/.test(line)) {\n    return;\n  }\n\n  const resourceMatch = line.match(/^([a-zA-Z_][a-zA-Z\\d_\\-.]*):/);\n  let applyState: DeployingResourceApplyState;\n\n  switch (true) {\n    case /Creating.../.test(line):\n    case /Still creating.../.test(line):\n      applyState = DeployingResourceApplyState.CREATING;\n      break;\n    case /Creation complete/.test(line):\n      applyState = DeployingResourceApplyState.CREATED;\n      break;\n    case /Modifying.../.test(line):\n      applyState = DeployingResourceApplyState.UPDATING;\n      break;\n    case /Modifications complete/.test(line):\n      applyState = DeployingResourceApplyState.UPDATED;\n      break;\n    case /Destroying.../.test(line):\n    case /Still destroying.../.test(line):\n      applyState = DeployingResourceApplyState.DESTROYING;\n      break;\n    case /Destruction complete/.test(line):\n      applyState = DeployingResourceApplyState.DESTROYED;\n      break;\n    default:\n      return;\n  }\n\n  if (\n    resourceMatch &&\n    resourceMatch.length >= 0 &&\n    resourceMatch[1] != \"Warning\"\n  ) {\n    return {\n      id: resourceMatch[1],\n      applyState,\n    };\n  } else {\n    return;\n  }\n};\n\nexport const parseOutput = (str: string): DeployingResource[] => {\n  const lines = stripAnsi(str.toString()).split(\"\\n\");\n\n  const resources = lines.map((line) => {\n    const parsed = parseJsonOutputLine(line) || parseTextOutputLine(line);\n    if (parsed === undefined) {\n      return;\n    }\n\n    const { id, applyState } = parsed;\n    return {\n      id,\n      applyState,\n      action: PlannedResourceAction.CREATE,\n    };\n  });\n\n  return resources.reduce((acc, resource) => {\n    if (resource) {\n      acc.push(resource);\n    }\n    return acc;\n    // eslint-disable-next-line @typescript-eslint/no-array-constructor\n  }, new Array());\n};\n\nconst isObjectEmpty = (obj: Record<string, any>): boolean => {\n  if (typeof obj !== \"object\") {\n    return false;\n  }\n  return (\n    Object.keys(obj).length === 0 ||\n    Object.values(obj).every(\n      (v) => v === undefined || v === null || isObjectEmpty(v),\n    )\n  );\n};\n\nexport const getConstructIdsForOutputs = (\n  stackContent: Record<string, any>,\n  outputs: { [key: string]: TerraformOutput },\n): NestedTerraformOutputs => {\n  // Older cdktf versions might not have the output metadata\n  if (!(\"//\" in stackContent) || !(\"outputs\" in stackContent[\"//\"])) {\n    return outputs;\n  }\n  const outputsMapping = stackContent[\"//\"].outputs;\n\n  const mapOutputs = (value: OutputIdMap): NestedTerraformOutputs => {\n    return Object.entries(value).reduce((acc, [key, value]) => {\n      if (typeof value === \"string\") {\n        return { ...acc, [key]: outputs[value] };\n      }\n\n      const mapped = mapOutputs(value);\n      if (isObjectEmpty(mapped)) {\n        return acc;\n      }\n\n      return {\n        ...acc,\n        [key]: mapped,\n      };\n    }, {});\n  };\n\n  return mapOutputs(outputsMapping);\n};\n"]}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provider-add.d.ts","sourceRoot":"","sources":["../../src/lib/provider-add.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAO1C,MAAM,MAAM,eAAe,GAAG;IAC5B,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,QAAQ,EAAE,QAAQ,CAAC;IACnB,gBAAgB,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,wBAAsB,WAAW,CAAC,EAChC,SAAS,EACT,QAAQ,EACR,gBAAgB,EAChB,YAAY,EACZ,IAAI,EACJ,UAAU,GACX,EAAE,eAAe,GAAG,OAAO,CAAC,OAAO,CAAC,CAsBpC"}
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) HashiCorp, Inc.
4
+ * SPDX-License-Identifier: MPL-2.0
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.providerAdd = void 0;
8
+ const dependency_manager_1 = require("./dependencies/dependency-manager");
9
+ const init_1 = require("./init");
10
+ async function providerAdd({ providers, language, projectDirectory, cdktfVersion, dist, forceLocal, }) {
11
+ const version = cdktfVersion || (await (0, init_1.determineDeps)(cdktfVersion, dist)).cdktf_version;
12
+ const manager = new dependency_manager_1.DependencyManager(language, version, projectDirectory);
13
+ let needsGet = false;
14
+ for (const provider of providers) {
15
+ const constraint = dependency_manager_1.ProviderConstraint.fromConfigEntry(provider);
16
+ if (forceLocal) {
17
+ needsGet = true;
18
+ await manager.addLocalProvider(constraint);
19
+ }
20
+ else {
21
+ const { addedLocalProvider } = await manager.addProvider(constraint);
22
+ if (addedLocalProvider) {
23
+ needsGet = true;
24
+ }
25
+ }
26
+ }
27
+ return needsGet;
28
+ }
29
+ exports.providerAdd = providerAdd;
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXItYWRkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi9wcm92aWRlci1hZGQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7R0FHRzs7O0FBR0gsMEVBRzJDO0FBQzNDLGlDQUF1QztBQVdoQyxLQUFLLFVBQVUsV0FBVyxDQUFDLEVBQ2hDLFNBQVMsRUFDVCxRQUFRLEVBQ1IsZ0JBQWdCLEVBQ2hCLFlBQVksRUFDWixJQUFJLEVBQ0osVUFBVSxHQUNNO0lBQ2hCLE1BQU0sT0FBTyxHQUNYLFlBQVksSUFBSSxDQUFDLE1BQU0sSUFBQSxvQkFBYSxFQUFDLFlBQVksRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQztJQUUxRSxNQUFNLE9BQU8sR0FBRyxJQUFJLHNDQUFpQixDQUFDLFFBQVEsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztJQUUzRSxJQUFJLFFBQVEsR0FBRyxLQUFLLENBQUM7SUFFckIsS0FBSyxNQUFNLFFBQVEsSUFBSSxTQUFTLEVBQUUsQ0FBQztRQUNqQyxNQUFNLFVBQVUsR0FBRyx1Q0FBa0IsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDaEUsSUFBSSxVQUFVLEVBQUUsQ0FBQztZQUNmLFFBQVEsR0FBRyxJQUFJLENBQUM7WUFDaEIsTUFBTSxPQUFPLENBQUMsZ0JBQWdCLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDN0MsQ0FBQzthQUFNLENBQUM7WUFDTixNQUFNLEVBQUUsa0JBQWtCLEVBQUUsR0FBRyxNQUFNLE9BQU8sQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDckUsSUFBSSxrQkFBa0IsRUFBRSxDQUFDO2dCQUN2QixRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ2xCLENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQztJQUVELE9BQU8sUUFBUSxDQUFDO0FBQ2xCLENBQUM7QUE3QkQsa0NBNkJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIEhhc2hpQ29ycCwgSW5jLlxuICogU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IE1QTC0yLjBcbiAqL1xuXG5pbXBvcnQgeyBMYW5ndWFnZSB9IGZyb20gXCJAY2RrdG4vY29tbW9uc1wiO1xuaW1wb3J0IHtcbiAgRGVwZW5kZW5jeU1hbmFnZXIsXG4gIFByb3ZpZGVyQ29uc3RyYWludCxcbn0gZnJvbSBcIi4vZGVwZW5kZW5jaWVzL2RlcGVuZGVuY3ktbWFuYWdlclwiO1xuaW1wb3J0IHsgZGV0ZXJtaW5lRGVwcyB9IGZyb20gXCIuL2luaXRcIjtcblxuZXhwb3J0IHR5cGUgUHJvdmlkZXJBZGRBcmdzID0ge1xuICBwcm92aWRlcnM6IHN0cmluZ1tdO1xuICBsYW5ndWFnZTogTGFuZ3VhZ2U7XG4gIHByb2plY3REaXJlY3Rvcnk6IHN0cmluZztcbiAgY2RrdGZWZXJzaW9uPzogc3RyaW5nO1xuICBmb3JjZUxvY2FsPzogYm9vbGVhbjtcbiAgZGlzdD86IHN0cmluZztcbn07XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBwcm92aWRlckFkZCh7XG4gIHByb3ZpZGVycyxcbiAgbGFuZ3VhZ2UsXG4gIHByb2plY3REaXJlY3RvcnksXG4gIGNka3RmVmVyc2lvbixcbiAgZGlzdCxcbiAgZm9yY2VMb2NhbCxcbn06IFByb3ZpZGVyQWRkQXJncyk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICBjb25zdCB2ZXJzaW9uID1cbiAgICBjZGt0ZlZlcnNpb24gfHwgKGF3YWl0IGRldGVybWluZURlcHMoY2RrdGZWZXJzaW9uLCBkaXN0KSkuY2RrdGZfdmVyc2lvbjtcblxuICBjb25zdCBtYW5hZ2VyID0gbmV3IERlcGVuZGVuY3lNYW5hZ2VyKGxhbmd1YWdlLCB2ZXJzaW9uLCBwcm9qZWN0RGlyZWN0b3J5KTtcblxuICBsZXQgbmVlZHNHZXQgPSBmYWxzZTtcblxuICBmb3IgKGNvbnN0IHByb3ZpZGVyIG9mIHByb3ZpZGVycykge1xuICAgIGNvbnN0IGNvbnN0cmFpbnQgPSBQcm92aWRlckNvbnN0cmFpbnQuZnJvbUNvbmZpZ0VudHJ5KHByb3ZpZGVyKTtcbiAgICBpZiAoZm9yY2VMb2NhbCkge1xuICAgICAgbmVlZHNHZXQgPSB0cnVlO1xuICAgICAgYXdhaXQgbWFuYWdlci5hZGRMb2NhbFByb3ZpZGVyKGNvbnN0cmFpbnQpO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCB7IGFkZGVkTG9jYWxQcm92aWRlciB9ID0gYXdhaXQgbWFuYWdlci5hZGRQcm92aWRlcihjb25zdHJhaW50KTtcbiAgICAgIGlmIChhZGRlZExvY2FsUHJvdmlkZXIpIHtcbiAgICAgICAgbmVlZHNHZXQgPSB0cnVlO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiBuZWVkc0dldDtcbn1cbiJdfQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"terraform-logs.d.ts","sourceRoot":"","sources":["../../../src/lib/server/terraform-logs.ts"],"names":[],"mappings":"AAWA,wBAAgB,uBAAuB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAEhE"}
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.extractJsonLogIfPresent = void 0;
4
+ // Copyright (c) HashiCorp, Inc
5
+ // SPDX-License-Identifier: MPL-2.0
6
+ function extractJsonLogLineIfPresent(logLine) {
7
+ try {
8
+ const extractedMessage = JSON.parse(logLine)["@message"];
9
+ return extractedMessage ? extractedMessage.trim() : logLine;
10
+ }
11
+ catch (_a) {
12
+ return logLine;
13
+ }
14
+ }
15
+ function extractJsonLogIfPresent(logLines) {
16
+ return logLines.split("\n").map(extractJsonLogLineIfPresent).join("\n");
17
+ }
18
+ exports.extractJsonLogIfPresent = extractJsonLogIfPresent;
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVycmFmb3JtLWxvZ3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3NlcnZlci90ZXJyYWZvcm0tbG9ncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwrQkFBK0I7QUFDL0IsbUNBQW1DO0FBQ25DLFNBQVMsMkJBQTJCLENBQUMsT0FBZTtJQUNsRCxJQUFJLENBQUM7UUFDSCxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDekQsT0FBTyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQztJQUM5RCxDQUFDO0lBQUMsV0FBTSxDQUFDO1FBQ1AsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQztBQUNILENBQUM7QUFFRCxTQUFnQix1QkFBdUIsQ0FBQyxRQUFnQjtJQUN0RCxPQUFPLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLDJCQUEyQixDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQzFFLENBQUM7QUFGRCwwREFFQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCAoYykgSGFzaGlDb3JwLCBJbmNcbi8vIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBNUEwtMi4wXG5mdW5jdGlvbiBleHRyYWN0SnNvbkxvZ0xpbmVJZlByZXNlbnQobG9nTGluZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgdHJ5IHtcbiAgICBjb25zdCBleHRyYWN0ZWRNZXNzYWdlID0gSlNPTi5wYXJzZShsb2dMaW5lKVtcIkBtZXNzYWdlXCJdO1xuICAgIHJldHVybiBleHRyYWN0ZWRNZXNzYWdlID8gZXh0cmFjdGVkTWVzc2FnZS50cmltKCkgOiBsb2dMaW5lO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gbG9nTGluZTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZXh0cmFjdEpzb25Mb2dJZlByZXNlbnQobG9nTGluZXM6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBsb2dMaW5lcy5zcGxpdChcIlxcblwiKS5tYXAoZXh0cmFjdEpzb25Mb2dMaW5lSWZQcmVzZW50KS5qb2luKFwiXFxuXCIpO1xufVxuIl19
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import { StackManifest, TerraformStackMetadata } from "cdktn";
2
3
  export interface SynthesizedStackMetadata {
3
4
  "//"?: {
@@ -0,0 +1 @@
1
+ {"version":3,"file":"synth-stack.d.ts","sourceRoot":"","sources":["../../src/lib/synth-stack.ts"],"names":[],"mappings":";AAMA,OAAO,EAGL,aAAa,EACb,sBAAsB,EACvB,MAAM,OAAO,CAAC;AAQf,MAAM,WAAW,wBAAwB;IACvC,IAAI,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,sBAAsB,CAAA;KAAE,CAAC;CAClD;AAED,MAAM,WAAW,gBAAiB,SAAQ,aAAa;IACrD,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,qBAAa,iBAAiB;IAKhB,OAAO,CAAC,QAAQ,CAAC,MAAM;IAJ5B,aAAa,EAAE,gBAAgB,EAAE,CAAM;IACvC,cAAc,EAAE,gBAAgB,EAAE,CAAM;IACxC,cAAc,EAAE,gBAAgB,EAAE,CAAM;gBAElB,MAAM,EAAE,gBAAgB,EAAE;IAIhD,QAAQ,CAAC,KAAK,EAAE,gBAAgB,GAAG,IAAI;IAOvC,SAAS,CAAC,KAAK,EAAE,gBAAgB,GAAG,IAAI;IAO/C,IAAW,uBAAuB,IAAI,gBAAgB,EAAE,CAYvD;CACF;AAOD,MAAM,MAAM,WAAW,GAAG,OAAO,CAAC;AAElC,qBAAa,UAAU;WACD,KAAK,CACvB,WAAW,EAAE,WAAW,EACxB,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,MAAM,EACd,gBAAgB,SAAgB,EAChC,QAAQ,UAAQ,EAAE,0DAA0D;IAC5E,OAAO,UAAQ,EACf,WAAW,CAAC,EAAE,WAAW,EACzB,GAAG,UAAQ,GACV,OAAO,CAAC,gBAAgB,EAAE,CAAC;WAmIV,cAAc,CAAC,MAAM,EAAE,MAAM;WAsB7B,qBAAqB,CACvC,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,gBAAgB,EAAE,CAAC;WAkCV,cAAc,CAChC,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,gBAAgB,EAAE,EAC1B,WAAW,CAAC,EAAE,WAAW,GACxB,OAAO,CAAC,IAAI,CAAC;WAiBI,mBAAmB,CAAC,WAAW,CAAC,EAAE,WAAW;CAGlE"}
@@ -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":["../../src/lib/synth-stack.ts"],"names":[],"mappings":"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","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 @@
1
+ {"version":3,"file":"synth.d.ts","sourceRoot":"","sources":["../../src/lib/synth.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAMjD;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,gBAAgB,EAAE,QA0C1D"}