@start9labs/start-sdk 0.3.6-beta.0 → 0.3.6-beta.10
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 +2 -9
- 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 +5 -4
- package/base/lib/dependencies/setupDependencies.js.map +1 -1
- package/base/lib/exver/exver.js.map +1 -1
- package/base/lib/exver/index.js +18 -9
- 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 -13
- package/base/lib/interfaces/Host.js +3 -21
- 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/AcmeProvider.d.ts +1 -0
- package/base/lib/osBindings/{HostKind.js → AcmeProvider.js} +1 -1
- package/base/lib/osBindings/AcmeProvider.js.map +1 -0
- package/base/lib/osBindings/AcmeSettings.d.ts +0 -8
- package/base/lib/osBindings/BindInfo.d.ts +2 -2
- 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/DomainConfig.d.ts +5 -0
- package/base/lib/osBindings/{GetPrimaryUrlParams.js → DomainConfig.js} +1 -1
- package/base/lib/osBindings/DomainConfig.js.map +1 -0
- package/base/lib/osBindings/ExportServiceInterfaceParams.d.ts +0 -1
- package/base/lib/osBindings/ForgetInterfaceParams.d.ts +3 -0
- package/base/lib/osBindings/ForgetInterfaceParams.js +4 -0
- package/base/lib/osBindings/ForgetInterfaceParams.js.map +1 -0
- package/base/lib/osBindings/Host.d.ts +5 -4
- 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 +6 -4
- package/base/lib/osBindings/IpInfo.js +0 -1
- package/base/lib/osBindings/IpInfo.js.map +1 -1
- package/base/lib/osBindings/Manifest.d.ts +2 -1
- package/base/lib/osBindings/NetworkInterfaceInfo.d.ts +1 -2
- 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/{SetPublicParams.js → NetworkInterfaceType.js} +1 -1
- package/base/lib/osBindings/NetworkInterfaceType.js.map +1 -0
- package/base/lib/osBindings/PackageVersionInfo.d.ts +2 -1
- package/base/lib/osBindings/ServerInfo.d.ts +9 -10
- 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/{LanInfo.js → TestSmtpParams.js} +1 -1
- package/base/lib/osBindings/TestSmtpParams.js.map +1 -0
- package/base/lib/osBindings/index.d.ts +11 -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.d.ts +5 -28
- 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 +20 -2
- 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 +2 -3
- 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 +7 -9
- package/base/lib/util/getServiceInterface.js +27 -19
- package/base/lib/util/getServiceInterface.js.map +1 -1
- package/base/lib/util/getServiceInterfaces.d.ts +7 -3
- package/base/lib/util/getServiceInterfaces.js +23 -18
- 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 +75 -284
- package/package/lib/StartSdk.js +72 -33
- 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 +3 -1
- package/package/lib/health/HealthCheck.js +10 -8
- 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/index.js +17 -7
- package/package/lib/index.js.map +1 -1
- package/package/lib/inits/setupInit.js +1 -2
- package/package/lib/inits/setupInit.js.map +1 -1
- package/package/lib/inits/setupInstall.js +2 -2
- 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 +7 -9
- package/package/lib/mainFn/CommandController.js +97 -41
- package/package/lib/mainFn/CommandController.js.map +1 -1
- package/package/lib/mainFn/Daemon.d.ts +6 -8
- package/package/lib/mainFn/Daemon.js +6 -4
- package/package/lib/mainFn/Daemon.js.map +1 -1
- package/package/lib/mainFn/Daemons.d.ts +21 -21
- package/package/lib/mainFn/Daemons.js +24 -15
- package/package/lib/mainFn/Daemons.js.map +1 -1
- package/package/lib/mainFn/HealthDaemon.d.ts +4 -1
- package/package/lib/mainFn/HealthDaemon.js +18 -7
- package/package/lib/mainFn/HealthDaemon.js.map +1 -1
- 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.js +12 -26
- package/package/lib/manifest/setupManifest.js.map +1 -1
- package/package/lib/store/getStore.d.ts +6 -2
- package/package/lib/store/getStore.js +22 -4
- 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.js +386 -297
- package/package/lib/test/output.js.map +1 -1
- package/package/lib/test/output.sdk.d.ts +137 -126
- 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/util/GetSslCertificate.d.ts +7 -3
- package/package/lib/util/GetSslCertificate.js +21 -3
- package/package/lib/util/GetSslCertificate.js.map +1 -1
- package/package/lib/util/SubContainer.d.ts +4 -5
- package/package/lib/util/SubContainer.js +51 -20
- package/package/lib/util/SubContainer.js.map +1 -1
- package/package/lib/util/fileHelper.d.ts +3 -1
- package/package/lib/util/fileHelper.js +55 -20
- package/package/lib/util/fileHelper.js.map +1 -1
- 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 -3
- package/base/lib/dependencies/Dependency.d.ts +0 -29
- package/base/lib/dependencies/Dependency.js +0 -10
- package/base/lib/dependencies/Dependency.js.map +0 -1
- package/base/lib/osBindings/GetPrimaryUrlParams.d.ts +0 -8
- 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/LanInfo.d.ts +0 -4
- package/base/lib/osBindings/LanInfo.js.map +0 -1
- package/base/lib/osBindings/SetPublicParams.js.map +0 -1
|
@@ -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":";;;AAoBA,oCAIC;AAnBD,MAAa,OAAO;IAClB,YAA6B,EAA8B;QAA9B,OAAE,GAAF,EAAE,CAA4B;IAAG,CAAC;IAC/D,MAAM,CAAC,EAAE,CACP,EAA8B;QAE9B,OAAO,IAAI,OAAO,CAAC,EAAE,CAAC,CAAA;IACxB,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,EAAE,OAAO,EAAgD;QACrE,MAAM,IAAI,CAAC,EAAE,CAAC;YACZ,OAAO;SACR,CAAC,CAAA;IACJ,CAAC;CACF;AAbD,0BAaC;AAED,SAAgB,YAAY,CAC1B,EAA8B;IAE9B,OAAO,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,CAAA;AACvB,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,5 +1,3 @@
|
|
|
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
|
export declare class CommandController {
|
|
@@ -10,23 +8,23 @@ export declare class CommandController {
|
|
|
10
8
|
readonly sigtermTimeout: number;
|
|
11
9
|
private constructor();
|
|
12
10
|
static of<Manifest extends T.SDKManifest>(): <A extends string>(effects: T.Effects, subcontainer: {
|
|
13
|
-
|
|
11
|
+
imageId: keyof Manifest["images"] & T.ImageId;
|
|
14
12
|
sharedRun?: boolean;
|
|
15
13
|
} | SubContainer, command: T.CommandType, options: {
|
|
16
|
-
subcontainerName?: string
|
|
17
|
-
sigtermTimeout?: number
|
|
14
|
+
subcontainerName?: string;
|
|
15
|
+
sigtermTimeout?: number;
|
|
18
16
|
mounts?: {
|
|
19
17
|
path: string;
|
|
20
18
|
options: MountOptions;
|
|
21
|
-
}[]
|
|
22
|
-
runAsInit?: boolean
|
|
19
|
+
}[];
|
|
20
|
+
runAsInit?: boolean;
|
|
23
21
|
env?: {
|
|
24
22
|
[variable: string]: string;
|
|
25
23
|
} | undefined;
|
|
26
24
|
cwd?: string | undefined;
|
|
27
25
|
user?: string | undefined;
|
|
28
|
-
onStdout?: (
|
|
29
|
-
onStderr?: (
|
|
26
|
+
onStdout?: (chunk: Buffer | string | any) => void;
|
|
27
|
+
onStderr?: (chunk: Buffer | string | any) => void;
|
|
30
28
|
}) => Promise<CommandController>;
|
|
31
29
|
get subContainerHandle(): SubContainerHandle;
|
|
32
30
|
wait({ timeout }?: {
|
|
@@ -1,10 +1,45 @@
|
|
|
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");
|
|
42
|
+
const fs = __importStar(require("node:fs/promises"));
|
|
8
43
|
class CommandController {
|
|
9
44
|
constructor(runningAnswer, state, subcontainer, process, sigtermTimeout = _1.DEFAULT_SIGTERM_TIMEOUT) {
|
|
10
45
|
this.runningAnswer = runningAnswer;
|
|
@@ -15,58 +50,80 @@ class CommandController {
|
|
|
15
50
|
}
|
|
16
51
|
static of() {
|
|
17
52
|
return async (effects, subcontainer, command, options) => {
|
|
18
|
-
|
|
19
|
-
|
|
53
|
+
let commands;
|
|
54
|
+
if (command instanceof T.UseEntrypoint) {
|
|
55
|
+
const imageMeta = await fs
|
|
56
|
+
.readFile(`/media/startos/images/${subcontainer.imageId}.json`, {
|
|
57
|
+
encoding: "utf8",
|
|
58
|
+
})
|
|
59
|
+
.catch(() => "{}")
|
|
60
|
+
.then(JSON.parse);
|
|
61
|
+
commands = imageMeta.entrypoint ?? [];
|
|
62
|
+
commands.concat(...(command.overridCmd ?? imageMeta.cmd ?? []));
|
|
63
|
+
}
|
|
64
|
+
else
|
|
65
|
+
commands = (0, util_1.splitCommand)(command);
|
|
20
66
|
const subc = subcontainer instanceof SubContainer_1.SubContainer
|
|
21
67
|
? subcontainer
|
|
22
68
|
: await (async () => {
|
|
23
|
-
const subc = await SubContainer_1.SubContainer.of(effects, subcontainer,
|
|
24
|
-
|
|
25
|
-
|
|
69
|
+
const subc = await SubContainer_1.SubContainer.of(effects, subcontainer, options?.subcontainerName || commands.join(" "));
|
|
70
|
+
try {
|
|
71
|
+
for (let mount of options.mounts || []) {
|
|
72
|
+
await subc.mount(mount.options, mount.path);
|
|
73
|
+
}
|
|
74
|
+
return subc;
|
|
75
|
+
}
|
|
76
|
+
catch (e) {
|
|
77
|
+
await subc.destroy();
|
|
78
|
+
throw e;
|
|
26
79
|
}
|
|
27
|
-
return subc;
|
|
28
80
|
})();
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
81
|
+
try {
|
|
82
|
+
let childProcess;
|
|
83
|
+
if (options.runAsInit) {
|
|
84
|
+
childProcess = await subc.launch(commands, {
|
|
85
|
+
env: options.env,
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
childProcess = await subc.spawn(commands, {
|
|
90
|
+
env: options.env,
|
|
91
|
+
stdio: options.onStdout || options.onStderr ? "pipe" : "inherit",
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
if (options.onStdout)
|
|
95
|
+
childProcess.stdout?.on("data", options.onStdout);
|
|
96
|
+
if (options.onStderr)
|
|
97
|
+
childProcess.stderr?.on("data", options.onStderr);
|
|
98
|
+
const state = { exited: false };
|
|
99
|
+
const answer = new Promise((resolve, reject) => {
|
|
100
|
+
childProcess.on("exit", (code) => {
|
|
101
|
+
state.exited = true;
|
|
102
|
+
if (code === 0 ||
|
|
103
|
+
code === 143 ||
|
|
104
|
+
(code === null && childProcess.signalCode == "SIGTERM")) {
|
|
105
|
+
return resolve(null);
|
|
106
|
+
}
|
|
107
|
+
if (code) {
|
|
108
|
+
return reject(new Error(`${commands[0]} exited with code ${code}`));
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
return reject(new Error(`${commands[0]} exited with signal ${childProcess.signalCode}`));
|
|
112
|
+
}
|
|
113
|
+
});
|
|
33
114
|
});
|
|
115
|
+
return new CommandController(answer, state, subc, childProcess, options.sigtermTimeout);
|
|
34
116
|
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
stdio: options.onStdout || options.onStderr ? "pipe" : "inherit",
|
|
39
|
-
});
|
|
117
|
+
catch (e) {
|
|
118
|
+
await subc.destroy();
|
|
119
|
+
throw e;
|
|
40
120
|
}
|
|
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
121
|
};
|
|
64
122
|
}
|
|
65
123
|
get subContainerHandle() {
|
|
66
124
|
return new SubContainer_1.SubContainerHandle(this.subcontainer);
|
|
67
125
|
}
|
|
68
126
|
async wait({ timeout = types_1.NO_TIMEOUT } = {}) {
|
|
69
|
-
var _a, _b;
|
|
70
127
|
if (timeout > 0)
|
|
71
128
|
setTimeout(() => {
|
|
72
129
|
this.term();
|
|
@@ -78,11 +135,10 @@ class CommandController {
|
|
|
78
135
|
if (!this.state.exited) {
|
|
79
136
|
this.process.kill("SIGKILL");
|
|
80
137
|
}
|
|
81
|
-
await
|
|
138
|
+
await this.subcontainer.destroy().catch((_) => { });
|
|
82
139
|
}
|
|
83
140
|
}
|
|
84
141
|
async term({ signal = types_1.SIGTERM, timeout = this.sigtermTimeout } = {}) {
|
|
85
|
-
var _a, _b;
|
|
86
142
|
try {
|
|
87
143
|
if (!this.state.exited) {
|
|
88
144
|
if (signal !== "SIGKILL") {
|
|
@@ -98,7 +154,7 @@ class CommandController {
|
|
|
98
154
|
await this.runningAnswer;
|
|
99
155
|
}
|
|
100
156
|
finally {
|
|
101
|
-
await
|
|
157
|
+
await this.subcontainer.destroy();
|
|
102
158
|
}
|
|
103
159
|
}
|
|
104
160
|
}
|
|
@@ -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":"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"}
|
|
@@ -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";
|
|
@@ -14,22 +12,22 @@ export declare class Daemon {
|
|
|
14
12
|
constructor(startCommand: () => Promise<CommandController>);
|
|
15
13
|
get subContainerHandle(): undefined | ExecSpawnable;
|
|
16
14
|
static of<Manifest extends T.SDKManifest>(): <A extends string>(effects: T.Effects, subcontainer: {
|
|
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
|
path: 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) => {
|
|
@@ -33,6 +32,8 @@ class Daemon {
|
|
|
33
32
|
let timeoutCounter = 0;
|
|
34
33
|
new Promise(async () => {
|
|
35
34
|
while (this.shouldBeRunning) {
|
|
35
|
+
if (this.commandController)
|
|
36
|
+
await this.commandController.term().catch((err) => console.error(err));
|
|
36
37
|
this.commandController = await this.startCommand();
|
|
37
38
|
await this.commandController.wait().catch((err) => console.error(err));
|
|
38
39
|
await new Promise((resolve) => setTimeout(resolve, timeoutCounter));
|
|
@@ -47,9 +48,10 @@ class Daemon {
|
|
|
47
48
|
return this.stop(termOptions);
|
|
48
49
|
}
|
|
49
50
|
async stop(termOptions) {
|
|
50
|
-
var _a;
|
|
51
51
|
this.shouldBeRunning = false;
|
|
52
|
-
await
|
|
52
|
+
await this.commandController
|
|
53
|
+
?.term({ ...termOptions })
|
|
54
|
+
.catch((e) => console.error((0, asError_1.asError)(e)));
|
|
53
55
|
this.commandController = null;
|
|
54
56
|
}
|
|
55
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"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
/// <reference types="node" />
|
|
3
|
-
import { HealthReceipt, Signals } from "../../../base/lib/types";
|
|
1
|
+
import { HealthReceipt } from "../../../base/lib/types";
|
|
4
2
|
import { HealthCheckResult } from "../health/checkFns";
|
|
5
3
|
import { Trigger } from "../trigger";
|
|
6
4
|
import * as T from "../../../base/lib/types";
|
|
7
5
|
import { Mounts } from "./Mounts";
|
|
8
|
-
import { ExecSpawnable, MountOptions } from "../util/SubContainer";
|
|
6
|
+
import { ExecSpawnable, MountOptions, SubContainer } from "../util/SubContainer";
|
|
9
7
|
import * as CP from "node:child_process";
|
|
10
8
|
export { Daemon } from "./Daemon";
|
|
11
9
|
export { CommandController } from "./CommandController";
|
|
@@ -32,21 +30,27 @@ export type Ready = {
|
|
|
32
30
|
* ```
|
|
33
31
|
*/
|
|
34
32
|
fn: (spawnable: ExecSpawnable) => Promise<HealthCheckResult> | HealthCheckResult;
|
|
33
|
+
/**
|
|
34
|
+
* A duration in milliseconds to treat a failing health check as "starting"
|
|
35
|
+
*
|
|
36
|
+
* defaults to 5000
|
|
37
|
+
*/
|
|
38
|
+
gracePeriod?: number;
|
|
35
39
|
trigger?: Trigger;
|
|
36
40
|
};
|
|
37
41
|
type DaemonsParams<Manifest extends T.SDKManifest, Ids extends string, Command extends string, Id extends string> = {
|
|
38
42
|
/** The command line command to start the daemon */
|
|
39
43
|
command: T.CommandType;
|
|
40
|
-
/** Information about the
|
|
41
|
-
|
|
44
|
+
/** Information about the subcontainer in which the daemon runs */
|
|
45
|
+
subcontainer: {
|
|
42
46
|
/** The ID of the image. Must be one of the image IDs declared in the manifest */
|
|
43
|
-
|
|
47
|
+
imageId: keyof Manifest["images"] & T.ImageId;
|
|
44
48
|
/**
|
|
45
49
|
* Whether or not to share the `/run` directory with the parent container.
|
|
46
50
|
* This is useful if you are trying to connect to a service that exposes a unix domain socket or auth cookie via the `/run` directory
|
|
47
51
|
*/
|
|
48
52
|
sharedRun?: boolean;
|
|
49
|
-
};
|
|
53
|
+
} | SubContainer;
|
|
50
54
|
/** For mounting the necessary volumes. Syntax: sdk.Mounts.of().addVolume() */
|
|
51
55
|
mounts: Mounts<Manifest>;
|
|
52
56
|
env?: Record<string, string>;
|
|
@@ -58,24 +62,24 @@ type DaemonsParams<Manifest extends T.SDKManifest, Ids extends string, Command e
|
|
|
58
62
|
onStderr?: (chunk: Buffer | string | any) => void;
|
|
59
63
|
};
|
|
60
64
|
type ErrorDuplicateId<Id extends string> = `The id '${Id}' is already used`;
|
|
61
|
-
export declare const runCommand: <Manifest extends T.SDKManifest>() => <A extends string>(effects: T.Effects, subcontainer:
|
|
62
|
-
|
|
63
|
-
sharedRun?: boolean
|
|
65
|
+
export declare const runCommand: <Manifest extends T.SDKManifest>() => <A extends string>(effects: T.Effects, subcontainer: SubContainer | {
|
|
66
|
+
imageId: keyof Manifest["images"] & string;
|
|
67
|
+
sharedRun?: boolean;
|
|
64
68
|
}, command: T.CommandType, options: {
|
|
65
|
-
subcontainerName?: string
|
|
66
|
-
sigtermTimeout?: number
|
|
69
|
+
subcontainerName?: string;
|
|
70
|
+
sigtermTimeout?: number;
|
|
67
71
|
mounts?: {
|
|
68
72
|
path: string;
|
|
69
73
|
options: MountOptions;
|
|
70
74
|
}[] | undefined;
|
|
71
|
-
runAsInit?: boolean
|
|
75
|
+
runAsInit?: boolean;
|
|
72
76
|
env?: {
|
|
73
77
|
[variable: string]: string;
|
|
74
78
|
} | undefined;
|
|
75
79
|
cwd?: string | undefined;
|
|
76
80
|
user?: string | undefined;
|
|
77
|
-
onStdout?: ((chunk: any) => void) | undefined;
|
|
78
|
-
onStderr?: ((chunk: any) => void) | undefined;
|
|
81
|
+
onStdout?: ((chunk: Buffer | string | any) => void) | undefined;
|
|
82
|
+
onStderr?: ((chunk: Buffer | string | any) => void) | undefined;
|
|
79
83
|
}) => Promise<CommandController>;
|
|
80
84
|
/**
|
|
81
85
|
* A class for defining and controlling the service daemons
|
|
@@ -130,10 +134,6 @@ export declare class Daemons<Manifest extends T.SDKManifest, Ids extends string>
|
|
|
130
134
|
*/
|
|
131
135
|
addDaemon<Id extends string, Command extends string>(id: "" extends Id ? never : ErrorDuplicateId<Id> extends Id ? never : Id extends Ids ? ErrorDuplicateId<Id> : Id, options: DaemonsParams<Manifest, Ids, Command, Id>): Daemons<Manifest, Ids | Id>;
|
|
132
136
|
build(): Promise<{
|
|
133
|
-
term: (
|
|
134
|
-
signal?: Signals;
|
|
135
|
-
timeout?: number;
|
|
136
|
-
}) => Promise<void>;
|
|
137
|
+
term: () => Promise<void>;
|
|
137
138
|
}>;
|
|
138
|
-
private updateMainHealth;
|
|
139
139
|
}
|
|
@@ -15,13 +15,23 @@ 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
36
|
exports.Daemons = exports.runCommand = exports.cpExecFile = exports.cpExec = exports.CommandController = exports.Daemon = void 0;
|
|
27
37
|
const node_util_1 = require("node:util");
|
|
@@ -91,7 +101,7 @@ class Daemons {
|
|
|
91
101
|
// prettier-ignore
|
|
92
102
|
id, options) {
|
|
93
103
|
const daemonIndex = this.daemons.length;
|
|
94
|
-
const daemon = Daemon_2.Daemon.of()(this.effects, options.
|
|
104
|
+
const daemon = Daemon_2.Daemon.of()(this.effects, options.subcontainer, options.command, {
|
|
95
105
|
...options,
|
|
96
106
|
mounts: options.mounts.build(),
|
|
97
107
|
subcontainerName: id,
|
|
@@ -106,12 +116,14 @@ class Daemons {
|
|
|
106
116
|
return new Daemons(this.effects, this.started, daemons, ids, healthDaemons);
|
|
107
117
|
}
|
|
108
118
|
async build() {
|
|
109
|
-
this.updateMainHealth();
|
|
110
|
-
this.healthDaemons.forEach((x) => x.addWatcher(() => this.updateMainHealth()));
|
|
111
119
|
const built = {
|
|
112
|
-
term: async (
|
|
120
|
+
term: async () => {
|
|
113
121
|
try {
|
|
114
|
-
await Promise.
|
|
122
|
+
for (let result of await Promise.allSettled(this.healthDaemons.map((x) => x.term({ timeout: x.sigtermTimeout })))) {
|
|
123
|
+
if (result.status === "rejected") {
|
|
124
|
+
console.error(result.reason);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
115
127
|
}
|
|
116
128
|
finally {
|
|
117
129
|
this.effects.setMainStatus({ status: "stopped" });
|
|
@@ -121,9 +133,6 @@ class Daemons {
|
|
|
121
133
|
this.started(() => built.term());
|
|
122
134
|
return built;
|
|
123
135
|
}
|
|
124
|
-
updateMainHealth() {
|
|
125
|
-
this.effects.setMainStatus({ status: "running" });
|
|
126
|
-
}
|
|
127
136
|
}
|
|
128
137
|
exports.Daemons = Daemons;
|
|
129
138
|
//# sourceMappingURL=Daemons.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Daemons.js","sourceRoot":"","sources":["../../../../package/lib/mainFn/Daemons.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Daemons.js","sourceRoot":"","sources":["../../../../package/lib/mainFn/Daemons.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
1
|
import { HealthCheckResult } from "../health/checkFns";
|
|
3
2
|
import { Ready } from "./Daemons";
|
|
4
3
|
import { Daemon } from "./Daemon";
|
|
@@ -22,6 +21,9 @@ export declare class HealthDaemon {
|
|
|
22
21
|
private _health;
|
|
23
22
|
private healthWatchers;
|
|
24
23
|
private running;
|
|
24
|
+
private started?;
|
|
25
|
+
private resolveReady;
|
|
26
|
+
private readyPromise;
|
|
25
27
|
constructor(daemon: Promise<Daemon>, daemonIndex: number, dependencies: HealthDaemon[], id: string, ids: string[], ready: Ready, effects: Effects, sigtermTimeout?: number);
|
|
26
28
|
/** Run after we want to do cleanup */
|
|
27
29
|
term(termOptions?: {
|
|
@@ -35,6 +37,7 @@ export declare class HealthDaemon {
|
|
|
35
37
|
private healthCheckCleanup;
|
|
36
38
|
private turnOffHealthCheck;
|
|
37
39
|
private setupHealthCheck;
|
|
40
|
+
onReady(): Promise<void>;
|
|
38
41
|
private setHealth;
|
|
39
42
|
private updateStatus;
|
|
40
43
|
}
|
|
@@ -32,15 +32,15 @@ class HealthDaemon {
|
|
|
32
32
|
this.healthWatchers = [];
|
|
33
33
|
this.running = false;
|
|
34
34
|
this.healthCheckCleanup = null;
|
|
35
|
+
this.readyPromise = new Promise((resolve) => (this.resolveReady = resolve));
|
|
35
36
|
this.updateStatus();
|
|
36
37
|
this.dependencies.forEach((d) => d.addWatcher(() => this.updateStatus()));
|
|
37
38
|
}
|
|
38
39
|
/** Run after we want to do cleanup */
|
|
39
40
|
async term(termOptions) {
|
|
40
|
-
var _a;
|
|
41
41
|
this.healthWatchers = [];
|
|
42
42
|
this.running = false;
|
|
43
|
-
|
|
43
|
+
this.healthCheckCleanup?.();
|
|
44
44
|
await this.daemon.then((d) => d.term({
|
|
45
45
|
timeout: this.sigtermTimeout,
|
|
46
46
|
...termOptions,
|
|
@@ -60,6 +60,7 @@ class HealthDaemon {
|
|
|
60
60
|
if (newStatus) {
|
|
61
61
|
;
|
|
62
62
|
(await this.daemon).start();
|
|
63
|
+
this.started = performance.now();
|
|
63
64
|
this.setupHealthCheck();
|
|
64
65
|
}
|
|
65
66
|
else {
|
|
@@ -70,14 +71,12 @@ class HealthDaemon {
|
|
|
70
71
|
}
|
|
71
72
|
}
|
|
72
73
|
turnOffHealthCheck() {
|
|
73
|
-
|
|
74
|
-
(_a = this.healthCheckCleanup) === null || _a === void 0 ? void 0 : _a.call(this);
|
|
74
|
+
this.healthCheckCleanup?.();
|
|
75
75
|
}
|
|
76
76
|
async setupHealthCheck() {
|
|
77
|
-
var _a;
|
|
78
77
|
if (this.healthCheckCleanup)
|
|
79
78
|
return;
|
|
80
|
-
const trigger = (
|
|
79
|
+
const trigger = (this.ready.trigger ?? defaultTrigger_1.defaultTrigger)(() => ({
|
|
81
80
|
lastResult: this._health.result,
|
|
82
81
|
}));
|
|
83
82
|
const { promise: status, resolve: setStatus } = oncePromise();
|
|
@@ -92,6 +91,10 @@ class HealthDaemon {
|
|
|
92
91
|
message: "message" in err ? err.message : String(err),
|
|
93
92
|
};
|
|
94
93
|
});
|
|
94
|
+
if (this.resolveReady &&
|
|
95
|
+
(response.result === "success" || response.result === "disabled")) {
|
|
96
|
+
this.resolveReady();
|
|
97
|
+
}
|
|
95
98
|
await this.setHealth(response);
|
|
96
99
|
}
|
|
97
100
|
else {
|
|
@@ -108,18 +111,26 @@ class HealthDaemon {
|
|
|
108
111
|
return null;
|
|
109
112
|
};
|
|
110
113
|
}
|
|
114
|
+
onReady() {
|
|
115
|
+
return this.readyPromise;
|
|
116
|
+
}
|
|
111
117
|
async setHealth(health) {
|
|
112
118
|
this._health = health;
|
|
113
119
|
this.healthWatchers.forEach((watcher) => watcher());
|
|
114
120
|
const display = this.ready.display;
|
|
115
|
-
const result = health.result;
|
|
116
121
|
if (!display) {
|
|
117
122
|
return;
|
|
118
123
|
}
|
|
124
|
+
let result = health.result;
|
|
125
|
+
if (result === "failure" &&
|
|
126
|
+
this.started &&
|
|
127
|
+
performance.now() - this.started <= (this.ready.gracePeriod ?? 5000))
|
|
128
|
+
result = "starting";
|
|
119
129
|
await this.effects.setHealth({
|
|
120
130
|
...health,
|
|
121
131
|
id: this.id,
|
|
122
132
|
name: display,
|
|
133
|
+
result,
|
|
123
134
|
});
|
|
124
135
|
}
|
|
125
136
|
async updateStatus() {
|