@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.
- package/ambient.d.ts +0 -1
- package/build/lib/cdktf-config.d.ts.map +1 -0
- package/build/lib/cdktf-config.js +108 -0
- package/build/lib/cdktf-project-io-handler.d.ts.map +1 -0
- package/build/lib/cdktf-project-io-handler.js +84 -0
- package/build/lib/cdktf-project.d.ts.map +1 -0
- package/build/lib/cdktf-project.js +370 -0
- package/{src → build}/lib/cdktf-stack.d.ts +1 -0
- package/build/lib/cdktf-stack.d.ts.map +1 -0
- package/build/lib/cdktf-stack.js +386 -0
- package/build/lib/convert.d.ts.map +1 -0
- package/build/lib/convert.js +51 -0
- package/build/lib/dependencies/cdktf-config-manager.d.ts.map +1 -0
- package/build/lib/dependencies/cdktf-config-manager.js +36 -0
- package/build/lib/dependencies/dependency-manager.d.ts.map +1 -0
- package/build/lib/dependencies/dependency-manager.js +393 -0
- package/build/lib/dependencies/package-manager.d.ts.map +1 -0
- package/build/lib/dependencies/package-manager.js +581 -0
- package/build/lib/dependencies/prebuilt-providers.d.ts.map +1 -0
- package/build/lib/dependencies/prebuilt-providers.js +221 -0
- package/build/lib/dependencies/registry-api.d.ts.map +1 -0
- package/build/lib/dependencies/registry-api.js +77 -0
- package/build/lib/dependencies/version-constraints.d.ts.map +1 -0
- package/build/lib/dependencies/version-constraints.js +95 -0
- package/build/lib/error-reporting.d.ts.map +1 -0
- package/build/lib/error-reporting.js +133 -0
- package/build/lib/errors.d.ts.map +1 -0
- package/build/lib/errors.js +10 -0
- package/build/lib/execution-logs.d.ts.map +1 -0
- package/build/lib/execution-logs.js +47 -0
- package/build/lib/get.d.ts.map +1 -0
- package/build/lib/get.js +90 -0
- package/build/lib/helpers/stack-helpers.d.ts.map +1 -0
- package/build/lib/helpers/stack-helpers.js +155 -0
- package/build/lib/index.d.ts.map +1 -0
- package/{src → build}/lib/index.js +1 -2
- package/build/lib/init.d.ts.map +1 -0
- package/build/lib/init.js +131 -0
- package/build/lib/local-provider-constraints.d.ts.map +1 -0
- package/build/lib/local-provider-constraints.js +95 -0
- package/build/lib/local-provider-versions.d.ts.map +1 -0
- package/build/lib/local-provider-versions.js +73 -0
- package/{src → build}/lib/models/deploy-machine.d.ts +3 -11
- package/build/lib/models/deploy-machine.d.ts.map +1 -0
- package/build/lib/models/deploy-machine.js +283 -0
- package/build/lib/models/interactive-process.d.ts +28 -0
- package/build/lib/models/interactive-process.d.ts.map +1 -0
- package/build/lib/models/interactive-process.js +59 -0
- package/{src → build}/lib/models/schema.d.ts.map +1 -1
- package/build/lib/models/schema.js +181 -0
- package/{src → build}/lib/models/terraform-cli.d.ts +1 -0
- package/build/lib/models/terraform-cli.d.ts.map +1 -0
- package/build/lib/models/terraform-cli.js +355 -0
- package/build/lib/models/terraform.d.ts.map +1 -0
- package/build/lib/models/terraform.js +72 -0
- package/build/lib/output.d.ts.map +1 -0
- package/build/lib/output.js +211 -0
- package/build/lib/provider-add.d.ts.map +1 -0
- package/build/lib/provider-add.js +30 -0
- package/build/lib/server/terraform-logs.d.ts.map +1 -0
- package/build/lib/server/terraform-logs.js +19 -0
- package/{src → build}/lib/synth-stack.d.ts +1 -0
- package/build/lib/synth-stack.d.ts.map +1 -0
- package/build/lib/synth-stack.js +251 -0
- package/build/lib/synth.d.ts.map +1 -0
- package/build/lib/synth.js +67 -0
- package/{src → build}/lib/terraform-json.d.ts.map +1 -1
- package/build/lib/terraform-json.js +82 -0
- package/build/lib/terraform-provider-lock.d.ts.map +1 -0
- package/{src → build}/lib/terraform-provider-lock.js +2 -2
- package/{src → build}/lib/watch.d.ts +1 -0
- package/build/lib/watch.d.ts.map +1 -0
- package/build/lib/watch.js +155 -0
- package/eslint.config.mjs +2 -70
- package/package.json +22 -33
- package/templates/go/go.mod +1 -1
- package/templates/python/Pipfile +1 -1
- package/templates/typescript/.hooks.sscaff.js +1 -1
- package/templates/typescript/jest.config.js +1 -1
- package/src/lib/cdktf-config.d.ts.map +0 -1
- package/src/lib/cdktf-config.js +0 -108
- package/src/lib/cdktf-project-io-handler.d.ts.map +0 -1
- package/src/lib/cdktf-project-io-handler.js +0 -84
- package/src/lib/cdktf-project.d.ts.map +0 -1
- package/src/lib/cdktf-project.js +0 -371
- package/src/lib/cdktf-stack.d.ts.map +0 -1
- package/src/lib/cdktf-stack.js +0 -386
- package/src/lib/convert.d.ts.map +0 -1
- package/src/lib/convert.js +0 -51
- package/src/lib/dependencies/cdktf-config-manager.d.ts.map +0 -1
- package/src/lib/dependencies/cdktf-config-manager.js +0 -36
- package/src/lib/dependencies/dependency-manager.d.ts.map +0 -1
- package/src/lib/dependencies/dependency-manager.js +0 -393
- package/src/lib/dependencies/package-manager.d.ts.map +0 -1
- package/src/lib/dependencies/package-manager.js +0 -581
- package/src/lib/dependencies/prebuilt-providers.d.ts.map +0 -1
- package/src/lib/dependencies/prebuilt-providers.js +0 -220
- package/src/lib/dependencies/registry-api.d.ts.map +0 -1
- package/src/lib/dependencies/registry-api.js +0 -77
- package/src/lib/dependencies/version-constraints.d.ts.map +0 -1
- package/src/lib/dependencies/version-constraints.js +0 -95
- package/src/lib/error-reporting.d.ts.map +0 -1
- package/src/lib/error-reporting.js +0 -133
- package/src/lib/errors.d.ts.map +0 -1
- package/src/lib/errors.js +0 -10
- package/src/lib/execution-logs.d.ts.map +0 -1
- package/src/lib/execution-logs.js +0 -47
- package/src/lib/get.d.ts.map +0 -1
- package/src/lib/get.js +0 -90
- package/src/lib/helpers/stack-helpers.d.ts.map +0 -1
- package/src/lib/helpers/stack-helpers.js +0 -155
- package/src/lib/index.d.ts.map +0 -1
- package/src/lib/init.d.ts.map +0 -1
- package/src/lib/init.js +0 -131
- package/src/lib/local-provider-constraints.d.ts.map +0 -1
- package/src/lib/local-provider-constraints.js +0 -95
- package/src/lib/local-provider-versions.d.ts.map +0 -1
- package/src/lib/local-provider-versions.js +0 -73
- package/src/lib/models/deploy-machine.d.ts.map +0 -1
- package/src/lib/models/deploy-machine.js +0 -280
- package/src/lib/models/pty-process.d.ts +0 -29
- package/src/lib/models/pty-process.d.ts.map +0 -1
- package/src/lib/models/pty-process.js +0 -132
- package/src/lib/models/schema.js +0 -181
- package/src/lib/models/terraform-cli.d.ts.map +0 -1
- package/src/lib/models/terraform-cli.js +0 -357
- package/src/lib/models/terraform.d.ts.map +0 -1
- package/src/lib/models/terraform.js +0 -72
- package/src/lib/output.d.ts.map +0 -1
- package/src/lib/output.js +0 -211
- package/src/lib/provider-add.d.ts.map +0 -1
- package/src/lib/provider-add.js +0 -30
- package/src/lib/server/terraform-logs.d.ts.map +0 -1
- package/src/lib/server/terraform-logs.js +0 -19
- package/src/lib/synth-stack.d.ts.map +0 -1
- package/src/lib/synth-stack.js +0 -251
- package/src/lib/synth.d.ts.map +0 -1
- package/src/lib/synth.js +0 -67
- package/src/lib/terraform-json.js +0 -82
- package/src/lib/terraform-provider-lock.d.ts.map +0 -1
- package/src/lib/watch.d.ts.map +0 -1
- package/src/lib/watch.js +0 -155
- /package/{src → build}/lib/cdktf-config.d.ts +0 -0
- /package/{src → build}/lib/cdktf-project-io-handler.d.ts +0 -0
- /package/{src → build}/lib/cdktf-project.d.ts +0 -0
- /package/{src → build}/lib/convert.d.ts +0 -0
- /package/{src → build}/lib/dependencies/cdktf-config-manager.d.ts +0 -0
- /package/{src → build}/lib/dependencies/dependency-manager.d.ts +0 -0
- /package/{src → build}/lib/dependencies/package-manager.d.ts +0 -0
- /package/{src → build}/lib/dependencies/prebuilt-providers.d.ts +0 -0
- /package/{src → build}/lib/dependencies/registry-api.d.ts +0 -0
- /package/{src → build}/lib/dependencies/version-constraints.d.ts +0 -0
- /package/{src → build}/lib/error-reporting.d.ts +0 -0
- /package/{src → build}/lib/errors.d.ts +0 -0
- /package/{src → build}/lib/execution-logs.d.ts +0 -0
- /package/{src → build}/lib/get.d.ts +0 -0
- /package/{src → build}/lib/helpers/stack-helpers.d.ts +0 -0
- /package/{src → build}/lib/index.d.ts +0 -0
- /package/{src → build}/lib/init.d.ts +0 -0
- /package/{src → build}/lib/local-provider-constraints.d.ts +0 -0
- /package/{src → build}/lib/local-provider-versions.d.ts +0 -0
- /package/{src → build}/lib/models/schema.d.ts +0 -0
- /package/{src → build}/lib/models/terraform.d.ts +0 -0
- /package/{src → build}/lib/output.d.ts +0 -0
- /package/{src → build}/lib/provider-add.d.ts +0 -0
- /package/{src → build}/lib/server/terraform-logs.d.ts +0 -0
- /package/{src → build}/lib/synth.d.ts +0 -0
- /package/{src → build}/lib/terraform-json.d.ts +0 -0
- /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
|
|
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:
|
|
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
|
|
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"}
|