Spaces:
Running
Running
import express, { type Request, Response, NextFunction } from "express"; | |
import { registerRoutes } from "./routes"; | |
import { setupVite, serveStatic, log } from "./vite"; | |
const app = express(); | |
app.use(express.json()); | |
app.use(express.urlencoded({ extended: false })); | |
// Add CORS headers to bypass preflight requests | |
app.use((req, res, next) => { | |
res.header('Access-Control-Allow-Origin', '*'); | |
res.header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS'); | |
res.header('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept, Authorization'); | |
// Handle preflight OPTIONS requests | |
if (req.method === 'OPTIONS') { | |
res.sendStatus(200); | |
return; | |
} | |
next(); | |
}); | |
app.use((req, res, next) => { | |
const start = Date.now(); | |
const path = req.path; | |
let capturedJsonResponse: Record<string, any> | undefined = undefined; | |
const originalResJson = res.json; | |
res.json = function (bodyJson, ...args) { | |
capturedJsonResponse = bodyJson; | |
return originalResJson.apply(res, [bodyJson, ...args]); | |
}; | |
res.on("finish", () => { | |
const duration = Date.now() - start; | |
if (path.startsWith("/api")) { | |
let logLine = `${req.method} ${path} ${res.statusCode} in ${duration}ms`; | |
if (capturedJsonResponse) { | |
logLine += ` :: ${JSON.stringify(capturedJsonResponse)}`; | |
} | |
if (logLine.length > 80) { | |
logLine = logLine.slice(0, 79) + "…"; | |
} | |
log(logLine); | |
} | |
}); | |
next(); | |
}); | |
(async () => { | |
const server = await registerRoutes(app); | |
// Add placeholder images on startup (one-time setup) | |
try { | |
const { addPlaceholderImages } = await import('./add-placeholder-images'); | |
console.log('🖼️ Adding placeholder images to categories and products...'); | |
await addPlaceholderImages(); | |
} catch (error) { | |
console.error('Failed to add placeholder images:', error); | |
} | |
app.use((err: any, _req: Request, res: Response, _next: NextFunction) => { | |
const status = err.status || err.statusCode || 500; | |
const message = err.message || "Internal Server Error"; | |
res.status(status).json({ message }); | |
throw err; | |
}); | |
// importantly only setup vite in development and after | |
// setting up all the other routes so the catch-all route | |
// doesn't interfere with the other routes | |
if (app.get("env") === "development") { | |
await setupVite(app, server); | |
} else { | |
serveStatic(app); | |
} | |
// ALWAYS serve the app on the port specified in the environment variable PORT | |
// Other ports are firewalled. Default to 5000 if not specified. | |
// this serves both the API and the client. | |
// It is the only port that is not firewalled. | |
const port = parseInt(process.env.PORT || '5000', 10); | |
server.listen({ | |
port, | |
host: "0.0.0.0", | |
reusePort: true, | |
}, () => { | |
log(`serving on port ${port}`); | |
}); | |
})(); | |