refactor: ♻️ Rewrite build system to fit the monorepo architecture
Some checks failed
Mirror to Codeberg / Mirror (push) Failing after 0s
Test Publish / build (client) (push) Failing after 1s
Test Publish / build (sdk) (push) Failing after 0s

This commit is contained in:
Jesse Wierzbinski 2025-07-04 06:29:43 +02:00
parent 7de4b573e3
commit 90b6399407
No known key found for this signature in database
217 changed files with 2143 additions and 1858 deletions

View file

@ -1,36 +1,19 @@
import { $, build } from "bun";
import manifest from "./package.json" with { type: "json" };
console.log("Building...");
await $`rm -rf dist && mkdir dist`;
await build({
entrypoints: [
"packages/worker/index.ts",
// HACK: Include to avoid cyclical import errors
"packages/config/index.ts",
"cli/index.ts",
],
entrypoints: Object.values(manifest.exports).map((entry) => entry.import),
outdir: "dist",
target: "bun",
splitting: true,
minify: false,
minify: true,
external: [
...Object.keys(manifest.dependencies).filter((dep) =>
dep.startsWith("@versia"),
),
],
});
console.log("Copying files...");
// Fix Bun build mistake
await $`sed -i 's/ProxiableUrl, exportedConfig/exportedConfig/g' dist/packages/config/*.js`;
// Copy Drizzle stuff
await $`mkdir -p dist/packages/plugin-kit/tables`;
await $`cp -rL packages/plugin-kit/tables/migrations dist/packages/plugin-kit/tables`;
// Copy Sharp to dist
await $`mkdir -p dist/node_modules/@img`;
await $`cp -rL node_modules/@img/sharp-libvips-linux* dist/node_modules/@img`;
await $`cp -rL node_modules/@img/sharp-linux* dist/node_modules/@img`;
await $`cp -rL node_modules/detect-libc dist/node_modules/`;
console.log("Build complete!");

View file

@ -1,18 +0,0 @@
import process from "node:process";
import { serverLogger } from "@versia-server/logging";
import chalk from "chalk";
import { workers } from "./workers.ts";
process.on("SIGINT", () => {
process.exit();
});
await import("./setup.ts");
for (const [worker, fn] of Object.entries(workers)) {
serverLogger.info`Starting ${worker} Worker...`;
fn();
serverLogger.info`${chalk.green("✔")} ${worker} Worker started`;
}
serverLogger.info`${chalk.green("✔✔✔✔✔✔")} All workers started`;

View file

@ -35,7 +35,15 @@
"private": true,
"scripts": {
"dev": "bun run --hot index.ts",
"build": "bun run build-worker.ts"
"build": "bun run build.ts"
},
"exports": {
".": {
"import": "./workers.ts"
},
"./setup": {
"import": "./setup.ts"
}
},
"dependencies": {
"@versia-server/config": "workspace:*",

View file

@ -1,9 +1,9 @@
import { config } from "@versia-server/config";
import { Note, setupDatabase } from "@versia-server/kit/db";
import { connection } from "@versia-server/kit/redis";
import { searchManager } from "@versia-server/kit/search";
import { serverLogger } from "@versia-server/logging";
import chalk from "chalk";
import { searchManager } from "../../classes/search/search-manager.ts";
const timeAtStart = performance.now();

View file

@ -1,9 +1,9 @@
import { getDeliveryWorker } from "@versia-server/kit/queues/delivery";
import { getFetchWorker } from "@versia-server/kit/queues/fetch";
import { getInboxWorker } from "@versia-server/kit/queues/inbox";
import { getMediaWorker } from "@versia-server/kit/queues/media";
import { getPushWorker } from "@versia-server/kit/queues/push";
import { getRelationshipWorker } from "@versia-server/kit/queues/relationships";
import { getDeliveryWorker } from "@versia-server/kit/queues/delivery/worker";
import { getFetchWorker } from "@versia-server/kit/queues/fetch/worker";
import { getInboxWorker } from "@versia-server/kit/queues/inbox/worker";
import { getMediaWorker } from "@versia-server/kit/queues/media/worker";
import { getPushWorker } from "@versia-server/kit/queues/push/worker";
import { getRelationshipWorker } from "@versia-server/kit/queues/relationships/worker";
export const workers = {
fetch: getFetchWorker,