main.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. import 'dotenv/config';
  2. import express from 'express';
  3. import expressWs from 'express-ws';
  4. import cookieParser from 'cookie-parser';
  5. import Logs from './libs/logs.js';
  6. import authRoutes from './routes/auth.js';
  7. import gamesRoutes from './routes/games.js';
  8. import localesRoutes from './routes/locales.js';
  9. import platformsRoutes from './routes/platforms.js';
  10. import requireAuth from './middleware/requireAuth.js';
  11. import requireInternalToken from './middleware/requireInternalToken.js';
  12. const app = express();
  13. const wsInstance = expressWs(app);
  14. // 添加 CORS 支持.env
  15. app.use((req, res, next) => {
  16. const origin = req.headers.origin;
  17. res.header('Access-Control-Allow-Origin', origin || '*');
  18. res.header('Access-Control-Allow-Credentials', 'true');
  19. res.header('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept, Authorization, X-Internal-Token');
  20. res.header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS');
  21. res.header('Vary', 'Origin');
  22. if (req.method === 'OPTIONS') {
  23. return res.sendStatus(200);
  24. }
  25. next();
  26. });
  27. // 中间件
  28. app.use(express.json({ limit: '10mb' }));
  29. app.use(cookieParser());
  30. app.use((req, res, next) => {
  31. res.badRequest = (data, msg) => {
  32. if (!msg && typeof data === 'string') {
  33. msg = data;
  34. data = undefined;
  35. }
  36. return res.status(400).json({ statusCode: 400, code: -1, message: msg ?? 'Bad Request', data });
  37. }
  38. res.unauthorized = (data, msg) => {
  39. if (!msg && typeof data === 'string') {
  40. msg = data;
  41. data = undefined;
  42. }
  43. return res.status(401).json({ statusCode: 401, code: -1, message: msg ?? 'Unauthorized', data });
  44. }
  45. res.notFound = (data, msg) => {
  46. if (!msg && typeof data === 'string') {
  47. msg = data;
  48. data = undefined;
  49. }
  50. return res.status(404).json({ statusCode: 404, code: -1, message: msg ?? 'Not Found', data });
  51. }
  52. res.serverError = (data, msg) => {
  53. if (!msg && typeof data === 'string') {
  54. msg = data;
  55. data = undefined;
  56. }
  57. return res.status(500).json({ statusCode: 500, code: -1, message: msg ?? 'Internal Server Error', data });
  58. }
  59. res.sendSuccess = (data, msg) => {
  60. const response = { statusCode: 200, code: 0, message: msg ?? 'OK' }
  61. if (data) {
  62. response.data = data;
  63. }
  64. return res.status(200).json(response);
  65. }
  66. res.sendError = (err) => {
  67. if (err.cause == 400) {
  68. return res.badRequest(err.data, err.message);
  69. }
  70. else if (err.cause == 401) {
  71. return res.unauthorized(err.data, err.message);
  72. }
  73. else if (err.cause == 404) {
  74. return res.notFound(err.data, err.message);
  75. }
  76. else {
  77. return res.serverError(err.data, err.message);
  78. }
  79. }
  80. next();
  81. });
  82. app.use('/api/auth', authRoutes);
  83. app.use('/api/games', requireAuth, gamesRoutes);
  84. app.use('/api/locales', requireAuth, localesRoutes);
  85. app.use('/api/platforms', requireInternalToken, platformsRoutes);
  86. // 启动服务
  87. const PORT = process.env.PORT || 9020;
  88. app.listen(PORT, () => Logs.out(`Server running on port ${PORT}`));