@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,95 @@
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.LocalProviderConstraints = void 0;
30
+ // Copyright (c) HashiCorp, Inc
31
+ // SPDX-License-Identifier: MPL-2.0
32
+ const fs_extra_1 = __importDefault(require("fs-extra"));
33
+ const path_1 = __importDefault(require("path"));
34
+ const commons_1 = require("@cdktn/commons");
35
+ const cdktf_config_1 = require("./cdktf-config");
36
+ const z = __importStar(require("zod"));
37
+ const constraintsType = z.object({
38
+ cdktf: z.string(),
39
+ providers: z.record(z.string()),
40
+ });
41
+ // TODO: move this to @cdktn/commons
42
+ // tracked here https://github.com/hashicorp/terraform-cdk/issues/1814
43
+ /**
44
+ * Class to help with reading `constraints.json` file
45
+ * published by `provider get` or `provider add` commands
46
+ */
47
+ class LocalProviderConstraints {
48
+ get jsonFilePath() {
49
+ const config = cdktf_config_1.CdktfConfig.read();
50
+ return path_1.default.resolve(config.codeMakerOutput, "constraints.json");
51
+ }
52
+ async readLocalConstraintsJson() {
53
+ let constraintsJson;
54
+ try {
55
+ constraintsJson = await fs_extra_1.default.readFile(this.jsonFilePath, "utf8");
56
+ }
57
+ catch (e) {
58
+ // If we cannot read the constraints.json file, it may not exist
59
+ commons_1.logger.debug("constraints.json file reading error: ", e);
60
+ this.constraints = undefined;
61
+ return;
62
+ }
63
+ let providerConstraints;
64
+ try {
65
+ providerConstraints = constraintsType.parse(JSON.parse(constraintsJson));
66
+ providerConstraints.providers = Object.fromEntries(Object.entries(providerConstraints.providers).map(([name, constraint]) => {
67
+ return [name.toLowerCase(), constraint];
68
+ }));
69
+ }
70
+ catch (e) {
71
+ throw commons_1.Errors.External("constraints.json file is malformed. The root must be a JSON object.", e);
72
+ }
73
+ this.constraints = providerConstraints;
74
+ }
75
+ async constraintsForAllProviders() {
76
+ if (this.constraints) {
77
+ return this.constraints;
78
+ }
79
+ await this.readLocalConstraintsJson();
80
+ return this.constraints;
81
+ }
82
+ async constraintForProvider(providerName) {
83
+ const constraints = await this.constraintsForAllProviders();
84
+ if (!constraints) {
85
+ return null;
86
+ }
87
+ const providerConstraint = constraints.providers[providerName.toLowerCase()];
88
+ if (!providerName) {
89
+ return null;
90
+ }
91
+ return providerConstraint;
92
+ }
93
+ }
94
+ exports.LocalProviderConstraints = LocalProviderConstraints;
95
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWwtcHJvdmlkZXItY29uc3RyYWludHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGliL2xvY2FsLXByb3ZpZGVyLWNvbnN0cmFpbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsK0JBQStCO0FBQy9CLG1DQUFtQztBQUNuQyx3REFBMEI7QUFDMUIsZ0RBQXdCO0FBQ3hCLDRDQUFnRDtBQUNoRCxpREFBNkM7QUFFN0MsdUNBQXlCO0FBRXpCLE1BQU0sZUFBZSxHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDL0IsS0FBSyxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUU7SUFDakIsU0FBUyxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDO0NBQ2hDLENBQUMsQ0FBQztBQUlILG9DQUFvQztBQUNwQyxzRUFBc0U7QUFDdEU7OztHQUdHO0FBQ0gsTUFBYSx3QkFBd0I7SUFHbkMsSUFBWSxZQUFZO1FBQ3RCLE1BQU0sTUFBTSxHQUFHLDBCQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDbEMsT0FBTyxjQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxlQUFlLEVBQUUsa0JBQWtCLENBQUMsQ0FBQztJQUNsRSxDQUFDO0lBRU8sS0FBSyxDQUFDLHdCQUF3QjtRQUNwQyxJQUFJLGVBQWUsQ0FBQztRQUNwQixJQUFJLENBQUM7WUFDSCxlQUFlLEdBQUcsTUFBTSxrQkFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ2pFLENBQUM7UUFBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQ1gsZ0VBQWdFO1lBQ2hFLGdCQUFNLENBQUMsS0FBSyxDQUFDLHVDQUF1QyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ3pELElBQUksQ0FBQyxXQUFXLEdBQUcsU0FBUyxDQUFDO1lBQzdCLE9BQU87UUFDVCxDQUFDO1FBRUQsSUFBSSxtQkFBbUIsQ0FBQztRQUN4QixJQUFJLENBQUM7WUFDSCxtQkFBbUIsR0FBRyxlQUFlLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQztZQUN6RSxtQkFBbUIsQ0FBQyxTQUFTLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FDaEQsTUFBTSxDQUFDLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFHLENBQy9DLENBQUMsQ0FBQyxJQUFJLEVBQUUsVUFBVSxDQUFDLEVBQUUsRUFBRTtnQkFDckIsT0FBTyxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRSxVQUFVLENBQUMsQ0FBQztZQUMxQyxDQUFDLENBQ0YsQ0FDRixDQUFDO1FBQ0osQ0FBQztRQUFDLE9BQU8sQ0FBTSxFQUFFLENBQUM7WUFDaEIsTUFBTSxnQkFBTSxDQUFDLFFBQVEsQ0FDbkIscUVBQXFFLEVBQ3JFLENBQUMsQ0FDRixDQUFDO1FBQ0osQ0FBQztRQUVELElBQUksQ0FBQyxXQUFXLEdBQUcsbUJBQW1CLENBQUM7SUFDekMsQ0FBQztJQUVNLEtBQUssQ0FBQywwQkFBMEI7UUFDckMsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDckIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDO1FBQzFCLENBQUM7UUFFRCxNQUFNLElBQUksQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1FBRXRDLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDO0lBRU0sS0FBSyxDQUFDLHFCQUFxQixDQUNoQyxZQUFvQjtRQUVwQixNQUFNLFdBQVcsR0FBRyxNQUFNLElBQUksQ0FBQywwQkFBMEIsRUFBRSxDQUFDO1FBRTVELElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUNqQixPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFFRCxNQUFNLGtCQUFrQixHQUN0QixXQUFXLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQ3BELElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUNsQixPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFFRCxPQUFPLGtCQUFrQixDQUFDO0lBQzVCLENBQUM7Q0FDRjtBQWxFRCw0REFrRUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgKGMpIEhhc2hpQ29ycCwgSW5jXG4vLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogTVBMLTIuMFxuaW1wb3J0IGZzIGZyb20gXCJmcy1leHRyYVwiO1xuaW1wb3J0IHBhdGggZnJvbSBcInBhdGhcIjtcbmltcG9ydCB7IEVycm9ycywgbG9nZ2VyIH0gZnJvbSBcIkBjZGt0bi9jb21tb25zXCI7XG5pbXBvcnQgeyBDZGt0ZkNvbmZpZyB9IGZyb20gXCIuL2Nka3RmLWNvbmZpZ1wiO1xuXG5pbXBvcnQgKiBhcyB6IGZyb20gXCJ6b2RcIjtcblxuY29uc3QgY29uc3RyYWludHNUeXBlID0gei5vYmplY3Qoe1xuICBjZGt0Zjogei5zdHJpbmcoKSxcbiAgcHJvdmlkZXJzOiB6LnJlY29yZCh6LnN0cmluZygpKSxcbn0pO1xuXG5leHBvcnQgdHlwZSBDb25zdHJhaW50cyA9IHouaW5mZXI8dHlwZW9mIGNvbnN0cmFpbnRzVHlwZT47XG5cbi8vIFRPRE86IG1vdmUgdGhpcyB0byBAY2RrdG4vY29tbW9uc1xuLy8gdHJhY2tlZCBoZXJlIGh0dHBzOi8vZ2l0aHViLmNvbS9oYXNoaWNvcnAvdGVycmFmb3JtLWNkay9pc3N1ZXMvMTgxNFxuLyoqXG4gKiBDbGFzcyB0byBoZWxwIHdpdGggcmVhZGluZyBgY29uc3RyYWludHMuanNvbmAgZmlsZVxuICogcHVibGlzaGVkIGJ5IGBwcm92aWRlciBnZXRgIG9yIGBwcm92aWRlciBhZGRgIGNvbW1hbmRzXG4gKi9cbmV4cG9ydCBjbGFzcyBMb2NhbFByb3ZpZGVyQ29uc3RyYWludHMge1xuICBwcml2YXRlIGNvbnN0cmFpbnRzOiBDb25zdHJhaW50cyB8IHVuZGVmaW5lZDtcblxuICBwcml2YXRlIGdldCBqc29uRmlsZVBhdGgoKTogc3RyaW5nIHtcbiAgICBjb25zdCBjb25maWcgPSBDZGt0ZkNvbmZpZy5yZWFkKCk7XG4gICAgcmV0dXJuIHBhdGgucmVzb2x2ZShjb25maWcuY29kZU1ha2VyT3V0cHV0LCBcImNvbnN0cmFpbnRzLmpzb25cIik7XG4gIH1cblxuICBwcml2YXRlIGFzeW5jIHJlYWRMb2NhbENvbnN0cmFpbnRzSnNvbigpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBsZXQgY29uc3RyYWludHNKc29uO1xuICAgIHRyeSB7XG4gICAgICBjb25zdHJhaW50c0pzb24gPSBhd2FpdCBmcy5yZWFkRmlsZSh0aGlzLmpzb25GaWxlUGF0aCwgXCJ1dGY4XCIpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIC8vIElmIHdlIGNhbm5vdCByZWFkIHRoZSBjb25zdHJhaW50cy5qc29uIGZpbGUsIGl0IG1heSBub3QgZXhpc3RcbiAgICAgIGxvZ2dlci5kZWJ1ZyhcImNvbnN0cmFpbnRzLmpzb24gZmlsZSByZWFkaW5nIGVycm9yOiBcIiwgZSk7XG4gICAgICB0aGlzLmNvbnN0cmFpbnRzID0gdW5kZWZpbmVkO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGxldCBwcm92aWRlckNvbnN0cmFpbnRzO1xuICAgIHRyeSB7XG4gICAgICBwcm92aWRlckNvbnN0cmFpbnRzID0gY29uc3RyYWludHNUeXBlLnBhcnNlKEpTT04ucGFyc2UoY29uc3RyYWludHNKc29uKSk7XG4gICAgICBwcm92aWRlckNvbnN0cmFpbnRzLnByb3ZpZGVycyA9IE9iamVjdC5mcm9tRW50cmllcyhcbiAgICAgICAgT2JqZWN0LmVudHJpZXMocHJvdmlkZXJDb25zdHJhaW50cy5wcm92aWRlcnMpLm1hcChcbiAgICAgICAgICAoW25hbWUsIGNvbnN0cmFpbnRdKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gW25hbWUudG9Mb3dlckNhc2UoKSwgY29uc3RyYWludF07XG4gICAgICAgICAgfSxcbiAgICAgICAgKSxcbiAgICAgICk7XG4gICAgfSBjYXRjaCAoZTogYW55KSB7XG4gICAgICB0aHJvdyBFcnJvcnMuRXh0ZXJuYWwoXG4gICAgICAgIFwiY29uc3RyYWludHMuanNvbiBmaWxlIGlzIG1hbGZvcm1lZC4gVGhlIHJvb3QgbXVzdCBiZSBhIEpTT04gb2JqZWN0LlwiLFxuICAgICAgICBlLFxuICAgICAgKTtcbiAgICB9XG5cbiAgICB0aGlzLmNvbnN0cmFpbnRzID0gcHJvdmlkZXJDb25zdHJhaW50cztcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBjb25zdHJhaW50c0ZvckFsbFByb3ZpZGVycygpIHtcbiAgICBpZiAodGhpcy5jb25zdHJhaW50cykge1xuICAgICAgcmV0dXJuIHRoaXMuY29uc3RyYWludHM7XG4gICAgfVxuXG4gICAgYXdhaXQgdGhpcy5yZWFkTG9jYWxDb25zdHJhaW50c0pzb24oKTtcblxuICAgIHJldHVybiB0aGlzLmNvbnN0cmFpbnRzO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGNvbnN0cmFpbnRGb3JQcm92aWRlcihcbiAgICBwcm92aWRlck5hbWU6IHN0cmluZyxcbiAgKTogUHJvbWlzZTxzdHJpbmcgfCBudWxsPiB7XG4gICAgY29uc3QgY29uc3RyYWludHMgPSBhd2FpdCB0aGlzLmNvbnN0cmFpbnRzRm9yQWxsUHJvdmlkZXJzKCk7XG5cbiAgICBpZiAoIWNvbnN0cmFpbnRzKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICBjb25zdCBwcm92aWRlckNvbnN0cmFpbnQgPVxuICAgICAgY29uc3RyYWludHMucHJvdmlkZXJzW3Byb3ZpZGVyTmFtZS50b0xvd2VyQ2FzZSgpXTtcbiAgICBpZiAoIXByb3ZpZGVyTmFtZSkge1xuICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuXG4gICAgcmV0dXJuIHByb3ZpZGVyQ29uc3RyYWludDtcbiAgfVxufVxuIl19
@@ -0,0 +1 @@
1
+ {"version":3,"file":"local-provider-versions.d.ts","sourceRoot":"","sources":["../../src/lib/local-provider-versions.ts"],"names":[],"mappings":"AAaA;;;GAGG;AACH,qBAAa,qBAAqB;IAChC,OAAO,CAAC,QAAQ,CAAqC;IAErD,OAAO,KAAK,YAAY,GAGvB;YAEa,qBAAqB;IAkCtB,uBAAuB;IAUvB,kBAAkB,CAC7B,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;CAc1B"}
@@ -0,0 +1,73 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.LocalProviderVersions = void 0;
7
+ // Copyright (c) HashiCorp, Inc
8
+ // SPDX-License-Identifier: MPL-2.0
9
+ const commons_1 = require("@cdktn/commons");
10
+ const fs_extra_1 = __importDefault(require("fs-extra"));
11
+ const path_1 = __importDefault(require("path"));
12
+ const cdktf_config_1 = require("./cdktf-config");
13
+ const dependency_manager_1 = require("./dependencies/dependency-manager");
14
+ // TODO: move this to @cdktn/commons
15
+ // tracked here https://github.com/hashicorp/terraform-cdk/issues/1814
16
+ /**
17
+ * Class to help with reading `versions.json` file
18
+ * published by `provider get` or `provider add` commands
19
+ */
20
+ class LocalProviderVersions {
21
+ get jsonFilePath() {
22
+ const config = cdktf_config_1.CdktfConfig.read();
23
+ return path_1.default.resolve(config.codeMakerOutput, "versions.json");
24
+ }
25
+ async readLocalVersionsJson() {
26
+ let versionsJson;
27
+ try {
28
+ versionsJson = await fs_extra_1.default.readFile(this.jsonFilePath, "utf8");
29
+ }
30
+ catch (e) {
31
+ // If we cannot read the versions.json file, it may not exist
32
+ commons_1.logger.debug("versions.json file reading error: ", e);
33
+ this.versions = undefined;
34
+ return;
35
+ }
36
+ let providerVersions;
37
+ try {
38
+ providerVersions = JSON.parse(versionsJson);
39
+ }
40
+ catch (e) {
41
+ throw commons_1.Errors.External("versions.json file is malformed. The root must be a JSON object.", e);
42
+ }
43
+ this.versions = Object.fromEntries(Object.entries(providerVersions).map(([providerFqn, versions]) => {
44
+ return [
45
+ providerFqn
46
+ .replace(`${dependency_manager_1.DEFAULT_HOSTNAME}/`, "")
47
+ .replace(`${dependency_manager_1.DEFAULT_NAMESPACE}/`, "")
48
+ .toLowerCase(),
49
+ versions,
50
+ ];
51
+ }));
52
+ }
53
+ async versionsForAllProviders() {
54
+ if (this.versions) {
55
+ return this.versions;
56
+ }
57
+ await this.readLocalVersionsJson();
58
+ return this.versions;
59
+ }
60
+ async versionForProvider(providerName) {
61
+ const versions = await this.versionsForAllProviders();
62
+ if (!versions) {
63
+ return null;
64
+ }
65
+ const providerVersion = versions[providerName.toLowerCase()];
66
+ if (!providerName) {
67
+ return null;
68
+ }
69
+ return providerVersion;
70
+ }
71
+ }
72
+ exports.LocalProviderVersions = LocalProviderVersions;
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWwtcHJvdmlkZXItdmVyc2lvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbGliL2xvY2FsLXByb3ZpZGVyLXZlcnNpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLCtCQUErQjtBQUMvQixtQ0FBbUM7QUFDbkMsNENBQWdEO0FBQ2hELHdEQUEwQjtBQUMxQixnREFBd0I7QUFDeEIsaURBQTZDO0FBQzdDLDBFQUcyQztBQUUzQyxvQ0FBb0M7QUFDcEMsc0VBQXNFO0FBQ3RFOzs7R0FHRztBQUNILE1BQWEscUJBQXFCO0lBR2hDLElBQVksWUFBWTtRQUN0QixNQUFNLE1BQU0sR0FBRywwQkFBVyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ2xDLE9BQU8sY0FBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsZUFBZSxFQUFFLGVBQWUsQ0FBQyxDQUFDO0lBQy9ELENBQUM7SUFFTyxLQUFLLENBQUMscUJBQXFCO1FBQ2pDLElBQUksWUFBWSxDQUFDO1FBQ2pCLElBQUksQ0FBQztZQUNILFlBQVksR0FBRyxNQUFNLGtCQUFFLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDOUQsQ0FBQztRQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7WUFDWCw2REFBNkQ7WUFDN0QsZ0JBQU0sQ0FBQyxLQUFLLENBQUMsb0NBQW9DLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDdEQsSUFBSSxDQUFDLFFBQVEsR0FBRyxTQUFTLENBQUM7WUFDMUIsT0FBTztRQUNULENBQUM7UUFFRCxJQUFJLGdCQUFnQixDQUFDO1FBQ3JCLElBQUksQ0FBQztZQUNILGdCQUFnQixHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUEyQixDQUFDO1FBQ3hFLENBQUM7UUFBQyxPQUFPLENBQU0sRUFBRSxDQUFDO1lBQ2hCLE1BQU0sZ0JBQU0sQ0FBQyxRQUFRLENBQ25CLGtFQUFrRSxFQUNsRSxDQUFDLENBQ0YsQ0FBQztRQUNKLENBQUM7UUFFRCxJQUFJLENBQUMsUUFBUSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQ2hDLE1BQU0sQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxRQUFRLENBQUMsRUFBRSxFQUFFO1lBQy9ELE9BQU87Z0JBQ0wsV0FBVztxQkFDUixPQUFPLENBQUMsR0FBRyxxQ0FBZ0IsR0FBRyxFQUFFLEVBQUUsQ0FBQztxQkFDbkMsT0FBTyxDQUFDLEdBQUcsc0NBQWlCLEdBQUcsRUFBRSxFQUFFLENBQUM7cUJBQ3BDLFdBQVcsRUFBRTtnQkFDaEIsUUFBUTthQUNULENBQUM7UUFDSixDQUFDLENBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQztJQUVNLEtBQUssQ0FBQyx1QkFBdUI7UUFDbEMsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDbEIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO1FBQ3ZCLENBQUM7UUFFRCxNQUFNLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO1FBRW5DLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN2QixDQUFDO0lBRU0sS0FBSyxDQUFDLGtCQUFrQixDQUM3QixZQUFvQjtRQUVwQixNQUFNLFFBQVEsR0FBRyxNQUFNLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxDQUFDO1FBRXRELElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNkLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUVELE1BQU0sZUFBZSxHQUFHLFFBQVEsQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztRQUM3RCxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDbEIsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBRUQsT0FBTyxlQUFlLENBQUM7SUFDekIsQ0FBQztDQUNGO0FBcEVELHNEQW9FQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCAoYykgSGFzaGlDb3JwLCBJbmNcbi8vIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBNUEwtMi4wXG5pbXBvcnQgeyBFcnJvcnMsIGxvZ2dlciB9IGZyb20gXCJAY2RrdG4vY29tbW9uc1wiO1xuaW1wb3J0IGZzIGZyb20gXCJmcy1leHRyYVwiO1xuaW1wb3J0IHBhdGggZnJvbSBcInBhdGhcIjtcbmltcG9ydCB7IENka3RmQ29uZmlnIH0gZnJvbSBcIi4vY2RrdGYtY29uZmlnXCI7XG5pbXBvcnQge1xuICBERUZBVUxUX0hPU1ROQU1FLFxuICBERUZBVUxUX05BTUVTUEFDRSxcbn0gZnJvbSBcIi4vZGVwZW5kZW5jaWVzL2RlcGVuZGVuY3ktbWFuYWdlclwiO1xuXG4vLyBUT0RPOiBtb3ZlIHRoaXMgdG8gQGNka3RuL2NvbW1vbnNcbi8vIHRyYWNrZWQgaGVyZSBodHRwczovL2dpdGh1Yi5jb20vaGFzaGljb3JwL3RlcnJhZm9ybS1jZGsvaXNzdWVzLzE4MTRcbi8qKlxuICogQ2xhc3MgdG8gaGVscCB3aXRoIHJlYWRpbmcgYHZlcnNpb25zLmpzb25gIGZpbGVcbiAqIHB1Ymxpc2hlZCBieSBgcHJvdmlkZXIgZ2V0YCBvciBgcHJvdmlkZXIgYWRkYCBjb21tYW5kc1xuICovXG5leHBvcnQgY2xhc3MgTG9jYWxQcm92aWRlclZlcnNpb25zIHtcbiAgcHJpdmF0ZSB2ZXJzaW9uczogUmVjb3JkPHN0cmluZywgc3RyaW5nPiB8IHVuZGVmaW5lZDtcblxuICBwcml2YXRlIGdldCBqc29uRmlsZVBhdGgoKTogc3RyaW5nIHtcbiAgICBjb25zdCBjb25maWcgPSBDZGt0ZkNvbmZpZy5yZWFkKCk7XG4gICAgcmV0dXJuIHBhdGgucmVzb2x2ZShjb25maWcuY29kZU1ha2VyT3V0cHV0LCBcInZlcnNpb25zLmpzb25cIik7XG4gIH1cblxuICBwcml2YXRlIGFzeW5jIHJlYWRMb2NhbFZlcnNpb25zSnNvbigpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBsZXQgdmVyc2lvbnNKc29uO1xuICAgIHRyeSB7XG4gICAgICB2ZXJzaW9uc0pzb24gPSBhd2FpdCBmcy5yZWFkRmlsZSh0aGlzLmpzb25GaWxlUGF0aCwgXCJ1dGY4XCIpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIC8vIElmIHdlIGNhbm5vdCByZWFkIHRoZSB2ZXJzaW9ucy5qc29uIGZpbGUsIGl0IG1heSBub3QgZXhpc3RcbiAgICAgIGxvZ2dlci5kZWJ1ZyhcInZlcnNpb25zLmpzb24gZmlsZSByZWFkaW5nIGVycm9yOiBcIiwgZSk7XG4gICAgICB0aGlzLnZlcnNpb25zID0gdW5kZWZpbmVkO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGxldCBwcm92aWRlclZlcnNpb25zO1xuICAgIHRyeSB7XG4gICAgICBwcm92aWRlclZlcnNpb25zID0gSlNPTi5wYXJzZSh2ZXJzaW9uc0pzb24pIGFzIFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG4gICAgfSBjYXRjaCAoZTogYW55KSB7XG4gICAgICB0aHJvdyBFcnJvcnMuRXh0ZXJuYWwoXG4gICAgICAgIFwidmVyc2lvbnMuanNvbiBmaWxlIGlzIG1hbGZvcm1lZC4gVGhlIHJvb3QgbXVzdCBiZSBhIEpTT04gb2JqZWN0LlwiLFxuICAgICAgICBlLFxuICAgICAgKTtcbiAgICB9XG5cbiAgICB0aGlzLnZlcnNpb25zID0gT2JqZWN0LmZyb21FbnRyaWVzKFxuICAgICAgT2JqZWN0LmVudHJpZXMocHJvdmlkZXJWZXJzaW9ucykubWFwKChbcHJvdmlkZXJGcW4sIHZlcnNpb25zXSkgPT4ge1xuICAgICAgICByZXR1cm4gW1xuICAgICAgICAgIHByb3ZpZGVyRnFuXG4gICAgICAgICAgICAucmVwbGFjZShgJHtERUZBVUxUX0hPU1ROQU1FfS9gLCBcIlwiKVxuICAgICAgICAgICAgLnJlcGxhY2UoYCR7REVGQVVMVF9OQU1FU1BBQ0V9L2AsIFwiXCIpXG4gICAgICAgICAgICAudG9Mb3dlckNhc2UoKSxcbiAgICAgICAgICB2ZXJzaW9ucyxcbiAgICAgICAgXTtcbiAgICAgIH0pLFxuICAgICk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgdmVyc2lvbnNGb3JBbGxQcm92aWRlcnMoKSB7XG4gICAgaWYgKHRoaXMudmVyc2lvbnMpIHtcbiAgICAgIHJldHVybiB0aGlzLnZlcnNpb25zO1xuICAgIH1cblxuICAgIGF3YWl0IHRoaXMucmVhZExvY2FsVmVyc2lvbnNKc29uKCk7XG5cbiAgICByZXR1cm4gdGhpcy52ZXJzaW9ucztcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyB2ZXJzaW9uRm9yUHJvdmlkZXIoXG4gICAgcHJvdmlkZXJOYW1lOiBzdHJpbmcsXG4gICk6IFByb21pc2U8c3RyaW5nIHwgbnVsbD4ge1xuICAgIGNvbnN0IHZlcnNpb25zID0gYXdhaXQgdGhpcy52ZXJzaW9uc0ZvckFsbFByb3ZpZGVycygpO1xuXG4gICAgaWYgKCF2ZXJzaW9ucykge1xuICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuXG4gICAgY29uc3QgcHJvdmlkZXJWZXJzaW9uID0gdmVyc2lvbnNbcHJvdmlkZXJOYW1lLnRvTG93ZXJDYXNlKCldO1xuICAgIGlmICghcHJvdmlkZXJOYW1lKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICByZXR1cm4gcHJvdmlkZXJWZXJzaW9uO1xuICB9XG59XG4iXX0=
@@ -3,15 +3,7 @@
3
3
  * SPDX-License-Identifier: MPL-2.0
4
4
  */
5
5
  import { EventObject, Sender, Receiver } from "xstate";
6
- import * as pty from "@cdktf/node-pty-prebuilt-multiarch";
7
- import { spawnPty } from "./pty-process";
8
- interface PtySpawnConfig {
9
- file: Parameters<typeof pty.spawn>[0];
10
- args: Parameters<typeof pty.spawn>[1];
11
- options: Parameters<typeof pty.spawn>[2] & {
12
- cwd: string;
13
- };
14
- }
6
+ import { spawnInteractive, InteractiveSpawnConfig } from "./interactive-process";
15
7
  interface DeployContext {
16
8
  exitCode?: number;
17
9
  /**
@@ -21,7 +13,7 @@ interface DeployContext {
21
13
  }
22
14
  export type DeployEvent = {
23
15
  type: "START";
24
- pty: PtySpawnConfig;
16
+ pty: InteractiveSpawnConfig;
25
17
  } | {
26
18
  type: "STOP";
27
19
  } | {
@@ -102,7 +94,7 @@ interface BufferedReceiverFunction {
102
94
  export declare function bufferUnterminatedLines(handler: (output: string) => void): BufferedReceiverFunction;
103
95
  export declare function handleLineReceived(send: (event: DeployEvent) => void): (output: string) => void;
104
96
  export declare const deployMachine: import("xstate").StateMachine<DeployContext, any, DeployEvent, DeployState, import("xstate").BaseActionObject, import("xstate").ServiceMap, import("xstate").ResolveTypegenMeta<import("xstate").TypegenDisabled, DeployEvent, import("xstate").BaseActionObject, import("xstate").ServiceMap>>;
105
- export declare function terraformPtyService(_context: DeployContext, event: DeployEvent, spawn?: typeof spawnPty): (send: Sender<DeployEvent>, onReceive: Receiver<DeployEvent>) => void;
97
+ export declare function terraformPtyService(_context: DeployContext, event: DeployEvent, spawn?: typeof spawnInteractive): (send: Sender<DeployEvent>, onReceive: Receiver<DeployEvent>) => void;
106
98
  export declare function createAndStartDeployService(options: {
107
99
  refreshOnly?: boolean;
108
100
  parallelism: number;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deploy-machine.d.ts","sourceRoot":"","sources":["../../../src/lib/models/deploy-machine.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,283 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) HashiCorp, Inc.
4
+ * SPDX-License-Identifier: MPL-2.0
5
+ */
6
+ var __importDefault = (this && this.__importDefault) || function (mod) {
7
+ return (mod && mod.__esModule) ? mod : { "default": mod };
8
+ };
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.createAndStartDestroyService = exports.createAndStartDeployService = exports.terraformPtyService = exports.deployMachine = exports.handleLineReceived = exports.bufferUnterminatedLines = exports.extractVariableNameFromPrompt = exports.isDeployEvent = void 0;
11
+ const xstate_1 = require("xstate");
12
+ const commons_1 = require("@cdktn/commons");
13
+ const errors_1 = require("../errors");
14
+ const strip_ansi_1 = __importDefault(require("strip-ansi"));
15
+ const os_1 = require("os");
16
+ const interactive_process_1 = require("./interactive-process");
17
+ function isDeployEvent(event, type) {
18
+ return event.type === type;
19
+ }
20
+ exports.isDeployEvent = isDeployEvent;
21
+ function extractVariableNameFromPrompt(line) {
22
+ const noColorLine = (0, strip_ansi_1.default)(line);
23
+ const lines = noColorLine.split("\n");
24
+ const lineWithVar = lines.find((line) => line.includes("var."));
25
+ if (!lineWithVar) {
26
+ throw commons_1.Errors.Internal(`Could not find variable name in prompt: ${line}. This is most likely a bug in cdktn. Please report it at http://cdktn.io/issues`);
27
+ }
28
+ return lineWithVar.split("var.")[1].trim();
29
+ }
30
+ exports.extractVariableNameFromPrompt = extractVariableNameFromPrompt;
31
+ // used to only send completed lines (= with a newline at the end of them) to our logic (#2827)
32
+ function bufferUnterminatedLines(handler) {
33
+ let buffer = "";
34
+ function bufferedReceiverFunction(output) {
35
+ buffer += output;
36
+ const lines = buffer.split(/[\n\r]+/);
37
+ // if the string ends with \n this will be an empty string
38
+ // else it will contain an "unfinished" line
39
+ // the fallback to an empty string is to make TS happy and should never happen
40
+ buffer = lines.pop() || "";
41
+ if (lines.length > 0)
42
+ handler(lines.join(os_1.EOL) + os_1.EOL);
43
+ }
44
+ bufferedReceiverFunction.getBuffer = () => buffer;
45
+ return bufferedReceiverFunction;
46
+ }
47
+ exports.bufferUnterminatedLines = bufferUnterminatedLines;
48
+ function handleLineReceived(send) {
49
+ return (output) => {
50
+ let hideOutput = false;
51
+ const noColorLine = (0, strip_ansi_1.default)(output);
52
+ // possible events based on line
53
+ if (noColorLine.includes("approved using the UI or API")) {
54
+ send({ type: "APPROVED_EXTERNALLY" });
55
+ }
56
+ else if (noColorLine.includes("discarded using the UI or API")) {
57
+ send({ type: "REJECTED_EXTERNALLY" });
58
+ }
59
+ else if (noColorLine.includes("Do you want to perform these actions") ||
60
+ noColorLine.includes("Do you really want to destroy all resources?") ||
61
+ noColorLine.includes("Do you really want to destroy all resources in workspace")) {
62
+ hideOutput = true;
63
+ send({ type: "OUTPUT_RECEIVED", output });
64
+ send({ type: "REQUEST_APPROVAL" });
65
+ }
66
+ else if (noColorLine.includes("var.")) {
67
+ hideOutput = true;
68
+ const variableName = extractVariableNameFromPrompt(output);
69
+ send({
70
+ type: "OUTPUT_RECEIVED",
71
+ output: (0, errors_1.missingVariable)(variableName),
72
+ });
73
+ send({ type: "VARIABLE_MISSING", variableName });
74
+ }
75
+ else if (noColorLine.includes("Enter a value:")) {
76
+ // This comes along with above block, but is a separate line
77
+ hideOutput = true;
78
+ }
79
+ else if (noColorLine.includes("Do you want to override the soft failed policy check?")) {
80
+ hideOutput = true;
81
+ send({ type: "OUTPUT_RECEIVED", output });
82
+ send({ type: "REQUEST_SENTINEL_OVERRIDE" });
83
+ }
84
+ else if (noColorLine.includes("overridden using the UI or API")) {
85
+ send({ type: "OVERRIDDEN_EXTERNALLY" });
86
+ }
87
+ if (!hideOutput) {
88
+ send({
89
+ type: "OUTPUT_RECEIVED",
90
+ output,
91
+ });
92
+ }
93
+ };
94
+ }
95
+ exports.handleLineReceived = handleLineReceived;
96
+ exports.deployMachine = (0, xstate_1.createMachine)({
97
+ predictableActionArguments: true,
98
+ context: {},
99
+ initial: "idle",
100
+ id: "root",
101
+ states: {
102
+ idle: {
103
+ on: {
104
+ START: { target: "running" },
105
+ },
106
+ },
107
+ running: {
108
+ invoke: {
109
+ id: "pty",
110
+ src: "runTerraformInPty",
111
+ },
112
+ on: {
113
+ EXITED: "exited",
114
+ STOP: "stopped",
115
+ },
116
+ initial: "processing",
117
+ states: {
118
+ // TODO: what else might TF CLI be asking? Can we detect any question from the TF CLI to show a good error?
119
+ processing: {
120
+ on: {
121
+ REQUEST_APPROVAL: "awaiting_approval",
122
+ REQUEST_SENTINEL_OVERRIDE: "awaiting_sentinel_override",
123
+ VARIABLE_MISSING: {
124
+ actions: (0, xstate_1.send)({ type: "EXITED", exitCode: 1 }),
125
+ },
126
+ },
127
+ },
128
+ awaiting_approval: {
129
+ on: {
130
+ APPROVED_EXTERNALLY: "processing",
131
+ REJECTED_EXTERNALLY: {
132
+ target: "#root.exited",
133
+ actions: (0, xstate_1.assign)({ cancelled: true }),
134
+ },
135
+ APPROVE: {
136
+ target: "processing",
137
+ actions: (0, xstate_1.send)({ type: "SEND_LINE", input: "yes" }, { to: "pty" }),
138
+ },
139
+ REJECT: {
140
+ target: "processing",
141
+ actions: [
142
+ (0, xstate_1.send)({ type: "SEND_LINE", input: "no" }, { to: "pty" }),
143
+ (0, xstate_1.assign)({
144
+ cancelled: true,
145
+ }),
146
+ ],
147
+ },
148
+ },
149
+ },
150
+ awaiting_sentinel_override: {
151
+ on: {
152
+ OVERRIDDEN_EXTERNALLY: "processing",
153
+ OVERRIDE_REJECTED_EXTERNALLY: {
154
+ target: "#root.exited",
155
+ actions: (0, xstate_1.assign)({ cancelled: true }),
156
+ },
157
+ // This is a bit of a hack, because the external discard message
158
+ // posted by Terraform UI is the same as during apply. So, we capture that
159
+ // and emit our own event to make it more specific.
160
+ REJECTED_EXTERNALLY: {
161
+ actions: (0, xstate_1.send)({ type: "OVERRIDE_REJECTED_EXTERNALLY" }),
162
+ },
163
+ OVERRIDE: {
164
+ target: "processing",
165
+ actions: (0, xstate_1.send)({ type: "SEND_LINE", input: "override" }, { to: "pty" }),
166
+ },
167
+ REJECT_OVERRIDE: {
168
+ target: "processing",
169
+ actions: [
170
+ (0, xstate_1.send)({ type: "SEND_LINE", input: "no" }, { to: "pty" }),
171
+ (0, xstate_1.assign)({
172
+ cancelled: true,
173
+ }),
174
+ ],
175
+ },
176
+ },
177
+ },
178
+ },
179
+ },
180
+ exited: { type: "final" },
181
+ stopped: { type: "final" },
182
+ },
183
+ }, {
184
+ services: {
185
+ runTerraformInPty: (context, event) => terraformPtyService(context, event, interactive_process_1.spawnInteractive),
186
+ },
187
+ });
188
+ function terraformPtyService(_context, event, spawn = interactive_process_1.spawnInteractive) {
189
+ return (send, onReceive) => {
190
+ if (event.type !== "START") {
191
+ throw commons_1.Errors.Internal(`Terraform CLI invocation state machine: Unexpected event caused transition to the running state: ${event.type}`);
192
+ }
193
+ // Communication from the pty to the caller
194
+ const receiver = bufferUnterminatedLines(handleLineReceived(send));
195
+ const { exitCode, actions } = spawn(event.pty, (data) => {
196
+ receiver(data);
197
+ });
198
+ // Communication from the caller to the pty
199
+ onReceive((event) => {
200
+ if (event.type === "SEND_LINE") {
201
+ actions.writeLine(event.input);
202
+ }
203
+ });
204
+ exitCode.then((exitCode) => {
205
+ const lastBuffer = receiver.getBuffer();
206
+ if (lastBuffer.length > 0) {
207
+ commons_1.logger.debug(`Terraform CLI exited but the last outputted line was not terminated with a newline and hence is still in the buffer and wasn't printed: "${lastBuffer}"`);
208
+ }
209
+ send({ type: "EXITED", exitCode });
210
+ });
211
+ return () => {
212
+ commons_1.logger.trace("Terraform CLI state machine: cleaning up pty");
213
+ actions.stop();
214
+ };
215
+ };
216
+ }
217
+ exports.terraformPtyService = terraformPtyService;
218
+ function createAndStartDeployService(options) {
219
+ var _a, _b;
220
+ const service = (0, xstate_1.interpret)(exports.deployMachine);
221
+ const args = [
222
+ "apply",
223
+ ...(options.autoApprove ? ["-auto-approve"] : []),
224
+ // "-input=false", we can't use this anymore but TODO: we need to detect TF CLI asking for missing inputs and either allow passing them or stop there and fail
225
+ ...options.extraOptions,
226
+ ...(options.refreshOnly ? ["-refresh-only"] : []),
227
+ ...(options.noColor ? ["-no-color"] : []),
228
+ ...(options.parallelism > -1
229
+ ? [`-parallelism=${options.parallelism}`]
230
+ : []),
231
+ ];
232
+ (_a = options.vars) === null || _a === void 0 ? void 0 : _a.forEach((v) => {
233
+ args.push(`-var=${v}`);
234
+ });
235
+ (_b = options.varFiles) === null || _b === void 0 ? void 0 : _b.forEach((v) => {
236
+ args.push(`-var-file=${v}`);
237
+ });
238
+ commons_1.logger.debug(`Executing ${options.terraformBinaryName} ${args.join(" ")} in ${options.workdir}`);
239
+ const config = {
240
+ file: options.terraformBinaryName,
241
+ args,
242
+ options: {
243
+ cwd: options.workdir,
244
+ env: process.env, // TODO: make this explicit and move to caller or whatever
245
+ },
246
+ };
247
+ service.send({ type: "START", pty: config });
248
+ return service;
249
+ }
250
+ exports.createAndStartDeployService = createAndStartDeployService;
251
+ function createAndStartDestroyService(options) {
252
+ var _a, _b;
253
+ const service = (0, xstate_1.interpret)(exports.deployMachine);
254
+ const args = [
255
+ "destroy",
256
+ ...(options.autoApprove ? ["-auto-approve"] : []),
257
+ // "-input=false", we can't use this anymore but TODO: we need to detect TF CLI asking for missing inputs and either allow passing them or stop there and fail
258
+ ...options.extraOptions,
259
+ ...(options.noColor ? ["-no-color"] : []),
260
+ ...(options.parallelism > -1
261
+ ? [`-parallelism=${options.parallelism}`]
262
+ : []),
263
+ ];
264
+ (_a = options.vars) === null || _a === void 0 ? void 0 : _a.forEach((v) => {
265
+ args.push(`-var=${v}`);
266
+ });
267
+ (_b = options.varFiles) === null || _b === void 0 ? void 0 : _b.forEach((v) => {
268
+ args.push(`-var-file=${v}`);
269
+ });
270
+ commons_1.logger.debug(`Executing ${options.terraformBinaryName} ${args.join(" ")} in ${options.workdir}`);
271
+ const config = {
272
+ file: options.terraformBinaryName,
273
+ args,
274
+ options: {
275
+ cwd: options.workdir,
276
+ env: process.env, // TODO: make this explicit and move to caller or whatever
277
+ },
278
+ };
279
+ service.send({ type: "START", pty: config });
280
+ return service;
281
+ }
282
+ exports.createAndStartDestroyService = createAndStartDestroyService;
283
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deploy-machine.js","sourceRoot":"","sources":["../../../src/lib/models/deploy-machine.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright (c) HashiCorp, Inc.\n * SPDX-License-Identifier: MPL-2.0\n */\n\nimport {\n  createMachine,\n  send,\n  interpret,\n  EventObject,\n  assign,\n  Sender,\n  Receiver,\n} from \"xstate\";\nimport { Errors, logger } from \"@cdktn/commons\";\nimport { missingVariable } from \"../errors\";\nimport stripAnsi from \"strip-ansi\";\nimport { EOL } from \"os\";\nimport {\n  spawnInteractive,\n  InteractiveSpawnConfig,\n} from \"./interactive-process\";\n\ninterface DeployContext {\n  exitCode?: number;\n  /**\n   * Terraform will exit with 1 if it was cancelled, but we don't want to fail in that case\n   */\n  cancelled?: boolean;\n}\n\nexport type DeployEvent =\n  | { type: \"START\"; pty: InteractiveSpawnConfig }\n  | { type: \"STOP\" }\n  | { type: \"SEND_LINE\"; input: string }\n  | { type: \"OUTPUT_RECEIVED\"; output: string }\n  | { type: \"APPROVED_EXTERNALLY\" } // e.g. via TFC UI or API\n  | { type: \"REJECTED_EXTERNALLY\" }\n  | { type: \"OVERRIDDEN_EXTERNALLY\" }\n  | { type: \"OVERRIDE_REJECTED_EXTERNALLY\" }\n  | { type: \"OVERRIDE\" }\n  | { type: \"REJECT_OVERRIDE\" }\n  | { type: \"REQUEST_APPROVAL\" }\n  | { type: \"VARIABLE_MISSING\"; variableName: string }\n  | { type: \"REQUEST_SENTINEL_OVERRIDE\" }\n  | { type: \"APPROVE\" }\n  | { type: \"REJECT\" }\n  | { type: \"EXITED\"; exitCode: number };\n\nexport function isDeployEvent<DeployEventType extends DeployEvent[\"type\"]>(\n  event: EventObject,\n  type: DeployEventType,\n): event is DeployEvent & { type: DeployEventType } {\n  return event.type === type;\n}\n\nexport type DeployState =\n  | {\n      value: \"idle\";\n      context: DeployContext;\n    }\n  | {\n      value: \"running\";\n      context: DeployContext;\n    }\n  | {\n      value: { running: \"processing\" };\n      context: DeployContext;\n    }\n  | {\n      value: { running: \"awaiting_approval\" };\n      context: DeployContext;\n    }\n  | {\n      value: { running: \"awaiting_sentinel_override\" };\n      context: DeployContext;\n    }\n  | {\n      value: \"exited\";\n      context: DeployContext & { exitCode: number };\n    }\n  | {\n      value: \"stopped\";\n      context: DeployContext;\n    };\n\nexport function extractVariableNameFromPrompt(line: string) {\n  const noColorLine = stripAnsi(line);\n  const lines = noColorLine.split(\"\\n\");\n  const lineWithVar = lines.find((line) => line.includes(\"var.\"));\n  if (!lineWithVar) {\n    throw Errors.Internal(\n      `Could not find variable name in prompt: ${line}. This is most likely a bug in cdktn. Please report it at http://cdktn.io/issues`,\n    );\n  }\n  return lineWithVar.split(\"var.\")[1].trim();\n}\n\ninterface BufferedReceiverFunction {\n  (output: string): void;\n  /**\n   * used to get the last buffer when the PTY exits to log a debug message if there's output left in there\n   * (might help debugging on Windows if EOL from Nodejs doesn't work in WSL)\n   */\n  getBuffer: () => string;\n}\n\n// used to only send completed lines (= with a newline at the end of them) to our logic (#2827)\nexport function bufferUnterminatedLines(\n  handler: (output: string) => void,\n): BufferedReceiverFunction {\n  let buffer = \"\";\n  function bufferedReceiverFunction(output: string) {\n    buffer += output;\n    const lines = buffer.split(/[\\n\\r]+/);\n\n    // if the string ends with \\n this will be an empty string\n    // else it will contain an \"unfinished\" line\n    // the fallback to an empty string is to make TS happy and should never happen\n    buffer = lines.pop() || \"\";\n\n    if (lines.length > 0) handler(lines.join(EOL) + EOL);\n  }\n  bufferedReceiverFunction.getBuffer = () => buffer;\n\n  return bufferedReceiverFunction;\n}\n\nexport function handleLineReceived(send: (event: DeployEvent) => void) {\n  return (output: string) => {\n    let hideOutput = false;\n    const noColorLine = stripAnsi(output);\n\n    // possible events based on line\n    if (noColorLine.includes(\"approved using the UI or API\")) {\n      send({ type: \"APPROVED_EXTERNALLY\" });\n    } else if (noColorLine.includes(\"discarded using the UI or API\")) {\n      send({ type: \"REJECTED_EXTERNALLY\" });\n    } else if (\n      noColorLine.includes(\"Do you want to perform these actions\") ||\n      noColorLine.includes(\"Do you really want to destroy all resources?\") ||\n      noColorLine.includes(\n        \"Do you really want to destroy all resources in workspace\",\n      )\n    ) {\n      hideOutput = true;\n      send({ type: \"OUTPUT_RECEIVED\", output });\n      send({ type: \"REQUEST_APPROVAL\" });\n    } else if (noColorLine.includes(\"var.\")) {\n      hideOutput = true;\n\n      const variableName = extractVariableNameFromPrompt(output);\n      send({\n        type: \"OUTPUT_RECEIVED\",\n        output: missingVariable(variableName),\n      });\n      send({ type: \"VARIABLE_MISSING\", variableName });\n    } else if (noColorLine.includes(\"Enter a value:\")) {\n      // This comes along with above block, but is a separate line\n      hideOutput = true;\n    } else if (\n      noColorLine.includes(\n        \"Do you want to override the soft failed policy check?\",\n      )\n    ) {\n      hideOutput = true;\n      send({ type: \"OUTPUT_RECEIVED\", output });\n\n      send({ type: \"REQUEST_SENTINEL_OVERRIDE\" });\n    } else if (noColorLine.includes(\"overridden using the UI or API\")) {\n      send({ type: \"OVERRIDDEN_EXTERNALLY\" });\n    }\n\n    if (!hideOutput) {\n      send({\n        type: \"OUTPUT_RECEIVED\",\n        output,\n      });\n    }\n  };\n}\n\nexport const deployMachine = createMachine<\n  DeployContext,\n  DeployEvent,\n  DeployState\n>(\n  {\n    predictableActionArguments: true,\n    context: {},\n    initial: \"idle\",\n    id: \"root\",\n    states: {\n      idle: {\n        on: {\n          START: { target: \"running\" },\n        },\n      },\n      running: {\n        invoke: {\n          id: \"pty\",\n          src: \"runTerraformInPty\",\n        },\n        on: {\n          EXITED: \"exited\",\n          STOP: \"stopped\",\n        },\n        initial: \"processing\",\n        states: {\n          // TODO: what else might TF CLI be asking? Can we detect any question from the TF CLI to show a good error?\n          processing: {\n            on: {\n              REQUEST_APPROVAL: \"awaiting_approval\",\n              REQUEST_SENTINEL_OVERRIDE: \"awaiting_sentinel_override\",\n              VARIABLE_MISSING: {\n                actions: send({ type: \"EXITED\", exitCode: 1 }),\n              },\n            },\n          },\n          awaiting_approval: {\n            on: {\n              APPROVED_EXTERNALLY: \"processing\",\n              REJECTED_EXTERNALLY: {\n                target: \"#root.exited\",\n                actions: assign<\n                  DeployContext,\n                  DeployEvent & { type: \"REJECTED_EXTERNALLY\" }\n                >({ cancelled: true }),\n              },\n              APPROVE: {\n                target: \"processing\",\n                actions: send(\n                  { type: \"SEND_LINE\", input: \"yes\" },\n                  { to: \"pty\" },\n                ),\n              },\n              REJECT: {\n                target: \"processing\",\n                actions: [\n                  send({ type: \"SEND_LINE\", input: \"no\" }, { to: \"pty\" }),\n                  assign<DeployContext, DeployEvent & { type: \"REJECT\" }>({\n                    cancelled: true,\n                  }),\n                ],\n              },\n            },\n          },\n          awaiting_sentinel_override: {\n            on: {\n              OVERRIDDEN_EXTERNALLY: \"processing\",\n              OVERRIDE_REJECTED_EXTERNALLY: {\n                target: \"#root.exited\",\n                actions: assign<\n                  DeployContext,\n                  DeployEvent & { type: \"OVERRIDE_REJECTED_EXTERNALLY\" }\n                >({ cancelled: true }),\n              },\n              // This is a bit of a hack, because the external discard message\n              // posted by Terraform UI is the same as during apply. So, we capture that\n              // and emit our own event to make it more specific.\n              REJECTED_EXTERNALLY: {\n                actions: send({ type: \"OVERRIDE_REJECTED_EXTERNALLY\" }),\n              },\n              OVERRIDE: {\n                target: \"processing\",\n                actions: send(\n                  { type: \"SEND_LINE\", input: \"override\" },\n                  { to: \"pty\" },\n                ),\n              },\n              REJECT_OVERRIDE: {\n                target: \"processing\",\n                actions: [\n                  send({ type: \"SEND_LINE\", input: \"no\" }, { to: \"pty\" }),\n                  assign<\n                    DeployContext,\n                    DeployEvent & { type: \"REJECT_OVERRIDE\" }\n                  >({\n                    cancelled: true,\n                  }),\n                ],\n              },\n            },\n          },\n        },\n      },\n      exited: { type: \"final\" },\n      stopped: { type: \"final\" },\n    },\n  },\n  {\n    services: {\n      runTerraformInPty: (context, event) =>\n        terraformPtyService(context, event, spawnInteractive),\n    },\n  },\n);\n\nexport function terraformPtyService(\n  _context: DeployContext,\n  event: DeployEvent,\n  spawn = spawnInteractive,\n): (send: Sender<DeployEvent>, onReceive: Receiver<DeployEvent>) => void {\n  return (send: Sender<DeployEvent>, onReceive: Receiver<DeployEvent>) => {\n    if (event.type !== \"START\") {\n      throw Errors.Internal(\n        `Terraform CLI invocation state machine: Unexpected event caused transition to the running state: ${event.type}`,\n      );\n    }\n\n    // Communication from the pty to the caller\n    const receiver = bufferUnterminatedLines(handleLineReceived(send));\n    const { exitCode, actions } = spawn(event.pty, (data) => {\n      receiver(data);\n    });\n\n    // Communication from the caller to the pty\n    onReceive((event: DeployEvent) => {\n      if (event.type === \"SEND_LINE\") {\n        actions.writeLine(event.input);\n      }\n    });\n\n    exitCode.then((exitCode) => {\n      const lastBuffer = receiver.getBuffer();\n      if (lastBuffer.length > 0) {\n        logger.debug(\n          `Terraform CLI exited but the last outputted line was not terminated with a newline and hence is still in the buffer and wasn't printed: \"${lastBuffer}\"`,\n        );\n      }\n\n      send({ type: \"EXITED\", exitCode });\n    });\n\n    return () => {\n      logger.trace(\"Terraform CLI state machine: cleaning up pty\");\n      actions.stop();\n    };\n  };\n}\n\nexport function createAndStartDeployService(options: {\n  refreshOnly?: boolean;\n  parallelism: number;\n  extraOptions: string[];\n  terraformBinaryName: string;\n  autoApprove?: boolean;\n  noColor?: boolean;\n  workdir: string;\n  vars?: string[];\n  varFiles?: string[];\n}) {\n  const service = interpret(deployMachine);\n  const args = [\n    \"apply\",\n    ...(options.autoApprove ? [\"-auto-approve\"] : []),\n    // \"-input=false\", we can't use this anymore but TODO: we need to detect TF CLI asking for missing inputs and either allow passing them or stop there and fail\n\n    ...options.extraOptions,\n    ...(options.refreshOnly ? [\"-refresh-only\"] : []),\n    ...(options.noColor ? [\"-no-color\"] : []),\n    ...(options.parallelism > -1\n      ? [`-parallelism=${options.parallelism}`]\n      : []),\n  ];\n\n  options.vars?.forEach((v) => {\n    args.push(`-var=${v}`);\n  });\n\n  options.varFiles?.forEach((v) => {\n    args.push(`-var-file=${v}`);\n  });\n\n  logger.debug(\n    `Executing ${options.terraformBinaryName} ${args.join(\" \")} in ${\n      options.workdir\n    }`,\n  );\n\n  const config: InteractiveSpawnConfig = {\n    file: options.terraformBinaryName,\n    args,\n    options: {\n      cwd: options.workdir,\n      env: process.env as { [key: string]: string }, // TODO: make this explicit and move to caller or whatever\n    },\n  };\n\n  service.send({ type: \"START\", pty: config });\n\n  return service;\n}\n\nexport function createAndStartDestroyService(options: {\n  parallelism: number;\n  extraOptions: string[];\n  terraformBinaryName: string;\n  autoApprove?: boolean;\n  noColor?: boolean;\n  workdir: string;\n  vars?: string[];\n  varFiles?: string[];\n}) {\n  const service = interpret(deployMachine);\n\n  const args = [\n    \"destroy\",\n    ...(options.autoApprove ? [\"-auto-approve\"] : []),\n    // \"-input=false\", we can't use this anymore but TODO: we need to detect TF CLI asking for missing inputs and either allow passing them or stop there and fail\n\n    ...options.extraOptions,\n    ...(options.noColor ? [\"-no-color\"] : []),\n    ...(options.parallelism > -1\n      ? [`-parallelism=${options.parallelism}`]\n      : []),\n  ];\n\n  options.vars?.forEach((v) => {\n    args.push(`-var=${v}`);\n  });\n\n  options.varFiles?.forEach((v) => {\n    args.push(`-var-file=${v}`);\n  });\n\n  logger.debug(\n    `Executing ${options.terraformBinaryName} ${args.join(\" \")} in ${\n      options.workdir\n    }`,\n  );\n\n  const config: InteractiveSpawnConfig = {\n    file: options.terraformBinaryName,\n    args,\n    options: {\n      cwd: options.workdir,\n      env: process.env as { [key: string]: string }, // TODO: make this explicit and move to caller or whatever\n    },\n  };\n\n  service.send({ type: \"START\", pty: config });\n\n  return service;\n}\n"]}
@@ -0,0 +1,28 @@
1
+ /**
2
+ * Copyright (c) HashiCorp, Inc.
3
+ * SPDX-License-Identifier: MPL-2.0
4
+ */
5
+ import { spawn } from "cross-spawn";
6
+ export interface InteractiveSpawnConfig {
7
+ file: Parameters<typeof spawn>[0];
8
+ args: Parameters<typeof spawn>[1];
9
+ options: Parameters<typeof spawn>[2] & {
10
+ cwd: string;
11
+ };
12
+ }
13
+ export interface InteractiveProcessActions {
14
+ write: (response: string) => void;
15
+ writeLine: (response: string) => void;
16
+ stop: () => void;
17
+ }
18
+ export interface InteractiveProcess {
19
+ exitCode: Promise<number>;
20
+ actions: InteractiveProcessActions;
21
+ }
22
+ /**
23
+ * A wrapper around child_process.spawn that handles the platform specific differences
24
+ * and provide an intuitive API for bidirectional communication with the
25
+ * spawned process.
26
+ */
27
+ export declare function spawnInteractive(config: InteractiveSpawnConfig, onData: (data: string) => void): InteractiveProcess;
28
+ //# sourceMappingURL=interactive-process.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interactive-process.d.ts","sourceRoot":"","sources":["../../../src/lib/models/interactive-process.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAIpC,MAAM,WAAW,sBAAsB;IACrC,IAAI,EAAE,UAAU,CAAC,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAClC,IAAI,EAAE,UAAU,CAAC,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAClC,OAAO,EAAE,UAAU,CAAC,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG;QAAE,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;CACxD;AAED,MAAM,WAAW,yBAAyB;IACxC,KAAK,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,SAAS,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;IACtC,IAAI,EAAE,MAAM,IAAI,CAAC;CAClB;AAED,MAAM,WAAW,kBAAkB;IAEjC,QAAQ,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;IAC1B,OAAO,EAAE,yBAAyB,CAAC;CACpC;AAED;;;;GAIG;AACH,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,sBAAsB,EAC9B,MAAM,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,GAC7B,kBAAkB,CA+DpB"}