@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
|
@@ -1,33 +1,20 @@
|
|
|
1
1
|
import { ValidateExVer } from "../../exver";
|
|
2
2
|
import * as T from "../../types";
|
|
3
|
+
export declare const IMPOSSIBLE: unique symbol;
|
|
4
|
+
export type MigrationOptions<Manifest extends T.Manifest, Store, Version extends string> = {
|
|
5
|
+
fromRange?: string;
|
|
6
|
+
version: Version & ValidateExVer<Version>;
|
|
7
|
+
up: ((opts: {
|
|
8
|
+
effects: T.Effects;
|
|
9
|
+
}) => Promise<void>) | typeof IMPOSSIBLE;
|
|
10
|
+
down?: (opts: {
|
|
11
|
+
effects: T.Effects;
|
|
12
|
+
}) => Promise<void>;
|
|
13
|
+
};
|
|
3
14
|
export declare class Migration<Manifest extends T.Manifest, Store, Version extends string> {
|
|
4
|
-
readonly options:
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
effects: T.Effects;
|
|
8
|
-
}) => Promise<void>;
|
|
9
|
-
down: (opts: {
|
|
10
|
-
effects: T.Effects;
|
|
11
|
-
}) => Promise<void>;
|
|
12
|
-
};
|
|
13
|
-
constructor(options: {
|
|
14
|
-
version: Version & ValidateExVer<Version>;
|
|
15
|
-
up: (opts: {
|
|
16
|
-
effects: T.Effects;
|
|
17
|
-
}) => Promise<void>;
|
|
18
|
-
down: (opts: {
|
|
19
|
-
effects: T.Effects;
|
|
20
|
-
}) => Promise<void>;
|
|
21
|
-
});
|
|
22
|
-
static of<Manifest extends T.Manifest, Store, Version extends string>(options: {
|
|
23
|
-
version: Version & ValidateExVer<Version>;
|
|
24
|
-
up: (opts: {
|
|
25
|
-
effects: T.Effects;
|
|
26
|
-
}) => Promise<void>;
|
|
27
|
-
down: (opts: {
|
|
28
|
-
effects: T.Effects;
|
|
29
|
-
}) => Promise<void>;
|
|
30
|
-
}): Migration<Manifest, Store, Version>;
|
|
15
|
+
readonly options: MigrationOptions<Manifest, Store, Version>;
|
|
16
|
+
constructor(options: MigrationOptions<Manifest, Store, Version>);
|
|
17
|
+
static of<Manifest extends T.Manifest, Store, Version extends string>(options: MigrationOptions<Manifest, Store, Version>): Migration<Manifest, Store, Version>;
|
|
31
18
|
up(opts: {
|
|
32
19
|
effects: T.Effects;
|
|
33
20
|
}): Promise<void>;
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
export const IMPOSSIBLE = Symbol("IMPOSSIBLE");
|
|
1
2
|
export class Migration {
|
|
2
3
|
options;
|
|
3
4
|
constructor(options) {
|
|
@@ -7,10 +8,16 @@ export class Migration {
|
|
|
7
8
|
return new Migration(options);
|
|
8
9
|
}
|
|
9
10
|
async up(opts) {
|
|
10
|
-
this.up
|
|
11
|
+
if (this.options.up === IMPOSSIBLE) {
|
|
12
|
+
throw new Error(`impossible to migrate to ${this.options.version} from the current version`);
|
|
13
|
+
}
|
|
14
|
+
return this.options.up(opts);
|
|
11
15
|
}
|
|
12
16
|
async down(opts) {
|
|
13
|
-
this.down
|
|
17
|
+
if (!this.options.down) {
|
|
18
|
+
throw new Error(`impossible to downgrade from ${this.options.version}`);
|
|
19
|
+
}
|
|
20
|
+
return this.options.down(opts);
|
|
14
21
|
}
|
|
15
22
|
}
|
|
16
23
|
//# sourceMappingURL=Migration.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Migration.js","sourceRoot":"","sources":["../../../../../lib/inits/migrations/Migration.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,SAAS;
|
|
1
|
+
{"version":3,"file":"Migration.js","sourceRoot":"","sources":["../../../../../lib/inits/migrations/Migration.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,MAAM,UAAU,GAAG,MAAM,CAAC,YAAY,CAAC,CAAA;AAa9C,MAAM,OAAO,SAAS;IAKC;IAArB,YAAqB,OAAmD;QAAnD,YAAO,GAAP,OAAO,CAA4C;IAAG,CAAC;IAC5E,MAAM,CAAC,EAAE,CACP,OAAmD;QAEnD,OAAO,IAAI,SAAS,CAA2B,OAAO,CAAC,CAAA;IACzD,CAAC;IAED,KAAK,CAAC,EAAE,CAAC,IAA4B;QACnC,IAAI,IAAI,CAAC,OAAO,CAAC,EAAE,KAAK,UAAU,EAAE;YAClC,MAAM,IAAI,KAAK,CACb,4BAA4B,IAAI,CAAC,OAAO,CAAC,OAAO,2BAA2B,CAC5E,CAAA;SACF;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC,CAAA;IAC9B,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,IAA4B;QACrC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE;YACtB,MAAM,IAAI,KAAK,CAAC,gCAAgC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAA;SACxE;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAChC,CAAC;CACF"}
|
|
@@ -1,14 +1,19 @@
|
|
|
1
|
+
import { ExtendedVersion, VersionRange } from "../../exver";
|
|
1
2
|
import * as T from "../../types";
|
|
2
3
|
import { Migration } from "./Migration";
|
|
3
4
|
export declare class Migrations<Manifest extends T.Manifest, Store> {
|
|
4
5
|
readonly manifest: T.Manifest;
|
|
5
|
-
readonly
|
|
6
|
+
private readonly migrationGraph;
|
|
6
7
|
private constructor();
|
|
7
|
-
|
|
8
|
-
private currentVersion;
|
|
8
|
+
currentVersion: () => ExtendedVersion;
|
|
9
9
|
static of<Manifest extends T.Manifest, Store, Migrations extends Array<Migration<Manifest, Store, any>>>(manifest: T.Manifest, ...migrations: EnsureUniqueId<Migrations>): import("./setupMigrations").Migrations<Manifest, Store>;
|
|
10
|
-
|
|
11
|
-
|
|
10
|
+
migrate({ effects, from, to, }: {
|
|
11
|
+
effects: T.Effects;
|
|
12
|
+
from: ExtendedVersion;
|
|
13
|
+
to: ExtendedVersion;
|
|
14
|
+
}): Promise<void>;
|
|
15
|
+
canMigrateFrom: () => VersionRange;
|
|
16
|
+
canMigrateTo: () => VersionRange;
|
|
12
17
|
}
|
|
13
18
|
export declare function setupMigrations<Manifest extends T.Manifest, Store, Migrations extends Array<Migration<Manifest, Store, any>>>(manifest: T.Manifest, ...migrations: EnsureUniqueId<Migrations>): import("./setupMigrations").Migrations<Manifest, Store>;
|
|
14
19
|
export type EnsureUniqueId<A, B = A, ids = never> = B extends [] ? A : B extends [Migration<any, any, infer id>, ...infer Rest] ? (id extends ids ? "One of the ids are not unique"[] : EnsureUniqueId<A, Rest, id | ids>) : "There exists a migration that is not a Migration"[];
|
|
@@ -1,44 +1,108 @@
|
|
|
1
|
-
import { ExtendedVersion } from "../../exver";
|
|
1
|
+
import { ExtendedVersion, VersionRange } from "../../exver";
|
|
2
|
+
import { Graph } from "../../util/graph";
|
|
2
3
|
import { once } from "../../util/once";
|
|
4
|
+
import { IMPOSSIBLE } from "./Migration";
|
|
3
5
|
export class Migrations {
|
|
4
6
|
manifest;
|
|
5
|
-
|
|
7
|
+
migrationGraph;
|
|
6
8
|
constructor(manifest, migrations) {
|
|
7
9
|
this.manifest = manifest;
|
|
8
|
-
this.
|
|
10
|
+
this.migrationGraph = once(() => {
|
|
11
|
+
const flavorMap = migrations.reduce((acc, x) => {
|
|
12
|
+
const v = ExtendedVersion.parse(x.options.version);
|
|
13
|
+
const flavor = v.flavor || "";
|
|
14
|
+
if (!(flavor in acc)) {
|
|
15
|
+
acc[flavor] = [];
|
|
16
|
+
}
|
|
17
|
+
acc[flavor].push({
|
|
18
|
+
fromRange: x.options.fromRange
|
|
19
|
+
? VersionRange.parse(x.options.fromRange)
|
|
20
|
+
: undefined,
|
|
21
|
+
toVersion: v,
|
|
22
|
+
up: x.up,
|
|
23
|
+
down: x.down,
|
|
24
|
+
});
|
|
25
|
+
return acc;
|
|
26
|
+
}, {});
|
|
27
|
+
const graph = new Graph();
|
|
28
|
+
for (let flavor in flavorMap) {
|
|
29
|
+
flavorMap[flavor].sort((a, b) => a.toVersion.compareForSort(b.toVersion));
|
|
30
|
+
const last = flavorMap[flavor][flavorMap[flavor].length - 1];
|
|
31
|
+
if (!last || last.toVersion.lessThan(this.currentVersion())) {
|
|
32
|
+
flavorMap[flavor].push({
|
|
33
|
+
toVersion: this.currentVersion(),
|
|
34
|
+
up: async () => { },
|
|
35
|
+
down: async () => { },
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
let prev;
|
|
39
|
+
for (let migration of flavorMap[flavor]) {
|
|
40
|
+
migration.vTo =
|
|
41
|
+
graph
|
|
42
|
+
.findVertex((v) => v.metadata instanceof ExtendedVersion &&
|
|
43
|
+
v.metadata.equals(migration.toVersion))
|
|
44
|
+
.next().value || graph.addVertex(migration.toVersion, [], []);
|
|
45
|
+
const fromRange = migration.fromRange ||
|
|
46
|
+
(prev
|
|
47
|
+
? VersionRange.anchor(">=", prev).and(VersionRange.anchor("<", migration.toVersion))
|
|
48
|
+
: VersionRange.anchor("<", migration.toVersion));
|
|
49
|
+
prev = migration.toVersion;
|
|
50
|
+
const vFrom = graph.addVertex(fromRange, [], []);
|
|
51
|
+
if (migration.up !== IMPOSSIBLE) {
|
|
52
|
+
graph.addEdge(migration.up, vFrom, migration.vTo);
|
|
53
|
+
}
|
|
54
|
+
if (migration.down) {
|
|
55
|
+
graph.addEdge(migration.down, migration.vTo, vFrom);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
for (let flavor in flavorMap) {
|
|
60
|
+
for (let migration of flavorMap[flavor]) {
|
|
61
|
+
if (migration.vTo) {
|
|
62
|
+
for (let vertex of graph.findVertex((v) => v instanceof VersionRange && v.satisfiedBy(migration.toVersion))) {
|
|
63
|
+
for (let edge of vertex.edges.filter((v) => v.from === vertex)) {
|
|
64
|
+
graph.addEdge(edge.metadata, migration.vTo, edge.to);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
return graph;
|
|
71
|
+
});
|
|
9
72
|
}
|
|
10
|
-
sortedMigrations = once(() => {
|
|
11
|
-
const migrationsAsVersions = this.migrations
|
|
12
|
-
.map((x) => [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
73
|
currentVersion = once(() => ExtendedVersion.parse(this.manifest.version));
|
|
18
74
|
static of(manifest, ...migrations) {
|
|
19
75
|
return new Migrations(manifest, migrations);
|
|
20
76
|
}
|
|
21
|
-
async
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
.
|
|
26
|
-
.
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
const reversed = [...this.sortedMigrations()].reverse();
|
|
35
|
-
for (const [_, migration] of reversed
|
|
36
|
-
.filter((x) => x[0].greaterThan(nextVersionExVer))
|
|
37
|
-
.filter((x) => x[0].lessThanOrEqual(this.currentVersion()))) {
|
|
38
|
-
await migration.down({ effects });
|
|
77
|
+
async migrate({ effects, from, to, }) {
|
|
78
|
+
const graph = this.migrationGraph();
|
|
79
|
+
if (from && to) {
|
|
80
|
+
const path = graph.shortestPath((v) => (v.metadata instanceof VersionRange &&
|
|
81
|
+
v.metadata.satisfiedBy(from)) ||
|
|
82
|
+
(v.metadata instanceof ExtendedVersion && v.metadata.equals(from)), (v) => (v.metadata instanceof VersionRange && v.metadata.satisfiedBy(to)) ||
|
|
83
|
+
(v.metadata instanceof ExtendedVersion && v.metadata.equals(to)));
|
|
84
|
+
if (path) {
|
|
85
|
+
for (let edge of path) {
|
|
86
|
+
await edge.metadata({ effects });
|
|
87
|
+
// TODO: track partial migrations
|
|
88
|
+
}
|
|
89
|
+
return;
|
|
39
90
|
}
|
|
40
91
|
}
|
|
92
|
+
throw new Error();
|
|
41
93
|
}
|
|
94
|
+
canMigrateFrom = once(() => Array.from(this.migrationGraph().reverseBfs((v) => (v.metadata instanceof VersionRange &&
|
|
95
|
+
v.metadata.satisfiedBy(this.currentVersion())) ||
|
|
96
|
+
(v.metadata instanceof ExtendedVersion &&
|
|
97
|
+
v.metadata.equals(this.currentVersion())))).reduce((acc, x) => acc.or(x.metadata instanceof VersionRange
|
|
98
|
+
? x.metadata
|
|
99
|
+
: VersionRange.anchor("=", x.metadata)), VersionRange.none()));
|
|
100
|
+
canMigrateTo = once(() => Array.from(this.migrationGraph().bfs((v) => (v.metadata instanceof VersionRange &&
|
|
101
|
+
v.metadata.satisfiedBy(this.currentVersion())) ||
|
|
102
|
+
(v.metadata instanceof ExtendedVersion &&
|
|
103
|
+
v.metadata.equals(this.currentVersion())))).reduce((acc, x) => acc.or(x.metadata instanceof VersionRange
|
|
104
|
+
? x.metadata
|
|
105
|
+
: VersionRange.anchor("=", x.metadata)), VersionRange.none()));
|
|
42
106
|
}
|
|
43
107
|
export function setupMigrations(manifest, ...migrations) {
|
|
44
108
|
return Migrations.of(manifest, ...migrations);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupMigrations.js","sourceRoot":"","sources":["../../../../../lib/inits/migrations/setupMigrations.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;
|
|
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,8 +1,21 @@
|
|
|
1
|
-
|
|
1
|
+
import { ExtendedVersion } from "../exver";
|
|
2
|
+
export function setupInit(versions, install, uninstall, setInterfaces, setDependencies, exposedStore) {
|
|
2
3
|
return {
|
|
3
4
|
init: async (opts) => {
|
|
4
|
-
await
|
|
5
|
-
|
|
5
|
+
const prev = await opts.effects.getDataVersion();
|
|
6
|
+
if (prev) {
|
|
7
|
+
await versions.migrate({
|
|
8
|
+
effects: opts.effects,
|
|
9
|
+
from: ExtendedVersion.parse(prev),
|
|
10
|
+
to: versions.currentVersion(),
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
await install.install(opts);
|
|
15
|
+
await opts.effects.setDataVersion({
|
|
16
|
+
version: versions.current.options.version,
|
|
17
|
+
});
|
|
18
|
+
}
|
|
6
19
|
await setInterfaces({
|
|
7
20
|
...opts,
|
|
8
21
|
input: null,
|
|
@@ -11,8 +24,19 @@ export function setupInit(migrations, install, uninstall, setInterfaces, setDepe
|
|
|
11
24
|
await setDependencies({ effects: opts.effects, input: null });
|
|
12
25
|
},
|
|
13
26
|
uninit: async (opts) => {
|
|
14
|
-
|
|
15
|
-
|
|
27
|
+
if (opts.nextVersion) {
|
|
28
|
+
const prev = await opts.effects.getDataVersion();
|
|
29
|
+
if (prev) {
|
|
30
|
+
await versions.migrate({
|
|
31
|
+
effects: opts.effects,
|
|
32
|
+
from: ExtendedVersion.parse(prev),
|
|
33
|
+
to: ExtendedVersion.parse(opts.nextVersion),
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
await uninstall.uninstall(opts);
|
|
39
|
+
}
|
|
16
40
|
},
|
|
17
41
|
};
|
|
18
42
|
}
|
|
@@ -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,OAAO,EAAE,eAAe,EAAgB,MAAM,UAAU,CAAA;AASxD,MAAM,UAAU,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,eAAe,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,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC;wBACjC,EAAE,EAAE,eAAe,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"}
|
|
@@ -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>;
|
|
@@ -6,11 +6,10 @@ export class Install {
|
|
|
6
6
|
static of(fn) {
|
|
7
7
|
return new Install(fn);
|
|
8
8
|
}
|
|
9
|
-
async
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
});
|
|
9
|
+
async install({ effects }) {
|
|
10
|
+
await this.fn({
|
|
11
|
+
effects,
|
|
12
|
+
});
|
|
14
13
|
}
|
|
15
14
|
}
|
|
16
15
|
export function setupInstall(fn) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupInstall.js","sourceRoot":"","sources":["../../../../lib/inits/setupInstall.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,OAAO;IACW;IAA7B,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,MAAM,OAAO,OAAO;IACW;IAA7B,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;AAED,MAAM,UAAU,YAAY,CAC1B,EAA8B;IAE9B,OAAO,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,CAAA;AACvB,CAAC"}
|
|
@@ -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,MAAM,OAAO,SAAS;IACS;IAA7B,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,MAAM,OAAO,SAAS;IACS;IAA7B,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;AAED,MAAM,UAAU,cAAc,CAC5B,EAAgC;IAEhC,OAAO,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,CAAA;AACzB,CAAC"}
|
|
@@ -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;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { DEFAULT_SIGTERM_TIMEOUT } from ".";
|
|
2
2
|
import { NO_TIMEOUT, SIGTERM } from "../StartSdk";
|
|
3
|
-
import {
|
|
3
|
+
import { asError } from "../util/asError";
|
|
4
|
+
import { NonDestroyableOverlay, Overlay, } from "../util/Overlay";
|
|
4
5
|
import { splitCommand } from "../util/splitCommand";
|
|
5
6
|
import { cpExecFile } from "./Daemons";
|
|
6
7
|
export class CommandController {
|
|
@@ -17,10 +18,14 @@ export class CommandController {
|
|
|
17
18
|
static of() {
|
|
18
19
|
return async (effects, imageId, command, options) => {
|
|
19
20
|
const commands = splitCommand(command);
|
|
20
|
-
const overlay = options.overlay ||
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
21
|
+
const overlay = options.overlay ||
|
|
22
|
+
(await (async () => {
|
|
23
|
+
const overlay = await Overlay.of(effects, imageId);
|
|
24
|
+
for (let mount of options.mounts || []) {
|
|
25
|
+
await overlay.mount(mount.options, mount.path);
|
|
26
|
+
}
|
|
27
|
+
return overlay;
|
|
28
|
+
})());
|
|
24
29
|
const childProcess = await overlay.spawn(commands, {
|
|
25
30
|
env: options.env,
|
|
26
31
|
});
|
|
@@ -31,7 +36,7 @@ export class CommandController {
|
|
|
31
36
|
}));
|
|
32
37
|
childProcess.stderr.on("data", options.onStderr ??
|
|
33
38
|
((data) => {
|
|
34
|
-
console.error(data
|
|
39
|
+
console.error(asError(data));
|
|
35
40
|
}));
|
|
36
41
|
childProcess.on("exit", (code) => {
|
|
37
42
|
if (code === 0) {
|
|
@@ -44,7 +49,10 @@ export class CommandController {
|
|
|
44
49
|
return new CommandController(answer, overlay, pid, options.sigtermTimeout);
|
|
45
50
|
};
|
|
46
51
|
}
|
|
47
|
-
|
|
52
|
+
get nonDestroyableOverlay() {
|
|
53
|
+
return new NonDestroyableOverlay(this.overlay);
|
|
54
|
+
}
|
|
55
|
+
async wait({ timeout = NO_TIMEOUT } = {}) {
|
|
48
56
|
if (timeout > 0)
|
|
49
57
|
setTimeout(() => {
|
|
50
58
|
this.term();
|
|
@@ -56,7 +64,7 @@ export class CommandController {
|
|
|
56
64
|
if (this.pid !== undefined) {
|
|
57
65
|
await cpExecFile("pkill", ["-9", "-s", String(this.pid)]).catch((_) => { });
|
|
58
66
|
}
|
|
59
|
-
await this.overlay.destroy().catch((_) => { });
|
|
67
|
+
await this.overlay.destroy?.().catch((_) => { });
|
|
60
68
|
}
|
|
61
69
|
}
|
|
62
70
|
async term({ signal = SIGTERM, timeout = this.sigtermTimeout } = {}) {
|
|
@@ -74,7 +82,7 @@ export class CommandController {
|
|
|
74
82
|
}
|
|
75
83
|
}
|
|
76
84
|
finally {
|
|
77
|
-
await this.overlay.destroy();
|
|
85
|
+
await this.overlay.destroy?.();
|
|
78
86
|
}
|
|
79
87
|
}
|
|
80
88
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommandController.js","sourceRoot":"","sources":["../../../../lib/mainFn/CommandController.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,GAAG,CAAA;AAC3C,OAAO,EAAE,UAAU,EAAW,OAAO,EAAE,MAAM,aAAa,CAAA;AAG1D,OAAO,
|
|
1
|
+
{"version":3,"file":"CommandController.js","sourceRoot":"","sources":["../../../../lib/mainFn/CommandController.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,GAAG,CAAA;AAC3C,OAAO,EAAE,UAAU,EAAW,OAAO,EAAE,MAAM,aAAa,CAAA;AAG1D,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACzC,OAAO,EAGL,qBAAqB,EACrB,OAAO,GACR,MAAM,iBAAiB,CAAA;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACnD,OAAO,EAAE,UAAU,EAAU,MAAM,WAAW,CAAA;AAE9C,MAAM,OAAO,iBAAiB;IAEjB;IACQ;IACR;IACA;IAJX,YACW,aAA+B,EACvB,OAAsB,EAC9B,GAAuB,EACvB,iBAAyB,uBAAuB;QAHhD,kBAAa,GAAb,aAAa,CAAkB;QACvB,YAAO,GAAP,OAAO,CAAe;QAC9B,QAAG,GAAH,GAAG,CAAoB;QACvB,mBAAc,GAAd,cAAc,CAAkC;IACxD,CAAC;IACJ,MAAM,CAAC,EAAE;QACP,OAAO,KAAK,EACV,OAAkB,EAClB,OAGC,EACD,OAAsB,EACtB,OAcC,EACD,EAAE;YACF,MAAM,QAAQ,GAAG,YAAY,CAAC,OAAO,CAAC,CAAA;YACtC,MAAM,OAAO,GACX,OAAO,CAAC,OAAO;gBACf,CAAC,MAAM,CAAC,KAAK,IAAI,EAAE;oBACjB,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;oBAClD,KAAK,IAAI,KAAK,IAAI,OAAO,CAAC,MAAM,IAAI,EAAE,EAAE;wBACtC,MAAM,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;qBAC/C;oBACD,OAAO,OAAO,CAAA;gBAChB,CAAC,CAAC,EAAE,CAAC,CAAA;YACP,MAAM,YAAY,GAAG,MAAM,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE;gBACjD,GAAG,EAAE,OAAO,CAAC,GAAG;aACjB,CAAC,CAAA;YACF,MAAM,MAAM,GAAG,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBACnD,YAAY,CAAC,MAAM,CAAC,EAAE,CACpB,MAAM,EACN,OAAO,CAAC,QAAQ;oBACd,CAAC,CAAC,IAAS,EAAE,EAAE;wBACb,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAA;oBAC9B,CAAC,CAAC,CACL,CAAA;gBACD,YAAY,CAAC,MAAM,CAAC,EAAE,CACpB,MAAM,EACN,OAAO,CAAC,QAAQ;oBACd,CAAC,CAAC,IAAS,EAAE,EAAE;wBACb,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAA;oBAC9B,CAAC,CAAC,CACL,CAAA;gBAED,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAS,EAAE,EAAE;oBACpC,IAAI,IAAI,KAAK,CAAC,EAAE;wBACd,OAAO,OAAO,CAAC,IAAI,CAAC,CAAA;qBACrB;oBACD,OAAO,MAAM,CAAC,IAAI,KAAK,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,qBAAqB,IAAI,EAAE,CAAC,CAAC,CAAA;gBACrE,CAAC,CAAC,CAAA;YACJ,CAAC,CAAC,CAAA;YAEF,MAAM,GAAG,GAAG,YAAY,CAAC,GAAG,CAAA;YAE5B,OAAO,IAAI,iBAAiB,CAAC,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE,OAAO,CAAC,cAAc,CAAC,CAAA;QAC5E,CAAC,CAAA;IACH,CAAC;IACD,IAAI,qBAAqB;QACvB,OAAO,IAAI,qBAAqB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;IAChD,CAAC;IACD,KAAK,CAAC,IAAI,CAAC,EAAE,OAAO,GAAG,UAAU,EAAE,GAAG,EAAE;QACtC,IAAI,OAAO,GAAG,CAAC;YACb,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,IAAI,EAAE,CAAA;YACb,CAAC,EAAE,OAAO,CAAC,CAAA;QACb,IAAI;YACF,OAAO,MAAM,IAAI,CAAC,aAAa,CAAA;SAChC;gBAAS;YACR,IAAI,IAAI,CAAC,GAAG,KAAK,SAAS,EAAE;gBAC1B,MAAM,UAAU,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAC7D,CAAC,CAAC,EAAE,EAAE,GAAE,CAAC,CACV,CAAA;aACF;YACD,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,GAAE,CAAC,CAAC,CAAA;SAChD;IACH,CAAC;IACD,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,EAAE,OAAO,GAAG,IAAI,CAAC,cAAc,EAAE,GAAG,EAAE;QACjE,IAAI,IAAI,CAAC,GAAG,KAAK,SAAS;YAAE,OAAM;QAClC,IAAI;YACF,MAAM,UAAU,CAAC,OAAO,EAAE;gBACxB,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,EAAE;gBAC/B,IAAI;gBACJ,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC;aACjB,CAAC,CAAA;YAEF,MAAM,UAAU,GAAG,MAAM,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,CAAC,CAAA;YACvD,IAAI,UAAU,EAAE;gBACd,MAAM,UAAU,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAC7D,CAAC,CAAC,EAAE,EAAE,GAAE,CAAC,CACV,CAAA;aACF;SACF;gBAAS;YACR,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAA;SAC/B;IACH,CAAC;CACF;AAED,SAAS,WAAW,CAClB,GAAW,EACX,OAAO,GAAG,UAAU,EACpB,QAAQ,GAAG,GAAG;IAEd,IAAI,YAAY,GAAG,QAAQ,GAAG,CAAC,CAAA;IAC/B,IAAI,OAAO,IAAI,CAAC,IAAI,OAAO,GAAG,YAAY,EAAE;QAC1C,YAAY,GAAG,OAAO,CAAA;KACvB;IACD,IAAI,WAAW,GAAG,OAAO,CAAA;IACzB,IAAI,OAAO,GAAG,CAAC,EAAE;QACf,IAAI,OAAO,IAAI,QAAQ,EAAE;YACvB,WAAW,IAAI,QAAQ,CAAA;SACxB;aAAM;YACL,WAAW,GAAG,CAAC,CAAA;SAChB;KACF;IACD,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,IAAI,IAAI,GAA0B,IAAI,CAAA;QACtC,IAAI,OAAO,KAAK,CAAC,EAAE;YACjB,IAAI,GAAG,UAAU,CAAC,GAAG,EAAE;gBACrB,WAAW,CAAC,GAAG,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;YACnE,CAAC,EAAE,QAAQ,CAAC,CAAA;SACb;QACD,UAAU,CAAC,IAAI,EAAE,CAAC,SAAS,GAAG,EAAE,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC,IAAI,CACrD,CAAC,CAAC,EAAE,EAAE;YACJ,IAAI,OAAO,KAAK,CAAC,EAAE;gBACjB,OAAO,CAAC,IAAI,CAAC,CAAA;aACd;QACH,CAAC,EACD,CAAC,CAAC,EAAE,EAAE;YACJ,IAAI,IAAI,EAAE;gBACR,YAAY,CAAC,IAAI,CAAC,CAAA;aACnB;YACD,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,IAAI,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE;gBACvD,OAAO,CAAC,KAAK,CAAC,CAAA;aACf;iBAAM;gBACL,MAAM,CAAC,CAAC,CAAC,CAAA;aACV;QACH,CAAC,CACF,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -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/mjs/lib/mainFn/Daemon.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { asError } from "../util/asError";
|
|
1
2
|
import { CommandController } from "./CommandController";
|
|
2
3
|
const TIMEOUT_INCREMENT_MS = 1000;
|
|
3
4
|
const MAX_TIMEOUT_MS = 30000;
|
|
@@ -12,6 +13,9 @@ export class Daemon {
|
|
|
12
13
|
constructor(startCommand) {
|
|
13
14
|
this.startCommand = startCommand;
|
|
14
15
|
}
|
|
16
|
+
get overlay() {
|
|
17
|
+
return this.commandController?.nonDestroyableOverlay;
|
|
18
|
+
}
|
|
15
19
|
static of() {
|
|
16
20
|
return async (effects, imageId, command, options) => {
|
|
17
21
|
const startCommand = () => CommandController.of()(effects, imageId, command, options);
|
|
@@ -33,7 +37,7 @@ export class Daemon {
|
|
|
33
37
|
timeoutCounter = Math.max(MAX_TIMEOUT_MS, timeoutCounter);
|
|
34
38
|
}
|
|
35
39
|
}).catch((err) => {
|
|
36
|
-
console.error(err);
|
|
40
|
+
console.error(asError(err));
|
|
37
41
|
});
|
|
38
42
|
}
|
|
39
43
|
async term(termOptions) {
|
|
@@ -42,8 +46,8 @@ export class Daemon {
|
|
|
42
46
|
async stop(termOptions) {
|
|
43
47
|
this.shouldBeRunning = false;
|
|
44
48
|
await this.commandController
|
|
45
|
-
?.term(termOptions)
|
|
46
|
-
.catch((e) => console.error(e));
|
|
49
|
+
?.term({ ...termOptions })
|
|
50
|
+
.catch((e) => console.error(asError(e)));
|
|
47
51
|
this.commandController = null;
|
|
48
52
|
}
|
|
49
53
|
}
|
|
@@ -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,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AAEzC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAEvD,MAAM,oBAAoB,GAAG,IAAI,CAAA;AACjC,MAAM,cAAc,GAAG,KAAK,CAAA;AAC5B;;;GAGG;AAEH,MAAM,OAAO,MAAM;IAGG;IAFZ,iBAAiB,GAA6B,IAAI,CAAA;IAClD,eAAe,GAAG,KAAK,CAAA;IAC/B,YAAoB,YAA8C;QAA9C,iBAAY,GAAZ,YAAY,CAAkC;IAAG,CAAC;IACtE,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,iBAAiB,EAAE,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,iBAAiB,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,OAAO,CAAC,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,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QAC1C,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAA;IAC/B,CAAC;CACF"}
|
|
@@ -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;
|