forked from Renu-code123/ExpenseFlow
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
85 lines (71 loc) · 2.28 KB
/
server.js
File metadata and controls
85 lines (71 loc) · 2.28 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
const express = require('express');
const http = require('http');
const socketIo = require('socket.io');
const mongoose = require('mongoose');
const cors = require('cors');
const socketAuth = require('./middleware/socketAuth');
const CronJobs = require('./services/cronJobs');
require('dotenv').config();
const authRoutes = require('./routes/auth');
const expenseRoutes = require('./routes/expenses');
const syncRoutes = require('./routes/sync');
const app = express();
const server = http.createServer(app);
const io = socketIo(server, {
cors: {
origin: "*",
methods: ["GET", "POST"]
}
});
const PORT = process.env.PORT || 3000;
// Middleware
app.use(cors());
app.use(express.json());
app.use(express.static('.'));
// Make io available to routes
app.set('io', io);
// Database connection
mongoose.connect(process.env.MONGODB_URI)
.then(() => {
console.log('MongoDB connected');
// Initialize cron jobs after DB connection
CronJobs.init();
console.log('Email cron jobs initialized');
})
.catch(err => console.error('MongoDB connection error:', err));
// Socket.IO authentication
io.use(socketAuth);
// Socket.IO connection handling
io.on('connection', (socket) => {
console.log(`User ${socket.user.name} connected`);
// Join user-specific room
socket.join(`user_${socket.userId}`);
// Handle sync requests
socket.on('sync_request', async (data) => {
try {
// Process sync queue for this user
const SyncQueue = require('./models/SyncQueue');
const pendingSync = await SyncQueue.find({
user: socket.userId,
processed: false
}).sort({ createdAt: 1 });
socket.emit('sync_data', pendingSync);
} catch (error) {
socket.emit('sync_error', { error: error.message });
}
});
socket.on('disconnect', () => {
console.log(`User ${socket.user.name} disconnected`);
});
});
// Routes
app.use('/api/auth', authRoutes);
app.use('/api/expenses', expenseRoutes);
app.use('/api/sync', syncRoutes);
app.use('/api/notifications', require('./routes/notifications'));
app.use('/api/receipts', require('./routes/receipts'));
app.use('/api/budgets', require('./routes/budgets'));
app.use('/api/goals', require('./routes/goals'));
server.listen(PORT, () => {
console.log(`Server running on port ${PORT}`);
});