2021-10-27 12:06:50 +00:00
|
|
|
const OError = require('@overleaf/o-error')
|
|
|
|
|
|
|
|
function errSerializer(err) {
|
|
|
|
if (!err) {
|
|
|
|
return err
|
|
|
|
}
|
2024-10-01 19:39:32 +00:00
|
|
|
let message = err.message
|
|
|
|
if (err.path) {
|
|
|
|
// filter paths from the message to avoid duplicate errors with different path in message
|
|
|
|
// (e.g. errors from `fs` methods which have a path attribute)
|
|
|
|
message = message.replace(` '${err.path}'`, '')
|
|
|
|
}
|
2021-10-27 12:06:50 +00:00
|
|
|
return {
|
2024-10-01 19:39:32 +00:00
|
|
|
message,
|
2021-10-27 12:06:50 +00:00
|
|
|
name: err.name,
|
2022-09-14 14:10:45 +00:00
|
|
|
stack: OError.getFullStack(err),
|
2021-10-27 12:06:50 +00:00
|
|
|
info: OError.getFullInfo(err),
|
|
|
|
code: err.code,
|
2021-12-16 09:04:32 +00:00
|
|
|
signal: err.signal,
|
2024-10-01 19:39:32 +00:00
|
|
|
path: err.path,
|
2021-10-27 12:06:50 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function reqSerializer(req) {
|
|
|
|
if (!req) {
|
|
|
|
return req
|
|
|
|
}
|
|
|
|
const headers = req.headers || {}
|
2021-11-09 15:49:57 +00:00
|
|
|
const entry = {
|
2021-10-27 12:06:50 +00:00
|
|
|
method: req.method,
|
|
|
|
url: req.originalUrl || req.url,
|
|
|
|
remoteAddress: getRemoteIp(req),
|
|
|
|
headers: {
|
|
|
|
referer: headers.referer || headers.referrer,
|
|
|
|
'user-agent': headers['user-agent'],
|
2021-12-16 09:04:32 +00:00
|
|
|
'content-length': headers['content-length'],
|
|
|
|
},
|
2021-10-27 12:06:50 +00:00
|
|
|
}
|
2022-02-16 13:03:21 +00:00
|
|
|
if (req.params) {
|
|
|
|
const projectId =
|
|
|
|
req.params.projectId || req.params.project_id || req.params.Project_id
|
|
|
|
const userId = req.params.userId || req.params.user_id
|
|
|
|
const docId = req.params.docId || req.params.doc_id
|
|
|
|
if (projectId) {
|
|
|
|
entry.projectId = projectId
|
|
|
|
}
|
|
|
|
if (userId) {
|
|
|
|
entry.userId = userId
|
|
|
|
}
|
|
|
|
if (docId) {
|
|
|
|
entry.docId = docId
|
|
|
|
}
|
2021-11-09 15:49:57 +00:00
|
|
|
}
|
|
|
|
return entry
|
2021-10-27 12:06:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function resSerializer(res) {
|
|
|
|
if (!res) {
|
|
|
|
return res
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
statusCode: res.statusCode,
|
|
|
|
headers: {
|
2021-12-16 09:04:32 +00:00
|
|
|
'content-length': res.getHeader && res.getHeader('content-length'),
|
|
|
|
},
|
2021-10-27 12:06:50 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function getRemoteIp(req) {
|
|
|
|
if (req.ip) {
|
|
|
|
return req.ip
|
|
|
|
}
|
|
|
|
if (req.socket) {
|
|
|
|
if (req.socket.socket && req.socket.socket.remoteAddress) {
|
|
|
|
return req.socket.socket.remoteAddress
|
|
|
|
} else if (req.socket.remoteAddress) {
|
|
|
|
return req.socket.remoteAddress
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = { err: errSerializer, req: reqSerializer, res: resSerializer }
|