mirror of
https://github.com/Start9Labs/start-os.git
synced 2026-03-30 04:01:58 +00:00
* bugfixes * update fe types * implement new registry types in marketplace and ui * fix marketplace types to have default params * add alt implementation toggle * merge cleanup * more cleanup and notes * fix build * cleanup sync with next/minor * add exver JS parser * parse ValidExVer to string * update types to interface * add VersionRange and comparative functions * Parse ExtendedVersion from string * add conjunction, disjunction, and inversion logic * consider flavor in satisfiedBy fn * consider prerelease for ordering * add compare fn for sorting * rename fns for consistency * refactoring * update compare fn to return null if flavors don't match * begin simplifying dependencies * under construction * wip * add dependency metadata to CurrentDependencyInfo * ditch inheritance for recursive VersionRange constructor. Recursive 'satisfiedBy' fn wip * preprocess manifest * misc fixes * use sdk version as osVersion in manifest * chore: Change the type to just validate and not generate all solutions. * add publishedAt * fix pegjs exports * integrate exver into sdk * misc fixes * complete satisfiedBy fn * refactor - use greaterThanOrEqual and lessThanOrEqual fns * fix tests * update dependency details * update types * remove interim types * rename alt implementation to flavor * cleanup os update * format exver.ts * add s9pk parsing endpoints * fix build * update to exver * exver and bug fixes * update static endpoints + cleanup * cleanup * update static proxy verification * make mocks more robust; fix dep icon fallback; cleanup * refactor alert versions and update fixtures * registry bugfixes * misc fixes * cleanup unused * convert patchdb ui seed to camelCase * update otherVersions type * change otherVersions: null to 'none' * refactor and complete feature * improve static endpoints * fix install params * mask systemd-networkd-wait-online * fix static file fetching * include non-matching versions in otherVersions * convert release notes to modal and clean up displayExver * alert for no other versions * Fix ack-instructions casing * fix indeterminate loader on service install --------- Co-authored-by: Aiden McClelland <me@drbonez.dev> Co-authored-by: Shadowy Super Coder <musashidisciple@proton.me> Co-authored-by: Aiden McClelland <3732071+dr-bonez@users.noreply.github.com> Co-authored-by: J H <dragondef@gmail.com> Co-authored-by: Matt Hill <mattnine@protonmail.com>
82 lines
2.4 KiB
TypeScript
82 lines
2.4 KiB
TypeScript
import { Effects } from "../types"
|
|
import { CheckResult } from "./checkFns/CheckResult"
|
|
import { HealthReceipt } from "./HealthReceipt"
|
|
import { Trigger } from "../trigger"
|
|
import { TriggerInput } from "../trigger/TriggerInput"
|
|
import { defaultTrigger } from "../trigger/defaultTrigger"
|
|
import { once } from "../util/once"
|
|
import { Overlay } from "../util/Overlay"
|
|
import { object, unknown } from "ts-matches"
|
|
import * as T from "../types"
|
|
|
|
export type HealthCheckParams<Manifest extends T.Manifest> = {
|
|
effects: Effects
|
|
name: string
|
|
image: {
|
|
id: keyof Manifest["images"] & T.ImageId
|
|
sharedRun?: boolean
|
|
}
|
|
trigger?: Trigger
|
|
fn(overlay: Overlay): Promise<CheckResult> | CheckResult
|
|
onFirstSuccess?: () => unknown | Promise<unknown>
|
|
}
|
|
|
|
export function healthCheck<Manifest extends T.Manifest>(
|
|
o: HealthCheckParams<Manifest>,
|
|
) {
|
|
new Promise(async () => {
|
|
const overlay = await Overlay.of(o.effects, o.image)
|
|
try {
|
|
let currentValue: TriggerInput = {
|
|
hadSuccess: false,
|
|
}
|
|
const getCurrentValue = () => currentValue
|
|
const trigger = (o.trigger ?? defaultTrigger)(getCurrentValue)
|
|
const triggerFirstSuccess = once(() =>
|
|
Promise.resolve(
|
|
"onFirstSuccess" in o && o.onFirstSuccess
|
|
? o.onFirstSuccess()
|
|
: undefined,
|
|
),
|
|
)
|
|
for (
|
|
let res = await trigger.next();
|
|
!res.done;
|
|
res = await trigger.next()
|
|
) {
|
|
try {
|
|
const { status, message } = await o.fn(overlay)
|
|
await o.effects.setHealth({
|
|
name: o.name,
|
|
id: o.name,
|
|
result: status,
|
|
message: message || "",
|
|
})
|
|
currentValue.hadSuccess = true
|
|
currentValue.lastResult = "success"
|
|
await triggerFirstSuccess().catch((err) => {
|
|
console.error(err)
|
|
})
|
|
} catch (e) {
|
|
await o.effects.setHealth({
|
|
name: o.name,
|
|
id: o.name,
|
|
result: "failure",
|
|
message: asMessage(e) || "",
|
|
})
|
|
currentValue.lastResult = "failure"
|
|
}
|
|
}
|
|
} finally {
|
|
await overlay.destroy()
|
|
}
|
|
})
|
|
return {} as HealthReceipt
|
|
}
|
|
function asMessage(e: unknown) {
|
|
if (object({ message: unknown }).test(e)) return String(e.message)
|
|
const value = String(e)
|
|
if (value.length == null) return null
|
|
return value
|
|
}
|