@start9labs/start-sdk 0.3.6-alpha7 → 0.3.6-alpha8
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/cjs/lib/StartSdk.d.ts +2 -17
- package/cjs/lib/StartSdk.js +2 -8
- package/cjs/lib/StartSdk.js.map +1 -1
- package/cjs/lib/backup/Backups.js +2 -1
- package/cjs/lib/backup/Backups.js.map +1 -1
- package/cjs/lib/backup/setupBackups.d.ts +1 -1
- package/cjs/lib/backup/setupBackups.js +2 -1
- package/cjs/lib/backup/setupBackups.js.map +1 -1
- package/cjs/lib/config/setupConfig.js +2 -1
- package/cjs/lib/config/setupConfig.js.map +1 -1
- package/cjs/lib/exver/index.d.ts +2 -2
- package/cjs/lib/exver/index.js +1 -0
- package/cjs/lib/exver/index.js.map +1 -1
- package/cjs/lib/health/HealthCheck.js +2 -1
- package/cjs/lib/health/HealthCheck.js.map +1 -1
- package/cjs/lib/health/checkFns/checkWebUrl.js +2 -1
- package/cjs/lib/health/checkFns/checkWebUrl.js.map +1 -1
- package/cjs/lib/index.d.ts +1 -0
- package/cjs/lib/index.js +4 -0
- package/cjs/lib/index.js.map +1 -1
- package/cjs/lib/inits/migrations/Migration.d.ts +14 -27
- package/cjs/lib/inits/migrations/Migration.js +10 -3
- package/cjs/lib/inits/migrations/Migration.js.map +1 -1
- package/cjs/lib/inits/migrations/setupMigrations.d.ts +10 -5
- package/cjs/lib/inits/migrations/setupMigrations.js +90 -26
- package/cjs/lib/inits/migrations/setupMigrations.js.map +1 -1
- package/cjs/lib/inits/setupInit.d.ts +2 -2
- package/cjs/lib/inits/setupInit.js +29 -5
- package/cjs/lib/inits/setupInit.js.map +1 -1
- package/cjs/lib/inits/setupInstall.d.ts +1 -1
- package/cjs/lib/inits/setupInstall.js +4 -5
- package/cjs/lib/inits/setupInstall.js.map +1 -1
- package/cjs/lib/inits/setupUninstall.d.ts +1 -1
- package/cjs/lib/inits/setupUninstall.js +1 -1
- package/cjs/lib/inits/setupUninstall.js.map +1 -1
- package/cjs/lib/mainFn/CommandController.d.ts +7 -4
- package/cjs/lib/mainFn/CommandController.js +18 -8
- package/cjs/lib/mainFn/CommandController.js.map +1 -1
- package/cjs/lib/mainFn/Daemon.d.ts +4 -2
- package/cjs/lib/mainFn/Daemon.js +7 -2
- package/cjs/lib/mainFn/Daemon.js.map +1 -1
- package/cjs/lib/mainFn/Daemons.d.ts +2 -2
- package/cjs/lib/mainFn/HealthDaemon.d.ts +6 -3
- package/cjs/lib/mainFn/HealthDaemon.js +23 -35
- package/cjs/lib/mainFn/HealthDaemon.js.map +1 -1
- package/cjs/lib/manifest/ManifestTypes.d.ts +1 -10
- package/cjs/lib/manifest/setupManifest.d.ts +2 -2
- package/cjs/lib/manifest/setupManifest.js +6 -2
- package/cjs/lib/manifest/setupManifest.js.map +1 -1
- package/cjs/lib/osBindings/Manifest.d.ts +2 -0
- package/cjs/lib/osBindings/PackageDataEntry.d.ts +2 -0
- package/cjs/lib/osBindings/SetDataVersionParams.d.ts +3 -0
- package/cjs/lib/osBindings/SetDataVersionParams.js +4 -0
- package/cjs/lib/osBindings/SetDataVersionParams.js.map +1 -0
- package/cjs/lib/osBindings/index.d.ts +1 -3
- package/cjs/lib/s9pk/merkleArchive/varint.js +2 -1
- package/cjs/lib/s9pk/merkleArchive/varint.js.map +1 -1
- package/cjs/lib/test/configBuilder.test.js +7 -4
- package/cjs/lib/test/configBuilder.test.js.map +1 -1
- package/cjs/lib/test/graph.test.d.ts +1 -0
- package/cjs/lib/test/graph.test.js +78 -0
- package/cjs/lib/test/graph.test.js.map +1 -0
- package/cjs/lib/test/output.sdk.d.ts +2 -214
- package/cjs/lib/test/output.sdk.js +9 -3
- package/cjs/lib/test/output.sdk.js.map +1 -1
- package/cjs/lib/test/startosTypeValidation.test.js +2 -0
- package/cjs/lib/test/startosTypeValidation.test.js.map +1 -1
- package/cjs/lib/types.d.ts +18 -14
- package/cjs/lib/types.js.map +1 -1
- package/cjs/lib/util/Overlay.d.ts +39 -2
- package/cjs/lib/util/Overlay.js +38 -6
- package/cjs/lib/util/Overlay.js.map +1 -1
- package/cjs/lib/util/asError.d.ts +1 -0
- package/cjs/lib/util/asError.js +11 -0
- package/cjs/lib/util/asError.js.map +1 -0
- package/cjs/lib/util/graph.d.ts +19 -0
- package/cjs/lib/util/graph.js +206 -0
- package/cjs/lib/util/graph.js.map +1 -0
- package/cjs/lib/util/index.d.ts +1 -0
- package/cjs/lib/util/index.js +3 -1
- package/cjs/lib/util/index.js.map +1 -1
- package/cjs/lib/version/VersionGraph.d.ts +18 -0
- package/cjs/lib/version/VersionGraph.js +104 -0
- package/cjs/lib/version/VersionGraph.js.map +1 -0
- package/cjs/lib/version/VersionInfo.d.ts +44 -0
- package/cjs/lib/version/VersionInfo.js +48 -0
- package/cjs/lib/version/VersionInfo.js.map +1 -0
- package/cjs/lib/version/index.d.ts +2 -0
- package/cjs/lib/version/index.js +19 -0
- package/cjs/lib/version/index.js.map +1 -0
- package/cjs/lib/versionInfo/VersionInfo.d.ts +44 -0
- package/cjs/lib/versionInfo/VersionInfo.js +48 -0
- package/cjs/lib/versionInfo/VersionInfo.js.map +1 -0
- package/cjs/lib/versionInfo/setupVersionGraph.d.ts +19 -0
- package/cjs/lib/versionInfo/setupVersionGraph.js +108 -0
- package/cjs/lib/versionInfo/setupVersionGraph.js.map +1 -0
- package/mjs/lib/StartSdk.d.ts +2 -17
- package/mjs/lib/StartSdk.js +2 -8
- package/mjs/lib/StartSdk.js.map +1 -1
- package/mjs/lib/backup/Backups.js +2 -1
- package/mjs/lib/backup/Backups.js.map +1 -1
- package/mjs/lib/backup/setupBackups.d.ts +1 -1
- package/mjs/lib/backup/setupBackups.js +2 -1
- package/mjs/lib/backup/setupBackups.js.map +1 -1
- package/mjs/lib/config/setupConfig.js +1 -1
- package/mjs/lib/config/setupConfig.js.map +1 -1
- package/mjs/lib/exver/index.d.ts +2 -2
- package/mjs/lib/exver/index.js +1 -0
- package/mjs/lib/exver/index.js.map +1 -1
- package/mjs/lib/health/HealthCheck.js +2 -1
- package/mjs/lib/health/HealthCheck.js.map +1 -1
- package/mjs/lib/health/checkFns/checkWebUrl.js +2 -1
- package/mjs/lib/health/checkFns/checkWebUrl.js.map +1 -1
- package/mjs/lib/index.d.ts +1 -0
- package/mjs/lib/index.js +1 -0
- package/mjs/lib/index.js.map +1 -1
- package/mjs/lib/inits/migrations/Migration.d.ts +14 -27
- package/mjs/lib/inits/migrations/Migration.js +9 -2
- package/mjs/lib/inits/migrations/Migration.js.map +1 -1
- package/mjs/lib/inits/migrations/setupMigrations.d.ts +10 -5
- package/mjs/lib/inits/migrations/setupMigrations.js +92 -28
- package/mjs/lib/inits/migrations/setupMigrations.js.map +1 -1
- package/mjs/lib/inits/setupInit.d.ts +2 -2
- package/mjs/lib/inits/setupInit.js +29 -5
- package/mjs/lib/inits/setupInit.js.map +1 -1
- package/mjs/lib/inits/setupInstall.d.ts +1 -1
- package/mjs/lib/inits/setupInstall.js +4 -5
- package/mjs/lib/inits/setupInstall.js.map +1 -1
- package/mjs/lib/inits/setupUninstall.d.ts +1 -1
- package/mjs/lib/inits/setupUninstall.js +1 -1
- package/mjs/lib/inits/setupUninstall.js.map +1 -1
- package/mjs/lib/mainFn/CommandController.d.ts +7 -4
- package/mjs/lib/mainFn/CommandController.js +17 -9
- package/mjs/lib/mainFn/CommandController.js.map +1 -1
- package/mjs/lib/mainFn/Daemon.d.ts +4 -2
- package/mjs/lib/mainFn/Daemon.js +7 -3
- package/mjs/lib/mainFn/Daemon.js.map +1 -1
- package/mjs/lib/mainFn/Daemons.d.ts +2 -2
- package/mjs/lib/mainFn/HealthDaemon.d.ts +6 -3
- package/mjs/lib/mainFn/HealthDaemon.js +22 -21
- package/mjs/lib/mainFn/HealthDaemon.js.map +1 -1
- package/mjs/lib/manifest/ManifestTypes.d.ts +1 -10
- package/mjs/lib/manifest/setupManifest.d.ts +2 -2
- package/mjs/lib/manifest/setupManifest.js +6 -2
- package/mjs/lib/manifest/setupManifest.js.map +1 -1
- package/mjs/lib/osBindings/Manifest.d.ts +2 -0
- package/mjs/lib/osBindings/PackageDataEntry.d.ts +2 -0
- package/mjs/lib/osBindings/SetDataVersionParams.d.ts +3 -0
- package/mjs/lib/osBindings/SetDataVersionParams.js +3 -0
- package/mjs/lib/osBindings/SetDataVersionParams.js.map +1 -0
- package/mjs/lib/osBindings/index.d.ts +1 -3
- package/mjs/lib/s9pk/merkleArchive/varint.js +2 -1
- package/mjs/lib/s9pk/merkleArchive/varint.js.map +1 -1
- package/mjs/lib/test/configBuilder.test.js +7 -4
- package/mjs/lib/test/configBuilder.test.js.map +1 -1
- package/mjs/lib/test/graph.test.d.ts +1 -0
- package/mjs/lib/test/graph.test.js +76 -0
- package/mjs/lib/test/graph.test.js.map +1 -0
- package/mjs/lib/test/output.sdk.d.ts +2 -214
- package/mjs/lib/test/output.sdk.js +9 -3
- package/mjs/lib/test/output.sdk.js.map +1 -1
- package/mjs/lib/test/startosTypeValidation.test.js +2 -0
- package/mjs/lib/test/startosTypeValidation.test.js.map +1 -1
- package/mjs/lib/types.d.ts +18 -14
- package/mjs/lib/types.js.map +1 -1
- package/mjs/lib/util/Overlay.d.ts +39 -2
- package/mjs/lib/util/Overlay.js +37 -5
- package/mjs/lib/util/Overlay.js.map +1 -1
- package/mjs/lib/util/asError.d.ts +1 -0
- package/mjs/lib/util/asError.js +7 -0
- package/mjs/lib/util/asError.js.map +1 -0
- package/mjs/lib/util/graph.d.ts +19 -0
- package/mjs/lib/util/graph.js +201 -0
- package/mjs/lib/util/graph.js.map +1 -0
- package/mjs/lib/util/index.d.ts +1 -0
- package/mjs/lib/util/index.js +1 -0
- package/mjs/lib/util/index.js.map +1 -1
- package/mjs/lib/version/VersionGraph.d.ts +18 -0
- package/mjs/lib/version/VersionGraph.js +102 -0
- package/mjs/lib/version/VersionGraph.js.map +1 -0
- package/mjs/lib/version/VersionInfo.d.ts +44 -0
- package/mjs/lib/version/VersionInfo.js +45 -0
- package/mjs/lib/version/VersionInfo.js.map +1 -0
- package/mjs/lib/version/index.d.ts +2 -0
- package/mjs/lib/version/index.js +3 -0
- package/mjs/lib/version/index.js.map +1 -0
- package/mjs/lib/versionInfo/VersionInfo.d.ts +44 -0
- package/mjs/lib/versionInfo/VersionInfo.js +45 -0
- package/mjs/lib/versionInfo/VersionInfo.js.map +1 -0
- package/mjs/lib/versionInfo/setupVersionGraph.d.ts +19 -0
- package/mjs/lib/versionInfo/setupVersionGraph.js +105 -0
- package/mjs/lib/versionInfo/setupVersionGraph.js.map +1 -0
- package/mjs/lib/versionInfo/setupVersionInfo.d.ts +19 -0
- package/mjs/lib/versionInfo/setupVersionInfo.js +105 -0
- package/mjs/lib/versionInfo/setupVersionInfo.js.map +1 -0
- package/package.json +1 -1
|
@@ -2,43 +2,107 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.setupMigrations = exports.Migrations = void 0;
|
|
4
4
|
const exver_1 = require("../../exver");
|
|
5
|
+
const graph_1 = require("../../util/graph");
|
|
5
6
|
const once_1 = require("../../util/once");
|
|
7
|
+
const Migration_1 = require("./Migration");
|
|
6
8
|
class Migrations {
|
|
7
9
|
constructor(manifest, migrations) {
|
|
8
10
|
this.manifest = manifest;
|
|
9
|
-
this.migrations = migrations;
|
|
10
|
-
this.sortedMigrations = (0, once_1.once)(() => {
|
|
11
|
-
const migrationsAsVersions = this.migrations
|
|
12
|
-
.map((x) => [exver_1.ExtendedVersion.parse(x.options.version), x])
|
|
13
|
-
.filter(([v, _]) => v.flavor === this.currentVersion().flavor);
|
|
14
|
-
migrationsAsVersions.sort((a, b) => a[0].compareForSort(b[0]));
|
|
15
|
-
return migrationsAsVersions;
|
|
16
|
-
});
|
|
17
11
|
this.currentVersion = (0, once_1.once)(() => exver_1.ExtendedVersion.parse(this.manifest.version));
|
|
12
|
+
this.canMigrateFrom = (0, once_1.once)(() => Array.from(this.migrationGraph().reverseBfs((v) => (v.metadata instanceof exver_1.VersionRange &&
|
|
13
|
+
v.metadata.satisfiedBy(this.currentVersion())) ||
|
|
14
|
+
(v.metadata instanceof exver_1.ExtendedVersion &&
|
|
15
|
+
v.metadata.equals(this.currentVersion())))).reduce((acc, x) => acc.or(x.metadata instanceof exver_1.VersionRange
|
|
16
|
+
? x.metadata
|
|
17
|
+
: exver_1.VersionRange.anchor("=", x.metadata)), exver_1.VersionRange.none()));
|
|
18
|
+
this.canMigrateTo = (0, once_1.once)(() => Array.from(this.migrationGraph().bfs((v) => (v.metadata instanceof exver_1.VersionRange &&
|
|
19
|
+
v.metadata.satisfiedBy(this.currentVersion())) ||
|
|
20
|
+
(v.metadata instanceof exver_1.ExtendedVersion &&
|
|
21
|
+
v.metadata.equals(this.currentVersion())))).reduce((acc, x) => acc.or(x.metadata instanceof exver_1.VersionRange
|
|
22
|
+
? x.metadata
|
|
23
|
+
: exver_1.VersionRange.anchor("=", x.metadata)), exver_1.VersionRange.none()));
|
|
24
|
+
this.migrationGraph = (0, once_1.once)(() => {
|
|
25
|
+
const flavorMap = migrations.reduce((acc, x) => {
|
|
26
|
+
const v = exver_1.ExtendedVersion.parse(x.options.version);
|
|
27
|
+
const flavor = v.flavor || "";
|
|
28
|
+
if (!(flavor in acc)) {
|
|
29
|
+
acc[flavor] = [];
|
|
30
|
+
}
|
|
31
|
+
acc[flavor].push({
|
|
32
|
+
fromRange: x.options.fromRange
|
|
33
|
+
? exver_1.VersionRange.parse(x.options.fromRange)
|
|
34
|
+
: undefined,
|
|
35
|
+
toVersion: v,
|
|
36
|
+
up: x.up,
|
|
37
|
+
down: x.down,
|
|
38
|
+
});
|
|
39
|
+
return acc;
|
|
40
|
+
}, {});
|
|
41
|
+
const graph = new graph_1.Graph();
|
|
42
|
+
for (let flavor in flavorMap) {
|
|
43
|
+
flavorMap[flavor].sort((a, b) => a.toVersion.compareForSort(b.toVersion));
|
|
44
|
+
const last = flavorMap[flavor][flavorMap[flavor].length - 1];
|
|
45
|
+
if (!last || last.toVersion.lessThan(this.currentVersion())) {
|
|
46
|
+
flavorMap[flavor].push({
|
|
47
|
+
toVersion: this.currentVersion(),
|
|
48
|
+
up: async () => { },
|
|
49
|
+
down: async () => { },
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
let prev;
|
|
53
|
+
for (let migration of flavorMap[flavor]) {
|
|
54
|
+
migration.vTo =
|
|
55
|
+
graph
|
|
56
|
+
.findVertex((v) => v.metadata instanceof exver_1.ExtendedVersion &&
|
|
57
|
+
v.metadata.equals(migration.toVersion))
|
|
58
|
+
.next().value || graph.addVertex(migration.toVersion, [], []);
|
|
59
|
+
const fromRange = migration.fromRange ||
|
|
60
|
+
(prev
|
|
61
|
+
? exver_1.VersionRange.anchor(">=", prev).and(exver_1.VersionRange.anchor("<", migration.toVersion))
|
|
62
|
+
: exver_1.VersionRange.anchor("<", migration.toVersion));
|
|
63
|
+
prev = migration.toVersion;
|
|
64
|
+
const vFrom = graph.addVertex(fromRange, [], []);
|
|
65
|
+
if (migration.up !== Migration_1.IMPOSSIBLE) {
|
|
66
|
+
graph.addEdge(migration.up, vFrom, migration.vTo);
|
|
67
|
+
}
|
|
68
|
+
if (migration.down) {
|
|
69
|
+
graph.addEdge(migration.down, migration.vTo, vFrom);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
for (let flavor in flavorMap) {
|
|
74
|
+
for (let migration of flavorMap[flavor]) {
|
|
75
|
+
if (migration.vTo) {
|
|
76
|
+
for (let vertex of graph.findVertex((v) => v instanceof exver_1.VersionRange && v.satisfiedBy(migration.toVersion))) {
|
|
77
|
+
for (let edge of vertex.edges.filter((v) => v.from === vertex)) {
|
|
78
|
+
graph.addEdge(edge.metadata, migration.vTo, edge.to);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return graph;
|
|
85
|
+
});
|
|
18
86
|
}
|
|
19
87
|
static of(manifest, ...migrations) {
|
|
20
88
|
return new Migrations(manifest, migrations);
|
|
21
89
|
}
|
|
22
|
-
async
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
.
|
|
27
|
-
.
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
const reversed = [...this.sortedMigrations()].reverse();
|
|
36
|
-
for (const [_, migration] of reversed
|
|
37
|
-
.filter((x) => x[0].greaterThan(nextVersionExVer))
|
|
38
|
-
.filter((x) => x[0].lessThanOrEqual(this.currentVersion()))) {
|
|
39
|
-
await migration.down({ effects });
|
|
90
|
+
async migrate({ effects, from, to, }) {
|
|
91
|
+
const graph = this.migrationGraph();
|
|
92
|
+
if (from && to) {
|
|
93
|
+
const path = graph.shortestPath((v) => (v.metadata instanceof exver_1.VersionRange &&
|
|
94
|
+
v.metadata.satisfiedBy(from)) ||
|
|
95
|
+
(v.metadata instanceof exver_1.ExtendedVersion && v.metadata.equals(from)), (v) => (v.metadata instanceof exver_1.VersionRange && v.metadata.satisfiedBy(to)) ||
|
|
96
|
+
(v.metadata instanceof exver_1.ExtendedVersion && v.metadata.equals(to)));
|
|
97
|
+
if (path) {
|
|
98
|
+
for (let edge of path) {
|
|
99
|
+
await edge.metadata({ effects });
|
|
100
|
+
// TODO: track partial migrations
|
|
101
|
+
}
|
|
102
|
+
return;
|
|
40
103
|
}
|
|
41
104
|
}
|
|
105
|
+
throw new Error();
|
|
42
106
|
}
|
|
43
107
|
}
|
|
44
108
|
exports.Migrations = Migrations;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupMigrations.js","sourceRoot":"","sources":["../../../../../lib/inits/migrations/setupMigrations.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"setupMigrations.js","sourceRoot":"","sources":["../../../../../lib/inits/migrations/setupMigrations.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,10 +2,10 @@ import { DependenciesReceipt } from "../config/setupConfig";
|
|
|
2
2
|
import { SetInterfaces } from "../interfaces/setupInterfaces";
|
|
3
3
|
import { ExposedStorePaths } from "../store/setupExposeStore";
|
|
4
4
|
import * as T from "../types";
|
|
5
|
-
import {
|
|
5
|
+
import { VersionGraph } from "../version/VersionGraph";
|
|
6
6
|
import { Install } from "./setupInstall";
|
|
7
7
|
import { Uninstall } from "./setupUninstall";
|
|
8
|
-
export declare function setupInit<Manifest extends T.Manifest, Store>(
|
|
8
|
+
export declare function setupInit<Manifest extends T.Manifest, Store>(versions: VersionGraph<Manifest["version"]>, install: Install<Manifest, Store>, uninstall: Uninstall<Manifest, Store>, setInterfaces: SetInterfaces<Manifest, Store, any, any>, setDependencies: (options: {
|
|
9
9
|
effects: T.Effects;
|
|
10
10
|
input: any;
|
|
11
11
|
}) => Promise<DependenciesReceipt>, exposedStore: ExposedStorePaths): {
|
|
@@ -1,11 +1,24 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.setupInit = void 0;
|
|
4
|
-
|
|
4
|
+
const exver_1 = require("../exver");
|
|
5
|
+
function setupInit(versions, install, uninstall, setInterfaces, setDependencies, exposedStore) {
|
|
5
6
|
return {
|
|
6
7
|
init: async (opts) => {
|
|
7
|
-
await
|
|
8
|
-
|
|
8
|
+
const prev = await opts.effects.getDataVersion();
|
|
9
|
+
if (prev) {
|
|
10
|
+
await versions.migrate({
|
|
11
|
+
effects: opts.effects,
|
|
12
|
+
from: exver_1.ExtendedVersion.parse(prev),
|
|
13
|
+
to: versions.currentVersion(),
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
await install.install(opts);
|
|
18
|
+
await opts.effects.setDataVersion({
|
|
19
|
+
version: versions.current.options.version,
|
|
20
|
+
});
|
|
21
|
+
}
|
|
9
22
|
await setInterfaces({
|
|
10
23
|
...opts,
|
|
11
24
|
input: null,
|
|
@@ -14,8 +27,19 @@ function setupInit(migrations, install, uninstall, setInterfaces, setDependencie
|
|
|
14
27
|
await setDependencies({ effects: opts.effects, input: null });
|
|
15
28
|
},
|
|
16
29
|
uninit: async (opts) => {
|
|
17
|
-
|
|
18
|
-
|
|
30
|
+
if (opts.nextVersion) {
|
|
31
|
+
const prev = await opts.effects.getDataVersion();
|
|
32
|
+
if (prev) {
|
|
33
|
+
await versions.migrate({
|
|
34
|
+
effects: opts.effects,
|
|
35
|
+
from: exver_1.ExtendedVersion.parse(prev),
|
|
36
|
+
to: exver_1.ExtendedVersion.parse(opts.nextVersion),
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
await uninstall.uninstall(opts);
|
|
42
|
+
}
|
|
19
43
|
},
|
|
20
44
|
};
|
|
21
45
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupInit.js","sourceRoot":"","sources":["../../../../lib/inits/setupInit.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"setupInit.js","sourceRoot":"","sources":["../../../../lib/inits/setupInit.ts"],"names":[],"mappings":";;;AACA,oCAAwD;AASxD,SAAgB,SAAS,CACvB,QAA2C,EAC3C,OAAiC,EACjC,SAAqC,EACrC,aAAuD,EACvD,eAGkC,EAClC,YAA+B;IAK/B,OAAO;QACL,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACnB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAA;YAChD,IAAI,IAAI,EAAE;gBACR,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;aACH;iBAAM;gBACL,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;aACH;YACD,MAAM,aAAa,CAAC;gBAClB,GAAG,IAAI;gBACP,KAAK,EAAE,IAAI;aACZ,CAAC,CAAA;YACF,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,KAAK,EAAE,IAAI,EAAE,CAAC,CAAA;QAC/D,CAAC;QACD,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YACrB,IAAI,IAAI,CAAC,WAAW,EAAE;gBACpB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAA;gBAChD,IAAI,IAAI,EAAE;oBACR,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;iBACH;aACF;iBAAM;gBACL,MAAM,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;aAChC;QACH,CAAC;KACF,CAAA;AACH,CAAC;AAnDD,8BAmDC"}
|
|
@@ -6,6 +6,6 @@ export declare class Install<Manifest extends T.Manifest, Store> {
|
|
|
6
6
|
readonly fn: InstallFn<Manifest, Store>;
|
|
7
7
|
private constructor();
|
|
8
8
|
static of<Manifest extends T.Manifest, Store>(fn: InstallFn<Manifest, Store>): Install<Manifest, Store>;
|
|
9
|
-
|
|
9
|
+
install({ effects }: Parameters<T.ExpectedExports.init>[0]): Promise<void>;
|
|
10
10
|
}
|
|
11
11
|
export declare function setupInstall<Manifest extends T.Manifest, Store>(fn: InstallFn<Manifest, Store>): Install<Manifest, Store>;
|
|
@@ -8,11 +8,10 @@ class Install {
|
|
|
8
8
|
static of(fn) {
|
|
9
9
|
return new Install(fn);
|
|
10
10
|
}
|
|
11
|
-
async
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
});
|
|
11
|
+
async install({ effects }) {
|
|
12
|
+
await this.fn({
|
|
13
|
+
effects,
|
|
14
|
+
});
|
|
16
15
|
}
|
|
17
16
|
}
|
|
18
17
|
exports.Install = Install;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupInstall.js","sourceRoot":"","sources":["../../../../lib/inits/setupInstall.ts"],"names":[],"mappings":";;;AAKA,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,
|
|
1
|
+
{"version":3,"file":"setupInstall.js","sourceRoot":"","sources":["../../../../lib/inits/setupInstall.ts"],"names":[],"mappings":";;;AAKA,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,EAAyC;QAC9D,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;AAJD,oCAIC"}
|
|
@@ -6,6 +6,6 @@ export declare class Uninstall<Manifest extends T.Manifest, Store> {
|
|
|
6
6
|
readonly fn: UninstallFn<Manifest, Store>;
|
|
7
7
|
private constructor();
|
|
8
8
|
static of<Manifest extends T.Manifest, Store>(fn: UninstallFn<Manifest, Store>): Uninstall<Manifest, Store>;
|
|
9
|
-
|
|
9
|
+
uninstall({ effects, nextVersion, }: Parameters<T.ExpectedExports.uninit>[0]): Promise<void>;
|
|
10
10
|
}
|
|
11
11
|
export declare function setupUninstall<Manifest extends T.Manifest, Store>(fn: UninstallFn<Manifest, Store>): Uninstall<Manifest, Store>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupUninstall.js","sourceRoot":"","sources":["../../../../lib/inits/setupUninstall.ts"],"names":[],"mappings":";;;AAKA,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,
|
|
1
|
+
{"version":3,"file":"setupUninstall.js","sourceRoot":"","sources":["../../../../lib/inits/setupUninstall.ts"],"names":[],"mappings":";;;AAKA,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,GAC6B;QACxC,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;AAJD,wCAIC"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
/// <reference types="node" />
|
|
3
3
|
import * as T from "../types";
|
|
4
|
-
import { MountOptions,
|
|
4
|
+
import { ExecSpawnable, MountOptions, NonDestroyableOverlay } from "../util/Overlay";
|
|
5
5
|
export declare class CommandController {
|
|
6
6
|
readonly runningAnswer: Promise<unknown>;
|
|
7
|
-
readonly overlay
|
|
7
|
+
private readonly overlay;
|
|
8
8
|
readonly pid: number | undefined;
|
|
9
9
|
readonly sigtermTimeout: number;
|
|
10
10
|
private constructor();
|
|
@@ -17,7 +17,7 @@ export declare class CommandController {
|
|
|
17
17
|
path: string;
|
|
18
18
|
options: MountOptions;
|
|
19
19
|
}[] | undefined;
|
|
20
|
-
overlay?:
|
|
20
|
+
overlay?: ExecSpawnable | undefined;
|
|
21
21
|
env?: {
|
|
22
22
|
[variable: string]: string;
|
|
23
23
|
} | undefined;
|
|
@@ -26,7 +26,10 @@ export declare class CommandController {
|
|
|
26
26
|
onStdout?: ((x: Buffer) => void) | undefined;
|
|
27
27
|
onStderr?: ((x: Buffer) => void) | undefined;
|
|
28
28
|
}) => Promise<CommandController>;
|
|
29
|
-
|
|
29
|
+
get nonDestroyableOverlay(): NonDestroyableOverlay;
|
|
30
|
+
wait({ timeout }?: {
|
|
31
|
+
timeout?: number | undefined;
|
|
32
|
+
}): Promise<unknown>;
|
|
30
33
|
term({ signal, timeout }?: {
|
|
31
34
|
signal?: NodeJS.Signals | undefined;
|
|
32
35
|
timeout?: number | undefined;
|
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.CommandController = void 0;
|
|
4
4
|
const _1 = require(".");
|
|
5
5
|
const StartSdk_1 = require("../StartSdk");
|
|
6
|
+
const asError_1 = require("../util/asError");
|
|
6
7
|
const Overlay_1 = require("../util/Overlay");
|
|
7
8
|
const splitCommand_1 = require("../util/splitCommand");
|
|
8
9
|
const Daemons_1 = require("./Daemons");
|
|
@@ -16,10 +17,14 @@ class CommandController {
|
|
|
16
17
|
static of() {
|
|
17
18
|
return async (effects, imageId, command, options) => {
|
|
18
19
|
const commands = (0, splitCommand_1.splitCommand)(command);
|
|
19
|
-
const overlay = options.overlay ||
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
20
|
+
const overlay = options.overlay ||
|
|
21
|
+
(await (async () => {
|
|
22
|
+
const overlay = await Overlay_1.Overlay.of(effects, imageId);
|
|
23
|
+
for (let mount of options.mounts || []) {
|
|
24
|
+
await overlay.mount(mount.options, mount.path);
|
|
25
|
+
}
|
|
26
|
+
return overlay;
|
|
27
|
+
})());
|
|
23
28
|
const childProcess = await overlay.spawn(commands, {
|
|
24
29
|
env: options.env,
|
|
25
30
|
});
|
|
@@ -29,7 +34,7 @@ class CommandController {
|
|
|
29
34
|
console.log(data.toString());
|
|
30
35
|
}));
|
|
31
36
|
childProcess.stderr.on("data", (_b = options.onStderr) !== null && _b !== void 0 ? _b : ((data) => {
|
|
32
|
-
console.error(
|
|
37
|
+
console.error((0, asError_1.asError)(data));
|
|
33
38
|
}));
|
|
34
39
|
childProcess.on("exit", (code) => {
|
|
35
40
|
if (code === 0) {
|
|
@@ -42,7 +47,11 @@ class CommandController {
|
|
|
42
47
|
return new CommandController(answer, overlay, pid, options.sigtermTimeout);
|
|
43
48
|
};
|
|
44
49
|
}
|
|
45
|
-
|
|
50
|
+
get nonDestroyableOverlay() {
|
|
51
|
+
return new Overlay_1.NonDestroyableOverlay(this.overlay);
|
|
52
|
+
}
|
|
53
|
+
async wait({ timeout = StartSdk_1.NO_TIMEOUT } = {}) {
|
|
54
|
+
var _a, _b;
|
|
46
55
|
if (timeout > 0)
|
|
47
56
|
setTimeout(() => {
|
|
48
57
|
this.term();
|
|
@@ -54,10 +63,11 @@ class CommandController {
|
|
|
54
63
|
if (this.pid !== undefined) {
|
|
55
64
|
await (0, Daemons_1.cpExecFile)("pkill", ["-9", "-s", String(this.pid)]).catch((_) => { });
|
|
56
65
|
}
|
|
57
|
-
await this.overlay.destroy().catch((_) => { });
|
|
66
|
+
await ((_b = (_a = this.overlay).destroy) === null || _b === void 0 ? void 0 : _b.call(_a).catch((_) => { }));
|
|
58
67
|
}
|
|
59
68
|
}
|
|
60
69
|
async term({ signal = StartSdk_1.SIGTERM, timeout = this.sigtermTimeout } = {}) {
|
|
70
|
+
var _a, _b;
|
|
61
71
|
if (this.pid === undefined)
|
|
62
72
|
return;
|
|
63
73
|
try {
|
|
@@ -72,7 +82,7 @@ class CommandController {
|
|
|
72
82
|
}
|
|
73
83
|
}
|
|
74
84
|
finally {
|
|
75
|
-
await this.overlay.destroy();
|
|
85
|
+
await ((_b = (_a = this.overlay).destroy) === null || _b === void 0 ? void 0 : _b.call(_a));
|
|
76
86
|
}
|
|
77
87
|
}
|
|
78
88
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommandController.js","sourceRoot":"","sources":["../../../../lib/mainFn/CommandController.ts"],"names":[],"mappings":";;;AAAA,wBAA2C;AAC3C,0CAA0D;AAG1D,
|
|
1
|
+
{"version":3,"file":"CommandController.js","sourceRoot":"","sources":["../../../../lib/mainFn/CommandController.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
/// <reference types="node" />
|
|
3
3
|
import * as T from "../types";
|
|
4
|
-
import { MountOptions, Overlay } from "../util/Overlay";
|
|
4
|
+
import { ExecSpawnable, MountOptions, Overlay } from "../util/Overlay";
|
|
5
|
+
import { CommandController } from "./CommandController";
|
|
5
6
|
/**
|
|
6
7
|
* This is a wrapper around CommandController that has a state of off, where the command shouldn't be running
|
|
7
8
|
* and the others state of running, where it will keep a living running command
|
|
@@ -10,7 +11,8 @@ export declare class Daemon {
|
|
|
10
11
|
private startCommand;
|
|
11
12
|
private commandController;
|
|
12
13
|
private shouldBeRunning;
|
|
13
|
-
|
|
14
|
+
constructor(startCommand: () => Promise<CommandController>);
|
|
15
|
+
get overlay(): undefined | ExecSpawnable;
|
|
14
16
|
static of<Manifest extends T.Manifest>(): <A extends string>(effects: T.Effects, imageId: {
|
|
15
17
|
id: keyof Manifest["images"] & T.ImageId;
|
|
16
18
|
sharedRun?: boolean;
|
package/cjs/lib/mainFn/Daemon.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.Daemon = void 0;
|
|
4
|
+
const asError_1 = require("../util/asError");
|
|
4
5
|
const CommandController_1 = require("./CommandController");
|
|
5
6
|
const TIMEOUT_INCREMENT_MS = 1000;
|
|
6
7
|
const MAX_TIMEOUT_MS = 30000;
|
|
@@ -14,6 +15,10 @@ class Daemon {
|
|
|
14
15
|
this.commandController = null;
|
|
15
16
|
this.shouldBeRunning = false;
|
|
16
17
|
}
|
|
18
|
+
get overlay() {
|
|
19
|
+
var _a;
|
|
20
|
+
return (_a = this.commandController) === null || _a === void 0 ? void 0 : _a.nonDestroyableOverlay;
|
|
21
|
+
}
|
|
17
22
|
static of() {
|
|
18
23
|
return async (effects, imageId, command, options) => {
|
|
19
24
|
const startCommand = () => CommandController_1.CommandController.of()(effects, imageId, command, options);
|
|
@@ -35,7 +40,7 @@ class Daemon {
|
|
|
35
40
|
timeoutCounter = Math.max(MAX_TIMEOUT_MS, timeoutCounter);
|
|
36
41
|
}
|
|
37
42
|
}).catch((err) => {
|
|
38
|
-
console.error(err);
|
|
43
|
+
console.error((0, asError_1.asError)(err));
|
|
39
44
|
});
|
|
40
45
|
}
|
|
41
46
|
async term(termOptions) {
|
|
@@ -44,7 +49,7 @@ class Daemon {
|
|
|
44
49
|
async stop(termOptions) {
|
|
45
50
|
var _a;
|
|
46
51
|
this.shouldBeRunning = false;
|
|
47
|
-
await ((_a = this.commandController) === null || _a === void 0 ? void 0 : _a.term(termOptions).catch((e) => console.error(e)));
|
|
52
|
+
await ((_a = this.commandController) === null || _a === void 0 ? void 0 : _a.term({ ...termOptions }).catch((e) => console.error((0, asError_1.asError)(e))));
|
|
48
53
|
this.commandController = null;
|
|
49
54
|
}
|
|
50
55
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Daemon.js","sourceRoot":"","sources":["../../../../lib/mainFn/Daemon.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"Daemon.js","sourceRoot":"","sources":["../../../../lib/mainFn/Daemon.ts"],"names":[],"mappings":";;;AACA,6CAAyC;AAEzC,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,OAAO;;QACT,OAAO,MAAA,IAAI,CAAC,iBAAiB,0CAAE,qBAAqB,CAAA;IACtD,CAAC;IACD,MAAM,CAAC,EAAE;QACP,OAAO,KAAK,EACV,OAAkB,EAClB,OAGC,EACD,OAAsB,EACtB,OAaC,EACD,EAAE;YACF,MAAM,YAAY,GAAG,GAAG,EAAE,CACxB,qCAAiB,CAAC,EAAE,EAAY,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAA;YACtE,OAAO,IAAI,MAAM,CAAC,YAAY,CAAC,CAAA;QACjC,CAAC,CAAA;IACH,CAAC;IACD,KAAK,CAAC,KAAK;QACT,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,OAAM;SACP;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;gBAC3B,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;aAC1D;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,CAAA,MAAA,IAAI,CAAC,iBAAiB,0CACxB,IAAI,CAAC,EAAE,GAAG,WAAW,EAAE,EACxB,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,IAAA,iBAAO,EAAC,CAAC,CAAC,CAAC,CAAC,CAAA,CAAA;QAC1C,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAA;IAC/B,CAAC;CACF;AArED,wBAqEC"}
|
|
@@ -6,7 +6,7 @@ import { HealthCheckResult } from "../health/checkFns";
|
|
|
6
6
|
import { Trigger } from "../trigger";
|
|
7
7
|
import * as T from "../types";
|
|
8
8
|
import { Mounts } from "./Mounts";
|
|
9
|
-
import { MountOptions
|
|
9
|
+
import { MountOptions } from "../util/Overlay";
|
|
10
10
|
import * as CP from "node:child_process";
|
|
11
11
|
export { Daemon } from "./Daemon";
|
|
12
12
|
export { CommandController } from "./CommandController";
|
|
@@ -42,7 +42,7 @@ export declare const runCommand: <Manifest extends T.Manifest>() => <A extends s
|
|
|
42
42
|
path: string;
|
|
43
43
|
options: MountOptions;
|
|
44
44
|
}[] | undefined;
|
|
45
|
-
overlay?: Overlay | undefined;
|
|
45
|
+
overlay?: import("../util/Overlay").ExecSpawnable | undefined;
|
|
46
46
|
env?: {
|
|
47
47
|
[variable: string]: string;
|
|
48
48
|
} | undefined;
|
|
@@ -11,15 +11,17 @@ import { Effects } from "../types";
|
|
|
11
11
|
*
|
|
12
12
|
*/
|
|
13
13
|
export declare class HealthDaemon {
|
|
14
|
-
|
|
15
|
-
readonly daemon: Promise<Daemon>;
|
|
14
|
+
private readonly daemon;
|
|
16
15
|
readonly daemonIndex: number;
|
|
17
|
-
readonly dependencies
|
|
16
|
+
private readonly dependencies;
|
|
18
17
|
readonly id: string;
|
|
19
18
|
readonly ids: string[];
|
|
20
19
|
readonly ready: Ready;
|
|
21
20
|
readonly effects: Effects;
|
|
22
21
|
readonly sigtermTimeout: number;
|
|
22
|
+
private _health;
|
|
23
|
+
private healthWatchers;
|
|
24
|
+
private running;
|
|
23
25
|
constructor(daemon: Promise<Daemon>, daemonIndex: number, dependencies: HealthDaemon[], id: string, ids: string[], ready: Ready, effects: Effects, sigtermTimeout?: number);
|
|
24
26
|
/** Run after we want to do cleanup */
|
|
25
27
|
term(termOptions?: {
|
|
@@ -30,6 +32,7 @@ export declare class HealthDaemon {
|
|
|
30
32
|
addWatcher(watcher: () => unknown): void;
|
|
31
33
|
get health(): Readonly<HealthCheckResult>;
|
|
32
34
|
private changeRunning;
|
|
35
|
+
private healthCheckCleanup;
|
|
33
36
|
private turnOffHealthCheck;
|
|
34
37
|
private setupHealthCheck;
|
|
35
38
|
private setHealth;
|