-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
40 lines (32 loc) · 1.13 KB
/
index.js
File metadata and controls
40 lines (32 loc) · 1.13 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
const express = require("express");
const userRouter = require("./routes/users");
const securityRouter = require("./routes/security");
const helloRouter = require("./routes/hello");
const checkRequestFormat = require("./middlewares/checkRequestFormat");
const errorHandler = require("./middlewares/errorHandler");
const app = express();
app.use(express.json());
app.use(function monitor(req, res, next) {
// Process request monitoring
console.log("request", req.url);
// Override default functions with monitored ones
const jsonFnc = res.json;
res.json = function (...args) {
console.log("response", res.statusCode, JSON.stringify(args));
return jsonFnc.call(res, ...args);
};
const sendStatusFnc = res.sendStatus;
res.sendStatus = function (...args) {
const result = sendStatusFnc.call(res, ...args);
console.log("response", res.statusCode);
return result;
};
next();
});
app.use(checkRequestFormat);
app.use(helloRouter);
app.use(securityRouter);
app.use(userRouter);
app.use(errorHandler);
const PORT = process.env.PORT || 3000;
app.listen(PORT, () => console.log("Server is listening on port " + PORT));