mirror of
https://github.com/Start9Labs/start-os.git
synced 2026-03-26 10:21:52 +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>
86 lines
2.4 KiB
TypeScript
86 lines
2.4 KiB
TypeScript
import * as T from "../types"
|
|
|
|
import * as D from "./configDependencies"
|
|
import { Config, ExtractConfigType } from "./builder/config"
|
|
import nullIfEmpty from "../util/nullIfEmpty"
|
|
import { InterfacesReceipt as InterfacesReceipt } from "../interfaces/setupInterfaces"
|
|
|
|
declare const dependencyProof: unique symbol
|
|
export type DependenciesReceipt = void & {
|
|
[dependencyProof]: never
|
|
}
|
|
|
|
export type Save<
|
|
A extends
|
|
| Record<string, any>
|
|
| Config<Record<string, any>, any>
|
|
| Config<Record<string, never>, never>,
|
|
> = (options: {
|
|
effects: T.Effects
|
|
input: ExtractConfigType<A> & Record<string, any>
|
|
}) => Promise<{
|
|
dependenciesReceipt: DependenciesReceipt
|
|
interfacesReceipt: InterfacesReceipt
|
|
restart: boolean
|
|
}>
|
|
export type Read<
|
|
Manifest extends T.Manifest,
|
|
Store,
|
|
A extends
|
|
| Record<string, any>
|
|
| Config<Record<string, any>, any>
|
|
| Config<Record<string, any>, never>,
|
|
> = (options: {
|
|
effects: T.Effects
|
|
}) => Promise<void | (ExtractConfigType<A> & Record<string, any>)>
|
|
/**
|
|
* We want to setup a config export with a get and set, this
|
|
* is going to be the default helper to setup config, because it will help
|
|
* enforce that we have a spec, write, and reading.
|
|
* @param options
|
|
* @returns
|
|
*/
|
|
export function setupConfig<
|
|
Store,
|
|
ConfigType extends
|
|
| Record<string, any>
|
|
| Config<any, any>
|
|
| Config<any, never>,
|
|
Manifest extends T.Manifest,
|
|
Type extends Record<string, any> = ExtractConfigType<ConfigType>,
|
|
>(
|
|
spec: Config<Type, Store> | Config<Type, never>,
|
|
write: Save<Type>,
|
|
read: Read<Manifest, Store, Type>,
|
|
) {
|
|
const validator = spec.validator
|
|
return {
|
|
setConfig: (async ({ effects, input }) => {
|
|
if (!validator.test(input)) {
|
|
await console.error(String(validator.errorMessage(input)))
|
|
return { error: "Set config type error for config" }
|
|
}
|
|
await effects.clearBindings()
|
|
await effects.clearServiceInterfaces()
|
|
const { restart } = await write({
|
|
input: JSON.parse(JSON.stringify(input)) as any,
|
|
effects,
|
|
})
|
|
if (restart) {
|
|
await effects.restart()
|
|
}
|
|
}) as T.ExpectedExports.setConfig,
|
|
getConfig: (async ({ effects }) => {
|
|
const configValue = nullIfEmpty((await read({ effects })) || null)
|
|
return {
|
|
spec: await spec.build({
|
|
effects,
|
|
}),
|
|
config: configValue,
|
|
}
|
|
}) as T.ExpectedExports.getConfig,
|
|
}
|
|
}
|
|
|
|
export default setupConfig
|