mirror of
https://github.com/overleaf/overleaf.git
synced 2024-12-02 09:39:33 -05:00
61 lines
1.2 KiB
JavaScript
61 lines
1.2 KiB
JavaScript
|
const OError = require('@overleaf/o-error')
|
||
|
|
||
|
function errSerializer(err) {
|
||
|
if (!err) {
|
||
|
return err
|
||
|
}
|
||
|
return {
|
||
|
message: err.message,
|
||
|
name: err.name,
|
||
|
stack: OError.getFullStack(err),
|
||
|
info: OError.getFullInfo(err),
|
||
|
code: err.code,
|
||
|
signal: err.signal
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function reqSerializer(req) {
|
||
|
if (!req) {
|
||
|
return req
|
||
|
}
|
||
|
const headers = req.headers || {}
|
||
|
return {
|
||
|
method: req.method,
|
||
|
url: req.originalUrl || req.url,
|
||
|
remoteAddress: getRemoteIp(req),
|
||
|
headers: {
|
||
|
referer: headers.referer || headers.referrer,
|
||
|
'user-agent': headers['user-agent'],
|
||
|
'content-length': headers['content-length']
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function resSerializer(res) {
|
||
|
if (!res) {
|
||
|
return res
|
||
|
}
|
||
|
return {
|
||
|
statusCode: res.statusCode,
|
||
|
headers: {
|
||
|
'content-length': res.getHeader && res.getHeader('content-length')
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
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 }
|