index.ts 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. import "dotenv/config";
  2. import express from "express";
  3. import { createServer } from "http";
  4. import net from "net";
  5. import { createExpressMiddleware } from "@trpc/server/adapters/express";
  6. import { registerOAuthRoutes } from "./oauth";
  7. import { appRouter } from "../routers";
  8. import { createContext } from "./context";
  9. import { serveStatic, setupVite } from "./vite";
  10. function isPortAvailable(port: number): Promise<boolean> {
  11. return new Promise(resolve => {
  12. const server = net.createServer();
  13. server.listen(port, () => {
  14. server.close(() => resolve(true));
  15. });
  16. server.on("error", () => resolve(false));
  17. });
  18. }
  19. async function findAvailablePort(startPort: number = 3000): Promise<number> {
  20. for (let port = startPort; port < startPort + 20; port++) {
  21. if (await isPortAvailable(port)) {
  22. return port;
  23. }
  24. }
  25. throw new Error(`No available port found starting from ${startPort}`);
  26. }
  27. async function startServer() {
  28. const app = express();
  29. const server = createServer(app);
  30. // Configure body parser with larger size limit for file uploads
  31. app.use(express.json({ limit: "50mb" }));
  32. app.use(express.urlencoded({ limit: "50mb", extended: true }));
  33. // OAuth callback under /api/oauth/callback
  34. registerOAuthRoutes(app);
  35. // tRPC API
  36. app.use(
  37. "/api/trpc",
  38. createExpressMiddleware({
  39. router: appRouter,
  40. createContext,
  41. })
  42. );
  43. // development mode uses Vite, production mode uses static files
  44. if (process.env.NODE_ENV === "development") {
  45. await setupVite(app, server);
  46. } else {
  47. serveStatic(app);
  48. }
  49. const preferredPort = parseInt(process.env.PORT || "3000");
  50. const port = await findAvailablePort(preferredPort);
  51. if (port !== preferredPort) {
  52. console.log(`Port ${preferredPort} is busy, using port ${port} instead`);
  53. }
  54. server.listen(port, () => {
  55. console.log(`Server running on http://localhost:${port}/`);
  56. });
  57. }
  58. startServer().catch(console.error);