2018-10-25 13:52:27 -05:00
|
|
|
const logger = require('winston');
|
2018-10-24 03:43:30 -05:00
|
|
|
const db = require('../models');
|
|
|
|
const httpContext = require('express-http-context');
|
|
|
|
|
2018-11-10 19:11:12 -05:00
|
|
|
function logMetricsMiddleware (req, res, next) {
|
2018-10-24 03:43:30 -05:00
|
|
|
res.on('finish', () => {
|
|
|
|
const userAgent = req.get('user-agent');
|
|
|
|
const routePath = httpContext.get('routePath');
|
|
|
|
|
2018-10-25 13:52:27 -05:00
|
|
|
let referrer = req.get('referrer');
|
|
|
|
|
2018-11-10 19:11:12 -05:00
|
|
|
if (referrer && referrer.length > 255) {
|
2018-11-09 10:55:19 -05:00
|
|
|
try {
|
|
|
|
// Attempt to "safely" clamp long URLs
|
|
|
|
referrer = /(.*?)#.*/.exec(referrer)[1];
|
2018-11-10 19:11:12 -05:00
|
|
|
} catch (e) {
|
2018-11-09 10:55:19 -05:00
|
|
|
// Cheap forced string conversion & clamp
|
2018-11-10 19:32:43 -05:00
|
|
|
referrer = String(referrer);
|
2018-11-09 10:55:19 -05:00
|
|
|
referrer = referrer.substr(0, 255);
|
|
|
|
}
|
2018-10-25 13:52:27 -05:00
|
|
|
|
2018-11-10 19:11:12 -05:00
|
|
|
if (referrer.length > 255) {
|
2018-10-25 13:52:27 -05:00
|
|
|
logger.warn('Request refferer exceeds 255 characters:', referrer);
|
|
|
|
referrer = referrer.substring(0, 255);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-24 03:43:30 -05:00
|
|
|
db.Metrics.create({
|
2018-11-10 19:11:12 -05:00
|
|
|
time : Date.now(),
|
2018-11-10 19:32:43 -05:00
|
|
|
isInternal: /node-fetch/.test(userAgent),
|
2018-11-10 19:11:12 -05:00
|
|
|
isChannel : res.isChannel,
|
|
|
|
claimId : res.claimId,
|
|
|
|
routePath : httpContext.get('routePath'),
|
|
|
|
params : JSON.stringify(req.params),
|
|
|
|
ip : req.headers['x-forwarded-for'] || req.connection.remoteAddress,
|
|
|
|
request : req.url,
|
|
|
|
routeData : JSON.stringify(httpContext.get('routeData')),
|
2018-10-25 13:52:27 -05:00
|
|
|
referrer,
|
2018-10-24 03:43:30 -05:00
|
|
|
userAgent,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
next();
|
|
|
|
}
|
|
|
|
|
2018-11-10 19:11:12 -05:00
|
|
|
function setRouteDataInContextMiddleware (routePath, routeData) {
|
2018-10-24 03:43:30 -05:00
|
|
|
return function (req, res, next) {
|
|
|
|
httpContext.set('routePath', routePath);
|
|
|
|
httpContext.set('routeData', routeData);
|
|
|
|
next();
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
logMetricsMiddleware,
|
|
|
|
setRouteDataInContextMiddleware,
|
|
|
|
};
|