Skip to content

Commit

Permalink
feat: add logger
Browse files Browse the repository at this point in the history
  • Loading branch information
nassiharel committed Jun 15, 2021
1 parent 8216a93 commit 63ba9d6
Show file tree
Hide file tree
Showing 5 changed files with 22 additions and 4 deletions.
2 changes: 2 additions & 0 deletions lib/app-server.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ const EventEmitter = require('events');
const bodyParser = require('body-parser');
const RateLimit = require('express-rate-limit');
const poweredBy = require('../middlewares/powered-by');
const logger = require('../middlewares/logger');
const cors = require('../middlewares/cors');
const errors = require('../middlewares/errors');
const swaggerRoute = require('./swagger-route');
Expand Down Expand Up @@ -85,6 +86,7 @@ class RestServer extends EventEmitter {
}

const bodySizeLimit = options.bodySizeLimit || '10mb';
this._app.use(logger(this));
this._app.use(cors); // CORS middleware
this._app.use(bodyParser.raw({ limit: bodySizeLimit }));
this._app.use(bodyParser.json({ limit: bodySizeLimit }));
Expand Down
16 changes: 16 additions & 0 deletions middlewares/logger.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@

const now = require('performance-now');

const logger = emitter => (req, res, next) => {
const start = now();
const { method, url } = req.method;
res.on('finish', () => {
const end = now();
const status = res.statusCode;
const duration = (start - end).toFixed(2);
emitter.emit('request', { method, url, status, duration });
});
next();
};

module.exports = logger;
4 changes: 2 additions & 2 deletions middlewares/powered-by.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@
* X-Powered-By middleware
*/

const powered = (poweredBy) => (req, res, next) => {
const powered = poweredBy => (req, res, next) => {
res.setHeader('X-Powered-By', poweredBy);
next();
};

module.exports = powered;
module.exports = powered;
3 changes: 1 addition & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
"fs-extra": "^9.0.1",
"js-yaml": "^4.0.0",
"json-refs": "^3.0.15",
"performance-now": "^2.1.0",
"swagger-parser": "^10.0.2"
},
"devDependencies": {
Expand Down

0 comments on commit 63ba9d6

Please sign in to comment.