Try and fix some building issues

This commit is contained in:
Jesse Wierzbinski 2024-03-12 08:27:50 -10:00
parent d29915456c
commit 986cc8a89c
No known key found for this signature in database
5 changed files with 84 additions and 82 deletions

View file

@ -1,6 +1,13 @@
// Delete dist directory // Delete dist directory
import chalk from "chalk";
import { rm, cp, mkdir, exists } from "fs/promises"; import { rm, cp, mkdir, exists } from "fs/promises";
console.log(
chalk.red(
"Warning: Build is currently broken due to a bug in Bun causing it not to parse dynamic imports"
)
);
if (!(await exists("./pages/dist"))) { if (!(await exists("./pages/dist"))) {
console.log("Please build the Vite server first, or use `bun prod-build`"); console.log("Please build the Vite server first, or use `bun prod-build`");
process.exit(1); process.exit(1);
@ -22,7 +29,7 @@ await Bun.build({
outdir: process.cwd() + "/dist", outdir: process.cwd() + "/dist",
target: "bun", target: "bun",
splitting: true, splitting: true,
minify: true, minify: false,
external: ["bullmq"], external: ["bullmq"],
}).then(output => { }).then(output => {
if (!output.success) { if (!output.success) {

View file

@ -1,4 +1,4 @@
import { Queue } from "bullmq"; // import { Queue } from "bullmq";
import { PrismaClient } from "@prisma/client"; import { PrismaClient } from "@prisma/client";
import { ConfigManager } from "config-manager"; import { ConfigManager } from "config-manager";
@ -8,13 +8,13 @@ const client = new PrismaClient({
datasourceUrl: `postgresql://${config.database.username}:${config.database.password}@${config.database.host}:${config.database.port}/${config.database.database}`, datasourceUrl: `postgresql://${config.database.username}:${config.database.password}@${config.database.host}:${config.database.port}/${config.database.database}`,
}); });
const federationQueue = new Queue("federation", { /* const federationQueue = new Queue("federation", {
connection: { connection: {
host: config.redis.queue.host, host: config.redis.queue.host,
port: Number(config.redis.queue.port), port: Number(config.redis.queue.port),
password: config.redis.queue.password || undefined, password: config.redis.queue.password || undefined,
db: config.redis.queue.database || undefined, db: config.redis.queue.database || undefined,
}, },
}); }); */
export { client, federationQueue }; export { client /* federationQueue */ };

View file

@ -1,5 +1,5 @@
import { Worker } from "bullmq"; // import { Worker } from "bullmq";
import { client, federationQueue } from "~database/datasource"; import { client /* federationQueue */ } from "~database/datasource";
import { import {
statusAndUserRelations, statusAndUserRelations,
statusToLysand, statusToLysand,
@ -10,7 +10,7 @@ import { ConfigManager } from "config-manager";
const config = await new ConfigManager({}).getConfig(); const config = await new ConfigManager({}).getConfig();
export const federationWorker = new Worker( /* export const federationWorker = new Worker(
"federation", "federation",
async job => { async job => {
await job.updateProgress(0); await job.updateProgress(0);
@ -123,7 +123,7 @@ export const federationWorker = new Worker(
count: 3000, count: 3000,
}, },
} }
); ); */
/** /**
* Convert a string into an ArrayBuffer * Convert a string into an ArrayBuffer
@ -191,7 +191,7 @@ export const federateStatusTo = async (
}; };
export const addStatusFederationJob = async (statusId: string) => { export const addStatusFederationJob = async (statusId: string) => {
await federationQueue.add("federation", { /* await federationQueue.add("federation", {
id: statusId, id: statusId,
}); }); */
}; };

View file

@ -1,6 +1,7 @@
generator client { generator client {
provider = "prisma-client-js" provider = "prisma-client-js"
previewFeatures = ["postgresqlExtensions"] previewFeatures = ["postgresqlExtensions"]
binaryTargets = ["native", "debian-openssl-3.0.x"]
} }
datasource db { datasource db {

136
routes.ts
View file

@ -1,167 +1,161 @@
import type { RouteHandler } from "~server/api/routes.type"; import type { RouteHandler } from "./server/api/routes.type";
import type { APIRouteMeta } from "~types/api"; import type { APIRouteMeta } from "./types/api";
const serverPath = process.cwd() + "/server/api";
// Why are these routes specified manually instead of using Bun's FileSystemRouter? // Why are these routes specified manually instead of using Bun's FileSystemRouter?
// This is to allow for compilation of the routes, so that we can minify them and // This is to allow for compilation of the routes, so that we can minify them and
// node_modules in production // node_modules in production
export const rawRoutes = { export const rawRoutes = {
"/api/v1/accounts": await import(serverPath + "/api/v1/accounts/index.ts"), "/api/v1/accounts": await import("./server/api/api/v1/accounts"),
"/api/v1/accounts/familiar_followers": await import( "/api/v1/accounts/familiar_followers": await import(
serverPath + "/api/v1/accounts/familiar_followers/index.ts" "./server/api/api/v1/accounts/familiar_followers/index"
), ),
"/api/v1/accounts/relationships": await import( "/api/v1/accounts/relationships": await import(
serverPath + "/api/v1/accounts/relationships/index.ts" "./server/api/api/v1/accounts/relationships/index"
), ),
"/api/v1/accounts/search": await import( "/api/v1/accounts/search": await import(
serverPath + "/api/v1/accounts/search/index.ts" "./server/api/api/v1/accounts/search/index"
), ),
"/api/v1/accounts/update_credentials": await import( "/api/v1/accounts/update_credentials": await import(
serverPath + "/api/v1/accounts/update_credentials/index.ts" "./server/api/api/v1/accounts/update_credentials/index"
), ),
"/api/v1/accounts/verify_credentials": await import( "/api/v1/accounts/verify_credentials": await import(
serverPath + "/api/v1/accounts/verify_credentials/index.ts" "./server/api/api/v1/accounts/verify_credentials/index"
), ),
"/api/v1/apps": await import(serverPath + "/api/v1/apps/index.ts"), "/api/v1/apps": await import("./server/api/api/v1/apps/index"),
"/api/v1/apps/verify_credentials": await import( "/api/v1/apps/verify_credentials": await import(
serverPath + "/api/v1/apps/verify_credentials/index.ts" "./server/api/api/v1/apps/verify_credentials/index"
), ),
"/api/v1/blocks": await import(serverPath + "/api/v1/blocks/index.ts"), "/api/v1/blocks": await import("./server/api/api/v1/blocks/index"),
"/api/v1/custom_emojis": await import( "/api/v1/custom_emojis": await import(
serverPath + "/api/v1/custom_emojis/index.ts" "./server/api/api/v1/custom_emojis/index"
),
"/api/v1/favourites": await import(
serverPath + "/api/v1/favourites/index.ts"
), ),
"/api/v1/favourites": await import("./server/api/api/v1/favourites/index"),
"/api/v1/follow_requests": await import( "/api/v1/follow_requests": await import(
serverPath + "/api/v1/follow_requests/index.ts" "./server/api/api/v1/follow_requests/index"
), ),
"/api/v1/instance": await import(serverPath + "/api/v1/instance/index.ts"), "/api/v1/instance": await import("./server/api/api/v1/instance/index"),
"/api/v1/media": await import(serverPath + "/api/v1/media/index.ts"), "/api/v1/media": await import("./server/api/api/v1/media/index"),
"/api/v1/mutes": await import(serverPath + "/api/v1/mutes/index.ts"), "/api/v1/mutes": await import("./server/api/api/v1/mutes/index"),
"/api/v1/notifications": await import( "/api/v1/notifications": await import(
serverPath + "/api/v1/notifications/index.ts" "./server/api/api/v1/notifications/index"
), ),
"/api/v1/profile/avatar": await import( "/api/v1/profile/avatar": await import(
serverPath + "/api/v1/profile/avatar.ts" "./server/api/api/v1/profile/avatar"
), ),
"/api/v1/profile/header": await import( "/api/v1/profile/header": await import(
serverPath + "/api/v1/profile/header.ts" "./server/api/api/v1/profile/header"
), ),
"/api/v1/statuses": await import(serverPath + "/api/v1/statuses/index.ts"), "/api/v1/statuses": await import("./server/api/api/v1/statuses/index"),
"/api/v1/timelines/home": await import( "/api/v1/timelines/home": await import(
serverPath + "/api/v1/timelines/home.ts" "./server/api/api/v1/timelines/home"
), ),
"/api/v1/timelines/public": await import( "/api/v1/timelines/public": await import(
serverPath + "/api/v1/timelines/public.ts" "./server/api/api/v1/timelines/public"
), ),
"/api/v2/media": await import(serverPath + "/api/v2/media/index.ts"), "/api/v2/media": await import("./server/api/api/v2/media/index"),
"/api/v2/search": await import(serverPath + "/api/v2/search/index.ts"), "/api/v2/search": await import("./server/api/api/v2/search/index"),
"/auth/login": await import(serverPath + "/auth/login/index.ts"), "/auth/login": await import("./server/api/auth/login/index"),
"/nodeinfo/2.0": await import(serverPath + "/nodeinfo/2.0/index.ts"), "/nodeinfo/2.0": await import("./server/api/nodeinfo/2.0/index"),
"/oauth/authorize-external": await import( "/oauth/authorize-external": await import(
serverPath + "/oauth/authorize-external/index.ts" "./server/api/oauth/authorize-external/index"
), ),
"/oauth/providers": await import(serverPath + "/oauth/providers/index.ts"), "/oauth/providers": await import("./server/api/oauth/providers/index"),
"/oauth/token": await import(serverPath + "/oauth/token/index.ts"), "/oauth/token": await import("./server/api/oauth/token/index"),
"/api/v1/accounts/[id]": await import( "/api/v1/accounts/[id]": await import(
serverPath + "/api/v1/accounts/[id]/index.ts" "./server/api/api/v1/accounts/[id]/index"
), ),
"/api/v1/accounts/[id]/block": await import( "/api/v1/accounts/[id]/block": await import(
serverPath + "/api/v1/accounts/[id]/block.ts" "./server/api/api/v1/accounts/[id]/block"
), ),
"/api/v1/accounts/[id]/follow": await import( "/api/v1/accounts/[id]/follow": await import(
serverPath + "/api/v1/accounts/[id]/follow.ts" "./server/api/api/v1/accounts/[id]/follow"
), ),
"/api/v1/accounts/[id]/followers": await import( "/api/v1/accounts/[id]/followers": await import(
serverPath + "/api/v1/accounts/[id]/followers.ts" "./server/api/api/v1/accounts/[id]/followers"
), ),
"/api/v1/accounts/[id]/following": await import( "/api/v1/accounts/[id]/following": await import(
serverPath + "/api/v1/accounts/[id]/following.ts" "./server/api/api/v1/accounts/[id]/following"
), ),
"/api/v1/accounts/[id]/mute": await import( "/api/v1/accounts/[id]/mute": await import(
serverPath + "/api/v1/accounts/[id]/mute.ts" "./server/api/api/v1/accounts/[id]/mute"
), ),
"/api/v1/accounts/[id]/note": await import( "/api/v1/accounts/[id]/note": await import(
serverPath + "/api/v1/accounts/[id]/note.ts" "./server/api/api/v1/accounts/[id]/note"
), ),
"/api/v1/accounts/[id]/pin": await import( "/api/v1/accounts/[id]/pin": await import(
serverPath + "/api/v1/accounts/[id]/pin.ts" "./server/api/api/v1/accounts/[id]/pin"
), ),
"/api/v1/accounts/[id]/remove_from_followers": await import( "/api/v1/accounts/[id]/remove_from_followers": await import(
serverPath + "/api/v1/accounts/[id]/remove_from_followers.ts" "./server/api/api/v1/accounts/[id]/remove_from_followers"
), ),
"/api/v1/accounts/[id]/statuses": await import( "/api/v1/accounts/[id]/statuses": await import(
serverPath + "/api/v1/accounts/[id]/statuses.ts" "./server/api/api/v1/accounts/[id]/statuses"
), ),
"/api/v1/accounts/[id]/unblock": await import( "/api/v1/accounts/[id]/unblock": await import(
serverPath + "/api/v1/accounts/[id]/unblock.ts" "./server/api/api/v1/accounts/[id]/unblock"
), ),
"/api/v1/accounts/[id]/unfollow": await import( "/api/v1/accounts/[id]/unfollow": await import(
serverPath + "/api/v1/accounts/[id]/unfollow.ts" "./server/api/api/v1/accounts/[id]/unfollow"
), ),
"/api/v1/accounts/[id]/unmute": await import( "/api/v1/accounts/[id]/unmute": await import(
serverPath + "/api/v1/accounts/[id]/unmute.ts" "./server/api/api/v1/accounts/[id]/unmute"
), ),
"/api/v1/accounts/[id]/unpin": await import( "/api/v1/accounts/[id]/unpin": await import(
serverPath + "/api/v1/accounts/[id]/unpin.ts" "./server/api/api/v1/accounts/[id]/unpin"
), ),
"/api/v1/follow_requests/[account_id]/authorize": await import( "/api/v1/follow_requests/[account_id]/authorize": await import(
serverPath + "/api/v1/follow_requests/[account_id]/authorize.ts" "./server/api/api/v1/follow_requests/[account_id]/authorize"
), ),
"/api/v1/follow_requests/[account_id]/reject": await import( "/api/v1/follow_requests/[account_id]/reject": await import(
serverPath + "/api/v1/follow_requests/[account_id]/reject.ts" "./server/api/api/v1/follow_requests/[account_id]/reject"
),
"/api/v1/media/[id]": await import(
serverPath + "/api/v1/media/[id]/index.ts"
), ),
"/api/v1/media/[id]": await import("./server/api/api/v1/media/[id]/index"),
"/api/v1/statuses/[id]": await import( "/api/v1/statuses/[id]": await import(
serverPath + "/api/v1/statuses/[id]/index.ts" "./server/api/api/v1/statuses/[id]/index"
), ),
"/api/v1/statuses/[id]/context": await import( "/api/v1/statuses/[id]/context": await import(
serverPath + "/api/v1/statuses/[id]/context.ts" "./server/api/api/v1/statuses/[id]/context"
), ),
"/api/v1/statuses/[id]/favourite": await import( "/api/v1/statuses/[id]/favourite": await import(
serverPath + "/api/v1/statuses/[id]/favourite.ts" "./server/api/api/v1/statuses/[id]/favourite"
), ),
"/api/v1/statuses/[id]/favourited_by": await import( "/api/v1/statuses/[id]/favourited_by": await import(
serverPath + "/api/v1/statuses/[id]/favourited_by.ts" "./server/api/api/v1/statuses/[id]/favourited_by"
), ),
"/api/v1/statuses/[id]/pin": await import( "/api/v1/statuses/[id]/pin": await import(
serverPath + "/api/v1/statuses/[id]/pin.ts" "./server/api/api/v1/statuses/[id]/pin"
), ),
"/api/v1/statuses/[id]/reblog": await import( "/api/v1/statuses/[id]/reblog": await import(
serverPath + "/api/v1/statuses/[id]/reblog.ts" "./server/api/api/v1/statuses/[id]/reblog"
), ),
"/api/v1/statuses/[id]/reblogged_by": await import( "/api/v1/statuses/[id]/reblogged_by": await import(
serverPath + "/api/v1/statuses/[id]/reblogged_by.ts" "./server/api/api/v1/statuses/[id]/reblogged_by"
), ),
"/api/v1/statuses/[id]/source": await import( "/api/v1/statuses/[id]/source": await import(
serverPath + "/api/v1/statuses/[id]/source.ts" "./server/api/api/v1/statuses/[id]/source"
), ),
"/api/v1/statuses/[id]/unfavourite": await import( "/api/v1/statuses/[id]/unfavourite": await import(
serverPath + "/api/v1/statuses/[id]/unfavourite.ts" "./server/api/api/v1/statuses/[id]/unfavourite"
), ),
"/api/v1/statuses/[id]/unpin": await import( "/api/v1/statuses/[id]/unpin": await import(
serverPath + "/api/v1/statuses/[id]/unpin.ts" "./server/api/api/v1/statuses/[id]/unpin"
), ),
"/api/v1/statuses/[id]/unreblog": await import( "/api/v1/statuses/[id]/unreblog": await import(
serverPath + "/api/v1/statuses/[id]/unreblog.ts" "./server/api/api/v1/statuses/[id]/unreblog"
), ),
"/media/[id]": await import(serverPath + "/media/[id]/index.ts"), "/media/[id]": await import("./server/api/media/[id]/index"),
"/oauth/callback/[issuer]": await import( "/oauth/callback/[issuer]": await import(
serverPath + "/oauth/callback/[issuer]/index.ts" "./server/api/oauth/callback/[issuer]/index"
), ),
"/object/[uuid]": await import(serverPath + "/object/[uuid]/index.ts"), "/object/[uuid]": await import("./server/api/object/[uuid]/index"),
"/users/[uuid]": await import(serverPath + "/users/[uuid]/index.ts"), "/users/[uuid]": await import("./server/api/users/[uuid]/index"),
"/users/[uuid]/inbox": await import( "/users/[uuid]/inbox": await import(
serverPath + "/users/[uuid]/inbox/index.ts" "./server/api/users/[uuid]/inbox/index"
), ),
"/users/[uuid]/outbox": await import( "/users/[uuid]/outbox": await import(
serverPath + "/users/[uuid]/outbox/index.ts" "./server/api/users/[uuid]/outbox/index"
), ),
"/[...404]": await import(serverPath + "/[...404].ts"), "/[...404]": await import("./server/api/[...404]"),
}; };
// Returns the route filesystem path when given a URL // Returns the route filesystem path when given a URL