mirror of
https://github.com/nicotsx/zerobyte.git
synced 2026-04-19 22:37:14 -04:00
* refactor: move to tanstack start * refactor: auth flow & volumes * refactor: repo & snapshot details * refactor: backups, create repo, volumes * refactor: create volume & restore snapshot * refactor: notifications * refactor: settings * refactor: breadcrumbs * fix: ts issues * refactor: prod deployment * fix: import css production * refactor: nitro build * refactor: winston -> consola * fix: memory leak is sse events cleanup * fix: cli usage * chore: remove rr routes file * refactor: pr feedbacks * refactor: patch api client to have a global client per call * refactor: pr feedbacks * fix(dockerfile): add explicit port * fix(e2e): healthcheck under /api
54 lines
1.4 KiB
TypeScript
54 lines
1.4 KiB
TypeScript
import * as schema from "./server/db/schema";
|
|
import { setSchema, runDbMigrations } from "./server/db/db";
|
|
import { startup } from "./server/modules/lifecycle/startup";
|
|
import { logger } from "./server/utils/logger";
|
|
import { shutdown } from "./server/modules/lifecycle/shutdown";
|
|
import { runCLI } from "./server/cli";
|
|
import { runMigrations } from "./server/modules/lifecycle/migrations";
|
|
import { createStartHandler, defaultStreamHandler, defineHandlerCallback } from "@tanstack/react-start/server";
|
|
import { createServerEntry } from "@tanstack/react-start/server-entry";
|
|
|
|
setSchema(schema);
|
|
|
|
const cliRun = await runCLI(Bun.argv);
|
|
if (cliRun) {
|
|
process.exit(0);
|
|
}
|
|
|
|
runDbMigrations();
|
|
|
|
await runMigrations();
|
|
await startup();
|
|
|
|
const customHandler = defineHandlerCallback((ctx) => {
|
|
return defaultStreamHandler(ctx);
|
|
});
|
|
|
|
const fetch = createStartHandler(customHandler);
|
|
|
|
export default createServerEntry({
|
|
fetch,
|
|
});
|
|
|
|
process.on("SIGTERM", async () => {
|
|
logger.info("SIGTERM received, starting graceful shutdown...");
|
|
try {
|
|
await shutdown();
|
|
} catch (err) {
|
|
logger.error("Error during shutdown", err);
|
|
} finally {
|
|
process.exit(0);
|
|
}
|
|
});
|
|
|
|
process.on("SIGINT", async () => {
|
|
logger.info("SIGINT received, starting graceful shutdown...");
|
|
try {
|
|
await shutdown();
|
|
} catch (err) {
|
|
logger.error("Error during shutdown", err);
|
|
} finally {
|
|
process.exit(0);
|
|
}
|
|
});
|