-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathserver.js
More file actions
56 lines (46 loc) · 1.62 KB
/
server.js
File metadata and controls
56 lines (46 loc) · 1.62 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
require('dotenv').config();
const express = require('express');
const cors = require('cors');
const path = require('path');
// Import routes
const authRoutes = require('./routes/auth');
const taskRoutes = require('./routes/TaskRoutes');
const groupRoutes = require('./routes/GroupRouter');
const userRoutes = require('./routes/UserRouter');
// Middlewares
const errorHandler = require('./middlewares/ErrorHandler');
const app = express();
// ===== Middleware =====
app.use(cors());
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
// Security Headers
app.use((req, res, next) => {
res.setHeader('X-Content-Type-Options', 'nosniff');
res.setHeader('X-Frame-Options', 'DENY');
res.setHeader('X-XSS-Protection', '1; mode=block');
next();
});
// ===== Serve Static Files (Frontend) =====
app.use('/views', express.static(path.join(__dirname, 'views')));
// Redirect root to login
app.get('/', (req, res) => {
res.redirect('/views/login.html');
});
// ===== API Routes =====
app.use('/api/auth', authRoutes);
app.use('/api/tasks', taskRoutes);
app.use('/api/groups', groupRoutes);
app.use('/api/users', userRoutes);
// Error handler
app.use(errorHandler);
// ===== Start Server =====
const PORT = process.env.PORT || 3000;
app.listen(PORT, () => {
console.log('=================================');
console.log(`🚀 Server running on port ${PORT}`);
console.log(`📱 Open: http://localhost:${PORT}`);
console.log(`📋 Frontend: http://localhost:${PORT}/views/login.html`);
console.log(`🔌 API: http://localhost:${PORT}/api`);
console.log('=================================');
});