dynamic-middleware

4.0.4 • Public • Published

dynamic-middleware Build Status

Replace or disable a connect/express middleware in runtime

compatible with express 3, express 4 and connect 3

Why?

its quite inconvenient to replace a middleware after you start a connect / express server

Install

    npm install dynamic-middleware

Usage

const DynamicMiddleware = require('dynamic-middleware')
const express = require('express')

const app = express()

// a simple middleware
function myMiddleware(req, res, next) {
    res.end('1')
}

// create a dynamic one from it
let dm = DynamicMiddleware.create(myMiddleware)

app.get('/', dm.handler()) 

// disable the middleware, will reply with 404 now
dm.disable() 

// enable it back
dm.enable()

// or replace it with something else
dm = dm.replace(function(req, res, next) {
    res.end('2')
})

// create a dynamic error middlware
let errorDm = DynamicMiddleware.create((err, req, res, next) => { ... })

app.use(errorDm.errorHandler())

see also

loadbalance module

loadbalance-middleware module

changelog

3.x.x

Previous versions operated by manipulating the internal state of express/connect , this approach worked well for real middlewares (.use()) but was terrible for routes (.get() etc..). The new version does not do that, but rather manages the state internally.

4.x.x

The public interface of this module has changed

license

MIT © yaniv kessler

Package Sidebar

Install

npm i dynamic-middleware

Weekly Downloads

33

Version

4.0.4

License

MIT

Unpacked Size

8.25 kB

Total Files

6

Last publish

Collaborators

  • kessler
  • yaniv