index.js 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. "use strict";
  2. var __importDefault = (this && this.__importDefault) || function (mod) {
  3. return (mod && mod.__esModule) ? mod : { "default": mod };
  4. };
  5. Object.defineProperty(exports, "__esModule", { value: true });
  6. const express_1 = __importDefault(require("express"));
  7. const cors_1 = __importDefault(require("cors"));
  8. const path_1 = __importDefault(require("path"));
  9. const database_1 = require("./db/database");
  10. const seed_1 = require("./db/seed");
  11. const templates_1 = require("./routes/templates");
  12. const creatives_1 = require("./routes/creatives");
  13. const assets_1 = require("./routes/assets");
  14. const builds_1 = require("./routes/builds");
  15. const preview_1 = require("./routes/preview");
  16. const preview_2 = require("./routes/preview");
  17. const errorHandler_1 = require("./middleware/errorHandler");
  18. const previewProxy_1 = require("./middleware/previewProxy");
  19. const PORT = process.env.PORT || 3001;
  20. const STORAGE_DIR = path_1.default.resolve(__dirname, "../../../storage");
  21. const CLIENT_DIST = path_1.default.resolve(__dirname, "../../client/dist");
  22. async function main() {
  23. // 初始化数据库
  24. const db = (0, database_1.initDatabase)(STORAGE_DIR);
  25. (0, seed_1.seedTemplates)(db);
  26. const app = (0, express_1.default)();
  27. // 中间件
  28. app.use((0, cors_1.default)());
  29. app.use(express_1.default.json());
  30. // API 路由
  31. app.use("/api/v1/templates", (0, templates_1.templatesRouter)(db));
  32. app.use("/api/v1/creatives", (0, creatives_1.creativesRouter)(db, STORAGE_DIR, preview_2.onThemeSaved));
  33. app.use("/api/v1", (0, assets_1.assetsRouter)(db, STORAGE_DIR));
  34. app.use("/api/v1", (0, builds_1.buildsRouter)(db, STORAGE_DIR, preview_2.onThemeSaved));
  35. app.use("/api/v1", (0, preview_1.previewRouter)(db, STORAGE_DIR));
  36. // Vite 预览代理:将 /preview/* 请求转发到 Vite dev server 并重写 HTML 路径
  37. app.use("/preview", previewProxy_1.previewProxy);
  38. // 生产环境:serve React 静态文件
  39. app.use(express_1.default.static(CLIENT_DIST));
  40. app.get("*", (_req, res) => {
  41. res.sendFile(path_1.default.join(CLIENT_DIST, "index.html"));
  42. });
  43. // 错误处理
  44. app.use(errorHandler_1.errorHandler);
  45. app.listen(PORT, () => {
  46. console.log(`[platform] Server running at http://localhost:${PORT}`);
  47. console.log(`[platform] Storage: ${STORAGE_DIR}`);
  48. });
  49. }
  50. main().catch((err) => {
  51. console.error("Failed to start server:", err);
  52. process.exit(1);
  53. });
  54. //# sourceMappingURL=index.js.map