@start9labs/start-sdk 0.3.6-beta.9 → 0.4.0-beta.0
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 +7 -2
- 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.js +85 -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/inputSpecTypes.js +1 -2
- package/base/lib/actions/input/inputSpecTypes.js.map +1 -1
- 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.js +1 -2
- 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 +0 -18
- package/base/lib/interfaces/Host.js +0 -12
- package/base/lib/interfaces/Host.js.map +1 -1
- package/base/lib/interfaces/Origin.js.map +1 -1
- package/base/lib/osBindings/Celsius.d.ts +1 -0
- package/base/lib/osBindings/Celsius.js +4 -0
- package/base/lib/osBindings/Celsius.js.map +1 -0
- package/base/lib/osBindings/GetContainerIpParams.d.ts +6 -0
- 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/GigaBytes.js +4 -0
- package/base/lib/osBindings/GigaBytes.js.map +1 -0
- package/base/lib/osBindings/ImageMetadata.d.ts +2 -0
- package/base/lib/osBindings/IpInfo.d.ts +1 -0
- package/base/lib/osBindings/LoginParams.d.ts +0 -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/Metrics.js +3 -0
- 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/NetworkInterfaceInfo.d.ts +2 -1
- 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/PackageVersionInfo.d.ts +1 -1
- 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 -13
- package/base/lib/osBindings/Session.d.ts +1 -1
- package/base/lib/osBindings/Sessions.d.ts +1 -1
- 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/WifiInfo.d.ts +1 -0
- package/base/lib/osBindings/index.d.ts +13 -2
- package/base/lib/s9pk/index.d.ts +8 -1
- package/base/lib/s9pk/index.js +54 -11
- 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 -6
- package/base/lib/types.js +25 -9
- package/base/lib/types.js.map +1 -1
- package/base/lib/util/GetSystemSmtp.js +2 -1
- 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 +2 -0
- package/base/lib/util/getServiceInterface.js +11 -5
- package/base/lib/util/getServiceInterface.js.map +1 -1
- package/base/lib/util/getServiceInterfaces.js +4 -3
- 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.js +17 -7
- package/base/lib/util/patterns.js.map +1 -1
- 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 +136 -196
- package/package/lib/StartSdk.js +111 -24
- 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 +16 -3
- package/package/lib/health/HealthCheck.js +98 -36
- package/package/lib/health/HealthCheck.js.map +1 -1
- package/package/lib/health/checkFns/checkPortListening.js +22 -14
- 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 +3 -3
- package/package/lib/inits/setupInit.js +11 -4
- package/package/lib/inits/setupInit.js.map +1 -1
- package/package/lib/inits/setupInstall.d.ts +12 -3
- package/package/lib/inits/setupInstall.js +31 -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 +10 -10
- package/package/lib/mainFn/CommandController.js +78 -20
- package/package/lib/mainFn/CommandController.js.map +1 -1
- package/package/lib/mainFn/Daemon.d.ts +6 -8
- package/package/lib/mainFn/Daemon.js +4 -4
- package/package/lib/mainFn/Daemon.js.map +1 -1
- package/package/lib/mainFn/Daemons.d.ts +18 -14
- package/package/lib/mainFn/Daemons.js +43 -27
- package/package/lib/mainFn/Daemons.js.map +1 -1
- package/package/lib/mainFn/HealthDaemon.d.ts +2 -2
- package/package/lib/mainFn/HealthDaemon.js +12 -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.js +4 -3
- package/package/lib/store/getStore.js.map +1 -1
- package/package/lib/test/output.js +386 -297
- package/package/lib/test/output.js.map +1 -1
- package/package/lib/test/output.sdk.d.ts +349 -167
- 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.js +2 -1
- package/package/lib/util/GetSslCertificate.js.map +1 -1
- package/package/lib/util/SubContainer.d.ts +18 -5
- package/package/lib/util/SubContainer.js +91 -28
- package/package/lib/util/SubContainer.js.map +1 -1
- package/package/lib/util/fileHelper.d.ts +5 -2
- package/package/lib/util/fileHelper.js +68 -21
- 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 +6 -2
|
@@ -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"}
|
|
@@ -3,11 +3,11 @@ import { UpdateServiceInterfaces } from "../../../base/lib/interfaces/setupInter
|
|
|
3
3
|
import { ExposedStorePaths } from "../../../base/lib/types";
|
|
4
4
|
import * as T from "../../../base/lib/types";
|
|
5
5
|
import { VersionGraph } from "../version/VersionGraph";
|
|
6
|
-
import {
|
|
6
|
+
import { PostInstall, PreInstall } from "./setupInstall";
|
|
7
7
|
import { Uninstall } from "./setupUninstall";
|
|
8
|
-
export declare function setupInit<Manifest extends T.SDKManifest, Store>(versions: VersionGraph<string>,
|
|
8
|
+
export declare function setupInit<Manifest extends T.SDKManifest, Store>(versions: VersionGraph<string>, preInstall: PreInstall<Manifest, Store>, postInstall: PostInstall<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,
|
|
5
|
+
function setupInit(versions, preInstall, postInstall, uninstall, setServiceInterfaces, setDependencies, actions, initStore, exposedStore) {
|
|
6
6
|
return {
|
|
7
7
|
packageInit: async (opts) => {
|
|
8
8
|
const prev = await opts.effects.getDataVersion();
|
|
@@ -14,7 +14,7 @@ function setupInit(versions, install, uninstall, setServiceInterfaces, setDepend
|
|
|
14
14
|
});
|
|
15
15
|
}
|
|
16
16
|
else {
|
|
17
|
-
await
|
|
17
|
+
await postInstall.postInstall(opts);
|
|
18
18
|
await opts.effects.setDataVersion({
|
|
19
19
|
version: versions.current.options.version,
|
|
20
20
|
});
|
|
@@ -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 preInstall.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,8BAgEC;AAzED,mDAAyD;AASzD,SAAgB,SAAS,CACvB,QAA8B,EAC9B,UAAuC,EACvC,WAAyC,EACzC,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,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;gBACnC,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,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;YACnC,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,17 @@ 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
|
+
protected constructor(fn: InstallFn<Manifest, Store>);
|
|
8
|
+
}
|
|
9
|
+
export declare class PreInstall<Manifest extends T.SDKManifest, Store> extends Install<Manifest, Store> {
|
|
10
|
+
private constructor();
|
|
11
|
+
static of<Manifest extends T.SDKManifest, Store>(fn: InstallFn<Manifest, Store>): PreInstall<Manifest, Store>;
|
|
12
|
+
preInstall({ effects }: Parameters<T.ExpectedExports.packageInit>[0]): Promise<void>;
|
|
13
|
+
}
|
|
14
|
+
export declare function setupPreInstall<Manifest extends T.SDKManifest, Store>(fn: InstallFn<Manifest, Store>): PreInstall<Manifest, Store>;
|
|
15
|
+
export declare class PostInstall<Manifest extends T.SDKManifest, Store> extends Install<Manifest, Store> {
|
|
7
16
|
private constructor();
|
|
8
|
-
static of<Manifest extends T.SDKManifest, Store>(fn: InstallFn<Manifest, Store>):
|
|
9
|
-
|
|
17
|
+
static of<Manifest extends T.SDKManifest, Store>(fn: InstallFn<Manifest, Store>): PostInstall<Manifest, Store>;
|
|
18
|
+
postInstall({ effects }: Parameters<T.ExpectedExports.packageInit>[0]): Promise<void>;
|
|
10
19
|
}
|
|
11
|
-
export declare function
|
|
20
|
+
export declare function setupPostInstall<Manifest extends T.SDKManifest, Store>(fn: InstallFn<Manifest, Store>): PostInstall<Manifest, Store>;
|
|
@@ -1,22 +1,46 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.PostInstall = exports.PreInstall = exports.Install = void 0;
|
|
4
|
+
exports.setupPreInstall = setupPreInstall;
|
|
5
|
+
exports.setupPostInstall = setupPostInstall;
|
|
4
6
|
class Install {
|
|
5
7
|
constructor(fn) {
|
|
6
8
|
this.fn = fn;
|
|
7
9
|
}
|
|
10
|
+
}
|
|
11
|
+
exports.Install = Install;
|
|
12
|
+
class PreInstall extends Install {
|
|
13
|
+
constructor(fn) {
|
|
14
|
+
super(fn);
|
|
15
|
+
}
|
|
8
16
|
static of(fn) {
|
|
9
|
-
return new
|
|
17
|
+
return new PreInstall(fn);
|
|
10
18
|
}
|
|
11
|
-
async
|
|
19
|
+
async preInstall({ effects }) {
|
|
12
20
|
await this.fn({
|
|
13
21
|
effects,
|
|
14
22
|
});
|
|
15
23
|
}
|
|
16
24
|
}
|
|
17
|
-
exports.
|
|
18
|
-
function
|
|
19
|
-
return
|
|
25
|
+
exports.PreInstall = PreInstall;
|
|
26
|
+
function setupPreInstall(fn) {
|
|
27
|
+
return PreInstall.of(fn);
|
|
28
|
+
}
|
|
29
|
+
class PostInstall extends Install {
|
|
30
|
+
constructor(fn) {
|
|
31
|
+
super(fn);
|
|
32
|
+
}
|
|
33
|
+
static of(fn) {
|
|
34
|
+
return new PostInstall(fn);
|
|
35
|
+
}
|
|
36
|
+
async postInstall({ effects }) {
|
|
37
|
+
await this.fn({
|
|
38
|
+
effects,
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
exports.PostInstall = PostInstall;
|
|
43
|
+
function setupPostInstall(fn) {
|
|
44
|
+
return PostInstall.of(fn);
|
|
20
45
|
}
|
|
21
|
-
exports.setupInstall = setupInstall;
|
|
22
46
|
//# 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":";;;AA6BA,0CAIC;AAsBD,4CAIC;AAtDD,MAAa,OAAO;IAClB,YAA+B,EAA8B;QAA9B,OAAE,GAAF,EAAE,CAA4B;IAAG,CAAC;CAClE;AAFD,0BAEC;AAED,MAAa,UAAkD,SAAQ,OAGtE;IACC,YAAoB,EAA8B;QAChD,KAAK,CAAC,EAAE,CAAC,CAAA;IACX,CAAC;IACD,MAAM,CAAC,EAAE,CACP,EAA8B;QAE9B,OAAO,IAAI,UAAU,CAAC,EAAE,CAAC,CAAA;IAC3B,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,EAAE,OAAO,EAAgD;QACxE,MAAM,IAAI,CAAC,EAAE,CAAC;YACZ,OAAO;SACR,CAAC,CAAA;IACJ,CAAC;CACF;AAlBD,gCAkBC;AAED,SAAgB,eAAe,CAC7B,EAA8B;IAE9B,OAAO,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC,CAAA;AAC1B,CAAC;AAED,MAAa,WAAmD,SAAQ,OAGvE;IACC,YAAoB,EAA8B;QAChD,KAAK,CAAC,EAAE,CAAC,CAAA;IACX,CAAC;IACD,MAAM,CAAC,EAAE,CACP,EAA8B;QAE9B,OAAO,IAAI,WAAW,CAAC,EAAE,CAAC,CAAA;IAC5B,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,EAAE,OAAO,EAAgD;QACzE,MAAM,IAAI,CAAC,EAAE,CAAC;YACZ,OAAO;SACR,CAAC,CAAA;IACJ,CAAC;CACF;AAlBD,kCAkBC;AAED,SAAgB,gBAAgB,CAC9B,EAA8B;IAE9B,OAAO,WAAW,CAAC,EAAE,CAAC,EAAE,CAAC,CAAA;AAC3B,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;
|
|
@@ -13,20 +12,20 @@ export declare class CommandController {
|
|
|
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,16 +51,33 @@ 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
82
|
try {
|
|
30
83
|
let childProcess;
|
|
@@ -40,9 +93,9 @@ class CommandController {
|
|
|
40
93
|
});
|
|
41
94
|
}
|
|
42
95
|
if (options.onStdout)
|
|
43
|
-
|
|
96
|
+
childProcess.stdout?.on("data", options.onStdout);
|
|
44
97
|
if (options.onStderr)
|
|
45
|
-
|
|
98
|
+
childProcess.stderr?.on("data", options.onStderr);
|
|
46
99
|
const state = { exited: false };
|
|
47
100
|
const answer = new Promise((resolve, reject) => {
|
|
48
101
|
childProcess.on("exit", (code) => {
|
|
@@ -72,39 +125,44 @@ class CommandController {
|
|
|
72
125
|
return new SubContainer_1.SubContainerHandle(this.subcontainer);
|
|
73
126
|
}
|
|
74
127
|
async wait({ timeout = types_1.NO_TIMEOUT } = {}) {
|
|
128
|
+
const self = this.weak();
|
|
75
129
|
if (timeout > 0)
|
|
76
130
|
setTimeout(() => {
|
|
77
|
-
|
|
131
|
+
self.term();
|
|
78
132
|
}, timeout);
|
|
79
133
|
try {
|
|
80
|
-
return await
|
|
134
|
+
return await self.runningAnswer;
|
|
81
135
|
}
|
|
82
136
|
finally {
|
|
83
|
-
if (!
|
|
84
|
-
|
|
137
|
+
if (!self.state.exited) {
|
|
138
|
+
self.process.kill("SIGKILL");
|
|
85
139
|
}
|
|
86
|
-
await
|
|
140
|
+
await self.subcontainer.destroy().catch((_) => { });
|
|
87
141
|
}
|
|
88
142
|
}
|
|
89
143
|
async term({ signal = types_1.SIGTERM, timeout = this.sigtermTimeout } = {}) {
|
|
144
|
+
const self = this.weak();
|
|
90
145
|
try {
|
|
91
|
-
if (!
|
|
146
|
+
if (!self.state.exited) {
|
|
92
147
|
if (signal !== "SIGKILL") {
|
|
93
148
|
setTimeout(() => {
|
|
94
|
-
if (!
|
|
95
|
-
|
|
149
|
+
if (!self.state.exited)
|
|
150
|
+
self.process.kill("SIGKILL");
|
|
96
151
|
}, timeout);
|
|
97
152
|
}
|
|
98
|
-
if (!
|
|
153
|
+
if (!self.process.kill(signal)) {
|
|
99
154
|
console.error(`failed to send signal ${signal} to pid ${this.process.pid}`);
|
|
100
155
|
}
|
|
101
156
|
}
|
|
102
|
-
await
|
|
157
|
+
await self.runningAnswer;
|
|
103
158
|
}
|
|
104
159
|
finally {
|
|
105
|
-
await
|
|
160
|
+
await self.subcontainer.destroy();
|
|
106
161
|
}
|
|
107
162
|
}
|
|
163
|
+
onDrop() {
|
|
164
|
+
this.term().catch(console.error);
|
|
165
|
+
}
|
|
108
166
|
}
|
|
109
167
|
exports.CommandController = CommandController;
|
|
110
168
|
//# sourceMappingURL=CommandController.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommandController.js","sourceRoot":"","sources":["../../../../package/lib/mainFn/CommandController.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"CommandController.js","sourceRoot":"","sources":["../../../../package/lib/mainFn/CommandController.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,wBAA2C;AAC3C,mDAA6D;AAE7D,2DAA4C;AAC5C,uDAI6B;AAC7B,kCAA4C;AAE5C,qDAAsC;AAEtC,MAAa,iBAAkB,SAAQ,WAAI;IACzC,YACW,aAA+B,EAChC,KAA0B,EACjB,YAA0B,EACnC,OAAwB,EACvB,iBAAyB,0BAAuB;QAEzD,KAAK,EAAE,CAAA;QANE,kBAAa,GAAb,aAAa,CAAkB;QAChC,UAAK,GAAL,KAAK,CAAqB;QACjB,iBAAY,GAAZ,YAAY,CAAc;QACnC,YAAO,GAAP,OAAO,CAAiB;QACvB,mBAAc,GAAd,cAAc,CAAkC;IAG3D,CAAC;IACD,MAAM,CAAC,EAAE;QACP,OAAO,KAAK,EACV,OAAkB,EAClB,YAKgB,EAChB,OAAsB,EACtB,OAeC,EACD,EAAE;YACF,IAAI,QAAkB,CAAA;YACtB,IAAI,OAAO,YAAY,CAAC,CAAC,aAAa,EAAE,CAAC;gBACvC,MAAM,SAAS,GAAoB,MAAM,EAAE;qBACxC,QAAQ,CAAC,yBAAyB,YAAY,CAAC,OAAO,OAAO,EAAE;oBAC9D,QAAQ,EAAE,MAAM;iBACjB,CAAC;qBACD,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;qBACjB,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;gBACnB,QAAQ,GAAG,SAAS,CAAC,UAAU,IAAI,EAAE,CAAA;gBACrC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,UAAU,IAAI,SAAS,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,CAAA;YACjE,CAAC;;gBAAM,QAAQ,GAAG,IAAA,mBAAY,EAAC,OAAO,CAAC,CAAA;YACvC,MAAM,IAAI,GACR,YAAY,YAAY,2BAAY;gBAClC,CAAC,CAAC,YAAY;gBACd,CAAC,CAAC,MAAM,CAAC,KAAK,IAAI,EAAE;oBAChB,MAAM,IAAI,GAAG,MAAM,2BAAY,CAAC,EAAE,CAChC,OAAO,EACP,YAAY,EACZ,OAAO,EAAE,gBAAgB,IAAI,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAChD,CAAA;oBACD,IAAI,CAAC;wBACH,KAAK,IAAI,KAAK,IAAI,OAAO,CAAC,MAAM,IAAI,EAAE,EAAE,CAAC;4BACvC,MAAM,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,UAAU,CAAC,CAAA;wBACnD,CAAC;wBACD,OAAO,IAAI,CAAA;oBACb,CAAC;oBAAC,OAAO,CAAC,EAAE,CAAC;wBACX,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;wBACpB,MAAM,CAAC,CAAA;oBACT,CAAC;gBACH,CAAC,CAAC,EAAE,CAAA;YAEV,IAAI,CAAC;gBACH,IAAI,YAA6B,CAAA;gBACjC,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;oBACtB,YAAY,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;wBACzC,GAAG,EAAE,OAAO,CAAC,GAAG;qBACjB,CAAC,CAAA;gBACJ,CAAC;qBAAM,CAAC;oBACN,YAAY,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;wBACxC,GAAG,EAAE,OAAO,CAAC,GAAG;wBAChB,KAAK,EAAE,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;qBACjE,CAAC,CAAA;gBACJ,CAAC;gBAED,IAAI,OAAO,CAAC,QAAQ;oBAAE,YAAY,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAA;gBACvE,IAAI,OAAO,CAAC,QAAQ;oBAAE,YAAY,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAA;gBAEvE,MAAM,KAAK,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAA;gBAC/B,MAAM,MAAM,GAAG,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;oBACnD,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;wBAC/B,KAAK,CAAC,MAAM,GAAG,IAAI,CAAA;wBACnB,IACE,IAAI,KAAK,CAAC;4BACV,IAAI,KAAK,GAAG;4BACZ,CAAC,IAAI,KAAK,IAAI,IAAI,YAAY,CAAC,UAAU,IAAI,SAAS,CAAC,EACvD,CAAC;4BACD,OAAO,OAAO,CAAC,IAAI,CAAC,CAAA;wBACtB,CAAC;wBACD,IAAI,IAAI,EAAE,CAAC;4BACT,OAAO,MAAM,CACX,IAAI,KAAK,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,qBAAqB,IAAI,EAAE,CAAC,CACrD,CAAA;wBACH,CAAC;6BAAM,CAAC;4BACN,OAAO,MAAM,CACX,IAAI,KAAK,CACP,GAAG,QAAQ,CAAC,CAAC,CAAC,uBAAuB,YAAY,CAAC,UAAU,EAAE,CAC/D,CACF,CAAA;wBACH,CAAC;oBACH,CAAC,CAAC,CAAA;gBACJ,CAAC,CAAC,CAAA;gBAEF,OAAO,IAAI,iBAAiB,CAC1B,MAAM,EACN,KAAK,EACL,IAAI,EACJ,YAAY,EACZ,OAAO,CAAC,cAAc,CACvB,CAAA;YACH,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;gBACpB,MAAM,CAAC,CAAA;YACT,CAAC;QACH,CAAC,CAAA;IACH,CAAC;IACD,IAAI,kBAAkB;QACpB,OAAO,IAAI,iCAAkB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;IAClD,CAAC;IACD,KAAK,CAAC,IAAI,CAAC,EAAE,OAAO,GAAG,kBAAU,EAAE,GAAG,EAAE;QACtC,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAA;QACxB,IAAI,OAAO,GAAG,CAAC;YACb,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,IAAI,EAAE,CAAA;YACb,CAAC,EAAE,OAAO,CAAC,CAAA;QACb,IAAI,CAAC;YACH,OAAO,MAAM,IAAI,CAAC,aAAa,CAAA;QACjC,CAAC;gBAAS,CAAC;YACT,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;gBACvB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YAC9B,CAAC;YACD,MAAM,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,GAAE,CAAC,CAAC,CAAA;QACpD,CAAC;IACH,CAAC;IACD,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,eAAO,EAAE,OAAO,GAAG,IAAI,CAAC,cAAc,EAAE,GAAG,EAAE;QACjE,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAA;QACxB,IAAI,CAAC;YACH,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;gBACvB,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;oBACzB,UAAU,CAAC,GAAG,EAAE;wBACd,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM;4BAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;oBACtD,CAAC,EAAE,OAAO,CAAC,CAAA;gBACb,CAAC;gBACD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;oBAC/B,OAAO,CAAC,KAAK,CACX,yBAAyB,MAAM,WAAW,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAC7D,CAAA;gBACH,CAAC;YACH,CAAC;YAED,MAAM,IAAI,CAAC,aAAa,CAAA;QAC1B,CAAC;gBAAS,CAAC;YACT,MAAM,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAA;QACnC,CAAC;IACH,CAAC;IACD,MAAM;QACJ,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IAClC,CAAC;CACF;AApKD,8CAoKC"}
|
|
@@ -1,5 +1,3 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
/// <reference types="node" />
|
|
3
1
|
import * as T from "../../../base/lib/types";
|
|
4
2
|
import { ExecSpawnable, MountOptions, SubContainer } from "../util/SubContainer";
|
|
5
3
|
import { CommandController } from "./CommandController";
|
|
@@ -17,19 +15,19 @@ export declare class Daemon {
|
|
|
17
15
|
imageId: keyof Manifest["images"] & T.ImageId;
|
|
18
16
|
sharedRun?: boolean;
|
|
19
17
|
} | SubContainer, command: T.CommandType, options: {
|
|
20
|
-
subcontainerName?: string
|
|
18
|
+
subcontainerName?: string;
|
|
21
19
|
mounts?: {
|
|
22
|
-
|
|
20
|
+
mountpoint: string;
|
|
23
21
|
options: MountOptions;
|
|
24
|
-
}[]
|
|
22
|
+
}[];
|
|
25
23
|
env?: {
|
|
26
24
|
[variable: string]: string;
|
|
27
25
|
} | undefined;
|
|
28
26
|
cwd?: string | undefined;
|
|
29
27
|
user?: string | undefined;
|
|
30
|
-
onStdout?: (
|
|
31
|
-
onStderr?: (
|
|
32
|
-
sigtermTimeout?: number
|
|
28
|
+
onStdout?: (chunk: Buffer | string | any) => void;
|
|
29
|
+
onStderr?: (chunk: Buffer | string | any) => void;
|
|
30
|
+
sigtermTimeout?: number;
|
|
33
31
|
}) => Promise<Daemon>;
|
|
34
32
|
start(): Promise<void>;
|
|
35
33
|
term(termOptions?: {
|
|
@@ -16,8 +16,7 @@ class Daemon {
|
|
|
16
16
|
this.shouldBeRunning = false;
|
|
17
17
|
}
|
|
18
18
|
get subContainerHandle() {
|
|
19
|
-
|
|
20
|
-
return (_a = this.commandController) === null || _a === void 0 ? void 0 : _a.subContainerHandle;
|
|
19
|
+
return this.commandController?.subContainerHandle;
|
|
21
20
|
}
|
|
22
21
|
static of() {
|
|
23
22
|
return async (effects, subcontainer, command, options) => {
|
|
@@ -49,9 +48,10 @@ class Daemon {
|
|
|
49
48
|
return this.stop(termOptions);
|
|
50
49
|
}
|
|
51
50
|
async stop(termOptions) {
|
|
52
|
-
var _a;
|
|
53
51
|
this.shouldBeRunning = false;
|
|
54
|
-
await
|
|
52
|
+
await this.commandController
|
|
53
|
+
?.term({ ...termOptions })
|
|
54
|
+
.catch((e) => console.error((0, asError_1.asError)(e)));
|
|
55
55
|
this.commandController = null;
|
|
56
56
|
}
|
|
57
57
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Daemon.js","sourceRoot":"","sources":["../../../../package/lib/mainFn/Daemon.ts"],"names":[],"mappings":";;;AACA,4DAAwD;AAExD,2DAAuD;AAEvD,MAAM,oBAAoB,GAAG,IAAI,CAAA;AACjC,MAAM,cAAc,GAAG,KAAK,CAAA;AAC5B;;;GAGG;AAEH,MAAa,MAAM;IAGjB,YAAoB,YAA8C;QAA9C,iBAAY,GAAZ,YAAY,CAAkC;QAF1D,sBAAiB,GAA6B,IAAI,CAAA;QAClD,oBAAe,GAAG,KAAK,CAAA;IACsC,CAAC;IACtE,IAAI,kBAAkB
|
|
1
|
+
{"version":3,"file":"Daemon.js","sourceRoot":"","sources":["../../../../package/lib/mainFn/Daemon.ts"],"names":[],"mappings":";;;AACA,4DAAwD;AAExD,2DAAuD;AAEvD,MAAM,oBAAoB,GAAG,IAAI,CAAA;AACjC,MAAM,cAAc,GAAG,KAAK,CAAA;AAC5B;;;GAGG;AAEH,MAAa,MAAM;IAGjB,YAAoB,YAA8C;QAA9C,iBAAY,GAAZ,YAAY,CAAkC;QAF1D,sBAAiB,GAA6B,IAAI,CAAA;QAClD,oBAAe,GAAG,KAAK,CAAA;IACsC,CAAC;IACtE,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,iBAAiB,EAAE,kBAAkB,CAAA;IACnD,CAAC;IACD,MAAM,CAAC,EAAE;QACP,OAAO,KAAK,EACV,OAAkB,EAClB,YAKgB,EAChB,OAAsB,EACtB,OAaC,EACD,EAAE;YACF,MAAM,YAAY,GAAG,GAAG,EAAE,CACxB,qCAAiB,CAAC,EAAE,EAAY,CAC9B,OAAO,EACP,YAAY,EACZ,OAAO,EACP,OAAO,CACR,CAAA;YACH,OAAO,IAAI,MAAM,CAAC,YAAY,CAAC,CAAA;QACjC,CAAC,CAAA;IACH,CAAC;IACD,KAAK,CAAC,KAAK;QACT,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,OAAM;QACR,CAAC;QACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAA;QAC3B,IAAI,cAAc,GAAG,CAAC,CAAA;QACtB,IAAI,OAAO,CAAC,KAAK,IAAI,EAAE;YACrB,OAAO,IAAI,CAAC,eAAe,EAAE,CAAC;gBAC5B,IAAI,IAAI,CAAC,iBAAiB;oBACxB,MAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAA;gBACxE,IAAI,CAAC,iBAAiB,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAA;gBAClD,MAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAA;gBACtE,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC,CAAA;gBACnE,cAAc,IAAI,oBAAoB,CAAA;gBACtC,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,cAAc,EAAE,cAAc,CAAC,CAAA;YAC3D,CAAC;QACH,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;YACf,OAAO,CAAC,KAAK,CAAC,IAAA,iBAAO,EAAC,GAAG,CAAC,CAAC,CAAA;QAC7B,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,KAAK,CAAC,IAAI,CAAC,WAGV;QACC,OAAO,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;IAC/B,CAAC;IACD,KAAK,CAAC,IAAI,CAAC,WAGV;QACC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAA;QAC5B,MAAM,IAAI,CAAC,iBAAiB;YAC1B,EAAE,IAAI,CAAC,EAAE,GAAG,WAAW,EAAE,CAAC;aACzB,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,IAAA,iBAAO,EAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QAC1C,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAA;IAC/B,CAAC;CACF;AA9ED,wBA8EC"}
|