// Custom Next.js server with scheduler initialization import { createServer } from "http"; import { parse } from "url"; import next from "next"; import { startScheduler } from "./lib/scheduler.js"; import { startProcessingScheduler } from "./lib/processingScheduler.js"; const dev = process.env.NODE_ENV !== "production"; const hostname = "localhost"; const port = parseInt(process.env.PORT || "3000", 10); // Initialize Next.js const app = next({ dev, hostname, port }); const handle = app.getRequestHandler(); app.prepare().then(() => { // Initialize schedulers when the server starts console.log("Starting schedulers..."); startScheduler(); startProcessingScheduler(); console.log("All schedulers initialized successfully"); createServer(async (req, res) => { try { // Parse the URL const parsedUrl = parse(req.url || "", true); // Let Next.js handle the request await handle(req, res, parsedUrl); } catch (err) { console.error("Error occurred handling", req.url, err); res.statusCode = 500; res.end("Internal Server Error"); } }).listen(port, () => { console.log(`> Ready on http://${hostname}:${port}`); }); });