@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.
Files changed (205) hide show
  1. package/base/lib/Effects.d.ts +2 -9
  2. package/base/lib/actions/index.d.ts +4 -4
  3. package/base/lib/actions/index.js.map +1 -1
  4. package/base/lib/actions/input/builder/inputSpec.js.map +1 -1
  5. package/base/lib/actions/input/builder/value.d.ts +3 -0
  6. package/base/lib/actions/input/builder/value.js +87 -111
  7. package/base/lib/actions/input/builder/value.js.map +1 -1
  8. package/base/lib/actions/input/builder/variants.js.map +1 -1
  9. package/base/lib/actions/input/index.js +17 -7
  10. package/base/lib/actions/input/index.js.map +1 -1
  11. package/base/lib/actions/input/inputSpecConstants.js +2 -2
  12. package/base/lib/actions/input/inputSpecConstants.js.map +1 -1
  13. package/base/lib/actions/input/inputSpecTypes.js +1 -2
  14. package/base/lib/actions/input/inputSpecTypes.js.map +1 -1
  15. package/base/lib/actions/setupActions.d.ts +3 -3
  16. package/base/lib/actions/setupActions.js.map +1 -1
  17. package/base/lib/dependencies/dependencies.js +1 -2
  18. package/base/lib/dependencies/dependencies.js.map +1 -1
  19. package/base/lib/dependencies/setupDependencies.d.ts +1 -1
  20. package/base/lib/dependencies/setupDependencies.js +5 -4
  21. package/base/lib/dependencies/setupDependencies.js.map +1 -1
  22. package/base/lib/exver/exver.js.map +1 -1
  23. package/base/lib/exver/index.js +18 -9
  24. package/base/lib/exver/index.js.map +1 -1
  25. package/base/lib/index.js +17 -7
  26. package/base/lib/index.js.map +1 -1
  27. package/base/lib/interfaces/Host.d.ts +6 -13
  28. package/base/lib/interfaces/Host.js +3 -21
  29. package/base/lib/interfaces/Host.js.map +1 -1
  30. package/base/lib/interfaces/Origin.d.ts +4 -4
  31. package/base/lib/interfaces/Origin.js +1 -2
  32. package/base/lib/interfaces/Origin.js.map +1 -1
  33. package/base/lib/interfaces/ServiceInterfaceBuilder.d.ts +0 -2
  34. package/base/lib/interfaces/ServiceInterfaceBuilder.js.map +1 -1
  35. package/base/lib/osBindings/AcmeProvider.d.ts +1 -0
  36. package/base/lib/osBindings/{HostKind.js → AcmeProvider.js} +1 -1
  37. package/base/lib/osBindings/AcmeProvider.js.map +1 -0
  38. package/base/lib/osBindings/AcmeSettings.d.ts +0 -8
  39. package/base/lib/osBindings/BindInfo.d.ts +2 -2
  40. package/base/lib/osBindings/BindParams.d.ts +0 -2
  41. package/base/lib/osBindings/BindingSetPublicParams.d.ts +4 -0
  42. package/base/lib/osBindings/BindingSetPublicParams.js +4 -0
  43. package/base/lib/osBindings/BindingSetPublicParams.js.map +1 -0
  44. package/base/lib/osBindings/DomainConfig.d.ts +5 -0
  45. package/base/lib/osBindings/{GetPrimaryUrlParams.js → DomainConfig.js} +1 -1
  46. package/base/lib/osBindings/DomainConfig.js.map +1 -0
  47. package/base/lib/osBindings/ExportServiceInterfaceParams.d.ts +0 -1
  48. package/base/lib/osBindings/ForgetInterfaceParams.d.ts +3 -0
  49. package/base/lib/osBindings/ForgetInterfaceParams.js +4 -0
  50. package/base/lib/osBindings/ForgetInterfaceParams.js.map +1 -0
  51. package/base/lib/osBindings/Host.d.ts +5 -4
  52. package/base/lib/osBindings/HostAddress.d.ts +3 -0
  53. package/base/lib/osBindings/HostAddress.js +0 -1
  54. package/base/lib/osBindings/HostAddress.js.map +1 -1
  55. package/base/lib/osBindings/ImageMetadata.d.ts +2 -0
  56. package/base/lib/osBindings/IpHostname.d.ts +1 -0
  57. package/base/lib/osBindings/IpInfo.d.ts +6 -4
  58. package/base/lib/osBindings/IpInfo.js +0 -1
  59. package/base/lib/osBindings/IpInfo.js.map +1 -1
  60. package/base/lib/osBindings/Manifest.d.ts +2 -1
  61. package/base/lib/osBindings/NetworkInterfaceInfo.d.ts +1 -2
  62. package/base/lib/osBindings/{SetPublicParams.d.ts → NetworkInterfaceSetPublicParams.d.ts} +1 -1
  63. package/base/lib/osBindings/NetworkInterfaceSetPublicParams.js +4 -0
  64. package/base/lib/osBindings/NetworkInterfaceSetPublicParams.js.map +1 -0
  65. package/base/lib/osBindings/NetworkInterfaceType.d.ts +1 -0
  66. package/base/lib/osBindings/{SetPublicParams.js → NetworkInterfaceType.js} +1 -1
  67. package/base/lib/osBindings/NetworkInterfaceType.js.map +1 -0
  68. package/base/lib/osBindings/PackageVersionInfo.d.ts +2 -1
  69. package/base/lib/osBindings/ServerInfo.d.ts +9 -10
  70. package/base/lib/osBindings/ServiceInterface.d.ts +0 -1
  71. package/base/lib/osBindings/SetupResult.d.ts +1 -1
  72. package/base/lib/osBindings/TestSmtpParams.d.ts +8 -0
  73. package/base/lib/osBindings/{LanInfo.js → TestSmtpParams.js} +1 -1
  74. package/base/lib/osBindings/TestSmtpParams.js.map +1 -0
  75. package/base/lib/osBindings/index.d.ts +11 -3
  76. package/base/lib/s9pk/index.js +7 -10
  77. package/base/lib/s9pk/index.js.map +1 -1
  78. package/base/lib/s9pk/merkleArchive/directoryContents.js +1 -1
  79. package/base/lib/s9pk/merkleArchive/directoryContents.js.map +1 -1
  80. package/base/lib/s9pk/merkleArchive/fileContents.js.map +1 -1
  81. package/base/lib/s9pk/merkleArchive/index.js +1 -1
  82. package/base/lib/s9pk/merkleArchive/index.js.map +1 -1
  83. package/base/lib/s9pk/merkleArchive/varint.js +2 -2
  84. package/base/lib/s9pk/merkleArchive/varint.js.map +1 -1
  85. package/base/lib/types.d.ts +5 -28
  86. package/base/lib/types.js +25 -9
  87. package/base/lib/types.js.map +1 -1
  88. package/base/lib/util/GetSystemSmtp.d.ts +9 -4
  89. package/base/lib/util/GetSystemSmtp.js +20 -2
  90. package/base/lib/util/GetSystemSmtp.js.map +1 -1
  91. package/base/lib/util/Hostname.js +1 -2
  92. package/base/lib/util/Hostname.js.map +1 -1
  93. package/base/lib/util/PathBuilder.d.ts +1 -1
  94. package/base/lib/util/PathBuilder.js.map +1 -1
  95. package/base/lib/util/asError.js.map +1 -1
  96. package/base/lib/util/deepEqual.js +1 -2
  97. package/base/lib/util/deepEqual.js.map +1 -1
  98. package/base/lib/util/deepMerge.js +2 -3
  99. package/base/lib/util/deepMerge.js.map +1 -1
  100. package/base/lib/util/getDefaultString.js +1 -2
  101. package/base/lib/util/getDefaultString.js.map +1 -1
  102. package/base/lib/util/getRandomCharInSet.js +1 -2
  103. package/base/lib/util/getRandomCharInSet.js.map +1 -1
  104. package/base/lib/util/getRandomString.js +1 -2
  105. package/base/lib/util/getRandomString.js.map +1 -1
  106. package/base/lib/util/getServiceInterface.d.ts +7 -9
  107. package/base/lib/util/getServiceInterface.js +27 -19
  108. package/base/lib/util/getServiceInterface.js.map +1 -1
  109. package/base/lib/util/getServiceInterfaces.d.ts +7 -3
  110. package/base/lib/util/getServiceInterfaces.js +23 -18
  111. package/base/lib/util/getServiceInterfaces.js.map +1 -1
  112. package/base/lib/util/graph.js.map +1 -1
  113. package/base/lib/util/index.js +17 -7
  114. package/base/lib/util/index.js.map +1 -1
  115. package/base/lib/util/nullIfEmpty.js +1 -2
  116. package/base/lib/util/nullIfEmpty.js.map +1 -1
  117. package/base/lib/util/once.js +1 -2
  118. package/base/lib/util/once.js.map +1 -1
  119. package/base/lib/util/patterns.d.ts +2 -0
  120. package/base/lib/util/patterns.js +37 -19
  121. package/base/lib/util/patterns.js.map +1 -1
  122. package/base/lib/util/regexes.d.ts +20 -11
  123. package/base/lib/util/regexes.js +35 -13
  124. package/base/lib/util/regexes.js.map +1 -1
  125. package/base/lib/util/stringFromStdErrOut.js +2 -3
  126. package/base/lib/util/stringFromStdErrOut.js.map +1 -1
  127. package/package/lib/StartSdk.d.ts +75 -284
  128. package/package/lib/StartSdk.js +72 -33
  129. package/package/lib/StartSdk.js.map +1 -1
  130. package/package/lib/backup/Backups.js +18 -9
  131. package/package/lib/backup/Backups.js.map +1 -1
  132. package/package/lib/backup/setupBackups.js +1 -2
  133. package/package/lib/backup/setupBackups.js.map +1 -1
  134. package/package/lib/health/HealthCheck.d.ts +3 -1
  135. package/package/lib/health/HealthCheck.js +10 -8
  136. package/package/lib/health/HealthCheck.js.map +1 -1
  137. package/package/lib/health/checkFns/checkPortListening.d.ts +1 -1
  138. package/package/lib/health/checkFns/checkPortListening.js +28 -19
  139. package/package/lib/health/checkFns/checkPortListening.js.map +1 -1
  140. package/package/lib/health/checkFns/index.js +2 -2
  141. package/package/lib/health/checkFns/index.js.map +1 -1
  142. package/package/lib/index.js +17 -7
  143. package/package/lib/index.js.map +1 -1
  144. package/package/lib/inits/setupInit.js +1 -2
  145. package/package/lib/inits/setupInit.js.map +1 -1
  146. package/package/lib/inits/setupInstall.js +2 -2
  147. package/package/lib/inits/setupInstall.js.map +1 -1
  148. package/package/lib/inits/setupUninstall.js +2 -2
  149. package/package/lib/inits/setupUninstall.js.map +1 -1
  150. package/package/lib/mainFn/CommandController.d.ts +7 -9
  151. package/package/lib/mainFn/CommandController.js +97 -41
  152. package/package/lib/mainFn/CommandController.js.map +1 -1
  153. package/package/lib/mainFn/Daemon.d.ts +6 -8
  154. package/package/lib/mainFn/Daemon.js +6 -4
  155. package/package/lib/mainFn/Daemon.js.map +1 -1
  156. package/package/lib/mainFn/Daemons.d.ts +21 -21
  157. package/package/lib/mainFn/Daemons.js +24 -15
  158. package/package/lib/mainFn/Daemons.js.map +1 -1
  159. package/package/lib/mainFn/HealthDaemon.d.ts +4 -1
  160. package/package/lib/mainFn/HealthDaemon.js +18 -7
  161. package/package/lib/mainFn/HealthDaemon.js.map +1 -1
  162. package/package/lib/mainFn/Mounts.js.map +1 -1
  163. package/package/lib/mainFn/index.js +1 -1
  164. package/package/lib/mainFn/index.js.map +1 -1
  165. package/package/lib/manifest/setupManifest.js +12 -26
  166. package/package/lib/manifest/setupManifest.js.map +1 -1
  167. package/package/lib/store/getStore.d.ts +6 -2
  168. package/package/lib/store/getStore.js +22 -4
  169. package/package/lib/store/getStore.js.map +1 -1
  170. package/package/lib/test/host.test.js +1 -2
  171. package/package/lib/test/host.test.js.map +1 -1
  172. package/package/lib/test/output.js +386 -297
  173. package/package/lib/test/output.js.map +1 -1
  174. package/package/lib/test/output.sdk.d.ts +137 -126
  175. package/package/lib/test/output.test.js +1 -2
  176. package/package/lib/test/output.test.js.map +1 -1
  177. package/package/lib/trigger/changeOnFirstSuccess.js +2 -3
  178. package/package/lib/trigger/changeOnFirstSuccess.js.map +1 -1
  179. package/package/lib/trigger/cooldownTrigger.js +1 -2
  180. package/package/lib/trigger/cooldownTrigger.js.map +1 -1
  181. package/package/lib/trigger/lastStatus.js +2 -4
  182. package/package/lib/trigger/lastStatus.js.map +1 -1
  183. package/package/lib/util/GetSslCertificate.d.ts +7 -3
  184. package/package/lib/util/GetSslCertificate.js +21 -3
  185. package/package/lib/util/GetSslCertificate.js.map +1 -1
  186. package/package/lib/util/SubContainer.d.ts +4 -5
  187. package/package/lib/util/SubContainer.js +51 -20
  188. package/package/lib/util/SubContainer.js.map +1 -1
  189. package/package/lib/util/fileHelper.d.ts +3 -1
  190. package/package/lib/util/fileHelper.js +55 -20
  191. package/package/lib/util/fileHelper.js.map +1 -1
  192. package/package/lib/version/VersionGraph.js.map +1 -1
  193. package/package/scripts/oldSpecToBuilder.js +49 -45
  194. package/package/scripts/oldSpecToBuilder.js.map +1 -1
  195. package/package.json +3 -3
  196. package/base/lib/dependencies/Dependency.d.ts +0 -29
  197. package/base/lib/dependencies/Dependency.js +0 -10
  198. package/base/lib/dependencies/Dependency.js.map +0 -1
  199. package/base/lib/osBindings/GetPrimaryUrlParams.d.ts +0 -8
  200. package/base/lib/osBindings/GetPrimaryUrlParams.js.map +0 -1
  201. package/base/lib/osBindings/HostKind.d.ts +0 -1
  202. package/base/lib/osBindings/HostKind.js.map +0 -1
  203. package/base/lib/osBindings/LanInfo.d.ts +0 -4
  204. package/base/lib/osBindings/LanInfo.js.map +0 -1
  205. 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":";;;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,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;AAJD,oCAIC"}
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.setupUninstall = exports.Uninstall = void 0;
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":";;;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,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;AAJD,wCAIC"}
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
- id: keyof Manifest["images"] & T.ImageId;
11
+ imageId: keyof Manifest["images"] & T.ImageId;
14
12
  sharedRun?: boolean;
15
13
  } | SubContainer, command: T.CommandType, options: {
16
- subcontainerName?: string | undefined;
17
- sigtermTimeout?: number | undefined;
14
+ subcontainerName?: string;
15
+ sigtermTimeout?: number;
18
16
  mounts?: {
19
17
  path: string;
20
18
  options: MountOptions;
21
- }[] | undefined;
22
- runAsInit?: boolean | undefined;
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?: ((chunk: Buffer | string | any) => void) | undefined;
29
- onStderr?: ((chunk: Buffer | string | any) => void) | undefined;
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
- var _a, _b;
19
- const commands = (0, util_1.splitCommand)(command);
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, (options === null || options === void 0 ? void 0 : options.subcontainerName) || commands.join(" "));
24
- for (let mount of options.mounts || []) {
25
- await subc.mount(mount.options, mount.path);
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
- let childProcess;
30
- if (options.runAsInit) {
31
- childProcess = await subc.launch(commands, {
32
- env: options.env,
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
- else {
36
- childProcess = await subc.spawn(commands, {
37
- env: options.env,
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 ((_b = (_a = this.subcontainer).destroy) === null || _b === void 0 ? void 0 : _b.call(_a).catch((_) => { }));
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 ((_b = (_a = this.subcontainer).destroy) === null || _b === void 0 ? void 0 : _b.call(_a));
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":"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"}
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
- id: keyof Manifest["images"] & T.ImageId;
15
+ imageId: keyof Manifest["images"] & T.ImageId;
18
16
  sharedRun?: boolean;
19
17
  } | SubContainer, command: T.CommandType, options: {
20
- subcontainerName?: string | undefined;
18
+ subcontainerName?: string;
21
19
  mounts?: {
22
20
  path: string;
23
21
  options: MountOptions;
24
- }[] | undefined;
22
+ }[];
25
23
  env?: {
26
24
  [variable: string]: string;
27
25
  } | undefined;
28
26
  cwd?: string | undefined;
29
27
  user?: string | undefined;
30
- onStdout?: ((chunk: Buffer | string | any) => void) | undefined;
31
- onStderr?: ((chunk: Buffer | string | any) => void) | undefined;
32
- sigtermTimeout?: number | undefined;
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
- var _a;
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 ((_a = this.commandController) === null || _a === void 0 ? void 0 : _a.term({ ...termOptions }).catch((e) => console.error((0, asError_1.asError)(e))));
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;;QACpB,OAAO,MAAA,IAAI,CAAC,iBAAiB,0CAAE,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;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;AA5ED,wBA4EC"}
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
- /// <reference types="node" />
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 image in which the daemon runs */
41
- image: {
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
- id: keyof Manifest["images"] & T.ImageId;
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: import("../util/SubContainer").SubContainer | {
62
- id: keyof Manifest["images"] & string;
63
- sharedRun?: boolean | undefined;
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 | undefined;
66
- sigtermTimeout?: number | undefined;
69
+ subcontainerName?: string;
70
+ sigtermTimeout?: number;
67
71
  mounts?: {
68
72
  path: string;
69
73
  options: MountOptions;
70
74
  }[] | undefined;
71
- runAsInit?: boolean | undefined;
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: (options?: {
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 (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
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.image, options.command, {
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 (options) => {
120
+ term: async () => {
113
121
  try {
114
- await Promise.all(this.healthDaemons.map((x) => x.term(options)));
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":"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"}
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
- (_a = this.healthCheckCleanup) === null || _a === void 0 ? void 0 : _a.call(this);
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
- var _a;
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 = ((_a = this.ready.trigger) !== null && _a !== void 0 ? _a : defaultTrigger_1.defaultTrigger)(() => ({
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() {