feat: Moved to stream zip downloading.
feat: Implemented Shortcuts. feat: Ensured it works on steam deck
This commit is contained in:
parent
f15bf9a1e0
commit
62f16cbcc1
45 changed files with 1415 additions and 631 deletions
|
|
@ -1,9 +1,7 @@
|
|||
import { RunBunServer } from './server';
|
||||
import { RunAPIServer } from './api/rpc';
|
||||
import { spawnBrowser } from './utils/browser-spawner';
|
||||
import { BuildParams } from './utils/browser-params';
|
||||
import { cleanup as appCleanup, events } from './api/app';
|
||||
import os from 'node:os';
|
||||
import init from './browser';
|
||||
|
||||
const api = RunAPIServer();
|
||||
let bunServer: { stop: () => void; url: URL; } | undefined;
|
||||
|
|
@ -15,6 +13,7 @@ if (!Bun.env.PUBLIC_ACCESS)
|
|||
|
||||
async function cleanup ()
|
||||
{
|
||||
console.log("Cleaning Up");
|
||||
await appCleanup();
|
||||
bunServer?.stop();
|
||||
await api.apiServer.stop();
|
||||
|
|
@ -22,73 +21,19 @@ async function cleanup ()
|
|||
process.exit(0);
|
||||
}
|
||||
|
||||
if (Bun.env.FORCE_BROWSER)
|
||||
if (Bun.env.HEADLESS)
|
||||
{
|
||||
await runBrowser();
|
||||
events.on('exitapp', () =>
|
||||
{
|
||||
process.send?.({ type: 'exitapp' });
|
||||
cleanup();
|
||||
});
|
||||
} else
|
||||
{
|
||||
try
|
||||
{
|
||||
await runWebview();
|
||||
} catch (error)
|
||||
{
|
||||
await runBrowser();
|
||||
}
|
||||
}
|
||||
|
||||
async function runWebview ()
|
||||
{
|
||||
const webviewWorker = new Worker(Bun.env.IS_BINARY ? `./webview/${os.platform()}.ts` : new URL(`./webview/${os.platform()}`, import.meta.url).href, {
|
||||
smol: true,
|
||||
});
|
||||
|
||||
await new Promise((resolve, reject) =>
|
||||
{
|
||||
webviewWorker.addEventListener('error', e =>
|
||||
{
|
||||
console.error(e.message);
|
||||
reject(e.error);
|
||||
});
|
||||
|
||||
webviewWorker.addEventListener('message', (e) =>
|
||||
{
|
||||
if (e.data === 'destroyed')
|
||||
{
|
||||
resolve(true);
|
||||
}
|
||||
});
|
||||
|
||||
events.on('exitapp', () =>
|
||||
{
|
||||
resolve(true);
|
||||
});
|
||||
});
|
||||
await init(events, !!Bun.env.FORCE_BROWSER);
|
||||
await cleanup();
|
||||
}
|
||||
|
||||
async function runBrowser ()
|
||||
{
|
||||
const browserParams = await BuildParams();
|
||||
if (!browserParams)
|
||||
{
|
||||
console.error("Could not find valid browser");
|
||||
await cleanup();
|
||||
} else
|
||||
{
|
||||
const browser = spawnBrowser({
|
||||
browser: browserParams.browser.type,
|
||||
args: browserParams.args,
|
||||
env: browserParams.env,
|
||||
detached: false,
|
||||
execPath: browserParams.browser.path,
|
||||
source: browserParams.browser.source,
|
||||
ipc (message)
|
||||
{
|
||||
console.log(message);
|
||||
},
|
||||
onExit: cleanup
|
||||
});
|
||||
|
||||
events.on('exitapp', () => browser.kill(15));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue