overleaf/services/filestore/app/js/RequestLogger.js

89 lines
2.2 KiB
JavaScript
Raw Normal View History

const logger = require('logger-sharelatex')
const metrics = require('metrics-sharelatex')
2020-01-14 12:02:39 +00:00
class RequestLogger {
constructor() {
this._logInfo = {}
this._logMessage = 'http request'
}
2020-01-14 17:13:12 +00:00
addFields(fields) {
Object.assign(this._logInfo, fields)
}
setMessage(message) {
this._logMessage = message
}
static attach(app) {
app.use(RequestLogger.middleware)
app.use(RequestLogger.errorHandler)
2020-01-14 12:02:39 +00:00
}
2020-01-14 17:13:12 +00:00
static errorHandler(err, req, res, next) {
req.requestLogger._logInfo.error = err
2020-01-14 12:02:39 +00:00
res
.send(err.message)
.status(500)
.end()
}
2020-01-14 12:02:39 +00:00
2020-01-14 17:13:12 +00:00
static middleware(req, res, next) {
2020-01-14 12:02:39 +00:00
const startTime = new Date()
2020-01-14 17:13:12 +00:00
req.requestLogger = new RequestLogger()
2020-01-14 12:02:39 +00:00
// override the 'end' method to log and record metrics
const end = res.end
res.end = function() {
// apply the standard request 'end' method before logging and metrics
end.apply(this, arguments)
2020-01-14 12:02:39 +00:00
const responseTime = new Date() - startTime
2020-01-14 12:02:39 +00:00
const routePath = req.route && req.route.path.toString()
2020-01-14 12:02:39 +00:00
if (routePath) {
metrics.timing('http_request', responseTime, null, {
method: req.method,
2020-01-14 12:02:39 +00:00
status_code: res.statusCode,
path: routePath
.replace(/\//g, '_')
.replace(/:/g, '')
.slice(1)
})
}
const level = res.statusCode >= 500 ? 'err' : 'log'
logger[level](
{
req: {
url: req.originalUrl || req.url,
route: routePath,
method: req.method,
referrer: req.headers.referer || req.headers.referrer,
'remote-addr':
req.ip ||
(req.socket && req.socket.remoteAddress) ||
(req.socket &&
req.socket.socket &&
req.socket.socket.remoteAddress),
'user-agent': req.headers['user-agent'],
'content-length': req.headers['content-length']
},
res: {
'content-length': res._headers['content-length'],
statusCode: res.statusCode,
'response-time': responseTime
},
2020-01-14 17:13:12 +00:00
info: req.requestLogger._logInfo
},
2020-01-14 17:13:12 +00:00
req.requestLogger._logMessage
2020-01-14 12:02:39 +00:00
)
}
2020-01-14 12:02:39 +00:00
next()
}
}
2020-01-14 12:02:39 +00:00
module.exports = RequestLogger