2014-05-07 09:58:52 +00:00
|
|
|
os = require("os")
|
2019-10-25 02:02:55 +00:00
|
|
|
yn = require("yn")
|
|
|
|
|
|
|
|
STACKDRIVER_LOGGING = yn(process.env['STACKDRIVER_LOGGING'])
|
2014-05-07 09:58:52 +00:00
|
|
|
|
|
|
|
module.exports.monitor = (logger) ->
|
|
|
|
return (req, res, next) ->
|
|
|
|
Metrics = require("./metrics")
|
2019-10-25 02:02:55 +00:00
|
|
|
startTime = process.hrtime()
|
2014-05-07 09:58:52 +00:00
|
|
|
end = res.end
|
|
|
|
res.end = () ->
|
|
|
|
end.apply(this, arguments)
|
2019-10-25 02:02:55 +00:00
|
|
|
responseTime = process.hrtime(startTime)
|
2020-03-25 13:39:21 +00:00
|
|
|
responseTimeMs = Math.round(responseTime[0] * 1000 + responseTime[1] / 1000000)
|
2020-03-11 20:25:33 +00:00
|
|
|
requestSize = parseInt(req.headers["content-length"], 10)
|
2015-05-14 15:14:24 +00:00
|
|
|
if req.route?.path?
|
|
|
|
routePath = req.route.path.toString().replace(/\//g, '_').replace(/\:/g, '').slice(1)
|
2019-10-25 02:02:55 +00:00
|
|
|
Metrics.timing("http_request", responseTimeMs, null, {method:req.method, status_code: res.statusCode, path:routePath})
|
2020-03-11 20:25:33 +00:00
|
|
|
if requestSize
|
2020-03-12 10:24:46 +00:00
|
|
|
Metrics.summary("http_request_size_bytes", requestSize, {method:req.method, status_code: res.statusCode, path:routePath})
|
2019-10-25 02:02:55 +00:00
|
|
|
remoteIp = req.ip || req.socket?.socket?.remoteAddress || req.socket?.remoteAddress
|
|
|
|
reqUrl = req.originalUrl || req.url
|
|
|
|
referrer = req.headers['referer'] || req.headers['referrer']
|
|
|
|
if STACKDRIVER_LOGGING
|
|
|
|
info =
|
|
|
|
httpRequest:
|
|
|
|
requestMethod: req.method
|
|
|
|
requestUrl: reqUrl
|
2020-03-11 20:25:33 +00:00
|
|
|
requestSize: requestSize
|
2019-10-25 02:02:55 +00:00
|
|
|
status: res.statusCode
|
|
|
|
responseSize: res._headers?["content-length"]
|
|
|
|
userAgent: req.headers["user-agent"]
|
|
|
|
remoteIp: remoteIp
|
|
|
|
referer: referrer
|
|
|
|
latency:
|
|
|
|
seconds: responseTime[0]
|
|
|
|
nanos: responseTime[1]
|
|
|
|
protocol: req.protocol
|
|
|
|
else
|
|
|
|
info =
|
|
|
|
req:
|
|
|
|
url: reqUrl
|
|
|
|
method: req.method
|
|
|
|
referrer: referrer
|
|
|
|
"remote-addr": remoteIp
|
|
|
|
"user-agent": req.headers["user-agent"]
|
|
|
|
"content-length": req.headers["content-length"]
|
|
|
|
res:
|
|
|
|
"content-length": res._headers?["content-length"]
|
|
|
|
statusCode: res.statusCode
|
|
|
|
"response-time": responseTimeMs
|
2020-03-18 12:41:11 +00:00
|
|
|
logger.info(info, "%s %s", req.method, reqUrl)
|
2014-05-07 09:58:52 +00:00
|
|
|
next()
|