@start9labs/start-sdk 0.3.6-beta.2 → 0.3.6-beta.20
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/base/lib/Effects.d.ts +6 -8
- package/base/lib/actions/index.d.ts +4 -4
- package/base/lib/actions/index.js.map +1 -1
- package/base/lib/actions/input/builder/inputSpec.js.map +1 -1
- package/base/lib/actions/input/builder/value.d.ts +3 -0
- package/base/lib/actions/input/builder/value.js +87 -111
- package/base/lib/actions/input/builder/value.js.map +1 -1
- package/base/lib/actions/input/builder/variants.js.map +1 -1
- package/base/lib/actions/input/index.js +17 -7
- package/base/lib/actions/input/index.js.map +1 -1
- package/base/lib/actions/input/inputSpecConstants.js +2 -2
- package/base/lib/actions/input/inputSpecConstants.js.map +1 -1
- package/base/lib/actions/input/inputSpecTypes.js +1 -2
- package/base/lib/actions/input/inputSpecTypes.js.map +1 -1
- package/base/lib/actions/setupActions.d.ts +3 -3
- package/base/lib/actions/setupActions.js.map +1 -1
- package/base/lib/dependencies/dependencies.js +1 -2
- package/base/lib/dependencies/dependencies.js.map +1 -1
- package/base/lib/dependencies/setupDependencies.d.ts +1 -1
- package/base/lib/dependencies/setupDependencies.js +4 -3
- package/base/lib/dependencies/setupDependencies.js.map +1 -1
- package/base/lib/exver/exver.d.ts +31 -5
- package/base/lib/exver/exver.js +513 -113
- package/base/lib/exver/exver.js.map +1 -1
- package/base/lib/exver/index.d.ts +77 -3
- package/base/lib/exver/index.js +487 -16
- package/base/lib/exver/index.js.map +1 -1
- package/base/lib/index.js +17 -7
- package/base/lib/index.js.map +1 -1
- package/base/lib/interfaces/Host.d.ts +6 -31
- package/base/lib/interfaces/Host.js +3 -33
- package/base/lib/interfaces/Host.js.map +1 -1
- package/base/lib/interfaces/Origin.d.ts +4 -4
- package/base/lib/interfaces/Origin.js +1 -2
- package/base/lib/interfaces/Origin.js.map +1 -1
- package/base/lib/interfaces/ServiceInterfaceBuilder.d.ts +0 -2
- package/base/lib/interfaces/ServiceInterfaceBuilder.js.map +1 -1
- package/base/lib/osBindings/BindParams.d.ts +0 -2
- package/base/lib/osBindings/BindingSetPublicParams.d.ts +4 -0
- package/base/lib/osBindings/BindingSetPublicParams.js +4 -0
- package/base/lib/osBindings/BindingSetPublicParams.js.map +1 -0
- package/base/lib/osBindings/Celsius.d.ts +1 -0
- package/base/lib/osBindings/{HostKind.js → Celsius.js} +1 -1
- package/base/lib/osBindings/Celsius.js.map +1 -0
- package/base/lib/osBindings/ExportServiceInterfaceParams.d.ts +0 -1
- package/base/lib/osBindings/{GetPrimaryUrlParams.d.ts → GetContainerIpParams.d.ts} +1 -3
- package/base/lib/osBindings/GetContainerIpParams.js +3 -0
- package/base/lib/osBindings/GetContainerIpParams.js.map +1 -0
- package/base/lib/osBindings/GigaBytes.d.ts +1 -0
- package/base/lib/osBindings/{SetPublicParams.js → GigaBytes.js} +1 -1
- package/base/lib/osBindings/GigaBytes.js.map +1 -0
- package/base/lib/osBindings/Host.d.ts +0 -2
- package/base/lib/osBindings/HostAddress.d.ts +3 -0
- package/base/lib/osBindings/HostAddress.js +0 -1
- package/base/lib/osBindings/HostAddress.js.map +1 -1
- package/base/lib/osBindings/ImageMetadata.d.ts +2 -0
- package/base/lib/osBindings/IpHostname.d.ts +1 -0
- package/base/lib/osBindings/IpInfo.d.ts +2 -0
- package/base/lib/osBindings/IpInfo.js +0 -1
- package/base/lib/osBindings/IpInfo.js.map +1 -1
- package/base/lib/osBindings/Manifest.d.ts +0 -1
- package/base/lib/osBindings/MebiBytes.d.ts +1 -0
- package/base/lib/osBindings/MebiBytes.js +4 -0
- package/base/lib/osBindings/MebiBytes.js.map +1 -0
- package/base/lib/osBindings/Metrics.d.ts +10 -0
- package/base/lib/osBindings/{GetPrimaryUrlParams.js → Metrics.js} +1 -1
- package/base/lib/osBindings/Metrics.js.map +1 -0
- package/base/lib/osBindings/MetricsCpu.d.ts +8 -0
- package/base/lib/osBindings/MetricsCpu.js +3 -0
- package/base/lib/osBindings/MetricsCpu.js.map +1 -0
- package/base/lib/osBindings/MetricsDisk.d.ts +8 -0
- package/base/lib/osBindings/MetricsDisk.js +3 -0
- package/base/lib/osBindings/MetricsDisk.js.map +1 -0
- package/base/lib/osBindings/MetricsGeneral.d.ts +4 -0
- package/base/lib/osBindings/MetricsGeneral.js +3 -0
- package/base/lib/osBindings/MetricsGeneral.js.map +1 -0
- package/base/lib/osBindings/MetricsMemory.d.ts +11 -0
- package/base/lib/osBindings/MetricsMemory.js +3 -0
- package/base/lib/osBindings/MetricsMemory.js.map +1 -0
- package/base/lib/osBindings/NetworkInfo.d.ts +15 -0
- package/base/lib/osBindings/NetworkInfo.js +3 -0
- package/base/lib/osBindings/NetworkInfo.js.map +1 -0
- package/base/lib/osBindings/NetworkInterfaceSetInboundParams.d.ts +4 -0
- package/base/lib/osBindings/NetworkInterfaceSetInboundParams.js +4 -0
- package/base/lib/osBindings/NetworkInterfaceSetInboundParams.js.map +1 -0
- package/base/lib/osBindings/{SetPublicParams.d.ts → NetworkInterfaceSetPublicParams.d.ts} +1 -1
- package/base/lib/osBindings/NetworkInterfaceSetPublicParams.js +4 -0
- package/base/lib/osBindings/NetworkInterfaceSetPublicParams.js.map +1 -0
- package/base/lib/osBindings/NetworkInterfaceType.d.ts +1 -0
- package/base/lib/osBindings/NetworkInterfaceType.js +4 -0
- package/base/lib/osBindings/NetworkInterfaceType.js.map +1 -0
- package/base/lib/osBindings/Percentage.d.ts +1 -0
- package/base/lib/osBindings/Percentage.js +4 -0
- package/base/lib/osBindings/Percentage.js.map +1 -0
- package/base/lib/osBindings/ServerInfo.d.ts +2 -6
- package/base/lib/osBindings/ServiceInterface.d.ts +0 -1
- package/base/lib/osBindings/SetupResult.d.ts +1 -1
- package/base/lib/osBindings/TestSmtpParams.d.ts +8 -0
- package/base/lib/osBindings/TestSmtpParams.js +4 -0
- package/base/lib/osBindings/TestSmtpParams.js.map +1 -0
- package/base/lib/osBindings/UnsetInboundParams.d.ts +3 -0
- package/base/lib/osBindings/UnsetInboundParams.js +4 -0
- package/base/lib/osBindings/UnsetInboundParams.js.map +1 -0
- package/base/lib/osBindings/index.d.ts +6 -3
- package/base/lib/s9pk/index.js +7 -10
- package/base/lib/s9pk/index.js.map +1 -1
- package/base/lib/s9pk/merkleArchive/directoryContents.js +1 -1
- package/base/lib/s9pk/merkleArchive/directoryContents.js.map +1 -1
- package/base/lib/s9pk/merkleArchive/fileContents.js.map +1 -1
- package/base/lib/s9pk/merkleArchive/index.js +1 -1
- package/base/lib/s9pk/merkleArchive/index.js.map +1 -1
- package/base/lib/s9pk/merkleArchive/varint.js +2 -2
- package/base/lib/s9pk/merkleArchive/varint.js.map +1 -1
- package/base/lib/types/ManifestTypes.d.ts +5 -8
- package/base/lib/types.d.ts +5 -32
- package/base/lib/types.js +25 -9
- package/base/lib/types.js.map +1 -1
- package/base/lib/util/GetSystemSmtp.d.ts +9 -4
- package/base/lib/util/GetSystemSmtp.js +22 -3
- package/base/lib/util/GetSystemSmtp.js.map +1 -1
- package/base/lib/util/Hostname.js +1 -2
- package/base/lib/util/Hostname.js.map +1 -1
- package/base/lib/util/PathBuilder.d.ts +1 -1
- package/base/lib/util/PathBuilder.js.map +1 -1
- package/base/lib/util/asError.js.map +1 -1
- package/base/lib/util/deepEqual.js +1 -2
- package/base/lib/util/deepEqual.js.map +1 -1
- package/base/lib/util/deepMerge.js +3 -7
- package/base/lib/util/deepMerge.js.map +1 -1
- package/base/lib/util/getDefaultString.js +1 -2
- package/base/lib/util/getDefaultString.js.map +1 -1
- package/base/lib/util/getRandomCharInSet.js +1 -2
- package/base/lib/util/getRandomCharInSet.js.map +1 -1
- package/base/lib/util/getRandomString.js +1 -2
- package/base/lib/util/getRandomString.js.map +1 -1
- package/base/lib/util/getServiceInterface.d.ts +9 -9
- package/base/lib/util/getServiceInterface.js +35 -20
- package/base/lib/util/getServiceInterface.js.map +1 -1
- package/base/lib/util/getServiceInterfaces.d.ts +7 -3
- package/base/lib/util/getServiceInterfaces.js +25 -19
- package/base/lib/util/getServiceInterfaces.js.map +1 -1
- package/base/lib/util/graph.js.map +1 -1
- package/base/lib/util/index.js +17 -7
- package/base/lib/util/index.js.map +1 -1
- package/base/lib/util/nullIfEmpty.js +1 -2
- package/base/lib/util/nullIfEmpty.js.map +1 -1
- package/base/lib/util/once.js +1 -2
- package/base/lib/util/once.js.map +1 -1
- package/base/lib/util/patterns.d.ts +2 -0
- package/base/lib/util/patterns.js +37 -19
- package/base/lib/util/patterns.js.map +1 -1
- package/base/lib/util/regexes.d.ts +20 -11
- package/base/lib/util/regexes.js +35 -13
- package/base/lib/util/regexes.js.map +1 -1
- package/base/lib/util/stringFromStdErrOut.js +2 -3
- package/base/lib/util/stringFromStdErrOut.js.map +1 -1
- package/package/lib/StartSdk.d.ts +88 -299
- package/package/lib/StartSdk.js +122 -43
- package/package/lib/StartSdk.js.map +1 -1
- package/package/lib/backup/Backups.js +18 -9
- package/package/lib/backup/Backups.js.map +1 -1
- package/package/lib/backup/setupBackups.js +1 -2
- package/package/lib/backup/setupBackups.js.map +1 -1
- package/package/lib/health/HealthCheck.d.ts +17 -3
- package/package/lib/health/HealthCheck.js +98 -36
- package/package/lib/health/HealthCheck.js.map +1 -1
- package/package/lib/health/checkFns/checkPortListening.d.ts +1 -1
- package/package/lib/health/checkFns/checkPortListening.js +28 -19
- package/package/lib/health/checkFns/checkPortListening.js.map +1 -1
- package/package/lib/health/checkFns/index.js +2 -2
- package/package/lib/health/checkFns/index.js.map +1 -1
- package/package/lib/health/index.d.ts +1 -0
- package/package/lib/health/index.js +3 -0
- package/package/lib/health/index.js.map +1 -1
- package/package/lib/index.d.ts +3 -2
- package/package/lib/index.js +19 -9
- package/package/lib/index.js.map +1 -1
- package/package/lib/inits/setupInit.d.ts +1 -1
- package/package/lib/inits/setupInit.js +10 -3
- package/package/lib/inits/setupInit.js.map +1 -1
- package/package/lib/inits/setupInstall.d.ts +4 -2
- package/package/lib/inits/setupInstall.js +14 -7
- package/package/lib/inits/setupInstall.js.map +1 -1
- package/package/lib/inits/setupUninstall.js +2 -2
- package/package/lib/inits/setupUninstall.js.map +1 -1
- package/package/lib/mainFn/CommandController.d.ts +11 -11
- package/package/lib/mainFn/CommandController.js +113 -51
- package/package/lib/mainFn/CommandController.js.map +1 -1
- package/package/lib/mainFn/Daemon.d.ts +7 -9
- package/package/lib/mainFn/Daemon.js +6 -4
- package/package/lib/mainFn/Daemon.js.map +1 -1
- package/package/lib/mainFn/Daemons.d.ts +25 -25
- package/package/lib/mainFn/Daemons.js +43 -28
- package/package/lib/mainFn/Daemons.js.map +1 -1
- package/package/lib/mainFn/HealthDaemon.d.ts +5 -2
- package/package/lib/mainFn/HealthDaemon.js +20 -10
- package/package/lib/mainFn/HealthDaemon.js.map +1 -1
- package/package/lib/mainFn/Mounts.d.ts +1 -4
- package/package/lib/mainFn/Mounts.js +3 -7
- package/package/lib/mainFn/Mounts.js.map +1 -1
- package/package/lib/mainFn/index.js +1 -1
- package/package/lib/mainFn/index.js.map +1 -1
- package/package/lib/manifest/setupManifest.d.ts +2 -4
- package/package/lib/manifest/setupManifest.js +13 -15
- package/package/lib/manifest/setupManifest.js.map +1 -1
- package/package/lib/store/getStore.d.ts +6 -2
- package/package/lib/store/getStore.js +24 -5
- package/package/lib/store/getStore.js.map +1 -1
- package/package/lib/test/host.test.js +1 -2
- package/package/lib/test/host.test.js.map +1 -1
- package/package/lib/test/output.sdk.d.ts +273 -171
- package/package/lib/test/output.test.js +1 -2
- package/package/lib/test/output.test.js.map +1 -1
- package/package/lib/trigger/changeOnFirstSuccess.js +2 -3
- package/package/lib/trigger/changeOnFirstSuccess.js.map +1 -1
- package/package/lib/trigger/cooldownTrigger.js +1 -2
- package/package/lib/trigger/cooldownTrigger.js.map +1 -1
- package/package/lib/trigger/lastStatus.js +2 -4
- package/package/lib/trigger/lastStatus.js.map +1 -1
- package/package/lib/types.d.ts +2 -0
- package/package/lib/types.js +21 -0
- package/package/lib/types.js.map +1 -0
- package/package/lib/util/Drop.d.ts +11 -0
- package/package/lib/util/Drop.js +28 -0
- package/package/lib/util/Drop.js.map +1 -0
- package/package/lib/util/GetSslCertificate.d.ts +7 -3
- package/package/lib/util/GetSslCertificate.js +23 -4
- package/package/lib/util/GetSslCertificate.js.map +1 -1
- package/package/lib/util/SubContainer.d.ts +20 -7
- package/package/lib/util/SubContainer.js +93 -30
- package/package/lib/util/SubContainer.js.map +1 -1
- package/package/lib/util/fileHelper.d.ts +8 -3
- package/package/lib/util/fileHelper.js +103 -31
- package/package/lib/util/fileHelper.js.map +1 -1
- package/package/lib/util/index.d.ts +1 -0
- package/package/lib/util/index.js +3 -1
- package/package/lib/util/index.js.map +1 -1
- package/package/lib/version/VersionGraph.js +8 -4
- package/package/lib/version/VersionGraph.js.map +1 -1
- package/package/scripts/oldSpecToBuilder.js +49 -45
- package/package/scripts/oldSpecToBuilder.js.map +1 -1
- package/package.json +3 -2
- package/base/lib/osBindings/GetPrimaryUrlParams.js.map +0 -1
- package/base/lib/osBindings/HostKind.d.ts +0 -1
- package/base/lib/osBindings/HostKind.js.map +0 -1
- package/base/lib/osBindings/SetPublicParams.js.map +0 -1
|
@@ -15,31 +15,40 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
15
15
|
}) : function(o, v) {
|
|
16
16
|
o["default"] = v;
|
|
17
17
|
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
};
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
25
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.
|
|
36
|
+
exports.containsAddress = containsAddress;
|
|
37
|
+
exports.checkPortListening = checkPortListening;
|
|
27
38
|
const util_1 = require("../../util");
|
|
28
39
|
const node_util_1 = require("node:util");
|
|
29
40
|
const CP = __importStar(require("node:child_process"));
|
|
30
41
|
const cpExec = (0, node_util_1.promisify)(CP.exec);
|
|
31
|
-
function containsAddress(x, port) {
|
|
42
|
+
function containsAddress(x, port, address) {
|
|
32
43
|
const readPorts = x
|
|
33
44
|
.split("\n")
|
|
34
45
|
.filter(Boolean)
|
|
35
46
|
.splice(1)
|
|
36
|
-
.map((x) =>
|
|
37
|
-
.filter(
|
|
38
|
-
.map((
|
|
39
|
-
|
|
40
|
-
return readPorts.indexOf(port) >= 0;
|
|
47
|
+
.map((x) => x.split(" ").filter(Boolean)[1]?.split(":"))
|
|
48
|
+
.filter((x) => x?.length > 1)
|
|
49
|
+
.map(([addr, p]) => [BigInt(`0x${addr}`), Number.parseInt(p, 16)]);
|
|
50
|
+
return !!readPorts.find(([addr, p]) => (address === undefined || address === addr) && port === p);
|
|
41
51
|
}
|
|
42
|
-
exports.containsAddress = containsAddress;
|
|
43
52
|
/**
|
|
44
53
|
* This is used to check if a port is listening on the system.
|
|
45
54
|
* Used during the health check fn or the check main fn.
|
|
@@ -48,7 +57,9 @@ async function checkPortListening(effects, port, options) {
|
|
|
48
57
|
return Promise.race([
|
|
49
58
|
Promise.resolve().then(async () => {
|
|
50
59
|
const hasAddress = containsAddress(await cpExec(`cat /proc/net/tcp`, {}).then(util_1.stringFromStdErrOut), port) ||
|
|
51
|
-
containsAddress(await cpExec(
|
|
60
|
+
containsAddress(await cpExec(`cat /proc/net/tcp6`, {}).then(util_1.stringFromStdErrOut), port, BigInt(0)) ||
|
|
61
|
+
containsAddress(await cpExec("cat /proc/net/udp", {}).then(util_1.stringFromStdErrOut), port) ||
|
|
62
|
+
containsAddress(await cpExec("cat /proc/net/udp6", {}).then(util_1.stringFromStdErrOut), port, BigInt(0));
|
|
52
63
|
if (hasAddress) {
|
|
53
64
|
return { result: "success", message: options.successMessage };
|
|
54
65
|
}
|
|
@@ -58,13 +69,11 @@ async function checkPortListening(effects, port, options) {
|
|
|
58
69
|
};
|
|
59
70
|
}),
|
|
60
71
|
new Promise((resolve) => {
|
|
61
|
-
var _a;
|
|
62
72
|
setTimeout(() => resolve({
|
|
63
73
|
result: "failure",
|
|
64
74
|
message: options.timeoutMessage || `Timeout trying to check port ${port}`,
|
|
65
|
-
}),
|
|
75
|
+
}), options.timeout ?? 1_000);
|
|
66
76
|
}),
|
|
67
77
|
]);
|
|
68
78
|
}
|
|
69
|
-
exports.checkPortListening = checkPortListening;
|
|
70
79
|
//# sourceMappingURL=checkPortListening.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"checkPortListening.js","sourceRoot":"","sources":["../../../../../package/lib/health/checkFns/checkPortListening.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"checkPortListening.js","sourceRoot":"","sources":["../../../../../package/lib/health/checkFns/checkPortListening.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAQA,0CAWC;AAMD,gDAmDC;AA3ED,qCAAgD;AAEhD,yCAAqC;AACrC,uDAAwC;AAExC,MAAM,MAAM,GAAG,IAAA,qBAAS,EAAC,EAAE,CAAC,IAAI,CAAC,CAAA;AAEjC,SAAgB,eAAe,CAAC,CAAS,EAAE,IAAY,EAAE,OAAgB;IACvE,MAAM,SAAS,GAAG,CAAC;SAChB,KAAK,CAAC,IAAI,CAAC;SACX,MAAM,CAAC,OAAO,CAAC;SACf,MAAM,CAAC,CAAC,CAAC;SACT,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;SACvD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC;SAC5B,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,IAAI,EAAE,CAAC,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CAAU,CAAC,CAAA;IAC7E,OAAO,CAAC,CAAC,SAAS,CAAC,IAAI,CACrB,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,KAAK,SAAS,IAAI,OAAO,KAAK,IAAI,CAAC,IAAI,IAAI,KAAK,CAAC,CACzE,CAAA;AACH,CAAC;AAED;;;GAGG;AACI,KAAK,UAAU,kBAAkB,CACtC,OAAgB,EAChB,IAAY,EACZ,OAKC;IAED,OAAO,OAAO,CAAC,IAAI,CAAoB;QACrC,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;YAChC,MAAM,UAAU,GACd,eAAe,CACb,MAAM,MAAM,CAAC,mBAAmB,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,0BAAmB,CAAC,EAC/D,IAAI,CACL;gBACD,eAAe,CACb,MAAM,MAAM,CAAC,oBAAoB,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,0BAAmB,CAAC,EAChE,IAAI,EACJ,MAAM,CAAC,CAAC,CAAC,CACV;gBACD,eAAe,CACb,MAAM,MAAM,CAAC,mBAAmB,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,0BAAmB,CAAC,EAC/D,IAAI,CACL;gBACD,eAAe,CACb,MAAM,MAAM,CAAC,oBAAoB,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,0BAAmB,CAAC,EAChE,IAAI,EACJ,MAAM,CAAC,CAAC,CAAC,CACV,CAAA;YACH,IAAI,UAAU,EAAE,CAAC;gBACf,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC,cAAc,EAAE,CAAA;YAC/D,CAAC;YACD,OAAO;gBACL,MAAM,EAAE,SAAS;gBACjB,OAAO,EAAE,OAAO,CAAC,YAAY;aAC9B,CAAA;QACH,CAAC,CAAC;QACF,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YACtB,UAAU,CACR,GAAG,EAAE,CACH,OAAO,CAAC;gBACN,MAAM,EAAE,SAAS;gBACjB,OAAO,EACL,OAAO,CAAC,cAAc,IAAI,gCAAgC,IAAI,EAAE;aACnE,CAAC,EACJ,OAAO,CAAC,OAAO,IAAI,KAAK,CACzB,CAAA;QACH,CAAC,CAAC;KACH,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.runHealthScript = exports.
|
|
3
|
+
exports.runHealthScript = exports.checkWebUrl = exports.checkPortListening = void 0;
|
|
4
|
+
exports.timeoutPromise = timeoutPromise;
|
|
4
5
|
const runHealthScript_1 = require("./runHealthScript");
|
|
5
6
|
Object.defineProperty(exports, "runHealthScript", { enumerable: true, get: function () { return runHealthScript_1.runHealthScript; } });
|
|
6
7
|
var checkPortListening_1 = require("./checkPortListening");
|
|
@@ -10,5 +11,4 @@ Object.defineProperty(exports, "checkWebUrl", { enumerable: true, get: function
|
|
|
10
11
|
function timeoutPromise(ms, { message = "Timed out" } = {}) {
|
|
11
12
|
return new Promise((resolve, reject) => setTimeout(() => reject(new Error(message)), ms));
|
|
12
13
|
}
|
|
13
|
-
exports.timeoutPromise = timeoutPromise;
|
|
14
14
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../package/lib/health/checkFns/index.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../package/lib/health/checkFns/index.ts"],"names":[],"mappings":";;;AAKA,wCAIC;AATD,uDAAmD;AAU1C,gGAVA,iCAAe,OAUA;AATxB,2DAAyD;AAAhD,wHAAA,kBAAkB,OAAA;AAE3B,6CAA2C;AAAlC,0GAAA,WAAW,OAAA;AAEpB,SAAgB,cAAc,CAAC,EAAU,EAAE,EAAE,OAAO,GAAG,WAAW,EAAE,GAAG,EAAE;IACvE,OAAO,IAAI,OAAO,CAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,CAC5C,UAAU,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,CAAC,CACjD,CAAA;AACH,CAAC"}
|
|
@@ -1,4 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.HealthCheck = void 0;
|
|
3
4
|
require("./checkFns");
|
|
5
|
+
var HealthCheck_1 = require("./HealthCheck");
|
|
6
|
+
Object.defineProperty(exports, "HealthCheck", { enumerable: true, get: function () { return HealthCheck_1.HealthCheck; } });
|
|
4
7
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../package/lib/health/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../package/lib/health/index.ts"],"names":[],"mappings":";;;AAAA,sBAAmB;AAEnB,6CAA2C;AAAlC,0GAAA,WAAW,OAAA"}
|
package/package/lib/index.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { S9pk, Version, VersionRange, ExtendedVersion, inputSpec, ISB, IST, types,
|
|
2
|
-
export { S9pk, Version, VersionRange, ExtendedVersion, inputSpec, ISB, IST, types,
|
|
1
|
+
import { S9pk, Version, VersionRange, ExtendedVersion, inputSpec, ISB, IST, types, matches, utils } from "../../base/lib";
|
|
2
|
+
export { S9pk, Version, VersionRange, ExtendedVersion, inputSpec, ISB, IST, types, matches, utils, };
|
|
3
|
+
export * as T from "./types";
|
|
3
4
|
export { Daemons } from "./mainFn/Daemons";
|
|
4
5
|
export { SubContainer } from "./util/SubContainer";
|
|
5
6
|
export { StartSdk } from "./StartSdk";
|
package/package/lib/index.js
CHANGED
|
@@ -15,18 +15,28 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
15
15
|
}) : function(o, v) {
|
|
16
16
|
o["default"] = v;
|
|
17
17
|
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
};
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
25
35
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
26
36
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
27
37
|
};
|
|
28
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.TOML = exports.YAML = exports.startSdk = exports.yaml = exports.toml = exports.mainFn = exports.inits = exports.healthFns = exports.health = exports.daemons = exports.backup = exports.actions = exports.pathBuilder = exports.setupExposeStore = exports.FileHelper = exports.buildManifest = exports.setupManifest = exports.StartSdk = exports.SubContainer = exports.Daemons = exports.
|
|
39
|
+
exports.TOML = exports.YAML = exports.startSdk = exports.yaml = exports.toml = exports.mainFn = exports.inits = exports.healthFns = exports.health = exports.daemons = exports.backup = exports.actions = exports.pathBuilder = exports.setupExposeStore = exports.FileHelper = exports.buildManifest = exports.setupManifest = exports.StartSdk = exports.SubContainer = exports.Daemons = exports.T = exports.utils = exports.matches = exports.types = exports.IST = exports.ISB = exports.inputSpec = exports.ExtendedVersion = exports.VersionRange = exports.Version = exports.S9pk = void 0;
|
|
30
40
|
const lib_1 = require("../../base/lib");
|
|
31
41
|
Object.defineProperty(exports, "S9pk", { enumerable: true, get: function () { return lib_1.S9pk; } });
|
|
32
42
|
Object.defineProperty(exports, "Version", { enumerable: true, get: function () { return lib_1.Version; } });
|
|
@@ -36,9 +46,9 @@ Object.defineProperty(exports, "inputSpec", { enumerable: true, get: function ()
|
|
|
36
46
|
Object.defineProperty(exports, "ISB", { enumerable: true, get: function () { return lib_1.ISB; } });
|
|
37
47
|
Object.defineProperty(exports, "IST", { enumerable: true, get: function () { return lib_1.IST; } });
|
|
38
48
|
Object.defineProperty(exports, "types", { enumerable: true, get: function () { return lib_1.types; } });
|
|
39
|
-
Object.defineProperty(exports, "T", { enumerable: true, get: function () { return lib_1.T; } });
|
|
40
49
|
Object.defineProperty(exports, "matches", { enumerable: true, get: function () { return lib_1.matches; } });
|
|
41
50
|
Object.defineProperty(exports, "utils", { enumerable: true, get: function () { return lib_1.utils; } });
|
|
51
|
+
exports.T = __importStar(require("./types"));
|
|
42
52
|
var Daemons_1 = require("./mainFn/Daemons");
|
|
43
53
|
Object.defineProperty(exports, "Daemons", { enumerable: true, get: function () { return Daemons_1.Daemons; } });
|
|
44
54
|
var SubContainer_1 = require("./util/SubContainer");
|
package/package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../package/lib/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../package/lib/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,wCAWuB;AAGrB,qFAbA,UAAI,OAaA;AACJ,wFAbA,aAAO,OAaA;AACP,6FAbA,kBAAY,OAaA;AACZ,gGAbA,qBAAe,OAaA;AACf,0FAbA,eAAS,OAaA;AACT,oFAbA,SAAG,OAaA;AACH,oFAbA,SAAG,OAaA;AACH,sFAbA,WAAK,OAaA;AACL,wFAbA,aAAO,OAaA;AACP,sFAbA,WAAK,OAaA;AAEP,6CAA4B;AAC5B,4CAA0C;AAAjC,kGAAA,OAAO,OAAA;AAChB,oDAAkD;AAAzC,4GAAA,YAAY,OAAA;AACrB,uCAAqC;AAA5B,oGAAA,QAAQ,OAAA;AACjB,0DAAuE;AAA9D,8GAAA,aAAa,OAAA;AAAE,8GAAA,aAAa,OAAA;AACrC,gDAA8C;AAArC,wGAAA,UAAU,OAAA;AACnB,6DAA2D;AAAlD,oHAAA,gBAAgB,OAAA;AACzB,+DAA6D;AAApD,0GAAA,WAAW,OAAA;AAEpB,kEAAiD;AACjD,mDAAkC;AAClC,4DAA2C;AAC3C,mDAAkC;AAClC,+DAA8C;AAC9C,iDAAgC;AAChC,mDAAkC;AAClC,oDAAmC;AACnC,6CAA4B;AAC5B,uDAAsC;AACtC,6CAA4B;AAC5B,oDAAmC;AACnC,4CAAyB"}
|
|
@@ -7,7 +7,7 @@ import { Install } from "./setupInstall";
|
|
|
7
7
|
import { Uninstall } from "./setupUninstall";
|
|
8
8
|
export declare function setupInit<Manifest extends T.SDKManifest, Store>(versions: VersionGraph<string>, install: Install<Manifest, Store>, uninstall: Uninstall<Manifest, Store>, setServiceInterfaces: UpdateServiceInterfaces<any>, setDependencies: (options: {
|
|
9
9
|
effects: T.Effects;
|
|
10
|
-
}) => Promise<null | void | undefined>, actions: Actions<Store, any>, exposedStore: ExposedStorePaths): {
|
|
10
|
+
}) => Promise<null | void | undefined>, actions: Actions<Store, any>, initStore: Store, exposedStore: ExposedStorePaths): {
|
|
11
11
|
packageInit: T.ExpectedExports.packageInit;
|
|
12
12
|
packageUninit: T.ExpectedExports.packageUninit;
|
|
13
13
|
containerInit: T.ExpectedExports.containerInit;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.setupInit =
|
|
3
|
+
exports.setupInit = setupInit;
|
|
4
4
|
const exver_1 = require("../../../base/lib/exver");
|
|
5
|
-
function setupInit(versions, install, uninstall, setServiceInterfaces, setDependencies, actions, exposedStore) {
|
|
5
|
+
function setupInit(versions, install, uninstall, setServiceInterfaces, setDependencies, actions, initStore, exposedStore) {
|
|
6
6
|
return {
|
|
7
7
|
packageInit: async (opts) => {
|
|
8
8
|
const prev = await opts.effects.getDataVersion();
|
|
@@ -36,6 +36,14 @@ function setupInit(versions, install, uninstall, setServiceInterfaces, setDepend
|
|
|
36
36
|
}
|
|
37
37
|
},
|
|
38
38
|
containerInit: async (opts) => {
|
|
39
|
+
const prev = await opts.effects.getDataVersion();
|
|
40
|
+
if (!prev) {
|
|
41
|
+
await opts.effects.store.set({
|
|
42
|
+
path: "",
|
|
43
|
+
value: initStore,
|
|
44
|
+
});
|
|
45
|
+
await install.preInstall(opts);
|
|
46
|
+
}
|
|
39
47
|
await setServiceInterfaces({
|
|
40
48
|
...opts,
|
|
41
49
|
});
|
|
@@ -45,5 +53,4 @@ function setupInit(versions, install, uninstall, setServiceInterfaces, setDepend
|
|
|
45
53
|
},
|
|
46
54
|
};
|
|
47
55
|
}
|
|
48
|
-
exports.setupInit = setupInit;
|
|
49
56
|
//# sourceMappingURL=setupInit.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupInit.js","sourceRoot":"","sources":["../../../../package/lib/inits/setupInit.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"setupInit.js","sourceRoot":"","sources":["../../../../package/lib/inits/setupInit.ts"],"names":[],"mappings":";;AAUA,8BA+DC;AAxED,mDAAyD;AASzD,SAAgB,SAAS,CACvB,QAA8B,EAC9B,OAAiC,EACjC,SAAqC,EACrC,oBAAkD,EAClD,eAEsC,EACtC,OAA4B,EAC5B,SAAgB,EAChB,YAA+B;IAM/B,OAAO;QACL,WAAW,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YAC1B,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAA;YAChD,IAAI,IAAI,EAAE,CAAC;gBACT,MAAM,QAAQ,CAAC,OAAO,CAAC;oBACrB,OAAO,EAAE,IAAI,CAAC,OAAO;oBACrB,IAAI,EAAE,uBAAe,CAAC,KAAK,CAAC,IAAI,CAAC;oBACjC,EAAE,EAAE,QAAQ,CAAC,cAAc,EAAE;iBAC9B,CAAC,CAAA;YACJ,CAAC;iBAAM,CAAC;gBACN,MAAM,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;gBAC3B,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC;oBAChC,OAAO,EAAE,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO;iBAC1C,CAAC,CAAA;YACJ,CAAC;QACH,CAAC;QACD,aAAa,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YAC5B,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;gBACrB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAA;gBAChD,IAAI,IAAI,EAAE,CAAC;oBACT,MAAM,QAAQ,CAAC,OAAO,CAAC;wBACrB,OAAO,EAAE,IAAI,CAAC,OAAO;wBACrB,IAAI,EAAE,uBAAe,CAAC,KAAK,CAAC,IAAI,CAAC;wBACjC,EAAE,EAAE,uBAAe,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC;qBAC5C,CAAC,CAAA;gBACJ,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,MAAM,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;YACjC,CAAC;QACH,CAAC;QACD,aAAa,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YAC5B,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAA;YAChD,IAAI,CAAC,IAAI,EAAE,CAAC;gBACV,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC;oBAC3B,IAAI,EAAE,EAAe;oBACrB,KAAK,EAAE,SAAS;iBACjB,CAAC,CAAA;gBACF,MAAM,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;YAChC,CAAC;YACD,MAAM,oBAAoB,CAAC;gBACzB,GAAG,IAAI;aACR,CAAC,CAAA;YACF,MAAM,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAA;YAC/C,MAAM,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAA;YAC/D,MAAM,eAAe,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAA;QAClD,CAAC;KACF,CAAA;AACH,CAAC"}
|
|
@@ -4,8 +4,10 @@ export type InstallFn<Manifest extends T.SDKManifest, Store> = (opts: {
|
|
|
4
4
|
}) => Promise<null | void | undefined>;
|
|
5
5
|
export declare class Install<Manifest extends T.SDKManifest, Store> {
|
|
6
6
|
readonly fn: InstallFn<Manifest, Store>;
|
|
7
|
+
readonly preFn?: InstallFn<Manifest, Store> | undefined;
|
|
7
8
|
private constructor();
|
|
8
|
-
static of<Manifest extends T.SDKManifest, Store>(fn: InstallFn<Manifest, Store>): Install<Manifest, Store>;
|
|
9
|
+
static of<Manifest extends T.SDKManifest, Store>(fn: InstallFn<Manifest, Store>, preFn?: InstallFn<Manifest, Store>): Install<Manifest, Store>;
|
|
9
10
|
install({ effects }: Parameters<T.ExpectedExports.packageInit>[0]): Promise<void>;
|
|
11
|
+
preInstall({ effects }: Parameters<T.ExpectedExports.packageInit>[0]): Promise<void>;
|
|
10
12
|
}
|
|
11
|
-
export declare function setupInstall<Manifest extends T.SDKManifest, Store>(fn: InstallFn<Manifest, Store>): Install<Manifest, Store>;
|
|
13
|
+
export declare function setupInstall<Manifest extends T.SDKManifest, Store>(fn: InstallFn<Manifest, Store>, preFn?: InstallFn<Manifest, Store>): Install<Manifest, Store>;
|
|
@@ -1,22 +1,29 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.Install = void 0;
|
|
4
|
+
exports.setupInstall = setupInstall;
|
|
4
5
|
class Install {
|
|
5
|
-
constructor(fn) {
|
|
6
|
+
constructor(fn, preFn) {
|
|
6
7
|
this.fn = fn;
|
|
8
|
+
this.preFn = preFn;
|
|
7
9
|
}
|
|
8
|
-
static of(fn) {
|
|
9
|
-
return new Install(fn);
|
|
10
|
+
static of(fn, preFn) {
|
|
11
|
+
return new Install(fn, preFn);
|
|
10
12
|
}
|
|
11
13
|
async install({ effects }) {
|
|
12
14
|
await this.fn({
|
|
13
15
|
effects,
|
|
14
16
|
});
|
|
15
17
|
}
|
|
18
|
+
async preInstall({ effects }) {
|
|
19
|
+
this.preFn &&
|
|
20
|
+
(await this.preFn({
|
|
21
|
+
effects,
|
|
22
|
+
}));
|
|
23
|
+
}
|
|
16
24
|
}
|
|
17
25
|
exports.Install = Install;
|
|
18
|
-
function setupInstall(fn) {
|
|
19
|
-
return Install.of(fn);
|
|
26
|
+
function setupInstall(fn, preFn) {
|
|
27
|
+
return Install.of(fn, preFn);
|
|
20
28
|
}
|
|
21
|
-
exports.setupInstall = setupInstall;
|
|
22
29
|
//# sourceMappingURL=setupInstall.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupInstall.js","sourceRoot":"","sources":["../../../../package/lib/inits/setupInstall.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"setupInstall.js","sourceRoot":"","sources":["../../../../package/lib/inits/setupInstall.ts"],"names":[],"mappings":";;;AA+BA,oCAKC;AA/BD,MAAa,OAAO;IAClB,YACW,EAA8B,EAC9B,KAAkC;QADlC,OAAE,GAAF,EAAE,CAA4B;QAC9B,UAAK,GAAL,KAAK,CAA6B;IAC1C,CAAC;IACJ,MAAM,CAAC,EAAE,CACP,EAA8B,EAC9B,KAAkC;QAElC,OAAO,IAAI,OAAO,CAAC,EAAE,EAAE,KAAK,CAAC,CAAA;IAC/B,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,EAAE,OAAO,EAAgD;QACrE,MAAM,IAAI,CAAC,EAAE,CAAC;YACZ,OAAO;SACR,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,EAAE,OAAO,EAAgD;QACxE,IAAI,CAAC,KAAK;YACR,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC;gBAChB,OAAO;aACR,CAAC,CAAC,CAAA;IACP,CAAC;CACF;AAxBD,0BAwBC;AAED,SAAgB,YAAY,CAC1B,EAA8B,EAC9B,KAAkC;IAElC,OAAO,OAAO,CAAC,EAAE,CAAC,EAAE,EAAE,KAAK,CAAC,CAAA;AAC9B,CAAC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.Uninstall = void 0;
|
|
4
|
+
exports.setupUninstall = setupUninstall;
|
|
4
5
|
class Uninstall {
|
|
5
6
|
constructor(fn) {
|
|
6
7
|
this.fn = fn;
|
|
@@ -19,5 +20,4 @@ exports.Uninstall = Uninstall;
|
|
|
19
20
|
function setupUninstall(fn) {
|
|
20
21
|
return Uninstall.of(fn);
|
|
21
22
|
}
|
|
22
|
-
exports.setupUninstall = setupUninstall;
|
|
23
23
|
//# sourceMappingURL=setupUninstall.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupUninstall.js","sourceRoot":"","sources":["../../../../package/lib/inits/setupUninstall.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"setupUninstall.js","sourceRoot":"","sources":["../../../../package/lib/inits/setupUninstall.ts"],"names":[],"mappings":";;;AAwBA,wCAIC;AAvBD,MAAa,SAAS;IACpB,YAA6B,EAAgC;QAAhC,OAAE,GAAF,EAAE,CAA8B;IAAG,CAAC;IACjE,MAAM,CAAC,EAAE,CACP,EAAgC;QAEhC,OAAO,IAAI,SAAS,CAAC,EAAE,CAAC,CAAA;IAC1B,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,EACd,OAAO,EACP,WAAW,GACoC;QAC/C,IAAI,CAAC,WAAW;YACd,MAAM,IAAI,CAAC,EAAE,CAAC;gBACZ,OAAO;aACR,CAAC,CAAA;IACN,CAAC;CACF;AAjBD,8BAiBC;AAED,SAAgB,cAAc,CAC5B,EAAgC;IAEhC,OAAO,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,CAAA;AACzB,CAAC"}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
/// <reference types="node" />
|
|
3
1
|
import * as T from "../../../base/lib/types";
|
|
4
2
|
import { MountOptions, SubContainerHandle, SubContainer } from "../util/SubContainer";
|
|
5
|
-
|
|
3
|
+
import { Drop } from "../util";
|
|
4
|
+
export declare class CommandController extends Drop {
|
|
6
5
|
readonly runningAnswer: Promise<unknown>;
|
|
7
6
|
private state;
|
|
8
7
|
private readonly subcontainer;
|
|
@@ -10,23 +9,23 @@ export declare class CommandController {
|
|
|
10
9
|
readonly sigtermTimeout: number;
|
|
11
10
|
private constructor();
|
|
12
11
|
static of<Manifest extends T.SDKManifest>(): <A extends string>(effects: T.Effects, subcontainer: {
|
|
13
|
-
|
|
12
|
+
imageId: keyof Manifest["images"] & T.ImageId;
|
|
14
13
|
sharedRun?: boolean;
|
|
15
14
|
} | SubContainer, command: T.CommandType, options: {
|
|
16
|
-
subcontainerName?: string
|
|
17
|
-
sigtermTimeout?: number
|
|
15
|
+
subcontainerName?: string;
|
|
16
|
+
sigtermTimeout?: number;
|
|
18
17
|
mounts?: {
|
|
19
|
-
|
|
18
|
+
mountpoint: string;
|
|
20
19
|
options: MountOptions;
|
|
21
|
-
}[]
|
|
22
|
-
runAsInit?: boolean
|
|
20
|
+
}[];
|
|
21
|
+
runAsInit?: boolean;
|
|
23
22
|
env?: {
|
|
24
23
|
[variable: string]: string;
|
|
25
24
|
} | undefined;
|
|
26
25
|
cwd?: string | undefined;
|
|
27
26
|
user?: string | undefined;
|
|
28
|
-
onStdout?: (
|
|
29
|
-
onStderr?: (
|
|
27
|
+
onStdout?: (chunk: Buffer | string | any) => void;
|
|
28
|
+
onStderr?: (chunk: Buffer | string | any) => void;
|
|
30
29
|
}) => Promise<CommandController>;
|
|
31
30
|
get subContainerHandle(): SubContainerHandle;
|
|
32
31
|
wait({ timeout }?: {
|
|
@@ -36,4 +35,5 @@ export declare class CommandController {
|
|
|
36
35
|
signal?: NodeJS.Signals | undefined;
|
|
37
36
|
timeout?: number | undefined;
|
|
38
37
|
}): Promise<void>;
|
|
38
|
+
onDrop(): void;
|
|
39
39
|
}
|
|
@@ -1,12 +1,48 @@
|
|
|
1
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 () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
2
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
36
|
exports.CommandController = void 0;
|
|
4
37
|
const _1 = require(".");
|
|
5
38
|
const types_1 = require("../../../base/lib/types");
|
|
39
|
+
const T = __importStar(require("../../../base/lib/types"));
|
|
6
40
|
const SubContainer_1 = require("../util/SubContainer");
|
|
7
41
|
const util_1 = require("../util");
|
|
8
|
-
|
|
42
|
+
const fs = __importStar(require("node:fs/promises"));
|
|
43
|
+
class CommandController extends util_1.Drop {
|
|
9
44
|
constructor(runningAnswer, state, subcontainer, process, sigtermTimeout = _1.DEFAULT_SIGTERM_TIMEOUT) {
|
|
45
|
+
super();
|
|
10
46
|
this.runningAnswer = runningAnswer;
|
|
11
47
|
this.state = state;
|
|
12
48
|
this.subcontainer = subcontainer;
|
|
@@ -15,92 +51,118 @@ class CommandController {
|
|
|
15
51
|
}
|
|
16
52
|
static of() {
|
|
17
53
|
return async (effects, subcontainer, command, options) => {
|
|
18
|
-
|
|
19
|
-
|
|
54
|
+
let commands;
|
|
55
|
+
if (command instanceof T.UseEntrypoint) {
|
|
56
|
+
const imageMeta = await fs
|
|
57
|
+
.readFile(`/media/startos/images/${subcontainer.imageId}.json`, {
|
|
58
|
+
encoding: "utf8",
|
|
59
|
+
})
|
|
60
|
+
.catch(() => "{}")
|
|
61
|
+
.then(JSON.parse);
|
|
62
|
+
commands = imageMeta.entrypoint ?? [];
|
|
63
|
+
commands.concat(...(command.overridCmd ?? imageMeta.cmd ?? []));
|
|
64
|
+
}
|
|
65
|
+
else
|
|
66
|
+
commands = (0, util_1.splitCommand)(command);
|
|
20
67
|
const subc = subcontainer instanceof SubContainer_1.SubContainer
|
|
21
68
|
? subcontainer
|
|
22
69
|
: await (async () => {
|
|
23
|
-
const subc = await SubContainer_1.SubContainer.of(effects, subcontainer,
|
|
24
|
-
|
|
25
|
-
|
|
70
|
+
const subc = await SubContainer_1.SubContainer.of(effects, subcontainer, options?.subcontainerName || commands.join(" "));
|
|
71
|
+
try {
|
|
72
|
+
for (let mount of options.mounts || []) {
|
|
73
|
+
await subc.mount(mount.options, mount.mountpoint);
|
|
74
|
+
}
|
|
75
|
+
return subc;
|
|
76
|
+
}
|
|
77
|
+
catch (e) {
|
|
78
|
+
await subc.destroy();
|
|
79
|
+
throw e;
|
|
26
80
|
}
|
|
27
|
-
return subc;
|
|
28
81
|
})();
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
82
|
+
try {
|
|
83
|
+
let childProcess;
|
|
84
|
+
if (options.runAsInit) {
|
|
85
|
+
childProcess = await subc.launch(commands, {
|
|
86
|
+
env: options.env,
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
childProcess = await subc.spawn(commands, {
|
|
91
|
+
env: options.env,
|
|
92
|
+
stdio: options.onStdout || options.onStderr ? "pipe" : "inherit",
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
if (options.onStdout)
|
|
96
|
+
childProcess.stdout?.on("data", options.onStdout);
|
|
97
|
+
if (options.onStderr)
|
|
98
|
+
childProcess.stderr?.on("data", options.onStderr);
|
|
99
|
+
const state = { exited: false };
|
|
100
|
+
const answer = new Promise((resolve, reject) => {
|
|
101
|
+
childProcess.on("exit", (code) => {
|
|
102
|
+
state.exited = true;
|
|
103
|
+
if (code === 0 ||
|
|
104
|
+
code === 143 ||
|
|
105
|
+
(code === null && childProcess.signalCode == "SIGTERM")) {
|
|
106
|
+
return resolve(null);
|
|
107
|
+
}
|
|
108
|
+
if (code) {
|
|
109
|
+
return reject(new Error(`${commands[0]} exited with code ${code}`));
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
return reject(new Error(`${commands[0]} exited with signal ${childProcess.signalCode}`));
|
|
113
|
+
}
|
|
114
|
+
});
|
|
33
115
|
});
|
|
116
|
+
return new CommandController(answer, state, subc, childProcess, options.sigtermTimeout);
|
|
34
117
|
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
stdio: options.onStdout || options.onStderr ? "pipe" : "inherit",
|
|
39
|
-
});
|
|
118
|
+
catch (e) {
|
|
119
|
+
await subc.destroy();
|
|
120
|
+
throw e;
|
|
40
121
|
}
|
|
41
|
-
if (options.onStdout)
|
|
42
|
-
(_a = childProcess.stdout) === null || _a === void 0 ? void 0 : _a.on("data", options.onStdout);
|
|
43
|
-
if (options.onStderr)
|
|
44
|
-
(_b = childProcess.stderr) === null || _b === void 0 ? void 0 : _b.on("data", options.onStderr);
|
|
45
|
-
const state = { exited: false };
|
|
46
|
-
const answer = new Promise((resolve, reject) => {
|
|
47
|
-
childProcess.on("exit", (code) => {
|
|
48
|
-
state.exited = true;
|
|
49
|
-
if (code === 0 ||
|
|
50
|
-
code === 143 ||
|
|
51
|
-
(code === null && childProcess.signalCode == "SIGTERM")) {
|
|
52
|
-
return resolve(null);
|
|
53
|
-
}
|
|
54
|
-
if (code) {
|
|
55
|
-
return reject(new Error(`${commands[0]} exited with code ${code}`));
|
|
56
|
-
}
|
|
57
|
-
else {
|
|
58
|
-
return reject(new Error(`${commands[0]} exited with signal ${childProcess.signalCode}`));
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
});
|
|
62
|
-
return new CommandController(answer, state, subc, childProcess, options.sigtermTimeout);
|
|
63
122
|
};
|
|
64
123
|
}
|
|
65
124
|
get subContainerHandle() {
|
|
66
125
|
return new SubContainer_1.SubContainerHandle(this.subcontainer);
|
|
67
126
|
}
|
|
68
127
|
async wait({ timeout = types_1.NO_TIMEOUT } = {}) {
|
|
69
|
-
|
|
128
|
+
const self = this.weak();
|
|
70
129
|
if (timeout > 0)
|
|
71
130
|
setTimeout(() => {
|
|
72
|
-
|
|
131
|
+
self.term();
|
|
73
132
|
}, timeout);
|
|
74
133
|
try {
|
|
75
|
-
return await
|
|
134
|
+
return await self.runningAnswer;
|
|
76
135
|
}
|
|
77
136
|
finally {
|
|
78
|
-
if (!
|
|
79
|
-
|
|
137
|
+
if (!self.state.exited) {
|
|
138
|
+
self.process.kill("SIGKILL");
|
|
80
139
|
}
|
|
81
|
-
await
|
|
140
|
+
await self.subcontainer.destroy().catch((_) => { });
|
|
82
141
|
}
|
|
83
142
|
}
|
|
84
143
|
async term({ signal = types_1.SIGTERM, timeout = this.sigtermTimeout } = {}) {
|
|
85
|
-
|
|
144
|
+
const self = this.weak();
|
|
86
145
|
try {
|
|
87
|
-
if (!
|
|
146
|
+
if (!self.state.exited) {
|
|
88
147
|
if (signal !== "SIGKILL") {
|
|
89
148
|
setTimeout(() => {
|
|
90
|
-
if (!
|
|
91
|
-
|
|
149
|
+
if (!self.state.exited)
|
|
150
|
+
self.process.kill("SIGKILL");
|
|
92
151
|
}, timeout);
|
|
93
152
|
}
|
|
94
|
-
if (!
|
|
153
|
+
if (!self.process.kill(signal)) {
|
|
95
154
|
console.error(`failed to send signal ${signal} to pid ${this.process.pid}`);
|
|
96
155
|
}
|
|
97
156
|
}
|
|
98
|
-
await
|
|
157
|
+
await self.runningAnswer;
|
|
99
158
|
}
|
|
100
159
|
finally {
|
|
101
|
-
await
|
|
160
|
+
await self.subcontainer.destroy();
|
|
102
161
|
}
|
|
103
162
|
}
|
|
163
|
+
onDrop() {
|
|
164
|
+
this.term().catch(console.error);
|
|
165
|
+
}
|
|
104
166
|
}
|
|
105
167
|
exports.CommandController = CommandController;
|
|
106
168
|
//# sourceMappingURL=CommandController.js.map
|