main.js 2.7 KB

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