-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
86 lines (73 loc) · 2.39 KB
/
index.js
File metadata and controls
86 lines (73 loc) · 2.39 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
86
const express = require('express');
const app = express();
require('dotenv').config();
const sequelize = require('./config/db');
const logger = require('./utils/logger');
const requestLoggerMiddleware = require('./middleware/requestLogger');
const securityMiddleware = require('./middleware/security');
const { metricsMiddleware, register } = require('./middleware/monitoring');
// Apply request logging middleware
app.use(requestLoggerMiddleware);
// Apply security middleware
app.use(securityMiddleware);
// Apply metrics middleware
app.use(metricsMiddleware);
// Expose Prometheus metrics endpoint
app.get('/metrics', async (req, res) => {
res.set('Content-Type', register.contentType);
res.end(await register.metrics());
});
// Basic middleware
app.use(express.json());
// Routes
app.use('/claims', require('./routes/claimRoutes'));
// Health check endpoint
app.get('/health', (req, res) => {
res.status(200).json({ status: 'UP', timestamp: new Date().toISOString() });
});
// 404 handler
app.use((req, res) => {
logger.warn(`Route not found: ${req.method} ${req.originalUrl}`, { ip: req.ip });
res.status(404).json({ error: 'Route not found' });
});
// Global error handler
app.use((err, req, res, next) => {
logger.error(`Unhandled error: ${err.message}`, {
stack: err.stack,
method: req.method,
url: req.originalUrl,
ip: req.ip
});
res.status(500).json({
error: process.env.NODE_ENV === 'production' ? 'Internal Server Error' : err.message
});
});
// Sync DB and Start Server
sequelize.authenticate()
.then(() => {
logger.info('Database connected successfully');
return sequelize.sync();
})
.then(() => {
const PORT = process.env.PORT || 5000;
app.listen(PORT, () => {
logger.info(`Server running on port ${PORT}`);
});
})
.catch(err => {
logger.error('Failed to start server', { error: err.message, stack: err.stack });
process.exit(1);
});
// Handle uncaught exceptions
process.on('uncaughtException', (err) => {
logger.error('Uncaught exception', { error: err.message, stack: err.stack });
process.exit(1);
});
// Handle unhandled promise rejections
process.on('unhandledRejection', (reason, promise) => {
logger.error('Unhandled promise rejection', {
reason: reason?.message || reason,
stack: reason?.stack
});
process.exit(1);
});