logreq

Logger-agnostic logging middleware for Node.js. Inspired by the "morgan" package.

Usage no npm install needed!

<script type="module">
  import logreq from 'https://cdn.skypack.dev/logreq';
</script>

README

OVERVIEW

Logger-agnostic logging middleware for Node.js. Inspired by the "morgan" package.

API

logreq({logger, level, format})

Create a new logreq logging middleware function. The "logger" is the only required parameter. The "level" parameter is a string that provides a means by which to set the log level (defaults to 'info'). The "format" parameter is a function for customizing the log message.

Default Message Format

${ip} ${method} ${url} ${statusCode} ${length} - ${ms} ms ${id}

EXAMPLE

Sample App

const express = require('express')
const winston = require('winston')
const app = express()

const logger = winston.createLogger({
  level: 'info',
  transports: [
    new winston.transports.Console({
      format: winston.format.simple()
    })
  ]
})

const logreq = require('logreq')({logger})
app.use(logreq)

app.get('/download', (req, res) => {
  res.sendFile(`${__dirname}/test.txt`)
})
app.listen(3000, () => console.log('Listening on port 3000!'))

Log Output

The below log output is from the above example app.

info: ::ffff:192.168.1.158 GET /download 200 3507 bytes - 14 ms
info: ::ffff:192.168.1.123 GET /download 200 3507 bytes - 19 ms
info: ::ffff:192.168.1.101 GET /download 200 3507 bytes - 33 ms
info: ::ffff:192.168.1.155 GET /download 200 3507 bytes - 26 ms

LICENSE

ISC