mirror of
https://github.com/Start9Labs/start-sdk.git
synced 2026-03-26 10:21:55 +00:00
feat:Deamons need over time after start
This commit is contained in:
@@ -15,7 +15,6 @@ export function healthCheck(o: {
|
||||
}) {
|
||||
new Promise(async () => {
|
||||
let currentValue: TriggerInput = {
|
||||
lastResult: null,
|
||||
hadSuccess: false,
|
||||
}
|
||||
const getCurrentValue = () => currentValue
|
||||
@@ -33,9 +32,9 @@ export function healthCheck(o: {
|
||||
message,
|
||||
})
|
||||
currentValue.hadSuccess = true
|
||||
currentValue.lastResult = "success"
|
||||
currentValue.lastResult = "passing"
|
||||
} catch (_) {
|
||||
currentValue.lastResult = "failure"
|
||||
currentValue.lastResult = "failing"
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
@@ -1,4 +1,6 @@
|
||||
import { HealthStatus } from "../../types"
|
||||
|
||||
export type TriggerInput = {
|
||||
lastResult?: "success" | "failure" | null
|
||||
lastResult?: HealthStatus
|
||||
hadSuccess?: boolean
|
||||
}
|
||||
|
||||
@@ -12,7 +12,7 @@ export function changeOnFirstSuccess(o: {
|
||||
beforeFirstSuccess.next()
|
||||
for (
|
||||
let res = await beforeFirstSuccess.next();
|
||||
currentValue?.lastResult !== "success" && !res.done;
|
||||
currentValue?.lastResult !== "passing" && !res.done;
|
||||
res = await beforeFirstSuccess.next()
|
||||
) {
|
||||
yield
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
import { HealthReceipt, ReadyProof } from "../health"
|
||||
import { HealthReceipt, ReadyProof, TriggerInput } from "../health"
|
||||
import { CheckResult } from "../health/checkFns"
|
||||
import { Trigger } from "../health/trigger"
|
||||
import { defaultTrigger } from "../health/trigger/defaultTrigger"
|
||||
@@ -82,21 +82,26 @@ export class Daemons<Ids extends string | never> {
|
||||
const { command } = daemon
|
||||
|
||||
const child = effects.runDaemon(command)
|
||||
let currentInput = {}
|
||||
let currentInput: TriggerInput = {}
|
||||
const getCurrentInput = () => currentInput
|
||||
const trigger = (daemon.ready.trigger ?? defaultTrigger)(
|
||||
getCurrentInput,
|
||||
)
|
||||
for (
|
||||
let res = await trigger.next();
|
||||
!res.done;
|
||||
res = await trigger.next()
|
||||
) {
|
||||
const response = await daemon.ready.fn()
|
||||
if (response.status === "passing") {
|
||||
return child
|
||||
return new Promise(async (resolve) => {
|
||||
for (
|
||||
let res = await trigger.next();
|
||||
!res.done;
|
||||
res = await trigger.next()
|
||||
) {
|
||||
const response = await daemon.ready.fn()
|
||||
currentInput.lastResult = response.status || null
|
||||
if (!currentInput.hadSuccess && response.status === "passing") {
|
||||
currentInput.hadSuccess = true
|
||||
resolve(child)
|
||||
}
|
||||
}
|
||||
}
|
||||
resolve(child)
|
||||
})
|
||||
return child
|
||||
})
|
||||
}
|
||||
|
||||
@@ -6,6 +6,7 @@ import {
|
||||
} from "../config/configTypes"
|
||||
import { deepMerge } from "../util"
|
||||
import { InputSpec, matchInputSpec } from "./output"
|
||||
import * as _I from "../index"
|
||||
|
||||
export type IfEquals<T, U, Y = unknown, N = never> = (<G>() => G extends T
|
||||
? 1
|
||||
|
||||
Reference in New Issue
Block a user