@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
@@ -1,181 +0,0 @@
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.schema = void 0;
27
- // Copyright (c) HashiCorp, Inc
28
- // SPDX-License-Identifier: MPL-2.0
29
- const z = __importStar(require("zod"));
30
- // Schemas from https://www.terraform.io/docs/internals/machine-readable-ui.html#change_summary
31
- const resource = z.object({
32
- addr: z.string(),
33
- module: z.string(),
34
- resource: z.string(),
35
- implied_provider: z.string(),
36
- resource_type: z.string(),
37
- resource_name: z.string(),
38
- resource_key: z.string().optional().nullable(),
39
- });
40
- const baseMessage = z
41
- .object({
42
- "@level": z.enum(["info", "error", "warn"]),
43
- "@message": z.string(),
44
- "@module": z.string(),
45
- "@timestamp": z.string(),
46
- })
47
- .nonstrict();
48
- const action = z.enum(["noop", "create", "read", "update", "delete"]);
49
- const change = z.object({
50
- resource,
51
- action,
52
- });
53
- const replaceChange = change.extend({
54
- action: z.literal("replace"),
55
- reason: z.enum(["tainted", "requested", "cannot_update"]),
56
- });
57
- const plannedChange = baseMessage.extend({
58
- type: z.literal("planned_change"),
59
- change: z.union([replaceChange, change]),
60
- });
61
- const version = baseMessage.extend({
62
- type: z.literal("version"),
63
- });
64
- const changeSummary = baseMessage.extend({
65
- type: z.literal("change_summary"),
66
- changes: z.object({
67
- add: z.number(),
68
- change: z.number(),
69
- remove: z.number(),
70
- operation: z.enum(["plan", "apply", "deploy"]),
71
- }),
72
- });
73
- const outputs = baseMessage.extend({
74
- type: z.literal("outputs"),
75
- outputs: z.record(z.object({
76
- sensitive: z.boolean(),
77
- type: z.string(),
78
- value: z.string(),
79
- })),
80
- });
81
- const applyStart = baseMessage.extend({
82
- type: z.literal("apply_start"),
83
- hook: z.object({
84
- resource,
85
- action,
86
- id_key: z.string().optional(),
87
- id_value: z.string().optional(),
88
- }),
89
- });
90
- const applyProgress = baseMessage.extend({
91
- type: z.literal("apply_progress"),
92
- hook: z.object({
93
- resource,
94
- action,
95
- elapsed_seconds: z.number(),
96
- }),
97
- });
98
- const applyComplete = baseMessage.extend({
99
- type: z.literal("apply_complete"),
100
- hook: z.object({
101
- resource,
102
- action,
103
- id_key: z.string().optional(),
104
- id_value: z.string().optional(),
105
- elapsed_seconds: z.number(),
106
- }),
107
- });
108
- const applyError = baseMessage.extend({
109
- type: z.literal("apply_errored"),
110
- hook: z.object({
111
- resource,
112
- action,
113
- elapsed_seconds: z.number(),
114
- }),
115
- });
116
- const provisionStart = baseMessage.extend({
117
- type: z.literal("provision_start"),
118
- hook: z.object({
119
- resource,
120
- provisioner: z.string(),
121
- }),
122
- });
123
- const provisionProgress = baseMessage.extend({
124
- type: z.literal("provision_progress"),
125
- hook: z.object({
126
- resource,
127
- provisioner: z.string(),
128
- output: z.string(),
129
- }),
130
- });
131
- const provisionComplete = baseMessage.extend({
132
- type: z.literal("provision_complete"),
133
- hook: z.object({
134
- resource,
135
- provisioner: z.string(),
136
- }),
137
- });
138
- const provisionErrored = baseMessage.extend({
139
- type: z.literal("provision_errored"),
140
- hook: z.object({
141
- resource,
142
- provisioner: z.string(),
143
- }),
144
- });
145
- const refreshStart = baseMessage.extend({
146
- type: z.literal("refresh_start"),
147
- hook: z.object({
148
- resource,
149
- id_key: z.string().optional(),
150
- id_value: z.string().optional(),
151
- }),
152
- });
153
- const refreshComplete = baseMessage.extend({
154
- type: z.literal("refresh_complete"),
155
- hook: z.object({
156
- resource,
157
- id_key: z.string().optional(),
158
- id_value: z.string().optional(),
159
- }),
160
- });
161
- const logMessage = baseMessage.extend({
162
- type: z.literal("log"),
163
- });
164
- exports.schema = z.union([
165
- version,
166
- plannedChange,
167
- changeSummary,
168
- outputs,
169
- applyStart,
170
- applyProgress,
171
- applyComplete,
172
- applyError,
173
- provisionStart,
174
- provisionProgress,
175
- provisionComplete,
176
- provisionErrored,
177
- refreshStart,
178
- refreshComplete,
179
- logMessage,
180
- ]);
181
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema.js","sourceRoot":"","sources":["schema.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\nimport * as z from \"zod\";\n\n// Schemas from https://www.terraform.io/docs/internals/machine-readable-ui.html#change_summary\nconst resource = z.object({\n  addr: z.string(),\n  module: z.string(),\n  resource: z.string(),\n  implied_provider: z.string(),\n  resource_type: z.string(),\n  resource_name: z.string(),\n  resource_key: z.string().optional().nullable(),\n});\nconst baseMessage = z\n  .object({\n    \"@level\": z.enum([\"info\", \"error\", \"warn\"]),\n    \"@message\": z.string(),\n    \"@module\": z.string(),\n    \"@timestamp\": z.string(),\n  })\n  .nonstrict();\n\nconst action = z.enum([\"noop\", \"create\", \"read\", \"update\", \"delete\"]);\nconst change = z.object({\n  resource,\n  action,\n});\nconst replaceChange = change.extend({\n  action: z.literal(\"replace\"),\n  reason: z.enum([\"tainted\", \"requested\", \"cannot_update\"]),\n});\nconst plannedChange = baseMessage.extend({\n  type: z.literal(\"planned_change\"),\n  change: z.union([replaceChange, change]),\n});\n\nconst version = baseMessage.extend({\n  type: z.literal(\"version\"),\n});\n\nconst changeSummary = baseMessage.extend({\n  type: z.literal(\"change_summary\"),\n  changes: z.object({\n    add: z.number(),\n    change: z.number(),\n    remove: z.number(),\n    operation: z.enum([\"plan\", \"apply\", \"deploy\"]),\n  }),\n});\n\nconst outputs = baseMessage.extend({\n  type: z.literal(\"outputs\"),\n  outputs: z.record(\n    z.object({\n      sensitive: z.boolean(),\n      type: z.string(),\n      value: z.string(),\n    }),\n  ),\n});\n\nconst applyStart = baseMessage.extend({\n  type: z.literal(\"apply_start\"),\n  hook: z.object({\n    resource,\n    action,\n    id_key: z.string().optional(),\n    id_value: z.string().optional(),\n  }),\n});\n\nconst applyProgress = baseMessage.extend({\n  type: z.literal(\"apply_progress\"),\n  hook: z.object({\n    resource,\n    action,\n    elapsed_seconds: z.number(),\n  }),\n});\n\nconst applyComplete = baseMessage.extend({\n  type: z.literal(\"apply_complete\"),\n  hook: z.object({\n    resource,\n    action,\n    id_key: z.string().optional(),\n    id_value: z.string().optional(),\n    elapsed_seconds: z.number(),\n  }),\n});\n\nconst applyError = baseMessage.extend({\n  type: z.literal(\"apply_errored\"),\n  hook: z.object({\n    resource,\n    action,\n    elapsed_seconds: z.number(),\n  }),\n});\n\nconst provisionStart = baseMessage.extend({\n  type: z.literal(\"provision_start\"),\n  hook: z.object({\n    resource,\n    provisioner: z.string(),\n  }),\n});\n\nconst provisionProgress = baseMessage.extend({\n  type: z.literal(\"provision_progress\"),\n  hook: z.object({\n    resource,\n    provisioner: z.string(),\n    output: z.string(),\n  }),\n});\n\nconst provisionComplete = baseMessage.extend({\n  type: z.literal(\"provision_complete\"),\n  hook: z.object({\n    resource,\n    provisioner: z.string(),\n  }),\n});\n\nconst provisionErrored = baseMessage.extend({\n  type: z.literal(\"provision_errored\"),\n  hook: z.object({\n    resource,\n    provisioner: z.string(),\n  }),\n});\n\nconst refreshStart = baseMessage.extend({\n  type: z.literal(\"refresh_start\"),\n  hook: z.object({\n    resource,\n    id_key: z.string().optional(),\n    id_value: z.string().optional(),\n  }),\n});\n\nconst refreshComplete = baseMessage.extend({\n  type: z.literal(\"refresh_complete\"),\n  hook: z.object({\n    resource,\n    id_key: z.string().optional(),\n    id_value: z.string().optional(),\n  }),\n});\n\nconst logMessage = baseMessage.extend({\n  type: z.literal(\"log\"),\n});\n\nexport const schema = z.union([\n  version,\n  plannedChange,\n  changeSummary,\n  outputs,\n  applyStart,\n  applyProgress,\n  applyComplete,\n  applyError,\n  provisionStart,\n  provisionProgress,\n  provisionComplete,\n  provisionErrored,\n  refreshStart,\n  refreshComplete,\n  logMessage,\n]);\n\nexport type ActionTypes = z.infer<typeof action>;\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"terraform-cli.d.ts","sourceRoot":"","sources":["terraform-cli.ts"],"names":[],"mappings":"AAUA,OAAO,EACL,SAAS,EACT,aAAa,EACb,eAAe,EACf,qBAAqB,EACrB,oBAAoB,EACrB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAgBlD,qBAAa,gBACX,SAAQ,qBACR,YAAW,aAAa;aAGN,QAAQ,EAAE,MAAM;aAChB,IAAI,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;KAAE;gBAD5B,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;KAAE;CAI/C;AAED,uBAAe,oBAAoB;IACjC,OAAc,SAAS,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC;IACnD,OAAc,SAAS,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,MAAM,CAAC;CACnD;AACD,MAAM,MAAM,YAAY,GAAG,OAAO,oBAAoB,CAAC;AAkCvD,qBAAa,YAAa,YAAW,SAAS;IAY1C,OAAO,CAAC,QAAQ,CAAC,WAAW;aACZ,KAAK,EAAE,gBAAgB;IAZzC,SAAgB,OAAO,EAAE,MAAM,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAGc;IACvC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAGkB;gBAGxB,WAAW,EAAE,WAAW,EACzB,KAAK,EAAE,gBAAgB,EACvC,yBAAyB,YAAY,MAAM,YAAY,YAAY,EAAE,eACzD,MAAM,2BAAuB;IAe9B,IAAI,CAAC,IAAI,EAAE;QACtB,YAAY,EAAE,OAAO,CAAC;QACtB,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,YAAY,EAAE,OAAO,CAAC;QACtB,mBAAmB,EAAE,OAAO,CAAC;KAC9B,GAAG,OAAO,CAAC,IAAI,CAAC;IAmFjB,OAAO,KAAK,YAAY,GAQvB;IAED,OAAO,KAAK,UAAU,GAMrB;IAEY,IAAI,CAAC,IAAI,EAAE;QACtB,OAAO,EAAE,OAAO,CAAC;QACjB,WAAW,CAAC,EAAE,OAAO,CAAC;QACtB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;QAChB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;QACpB,OAAO,CAAC,EAAE,OAAO,CAAC;KACnB,GAAG,OAAO,CAAC,IAAI,CAAC;IA8DJ,MAAM,CACjB,EACE,WAAmB,EACnB,WAAmB,EACnB,OAAe,EACf,WAAgB,EAChB,YAAiB,EACjB,IAAS,EACT,QAAa,GACd;;;;;;;;KAAA,EACD,QAAQ,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,IAAI,GAC9C,OAAO,CAAC;QAAE,SAAS,EAAE,OAAO,CAAA;KAAE,CAAC;IAgBrB,OAAO,CAClB,EACE,WAAmB,EACnB,WAAgB,EAChB,OAAe,EACf,YAAiB,EACjB,IAAS,EACT,QAAa,GACd;;;;;;;KAAA,EACD,QAAQ,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,IAAI,GAC9C,OAAO,CAAC;QAAE,SAAS,EAAE,OAAO,CAAA;KAAE,CAAC;YAepB,aAAa;IA+Fd,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC;IAqB1B,MAAM,IAAI,OAAO,CAAC;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,eAAe,CAAA;KAAE,CAAC;IAwBrD,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAa7B,KAAK;CAGnB;AAED,wBAAsB,iCAAiC,CACrD,UAAU,EAAE,MAAM,GACjB,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAMxB;AAED,wBAAsB,mCAAmC,CAAC,UAAU,EAAE,MAAM,iBAK3E"}
@@ -1,357 +0,0 @@
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.tryRemoveGeneratedConfigurationFile = exports.tryReadGeneratedConfigurationFile = exports.TerraformCli = exports.TerraformCliPlan = void 0;
30
- // Copyright (c) HashiCorp, Inc
31
- // SPDX-License-Identifier: MPL-2.0
32
- const strip_ansi_1 = __importDefault(require("strip-ansi"));
33
- const commons_1 = require("@cdktn/commons");
34
- const terraform_1 = require("./terraform");
35
- const deploy_machine_1 = require("./deploy-machine");
36
- const waitFor_1 = require("xstate/lib/waitFor");
37
- const errors_1 = require("../errors");
38
- const terraform_json_1 = require("../terraform-json");
39
- const pty_process_1 = require("./pty-process");
40
- const path_1 = __importDefault(require("path"));
41
- const fs = __importStar(require("fs-extra"));
42
- const GENERATE_CONFIG_OUT_FILE = "generated_resources.tf";
43
- class TerraformCliPlan extends terraform_1.AbstractTerraformPlan {
44
- constructor(planFile, plan) {
45
- super(planFile, plan === null || plan === void 0 ? void 0 : plan.resource_changes, plan === null || plan === void 0 ? void 0 : plan.output_changes);
46
- this.planFile = planFile;
47
- this.plan = plan;
48
- }
49
- }
50
- exports.TerraformCliPlan = TerraformCliPlan;
51
- class AbstractOutputFilter {
52
- }
53
- // The plan might error if there is a variable missing, but the error message hints the user
54
- // in a wrong direction. We therefore catch the error and rethrow it with a more helpful message
55
- class VariableRequiredFilter extends AbstractOutputFilter {
56
- // Example for "No value for required variable" error
57
- // ╷
58
- // │ Error: No value for required variable
59
- // │
60
- // │ on cdk.tf.json line 31, in variable:
61
- // │ 31: "with-dashes": {
62
- // │
63
- // │ The root module input variable "with-dashes" is not set, and has no default
64
- // │ value. Use a -var or -var-file command line argument to provide a value for
65
- // │ this variable
66
- static condition(input) {
67
- const line = (0, strip_ansi_1.default)(input);
68
- return (line.includes("Error: No value for required variable") &&
69
- line.includes("The root module input variable"));
70
- }
71
- static transform(line) {
72
- const startMarker = 'The root module input variable "';
73
- const variableName = line.substring(line.indexOf(startMarker) + startMarker.length, line.indexOf('" is not set'));
74
- return (0, errors_1.missingVariable)(variableName);
75
- }
76
- }
77
- class TerraformCli {
78
- constructor(abortSignal, stack, createTerraformLogHandler = (_phase, _filter) => (_stdout, _isErr = false) => { }) {
79
- this.abortSignal = abortSignal;
80
- this.stack = stack;
81
- this.workdir = stack.workingDirectory;
82
- this.onStdout =
83
- (phase, filter) => (stdout) => createTerraformLogHandler(phase, filter)(Buffer.isBuffer(stdout) ? stdout.toString() : stdout);
84
- this.onStderr =
85
- (phase, filter) => (stderr) => createTerraformLogHandler(phase, filter)(stderr.toString(), true);
86
- }
87
- async init(opts) {
88
- await this.setUserAgent();
89
- const args = ["init"];
90
- if (opts.needsUpgrade) {
91
- args.push("-upgrade");
92
- }
93
- if (opts.noColor) {
94
- args.push("-no-color");
95
- }
96
- if (opts.migrateState) {
97
- args.push("-migrate-state");
98
- }
99
- // eslint-disable-next-line @typescript-eslint/no-empty-function
100
- let initCanNotContinue = (_err) => { };
101
- const rejectsIfInitCanNotContinue = new Promise((_resolve, reject) => {
102
- initCanNotContinue = reject;
103
- });
104
- const stdout = this.onStdout("init");
105
- const { actions, exitCode } = (0, pty_process_1.spawnPty)({
106
- file: commons_1.terraformBinaryName,
107
- args,
108
- options: {
109
- cwd: this.workdir,
110
- env: process.env,
111
- },
112
- }, (data) => {
113
- stdout(data);
114
- if (data.includes("Should Terraform migrate your existing state?") ||
115
- data.includes("Do you want to copy existing state to the new backend")) {
116
- // TODO: This only happens when terraform is passed the -migrate-state anyway, so this check is redundant
117
- if (opts.migrateState) {
118
- actions.writeLine("yes");
119
- }
120
- else {
121
- actions.stop();
122
- initCanNotContinue("Please pass the --migrate-state flag to migrate your state");
123
- }
124
- }
125
- });
126
- this.abortSignal.addEventListener("abort", () => {
127
- actions.stop();
128
- });
129
- const progress = exitCode.then((code) => {
130
- if (code !== 0) {
131
- throw new Error(`terraform init failed with exit code ${code}`);
132
- }
133
- });
134
- await Promise.race([progress, rejectsIfInitCanNotContinue]);
135
- // TODO: this might have performance implications because we don't know if we're
136
- // running a remote plan or a local one (so we run it always for all platforms)
137
- // while we'd only need it for remote plans
138
- if (opts.needsLockfileUpdate) {
139
- await (0, commons_1.exec)(commons_1.terraformBinaryName, [
140
- "providers",
141
- "lock",
142
- "-platform=linux_amd64",
143
- ...(opts.noColor ? ["-no-color"] : []),
144
- ], {
145
- cwd: this.workdir,
146
- env: process.env,
147
- signal: this.abortSignal,
148
- noColor: opts.noColor,
149
- }, this.onStdout("init"), this.onStderr("init"));
150
- }
151
- }
152
- get isCloudStack() {
153
- var _a, _b, _c;
154
- const parsedStack = terraform_json_1.terraformJsonSchema.parse(JSON.parse(this.stack.content));
155
- return Boolean(((_b = (_a = parsedStack.terraform) === null || _a === void 0 ? void 0 : _a.backend) === null || _b === void 0 ? void 0 : _b.remote) || ((_c = parsedStack.terraform) === null || _c === void 0 ? void 0 : _c.cloud));
156
- }
157
- get hasImports() {
158
- const parsedStack = terraform_json_1.terraformJsonSchema.parse(JSON.parse(this.stack.content));
159
- return Boolean(parsedStack.import);
160
- }
161
- async plan(opts) {
162
- const { destroy = false, refreshOnly = false, parallelism = -1, vars = [], varFiles = [], noColor = false, } = opts;
163
- const options = ["plan", "-input=false"];
164
- const generatedConfigFile = path_1.default.join(this.workdir, GENERATE_CONFIG_OUT_FILE);
165
- if (fs.existsSync(generatedConfigFile)) {
166
- fs.remove(generatedConfigFile);
167
- }
168
- if (this.hasImports) {
169
- options.push(`-generate-config-out=${GENERATE_CONFIG_OUT_FILE}`);
170
- }
171
- if (!this.isCloudStack) {
172
- const planFile = "plan";
173
- options.push("-out", planFile);
174
- }
175
- if (destroy) {
176
- options.push("-destroy");
177
- }
178
- if (refreshOnly) {
179
- options.push("-refresh-only");
180
- }
181
- if (parallelism > -1) {
182
- options.push(`-parallelism=${parallelism}`);
183
- }
184
- if (noColor) {
185
- options.push("-no-color");
186
- }
187
- vars.forEach((v) => options.push(`-var=${v}`));
188
- varFiles.forEach((v) => options.push(`-var-file=${v}`));
189
- commons_1.logger.debug(`Executing ${commons_1.terraformBinaryName} ${options.join(" ")} in ${this.workdir}`);
190
- await this.setUserAgent();
191
- await (0, commons_1.exec)(commons_1.terraformBinaryName, options, {
192
- cwd: this.workdir,
193
- env: process.env,
194
- signal: this.abortSignal,
195
- noColor,
196
- }, this.onStdout("plan", [VariableRequiredFilter]), this.onStderr("plan", [VariableRequiredFilter]));
197
- }
198
- async deploy({ autoApprove = false, refreshOnly = false, noColor = false, parallelism = -1, extraOptions = [], vars = [], varFiles = [], }, callback) {
199
- await this.setUserAgent();
200
- const service = (0, deploy_machine_1.createAndStartDeployService)({
201
- terraformBinaryName: commons_1.terraformBinaryName,
202
- workdir: this.workdir,
203
- refreshOnly,
204
- noColor,
205
- autoApprove,
206
- parallelism,
207
- extraOptions,
208
- vars,
209
- varFiles,
210
- });
211
- return this.handleService("deploy", service, callback);
212
- }
213
- async destroy({ autoApprove = false, parallelism = -1, noColor = false, extraOptions = [], vars = [], varFiles = [], }, callback) {
214
- await this.setUserAgent();
215
- const service = (0, deploy_machine_1.createAndStartDestroyService)({
216
- terraformBinaryName: commons_1.terraformBinaryName,
217
- workdir: this.workdir,
218
- autoApprove,
219
- parallelism,
220
- noColor,
221
- extraOptions,
222
- vars,
223
- varFiles,
224
- });
225
- return this.handleService("destroy", service, callback);
226
- }
227
- async handleService(type, service, callback) {
228
- // stop terraform apply if signaled as such from the outside (e.g. via ctrl+c)
229
- this.abortSignal.addEventListener("abort", () => {
230
- service.send("STOP");
231
- }, { once: true });
232
- // relay logs to stdout
233
- service.onEvent((event) => {
234
- commons_1.logger.trace(`Terraform CLI state machine event: ${JSON.stringify(event)}`);
235
- if ((0, deploy_machine_1.isDeployEvent)(event, "OUTPUT_RECEIVED"))
236
- this.onStdout(type)(event.output);
237
- else if ((0, deploy_machine_1.isDeployEvent)(event, "APPROVED_EXTERNALLY"))
238
- callback({ type: "external approval reply", approved: true });
239
- else if ((0, deploy_machine_1.isDeployEvent)(event, "REJECTED_EXTERNALLY"))
240
- callback({ type: "external approval reply", approved: false });
241
- else if ((0, deploy_machine_1.isDeployEvent)(event, "OVERRIDDEN_EXTERNALLY"))
242
- callback({
243
- type: "external sentinel override reply",
244
- overridden: true,
245
- });
246
- else if ((0, deploy_machine_1.isDeployEvent)(event, "OVERRIDE_REJECTED_EXTERNALLY"))
247
- callback({
248
- type: "external sentinel override reply",
249
- overridden: false,
250
- });
251
- });
252
- let previousState = "idle";
253
- service.onTransition((state) => {
254
- // only send updates on actual state change
255
- // onTransition is called even if the state didn't change but only an event happened
256
- if (state.matches(previousState))
257
- return;
258
- commons_1.logger.trace(`Terraform CLI state machine state transition: ${JSON.stringify(previousState)} => ${JSON.stringify(state.value)}`);
259
- if (state.matches({ running: "awaiting_approval" })) {
260
- callback({
261
- type: "waiting for approval",
262
- approve: () => service.send("APPROVE"),
263
- reject: () => service.send("REJECT"),
264
- });
265
- }
266
- else if (state.matches({ running: "awaiting_sentinel_override" })) {
267
- callback({
268
- type: "waiting for sentinel override",
269
- override: () => service.send("OVERRIDE"),
270
- reject: () => service.send("REJECT_OVERRIDE"),
271
- });
272
- }
273
- else if (state.matches({ running: "processing" })) {
274
- callback({
275
- type: "running",
276
- cancelled: Boolean(state.context.cancelled),
277
- });
278
- }
279
- previousState = state.value;
280
- });
281
- service.start();
282
- const state = await (0, waitFor_1.waitFor)(service, (state) => !!state.done, {
283
- timeout: Infinity,
284
- });
285
- commons_1.logger.trace(`Invoking Terraform CLI for ${type} done (state machine reached final state). Last event: ${JSON.stringify(state.event)}. Context: ${JSON.stringify(state.context)}`);
286
- // example events: { type: 'EXITED', exitCode: 0 }, { type: 'EXTERNAL_REJECT' }
287
- if (state.event.type === "EXITED" &&
288
- state.event.exitCode !== 0 &&
289
- !state.context.cancelled // don't fail if we cancelled the run
290
- ) {
291
- throw `Invoking Terraform CLI failed with exit code ${state.event.exitCode}`;
292
- }
293
- return { cancelled: Boolean(state.context.cancelled) };
294
- }
295
- async version() {
296
- try {
297
- return await (0, commons_1.exec)(commons_1.terraformBinaryName, ["-v"], {
298
- cwd: this.workdir,
299
- env: process.env,
300
- signal: this.abortSignal,
301
- noColor: true,
302
- }, this.onStdout("version"), this.onStderr("version"));
303
- }
304
- catch (_a) {
305
- throw new Error("Terraform CLI not present - Please install a current version https://learn.hashicorp.com/terraform/getting-started/install.html");
306
- }
307
- }
308
- async output() {
309
- const output = await (0, commons_1.exec)(commons_1.terraformBinaryName, ["output", "-json"], {
310
- cwd: this.workdir,
311
- env: process.env,
312
- signal: this.abortSignal,
313
- noColor: true,
314
- },
315
- // We don't need to log the output here since we use it later on
316
- () => { }, // eslint-disable-line @typescript-eslint/no-empty-function
317
- this.onStderr("output"));
318
- try {
319
- return JSON.parse(output);
320
- }
321
- catch (e) {
322
- throw commons_1.Errors.External(`Failed to parse terraform output: ${e}. The output was '${output}'`);
323
- }
324
- }
325
- async setUserAgent() {
326
- // Read the cdktf version from the 'cdk.tf.json' file
327
- // and set the user agent.
328
- const version = await (0, commons_1.readCDKTFVersion)(this.workdir);
329
- if (version != "") {
330
- process.env.TF_APPEND_USER_AGENT =
331
- "cdktn/" +
332
- version +
333
- " (+https://github.com/open-constructs/cdk-terrain)";
334
- }
335
- }
336
- // We don't need to clean anything up for a running execution in the CLI since there is no left-over state in contrast to an open Terraform Cloud run
337
- async abort() {
338
- return;
339
- }
340
- }
341
- exports.TerraformCli = TerraformCli;
342
- async function tryReadGeneratedConfigurationFile(workingDir) {
343
- const generatedConfigPath = path_1.default.join(workingDir, GENERATE_CONFIG_OUT_FILE);
344
- if (!fs.existsSync(generatedConfigPath)) {
345
- return null;
346
- }
347
- return fs.readFileSync(generatedConfigPath, "utf-8");
348
- }
349
- exports.tryReadGeneratedConfigurationFile = tryReadGeneratedConfigurationFile;
350
- async function tryRemoveGeneratedConfigurationFile(workingDir) {
351
- const generatedConfigPath = path_1.default.join(workingDir, GENERATE_CONFIG_OUT_FILE);
352
- if (fs.existsSync(generatedConfigPath)) {
353
- fs.unlinkSync(generatedConfigPath);
354
- }
355
- }
356
- exports.tryRemoveGeneratedConfigurationFile = tryRemoveGeneratedConfigurationFile;
357
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"terraform-cli.js","sourceRoot":"","sources":["terraform-cli.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\nimport stripAnsi from \"strip-ansi\";\nimport {\n  Errors,\n  exec,\n  logger,\n  readCDKTFVersion,\n  terraformBinaryName,\n} from \"@cdktn/commons\";\nimport {\n  Terraform,\n  TerraformPlan,\n  TerraformOutput,\n  AbstractTerraformPlan,\n  TerraformDeployState,\n} from \"./terraform\";\nimport { SynthesizedStack } from \"../synth-stack\";\nimport {\n  createAndStartDeployService,\n  createAndStartDestroyService,\n  DeployState,\n  isDeployEvent,\n} from \"./deploy-machine\";\nimport { waitFor } from \"xstate/lib/waitFor\";\nimport { missingVariable } from \"../errors\";\nimport { terraformJsonSchema } from \"../terraform-json\";\nimport { spawnPty } from \"./pty-process\";\nimport path from \"path\";\nimport * as fs from \"fs-extra\";\n\nconst GENERATE_CONFIG_OUT_FILE = \"generated_resources.tf\";\n\nexport class TerraformCliPlan\n  extends AbstractTerraformPlan\n  implements TerraformPlan\n{\n  constructor(\n    public readonly planFile: string,\n    public readonly plan: { [key: string]: any },\n  ) {\n    super(planFile, plan?.resource_changes, plan?.output_changes);\n  }\n}\n\nabstract class AbstractOutputFilter {\n  public static condition: (line: string) => boolean;\n  public static transform: (line: string) => string;\n}\nexport type OutputFilter = typeof AbstractOutputFilter;\n\n// The plan might error if there is a variable missing, but the error message hints the user\n// in a wrong direction. We therefore catch the error and rethrow it with a more helpful message\nclass VariableRequiredFilter extends AbstractOutputFilter {\n  // Example for \"No value for required variable\" error\n  // ╷\n  // │ Error: No value for required variable\n  // │\n  // │   on cdk.tf.json line 31, in variable:\n  // │   31:     \"with-dashes\": {\n  // │\n  // │ The root module input variable \"with-dashes\" is not set, and has no default\n  // │ value. Use a -var or -var-file command line argument to provide a value for\n  // │ this variable\n  public static condition(input: string) {\n    const line = stripAnsi(input);\n\n    return (\n      line.includes(\"Error: No value for required variable\") &&\n      line.includes(\"The root module input variable\")\n    );\n  }\n  public static transform(line: string) {\n    const startMarker = 'The root module input variable \"';\n    const variableName = line.substring(\n      line.indexOf(startMarker) + startMarker.length,\n      line.indexOf('\" is not set'),\n    );\n\n    return missingVariable(variableName);\n  }\n}\n\nexport class TerraformCli implements Terraform {\n  public readonly workdir: string;\n  private readonly onStdout: (\n    stateName: string,\n    filter?: OutputFilter[],\n  ) => (stdout: Buffer | string) => void;\n  private readonly onStderr: (\n    stateName: string,\n    filter?: OutputFilter[],\n  ) => (stderr: string | Uint8Array) => void;\n\n  constructor(\n    private readonly abortSignal: AbortSignal,\n    public readonly stack: SynthesizedStack,\n    createTerraformLogHandler = (_phase: string, _filter?: OutputFilter[]) =>\n      (_stdout: string, _isErr = false) => {}, // eslint-disable-line @typescript-eslint/no-empty-function\n  ) {\n    this.workdir = stack.workingDirectory;\n    this.onStdout =\n      (phase: string, filter?: OutputFilter[]) => (stdout: Buffer | string) =>\n        createTerraformLogHandler(\n          phase,\n          filter,\n        )(Buffer.isBuffer(stdout) ? stdout.toString() : stdout);\n    this.onStderr =\n      (phase: string, filter?: OutputFilter[]) =>\n      (stderr: string | Uint8Array) =>\n        createTerraformLogHandler(phase, filter)(stderr.toString(), true);\n  }\n\n  public async init(opts: {\n    needsUpgrade: boolean;\n    noColor?: boolean;\n    migrateState: boolean;\n    needsLockfileUpdate: boolean;\n  }): Promise<void> {\n    await this.setUserAgent();\n\n    const args = [\"init\"];\n    if (opts.needsUpgrade) {\n      args.push(\"-upgrade\");\n    }\n    if (opts.noColor) {\n      args.push(\"-no-color\");\n    }\n    if (opts.migrateState) {\n      args.push(\"-migrate-state\");\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    let initCanNotContinue = (_err: any) => {};\n    const rejectsIfInitCanNotContinue = new Promise((_resolve, reject) => {\n      initCanNotContinue = reject;\n    });\n\n    const stdout = this.onStdout(\"init\");\n    const { actions, exitCode } = spawnPty(\n      {\n        file: terraformBinaryName,\n        args,\n        options: {\n          cwd: this.workdir,\n          env: process.env as any,\n        },\n      },\n      (data) => {\n        stdout(data);\n        if (\n          data.includes(\"Should Terraform migrate your existing state?\") ||\n          data.includes(\"Do you want to copy existing state to the new backend\")\n        ) {\n          // TODO: This only happens when terraform is passed the -migrate-state anyway, so this check is redundant\n          if (opts.migrateState) {\n            actions.writeLine(\"yes\");\n          } else {\n            actions.stop();\n            initCanNotContinue(\n              \"Please pass the --migrate-state flag to migrate your state\",\n            );\n          }\n        }\n      },\n    );\n    this.abortSignal.addEventListener(\"abort\", () => {\n      actions.stop();\n    });\n\n    const progress = exitCode.then((code) => {\n      if (code !== 0) {\n        throw new Error(`terraform init failed with exit code ${code}`);\n      }\n    });\n    await Promise.race([progress, rejectsIfInitCanNotContinue]);\n\n    // TODO: this might have performance implications because we don't know if we're\n    // running a remote plan or a local one (so we run it always for all platforms)\n    // while we'd only need it for remote plans\n    if (opts.needsLockfileUpdate) {\n      await exec(\n        terraformBinaryName,\n        [\n          \"providers\",\n          \"lock\",\n          \"-platform=linux_amd64\",\n          ...(opts.noColor ? [\"-no-color\"] : []),\n        ],\n        {\n          cwd: this.workdir,\n          env: process.env,\n          signal: this.abortSignal,\n          noColor: opts.noColor,\n        },\n        this.onStdout(\"init\"),\n        this.onStderr(\"init\"),\n      );\n    }\n  }\n\n  private get isCloudStack(): boolean {\n    const parsedStack = terraformJsonSchema.parse(\n      JSON.parse(this.stack.content),\n    );\n\n    return Boolean(\n      parsedStack.terraform?.backend?.remote || parsedStack.terraform?.cloud,\n    );\n  }\n\n  private get hasImports(): boolean {\n    const parsedStack = terraformJsonSchema.parse(\n      JSON.parse(this.stack.content),\n    );\n\n    return Boolean(parsedStack.import);\n  }\n\n  public async plan(opts: {\n    destroy: boolean;\n    refreshOnly?: boolean;\n    parallelism?: number;\n    vars?: string[];\n    varFiles?: string[];\n    noColor?: boolean;\n  }): Promise<void> {\n    const {\n      destroy = false,\n      refreshOnly = false,\n      parallelism = -1,\n      vars = [],\n      varFiles = [],\n      noColor = false,\n    } = opts;\n    const options = [\"plan\", \"-input=false\"];\n\n    const generatedConfigFile = path.join(\n      this.workdir,\n      GENERATE_CONFIG_OUT_FILE,\n    );\n    if (fs.existsSync(generatedConfigFile)) {\n      fs.remove(generatedConfigFile);\n    }\n    if (this.hasImports) {\n      options.push(`-generate-config-out=${GENERATE_CONFIG_OUT_FILE}`);\n    }\n    if (!this.isCloudStack) {\n      const planFile = \"plan\";\n      options.push(\"-out\", planFile);\n    }\n\n    if (destroy) {\n      options.push(\"-destroy\");\n    }\n    if (refreshOnly) {\n      options.push(\"-refresh-only\");\n    }\n    if (parallelism > -1) {\n      options.push(`-parallelism=${parallelism}`);\n    }\n    if (noColor) {\n      options.push(\"-no-color\");\n    }\n\n    vars.forEach((v) => options.push(`-var=${v}`));\n    varFiles.forEach((v) => options.push(`-var-file=${v}`));\n\n    logger.debug(\n      `Executing ${terraformBinaryName} ${options.join(\" \")} in ${this.workdir}`,\n    );\n\n    await this.setUserAgent();\n\n    await exec(\n      terraformBinaryName,\n      options,\n      {\n        cwd: this.workdir,\n        env: process.env,\n        signal: this.abortSignal,\n        noColor,\n      },\n      this.onStdout(\"plan\", [VariableRequiredFilter]),\n      this.onStderr(\"plan\", [VariableRequiredFilter]),\n    );\n  }\n\n  public async deploy(\n    {\n      autoApprove = false,\n      refreshOnly = false,\n      noColor = false,\n      parallelism = -1,\n      extraOptions = [],\n      vars = [],\n      varFiles = [],\n    },\n    callback: (state: TerraformDeployState) => void,\n  ): Promise<{ cancelled: boolean }> {\n    await this.setUserAgent();\n    const service = createAndStartDeployService({\n      terraformBinaryName,\n      workdir: this.workdir,\n      refreshOnly,\n      noColor,\n      autoApprove,\n      parallelism,\n      extraOptions,\n      vars,\n      varFiles,\n    });\n    return this.handleService(\"deploy\", service, callback);\n  }\n\n  public async destroy(\n    {\n      autoApprove = false,\n      parallelism = -1,\n      noColor = false,\n      extraOptions = [],\n      vars = [],\n      varFiles = [],\n    },\n    callback: (state: TerraformDeployState) => void,\n  ): Promise<{ cancelled: boolean }> {\n    await this.setUserAgent();\n    const service = createAndStartDestroyService({\n      terraformBinaryName,\n      workdir: this.workdir,\n      autoApprove,\n      parallelism,\n      noColor,\n      extraOptions,\n      vars,\n      varFiles,\n    });\n    return this.handleService(\"destroy\", service, callback);\n  }\n\n  private async handleService(\n    type: \"deploy\" | \"destroy\",\n    service:\n      | ReturnType<typeof createAndStartDeployService>\n      | ReturnType<typeof createAndStartDestroyService>,\n    callback: (state: TerraformDeployState) => void,\n  ): Promise<{ cancelled: boolean }> {\n    // stop terraform apply if signaled as such from the outside (e.g. via ctrl+c)\n    this.abortSignal.addEventListener(\n      \"abort\",\n      () => {\n        service.send(\"STOP\");\n      },\n      { once: true },\n    );\n\n    // relay logs to stdout\n    service.onEvent((event) => {\n      logger.trace(\n        `Terraform CLI state machine event: ${JSON.stringify(event)}`,\n      );\n      if (isDeployEvent(event, \"OUTPUT_RECEIVED\"))\n        this.onStdout(type)(event.output);\n      else if (isDeployEvent(event, \"APPROVED_EXTERNALLY\"))\n        callback({ type: \"external approval reply\", approved: true });\n      else if (isDeployEvent(event, \"REJECTED_EXTERNALLY\"))\n        callback({ type: \"external approval reply\", approved: false });\n      else if (isDeployEvent(event, \"OVERRIDDEN_EXTERNALLY\"))\n        callback({\n          type: \"external sentinel override reply\",\n          overridden: true,\n        });\n      else if (isDeployEvent(event, \"OVERRIDE_REJECTED_EXTERNALLY\"))\n        callback({\n          type: \"external sentinel override reply\",\n          overridden: false,\n        });\n    });\n\n    let previousState: DeployState[\"value\"] = \"idle\";\n\n    service.onTransition((state) => {\n      // only send updates on actual state change\n      // onTransition is called even if the state didn't change but only an event happened\n      if (state.matches(previousState as DeployState[\"value\"])) return;\n\n      logger.trace(\n        `Terraform CLI state machine state transition: ${JSON.stringify(\n          previousState,\n        )} => ${JSON.stringify(state.value)}`,\n      );\n\n      if (state.matches({ running: \"awaiting_approval\" })) {\n        callback({\n          type: \"waiting for approval\",\n          approve: () => service.send(\"APPROVE\"),\n          reject: () => service.send(\"REJECT\"),\n        });\n      } else if (state.matches({ running: \"awaiting_sentinel_override\" })) {\n        callback({\n          type: \"waiting for sentinel override\",\n          override: () => service.send(\"OVERRIDE\"),\n          reject: () => service.send(\"REJECT_OVERRIDE\"),\n        });\n      } else if (state.matches({ running: \"processing\" })) {\n        callback({\n          type: \"running\",\n          cancelled: Boolean(state.context.cancelled),\n        });\n      }\n      previousState = state.value as DeployState[\"value\"];\n    });\n    service.start();\n    const state = await waitFor(service, (state) => !!state.done, {\n      timeout: Infinity,\n    });\n\n    logger.trace(\n      `Invoking Terraform CLI for ${type} done (state machine reached final state). Last event: ${JSON.stringify(\n        state.event,\n      )}. Context: ${JSON.stringify(state.context)}`,\n    );\n\n    // example events: { type: 'EXITED', exitCode: 0 }, { type: 'EXTERNAL_REJECT' }\n    if (\n      state.event.type === \"EXITED\" &&\n      state.event.exitCode !== 0 &&\n      !state.context.cancelled // don't fail if we cancelled the run\n    ) {\n      throw `Invoking Terraform CLI failed with exit code ${state.event.exitCode}`;\n    }\n\n    return { cancelled: Boolean(state.context.cancelled) };\n  }\n\n  public async version(): Promise<string> {\n    try {\n      return await exec(\n        terraformBinaryName,\n        [\"-v\"],\n        {\n          cwd: this.workdir,\n          env: process.env,\n          signal: this.abortSignal,\n          noColor: true,\n        },\n        this.onStdout(\"version\"),\n        this.onStderr(\"version\"),\n      );\n    } catch {\n      throw new Error(\n        \"Terraform CLI not present - Please install a current version https://learn.hashicorp.com/terraform/getting-started/install.html\",\n      );\n    }\n  }\n\n  public async output(): Promise<{ [key: string]: TerraformOutput }> {\n    const output = await exec(\n      terraformBinaryName,\n      [\"output\", \"-json\"],\n      {\n        cwd: this.workdir,\n        env: process.env,\n        signal: this.abortSignal,\n        noColor: true,\n      },\n      // We don't need to log the output here since we use it later on\n      () => {}, // eslint-disable-line @typescript-eslint/no-empty-function\n      this.onStderr(\"output\"),\n    );\n\n    try {\n      return JSON.parse(output);\n    } catch (e) {\n      throw Errors.External(\n        `Failed to parse terraform output: ${e}. The output was '${output}'`,\n      );\n    }\n  }\n\n  public async setUserAgent(): Promise<void> {\n    // Read the cdktf version from the 'cdk.tf.json' file\n    // and set the user agent.\n    const version = await readCDKTFVersion(this.workdir);\n    if (version != \"\") {\n      process.env.TF_APPEND_USER_AGENT =\n        \"cdktn/\" +\n        version +\n        \" (+https://github.com/open-constructs/cdk-terrain)\";\n    }\n  }\n\n  // We don't need to clean anything up for a running execution in the CLI since there is no left-over state in contrast to an open Terraform Cloud run\n  public async abort() {\n    return;\n  }\n}\n\nexport async function tryReadGeneratedConfigurationFile(\n  workingDir: string,\n): Promise<string | null> {\n  const generatedConfigPath = path.join(workingDir, GENERATE_CONFIG_OUT_FILE);\n  if (!fs.existsSync(generatedConfigPath)) {\n    return null;\n  }\n  return fs.readFileSync(generatedConfigPath, \"utf-8\");\n}\n\nexport async function tryRemoveGeneratedConfigurationFile(workingDir: string) {\n  const generatedConfigPath = path.join(workingDir, GENERATE_CONFIG_OUT_FILE);\n  if (fs.existsSync(generatedConfigPath)) {\n    fs.unlinkSync(generatedConfigPath);\n  }\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"terraform.d.ts","sourceRoot":"","sources":["terraform.ts"],"names":[],"mappings":"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"}