rentease-backend-new/app.js

95 lines
3.9 KiB
JavaScript
Raw Normal View History

2026-04-20 06:43:09 +00:00
const express = require('express');
const cors = require('cors');
const sequelize = require('./config/db');
const { authMiddleware } = require('./middleware/auth');
const { operationLogMiddleware } = require('./utils/logger');
const { startCronJobs, stopCronJobs } = require('./cronJobs');
// 加载模型关联关系
require('./models');
// 导入路由
const apartmentRoutes = require('./routes/apartment');
const roomRoutes = require('./routes/room');
const rentalRoutes = require('./routes/rental');
const renterRoutes = require('./routes/renter');
const statisticsRoutes = require('./routes/statistics');
const meterReadingRoutes = require('./routes/meterReading');
const authRoutes = require('./routes/auth');
const userRoutes = require('./routes/user');
const roleRoutes = require('./routes/role');
const menuRoutes = require('./routes/menu');
const logRoutes = require('./routes/log');
const billRoutes = require('./routes/bill');
const billPaymentRoutes = require('./routes/billPayment');
const tenantRoutes = require('./routes/tenant');
const billingRoutes = require('./routes/billing');
const settingsRoutes = require('./routes/settings');
const app = express();
const PORT = process.env.PORT || 3000;
// 中间件
app.use(cors());
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
// 公开路由(不需要认证)
app.use('/api/auth', authRoutes);
// 需要认证的路由
app.use('/api/apartments', authMiddleware, operationLogMiddleware({ module: '公寓管理' }), apartmentRoutes);
app.use('/api/rooms', authMiddleware, operationLogMiddleware({ module: '房间管理' }), roomRoutes);
app.use('/api/rentals', authMiddleware, operationLogMiddleware({ module: '租房管理' }), rentalRoutes);
app.use('/api/renters', authMiddleware, operationLogMiddleware({ module: '租客管理' }), renterRoutes);
app.use('/api/statistics', authMiddleware, operationLogMiddleware({ module: '统计分析' }), statisticsRoutes);
app.use('/api/meter-readings', authMiddleware, operationLogMiddleware({ module: '抄表管理' }), meterReadingRoutes);
app.use('/api/users', authMiddleware, operationLogMiddleware({ module: '用户管理' }), userRoutes);
app.use('/api/roles', authMiddleware, operationLogMiddleware({ module: '角色管理' }), roleRoutes);
app.use('/api/menus', authMiddleware, operationLogMiddleware({ module: '菜单管理' }), menuRoutes);
app.use('/api/logs', authMiddleware, logRoutes);
app.use('/api/bills', authMiddleware, operationLogMiddleware({ module: '账单管理' }), billRoutes);
app.use('/api/bill-payments', authMiddleware, operationLogMiddleware({ module: '账单支付' }), billPaymentRoutes);
app.use('/api/tenants', authMiddleware, operationLogMiddleware({ module: '租户管理' }), tenantRoutes);
app.use('/api/billing', authMiddleware, billingRoutes); // 计费管理路由
app.use('/api/settings', authMiddleware, operationLogMiddleware({ module: '参数设置' }), settingsRoutes); // 参数设置路由
// 测试接口
app.get('/', (req, res) => {
res.json({ message: 'Rentease API 服务运行正常' });
});
// 启动服务器
console.log('正在启动服务器...');
console.log('使用端口:', PORT);
try {
const server = app.listen(PORT, '0.0.0.0', () => {
console.log(`服务器运行在 http://localhost:${PORT}`);
console.log(`服务器PID: ${process.pid}`);
console.log('服务器已成功启动,正在监听请求...');
});
// 错误处理
server.on('error', (error) => {
console.error('服务器启动错误:', error);
process.exit(1);
});
// 启动定时任务
startCronJobs();
// 进程终止处理
process.on('SIGINT', () => {
console.log('正在关闭服务器...');
stopCronJobs();
server.close(() => {
console.log('服务器已关闭');
process.exit(0);
});
});
} catch (error) {
console.error('服务器启动异常:', error);
process.exit(1);
}
module.exports = app;