2020-01-07 21:19:26 +00:00
|
|
|
const logger = require('logger-sharelatex')
|
2020-01-10 17:08:47 +00:00
|
|
|
const metrics = require('metrics-sharelatex')
|
2020-01-07 21:19:26 +00:00
|
|
|
|
2020-01-14 12:02:39 +00:00
|
|
|
class RequestLogger {
|
|
|
|
constructor() {
|
|
|
|
this._logInfo = {}
|
|
|
|
this._logMessage = 'http request'
|
|
|
|
}
|
2020-01-07 21:19:26 +00:00
|
|
|
|
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-10 17:08:47 +00:00
|
|
|
|
2020-01-14 17:13:12 +00:00
|
|
|
static errorHandler(err, req, res, next) {
|
2020-02-12 10:34:56 +00:00
|
|
|
req.requestLogger._logInfo.error = err
|
2020-01-14 12:02:39 +00:00
|
|
|
res
|
|
|
|
.send(err.message)
|
|
|
|
.status(500)
|
|
|
|
.end()
|
2020-01-10 17:08:47 +00:00
|
|
|
}
|
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-10 17:08:47 +00:00
|
|
|
|
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-10 17:08:47 +00:00
|
|
|
|
2020-01-14 12:02:39 +00:00
|
|
|
const responseTime = new Date() - startTime
|
2020-01-10 17:08:47 +00:00
|
|
|
|
2020-01-14 12:02:39 +00:00
|
|
|
const routePath = req.route && req.route.path.toString()
|
2020-01-10 17:08:47 +00:00
|
|
|
|
2020-01-14 12:02:39 +00:00
|
|
|
if (routePath) {
|
|
|
|
metrics.timing('http_request', responseTime, null, {
|
2020-01-10 17:08:47 +00:00
|
|
|
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-10 17:08:47 +00:00
|
|
|
},
|
2020-01-14 17:13:12 +00:00
|
|
|
req.requestLogger._logMessage
|
2020-01-14 12:02:39 +00:00
|
|
|
)
|
|
|
|
}
|
2020-01-10 17:08:47 +00:00
|
|
|
|
2020-01-14 12:02:39 +00:00
|
|
|
next()
|
|
|
|
}
|
2020-01-07 21:19:26 +00:00
|
|
|
}
|
2020-01-14 12:02:39 +00:00
|
|
|
|
|
|
|
module.exports = RequestLogger
|