mirror of
https://github.com/Start9Labs/start-os.git
synced 2026-04-01 21:13:09 +00:00
* store, properties, manifest * interfaces * init and backups * fix init and backups * file models * more versions * dependencies * config except dynamic types * clean up config * remove disabled from non-dynamic vaues * actions * standardize example code block formats * wip: actions refactor Co-authored-by: Jade <Blu-J@users.noreply.github.com> * commit types * fix types * update types * update action request type * update apis * add description to actionrequest * clean up imports * revert package json * chore: Remove the recursive to the index * chore: Remove the other thing I was testing * flatten action requests * update container runtime with new config paradigm * new actions strategy * seems to be working * misc backend fixes * fix fe bugs * only show breakages if breakages * only show success modal if result * don't panic on failed removal * hide config from actions page * polyfill autoconfig * use metadata strategy for actions instead of prev * misc fixes * chore: split the sdk into 2 libs (#2736) * follow sideload progress (#2718) * follow sideload progress * small bugfix * shareReplay with no refcount false * don't wrap sideload progress in RPCResult * dont present toast --------- Co-authored-by: Aiden McClelland <me@drbonez.dev> * chore: Add the initial of the creation of the two sdk * chore: Add in the baseDist * chore: Add in the baseDist * chore: Get the web and the runtime-container running * chore: Remove the empty file * chore: Fix it so the container-runtime works --------- Co-authored-by: Matt Hill <MattDHill@users.noreply.github.com> Co-authored-by: Aiden McClelland <me@drbonez.dev> * misc fixes * update todos * minor clean up * fix link script * update node version in CI test * fix node version syntax in ci build * wip: fixing callbacks * fix sdk makefile dependencies * add support for const outside of main * update apis * don't panic! * Chore: Capture weird case on rpc, and log that * fix procedure id issue * pass input value for dep auto config * handle disabled and warning for actions * chore: Fix for link not having node_modules * sdk fixes * fix build * fix build * fix build --------- Co-authored-by: Matt Hill <mattnine@protonmail.com> Co-authored-by: Jade <Blu-J@users.noreply.github.com> Co-authored-by: J H <dragondef@gmail.com> Co-authored-by: Jade <2364004+Blu-J@users.noreply.github.com> Co-authored-by: Matt Hill <MattDHill@users.noreply.github.com>
90 lines
2.7 KiB
TypeScript
90 lines
2.7 KiB
TypeScript
import * as T from "../../../base/lib/types"
|
|
import { asError } from "../../../base/lib/util/asError"
|
|
import { ExecSpawnable, MountOptions, SubContainer } from "../util/SubContainer"
|
|
import { CommandController } from "./CommandController"
|
|
|
|
const TIMEOUT_INCREMENT_MS = 1000
|
|
const MAX_TIMEOUT_MS = 30000
|
|
/**
|
|
* This is a wrapper around CommandController that has a state of off, where the command shouldn't be running
|
|
* and the others state of running, where it will keep a living running command
|
|
*/
|
|
|
|
export class Daemon {
|
|
private commandController: CommandController | null = null
|
|
private shouldBeRunning = false
|
|
constructor(private startCommand: () => Promise<CommandController>) {}
|
|
get subContainerHandle(): undefined | ExecSpawnable {
|
|
return this.commandController?.subContainerHandle
|
|
}
|
|
static of<Manifest extends T.Manifest>() {
|
|
return async <A extends string>(
|
|
effects: T.Effects,
|
|
subcontainer:
|
|
| {
|
|
id: keyof Manifest["images"] & T.ImageId
|
|
sharedRun?: boolean
|
|
}
|
|
| SubContainer,
|
|
command: T.CommandType,
|
|
options: {
|
|
subcontainerName?: string
|
|
mounts?: { path: string; options: MountOptions }[]
|
|
env?:
|
|
| {
|
|
[variable: string]: string
|
|
}
|
|
| undefined
|
|
cwd?: string | undefined
|
|
user?: string | undefined
|
|
onStdout?: (x: Buffer) => void
|
|
onStderr?: (x: Buffer) => void
|
|
sigtermTimeout?: number
|
|
},
|
|
) => {
|
|
const startCommand = () =>
|
|
CommandController.of<Manifest>()(
|
|
effects,
|
|
subcontainer,
|
|
command,
|
|
options,
|
|
)
|
|
return new Daemon(startCommand)
|
|
}
|
|
}
|
|
async start() {
|
|
if (this.commandController) {
|
|
return
|
|
}
|
|
this.shouldBeRunning = true
|
|
let timeoutCounter = 0
|
|
new Promise(async () => {
|
|
while (this.shouldBeRunning) {
|
|
this.commandController = await this.startCommand()
|
|
await this.commandController.wait().catch((err) => console.error(err))
|
|
await new Promise((resolve) => setTimeout(resolve, timeoutCounter))
|
|
timeoutCounter += TIMEOUT_INCREMENT_MS
|
|
timeoutCounter = Math.max(MAX_TIMEOUT_MS, timeoutCounter)
|
|
}
|
|
}).catch((err) => {
|
|
console.error(asError(err))
|
|
})
|
|
}
|
|
async term(termOptions?: {
|
|
signal?: NodeJS.Signals | undefined
|
|
timeout?: number | undefined
|
|
}) {
|
|
return this.stop(termOptions)
|
|
}
|
|
async stop(termOptions?: {
|
|
signal?: NodeJS.Signals | undefined
|
|
timeout?: number | undefined
|
|
}) {
|
|
this.shouldBeRunning = false
|
|
await this.commandController
|
|
?.term({ ...termOptions })
|
|
.catch((e) => console.error(asError(e)))
|
|
this.commandController = null
|
|
}
|
|
}
|