index.js 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. "use strict";
  2. var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
  3. if (k2 === undefined) k2 = k;
  4. var desc = Object.getOwnPropertyDescriptor(m, k);
  5. if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
  6. desc = { enumerable: true, get: function() { return m[k]; } };
  7. }
  8. Object.defineProperty(o, k2, desc);
  9. }) : (function(o, m, k, k2) {
  10. if (k2 === undefined) k2 = k;
  11. o[k2] = m[k];
  12. }));
  13. var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
  14. Object.defineProperty(o, "default", { enumerable: true, value: v });
  15. }) : function(o, v) {
  16. o["default"] = v;
  17. });
  18. var __importStar = (this && this.__importStar) || (function () {
  19. var ownKeys = function(o) {
  20. ownKeys = Object.getOwnPropertyNames || function (o) {
  21. var ar = [];
  22. for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
  23. return ar;
  24. };
  25. return ownKeys(o);
  26. };
  27. return function (mod) {
  28. if (mod && mod.__esModule) return mod;
  29. var result = {};
  30. if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
  31. __setModuleDefault(result, mod);
  32. return result;
  33. };
  34. })();
  35. var __importDefault = (this && this.__importDefault) || function (mod) {
  36. return (mod && mod.__esModule) ? mod : { "default": mod };
  37. };
  38. Object.defineProperty(exports, "__esModule", { value: true });
  39. exports.server = exports.app = void 0;
  40. const express_1 = __importDefault(require("express"));
  41. const cors_1 = __importDefault(require("cors"));
  42. const helmet_1 = __importDefault(require("helmet"));
  43. const dotenv_1 = __importDefault(require("dotenv"));
  44. const http_1 = require("http");
  45. const path_1 = __importDefault(require("path"));
  46. const fs_1 = __importDefault(require("fs"));
  47. const database_1 = require("./config/database");
  48. const routes_1 = __importDefault(require("./routes"));
  49. const errorHandler_1 = require("./middleware/errorHandler");
  50. const websocketService_1 = __importStar(require("./services/websocketService"));
  51. const firmware_1 = require("./models/firmware");
  52. const ota_1 = require("./models/ota");
  53. const mqttBrokerService_1 = require("./services/mqttBrokerService");
  54. const loggerService_1 = require("./services/loggerService");
  55. const requestLogger_1 = require("./middleware/requestLogger");
  56. dotenv_1.default.config({ override: false });
  57. const envPath = path_1.default.resolve(process.cwd(), '.env.production').trim();
  58. console.log('加载生产环境文件:', envPath);
  59. dotenv_1.default.config({ path: envPath, override: true });
  60. process.env.NODE_ENV = process.env.NODE_ENV || 'production';
  61. const app = (0, express_1.default)();
  62. exports.app = app;
  63. const server = (0, http_1.createServer)(app);
  64. exports.server = server;
  65. app.use((0, helmet_1.default)());
  66. app.use((0, cors_1.default)({
  67. origin: true,
  68. credentials: true,
  69. methods: ['GET', 'POST', 'PUT', 'DELETE', 'OPTIONS', 'PATCH'],
  70. allowedHeaders: ['Content-Type', 'Authorization', 'X-Requested-With', 'X-Forwarded-For', 'X-Real-IP']
  71. }));
  72. app.use(express_1.default.json());
  73. app.use(express_1.default.urlencoded({ extended: true }));
  74. app.use(requestLogger_1.requestLogger);
  75. app.use('/api', routes_1.default);
  76. const frontendPath = path_1.default.join(__dirname, '../../dist');
  77. if (fs_1.default.existsSync(frontendPath)) {
  78. app.use(express_1.default.static(frontendPath));
  79. app.get('*', (req, res) => {
  80. res.sendFile(path_1.default.join(frontendPath, 'index.html'));
  81. });
  82. console.log('前端静态文件服务已启用');
  83. }
  84. app.get('/health', (req, res) => {
  85. res.status(200).json({
  86. status: 'ok',
  87. message: 'MQTT Dashboard API is running',
  88. timestamp: new Date().toISOString()
  89. });
  90. });
  91. app.use(errorHandler_1.errorHandler);
  92. const PORT = parseInt(process.env.PORT || '3002');
  93. async function startServer() {
  94. try {
  95. await loggerService_1.LoggerService.info('MQTT Dashboard API服务器开始启动', {
  96. source: 'system',
  97. module: 'init',
  98. details: JSON.stringify({ port: PORT, environment: process.env.NODE_ENV })
  99. });
  100. await (0, database_1.testConnection)();
  101. console.log('数据库连接成功');
  102. await loggerService_1.LoggerService.info('数据库连接成功', {
  103. source: 'system',
  104. module: 'database'
  105. });
  106. await firmware_1.FirmwareFileModel.createTable();
  107. console.log('固件文件表创建成功');
  108. await ota_1.OTATaskModel.createTable();
  109. console.log('OTA任务表创建成功');
  110. const webSocketService = new websocketService_1.default(server);
  111. (0, websocketService_1.setWebSocketService)(webSocketService);
  112. console.log('WebSocket服务已初始化');
  113. webSocketService.startRealDataUpdates();
  114. console.log('实时数据更新服务已启动');
  115. const mqttBroker = mqttBrokerService_1.MqttBrokerService.getInstance();
  116. await mqttBroker.start();
  117. console.log('MQTT Broker服务已启动');
  118. await loggerService_1.LoggerService.info('MQTT Broker服务已启动', {
  119. source: 'system',
  120. module: 'mqtt_broker',
  121. details: JSON.stringify({ port: process.env.MQTT_BROKER_PORT || 1883 })
  122. });
  123. server.listen(PORT, '0.0.0.0', () => {
  124. console.log(`服务器运行在端口 ${PORT}`);
  125. console.log(`API文档地址: http://localhost:${PORT}/api`);
  126. console.log(`WebSocket服务地址: ws://localhost:${PORT}`);
  127. console.log(`MQTT Broker地址: mqtt://localhost:${process.env.MQTT_BROKER_PORT || 1883}`);
  128. loggerService_1.LoggerService.info('服务器启动成功', {
  129. source: 'system',
  130. module: 'http',
  131. details: JSON.stringify({
  132. port: PORT,
  133. apiUrl: `http://localhost:${PORT}/api`,
  134. wsUrl: `ws://localhost:${PORT}`,
  135. mqttBroker: `mqtt://localhost:${process.env.MQTT_BROKER_PORT || 1883}`
  136. })
  137. }).catch(() => { });
  138. });
  139. }
  140. catch (error) {
  141. console.error('启动服务器失败:', error);
  142. await loggerService_1.LoggerService.error('启动服务器失败', {
  143. source: 'system',
  144. module: 'init',
  145. details: JSON.stringify({ error: error instanceof Error ? error.message : '未知错误' })
  146. });
  147. process.exit(1);
  148. }
  149. }
  150. process.on('SIGINT', async () => {
  151. console.log('正在关闭服务器...');
  152. const mqttBroker = mqttBrokerService_1.MqttBrokerService.getInstance();
  153. await mqttBroker.stop();
  154. process.exit(0);
  155. });
  156. process.on('SIGTERM', async () => {
  157. console.log('正在关闭服务器...');
  158. const mqttBroker = mqttBrokerService_1.MqttBrokerService.getInstance();
  159. await mqttBroker.stop();
  160. process.exit(0);
  161. });
  162. startServer();
  163. //# sourceMappingURL=index.js.map