Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bhumijgupta/erel
Express-route-exit-log (EREL) is an customisable express middleware package to log useful request insights when route execution finishes
https://github.com/bhumijgupta/erel
express express-js express-logger express-middleware express-routes logger logger-middleware logging middleware
Last synced: 2 months ago
JSON representation
Express-route-exit-log (EREL) is an customisable express middleware package to log useful request insights when route execution finishes
- Host: GitHub
- URL: https://github.com/bhumijgupta/erel
- Owner: bhumijgupta
- License: mit
- Created: 2020-08-12T16:18:24.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-03-05T10:34:21.000Z (almost 2 years ago)
- Last Synced: 2024-09-23T05:42:50.149Z (4 months ago)
- Topics: express, express-js, express-logger, express-middleware, express-routes, logger, logger-middleware, logging, middleware
- Language: TypeScript
- Homepage:
- Size: 271 KB
- Stars: 4
- Watchers: 3
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
EREL
Express-route-exit-log (EREL) is a customisable express middleware package to log useful request insights when route execution finishes.#### Features
- Written in TypeScript
- Included types for intellisense in IDE
- Supports both CJS and ESM modules
- Small package and easy to set up
- Support for custom logging solution
- Provides route insights like IP address, status code, execution time. etc## Install
```bash
# NPM
npm i erel --save# Yarn
yarn add erel
```## Screenshot
Logging route insights using custom logger and EREL
![Demo screenshot](https://github.com/bhumijgupta/erel/raw/master/assets/screenshot.png)## Usage
1. For JavaScript
```javascript
const express = require('express');
const app = express();// Import exitLog from erel
const { exitLog } = require('erel');// Use your custom logging solution (optional but preferred)
const customLogger = (data, req, res) => {
Logger.info(
`${data.timestamp} - ${data.ip} - ${data.method} - ${data.route} - ${data.statusCode} - ${data.responseTime}`,
);
};
exitLog.setLogger(customLogger);// Configure express app to use the middleware
app.use(exitLog.middleware);
```2. For TypeScript
```typescript
import * as express from 'express';
const app = express();// import exitLog and LoggerCallback from erel
import { exitLog, LoggerCallback } from 'erel';// Use your custom logging solution (optional but preferred)
const customLogger: LoggerCallback = (data, req, res) => {
Logger.info(
`${data.timestamp} - ${data.ip} - ${data.method} - ${data.route} - ${data.statusCode} - ${data.responseTime}`,
);
};
exitLog.setLogger(customLogger);// Configure express app to use the middleware
app.use(exitLog.middleware);
```## API Reference
### exitLog
- #### `exitLog.setLogger`
`setLogger` method can be used to set your custom Logging function which will be called along with the request insights.
It accepts a logger function as argument which implements the `LoggerCallback` interface. See [LoggerCallback](#LoggerCallback) for more details.```typescript
// Exampleimport { exitLog } from 'erel';
// req and res is also passed to log custom objects, like req.userId
exitLog.setLogger((data, req, res) => {
Logger.log(`${data.timestamp} - ${req.userId} - ${data.ip} - ${data.statusCode}`);
});
```- #### `exitLog.middleware`
`middleware` is the inbuilt middleware function to be configured with express to use. This middleware will call the custom Logger function (if set using `exitLog.setLogger`), otherwise the default Logger.
```typescript
// Example
import * as express from 'express';
import { exitLog } from 'erel';
const app = express();
app.use(exitLog.middleware);
```### LoggerCallback
`LoggerCallback` is an interface for the custom logger function to be used.
```typescript
type LoggerCallback = (data: exitData, req?: Request, res?: Response) => void;
// data -> request insights
// req -> express request object
// res -> express response object
````data` contains the following properties
| Property | Type | Description |
|--------------|:-------------------:|:---------------------------------------------------:|
| `rawEnterDate` | `Date` | Date when request entered the route |
| `rawExitDate` | `Date` | Date when request finished route execution |
| `timestamp` | `string` | Timestamp when route finished execution |
| `statusCode` | `number` | Response status code |
| `route` | `string` | Route accessed |
| `ip` | `string \| undefined` | IP address of the request |
| `responseTime` | `number` | Time taken in millisecond to finish route execution |
| `method` | `string` | Request method to access the endpoint |#### Need more insights?
Consider opening a feature request [here](https://github.com/bhumijgupta/erel/issues/new).
### License
## Build with ♡ by
### Bhumij Gupta
![GitHub followers](https://img.shields.io/github/followers/bhumijgupta?label=Follow&style=social) [![LinkedIn](https://img.shields.io/static/v1.svg?label=connect&message=@bhumijgupta&color=success&logo=linkedin&style=flat&logoColor=white)](https://www.linkedin.com/in/bhumijgupta/) ![Twitter Follow](https://img.shields.io/twitter/follow/bhumijgupta?style=social)
---
```javascript
if (repo.isAwesome || repo.isHelpful) {
StarRepo();
}
```