-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
63 lines (52 loc) · 1.46 KB
/
server.js
File metadata and controls
63 lines (52 loc) · 1.46 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
require('dotenv').config();
const express = require('express');
const morgan = require('morgan');
const logger = require('./src/logger');
const { handleWebhook } = require('./src/webhook-handler');
const app = express();
const PORT = process.env.PORT || 3000;
app.use(express.json());
app.use(morgan('combined', {
stream: {
write: (message) => logger.info(message.trim())
}
}));
app.get('/health', (req, res) => {
res.status(200).json({
status: 'healthy',
timestamp: new Date().toISOString(),
service: 'feature-flag-webhook-receiver'
});
});
app.post('/webhook', handleWebhook);
app.use((err, req, res, next) => {
logger.error('Unhandled error', {
error: err.message,
stack: err.stack
});
res.status(500).json({
error: 'Internal server error',
details: err.message
});
});
const server = app.listen(PORT, () => {
logger.info(`Server started on port ${PORT}`);
logger.info('Endpoints:');
logger.info(` POST http://localhost:${PORT}/webhook - Receive feature flag webhooks`);
logger.info(` GET http://localhost:${PORT}/health - Health check`);
});
process.on('SIGTERM', () => {
logger.info('SIGTERM received, shutting down gracefully');
server.close(() => {
logger.info('Server closed');
process.exit(0);
});
});
process.on('SIGINT', () => {
logger.info('SIGINT received, shutting down gracefully');
server.close(() => {
logger.info('Server closed');
process.exit(0);
});
});
module.exports = app;