* Some colors and export file size changes occurred engine-side, update tests to match * Fix up focusrite example after adjacent edge switch * Yay now the export file is yet another new size * Update bracket example code and some test colors that broke * Use a shorter KCL sample so we don't experience weird locator behavior * A snapshot a day keeps the bugs away! 📷🐛 (OS: ubuntu-latest) * bump electron playwright timeout * Relax color expectations a little bit, as they can be different on web and electron * fix double export test * unused var * A snapshot a day keeps the bugs away! 📷🐛 (OS: windows-latest) * Re-run CI * Bump getGreatestPixDiff comparisons from 10 to 15 in projects.spec.ts * bump another pix diff to 15 * make retries work * update expect numbers * remove some logs --------- Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Kurt Hutten Irev-Dev <k.hutten@protonmail.ch>
97 lines
2.2 KiB
TypeScript
97 lines
2.2 KiB
TypeScript
import { isDesktop } from './isDesktop'
|
|
import { components } from './machine-api'
|
|
|
|
export type MachinesListing = Array<
|
|
components['schemas']['MachineInfoResponse']
|
|
>
|
|
|
|
export class MachineManager {
|
|
private _isDesktop: boolean = isDesktop()
|
|
private _machines: MachinesListing = []
|
|
private _machineApiIp: string | null = null
|
|
private _currentMachine: components['schemas']['MachineInfoResponse'] | null =
|
|
null
|
|
|
|
constructor() {
|
|
if (!this._isDesktop) {
|
|
return
|
|
}
|
|
|
|
this.updateMachines()
|
|
}
|
|
|
|
start() {
|
|
if (!this._isDesktop) {
|
|
return
|
|
}
|
|
|
|
// Start a background job to update the machines every ten seconds.
|
|
// If MDNS is already watching, this timeout will wait until it's done to trigger the
|
|
// finding again.
|
|
let timeoutId: ReturnType<typeof setTimeout> | undefined = undefined
|
|
const timeoutLoop = () => {
|
|
clearTimeout(timeoutId)
|
|
timeoutId = setTimeout(async () => {
|
|
await this.updateMachineApiIp()
|
|
await this.updateMachines()
|
|
timeoutLoop()
|
|
}, 10000)
|
|
}
|
|
timeoutLoop()
|
|
}
|
|
|
|
get machines(): MachinesListing {
|
|
return this._machines
|
|
}
|
|
|
|
machineCount(): number {
|
|
return this._machines.length
|
|
}
|
|
|
|
get machineApiIp(): string | null {
|
|
return this._machineApiIp
|
|
}
|
|
|
|
// Get the reason message for why there are no machines.
|
|
noMachinesReason(): string | undefined {
|
|
if (this.machineCount() > 0) {
|
|
return undefined
|
|
}
|
|
|
|
if (this.machineApiIp === null) {
|
|
return 'Machine API server was not discovered'
|
|
}
|
|
|
|
return 'Machine API server was discovered, but no machines are available'
|
|
}
|
|
|
|
get currentMachine(): components['schemas']['MachineInfoResponse'] | null {
|
|
return this._currentMachine
|
|
}
|
|
|
|
set currentMachine(
|
|
machine: components['schemas']['MachineInfoResponse'] | null
|
|
) {
|
|
this._currentMachine = machine
|
|
}
|
|
|
|
private async updateMachines(): Promise<void> {
|
|
if (!this._isDesktop) {
|
|
return
|
|
}
|
|
|
|
this._machines = await window.electron.listMachines()
|
|
}
|
|
|
|
private async updateMachineApiIp(): Promise<void> {
|
|
if (!this._isDesktop) {
|
|
return
|
|
}
|
|
|
|
this._machineApiIp = await window.electron.getMachineApiIp()
|
|
}
|
|
}
|
|
|
|
export const machineManager = new MachineManager()
|
|
machineManager.start()
|