forked from linuxfoundation/crowd.dev
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapiResponseHandler.ts
More file actions
61 lines (56 loc) · 1.75 KB
/
Copy pathapiResponseHandler.ts
File metadata and controls
61 lines (56 loc) · 1.75 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
import { LoggerBase } from '@crowd/logging'
import { IServiceOptions } from '../services/IServiceOptions'
const io = require('@pm2/io')
/* eslint-disable class-methods-use-this */
export default class ApiResponseHandler extends LoggerBase {
public constructor(options: IServiceOptions) {
super(options.log)
}
async download(req, res, path) {
res.download(path)
}
async success(_req, res, payload, status = 200) {
if (payload !== undefined) {
// We might want to send a custom status, even the operation succeeded
res.status(status).send(payload)
} else {
res.sendStatus(200)
}
}
async error(req, res, error) {
if (error && error.name && error.name.includes('Sequelize')) {
req.log.error(
error,
{
code: 500,
url: req.url,
method: req.method,
query: error.sql,
body: req.body,
errorMessage: error.original?.message,
},
'Database error while processing REST API request!',
)
io.notifyError(error)
res.status(500).send('Internal Server Error')
} else if (error && [400, 401, 403, 404].includes(error.code)) {
req.log.error(
error,
{ code: error.code, url: req.url, method: req.method, query: req.query, body: req.body },
'Client error while processing REST API request!',
)
res.status(error.code).send(error.message)
} else {
if (!error.code) {
error.code = 500
}
req.log.error(
error,
{ code: error.code, url: req.url, method: req.method, query: req.query, body: req.body },
'Error while processing REST API request!',
)
io.notifyError(error)
res.status(error.code).send(error.message)
}
}
}