-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrequestLogger.js
More file actions
39 lines (33 loc) · 760 Bytes
/
requestLogger.js
File metadata and controls
39 lines (33 loc) · 760 Bytes
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
/**
* Request logging middleware
*/
const logger = require('../utils/logger');
/**
* Middleware to log all incoming requests
*/
const requestLogger = (req, res, next) => {
// Log request details
logger.info({
type: 'request',
method: req.method,
path: req.path,
query: req.query,
ip: req.ip,
userAgent: req.get('User-Agent')
});
// Track response time
const start = Date.now();
// Once the request is processed, log the response
res.on('finish', () => {
const duration = Date.now() - start;
logger.info({
type: 'response',
method: req.method,
path: req.path,
statusCode: res.statusCode,
duration: `${duration}ms`
});
});
next();
};
module.exports = requestLogger;