Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

express-modern

magicdawn18MIT1.0.0TypeScript support: included

use async function or generator function with express

express, promise, async-function, async, generator

readme

express-modern

use async function or generator function with express

Build Status Coverage Status npm version npm downloads npm license

Install

npm i express-modern --save

supported case

  • normal handler app.get('/', modern((req, res, next) => { ... }))
  • error handler app.get('/', modern((err, req, res, next) => { ... }))
  • param handler app.param('user', modern((req, res, next, user) => { ... }))

API

const modern = require('express-modern')

generator function

const app = express();
app.get('/', modern(function * (req, res, next) {
  yield new Promise(r => setTimeout(r, 10));
  res.send('generator function');
}));

const res = yield request(app)
  .get('/')
  .endAsync();
res.text.should.match(/generator/);

the generator function will be wrap via co.wrap. and the modern function will take care of the arity of the handler. see http://expressjs.com/en/guide/error-handling.html

async function

const app = express();
app.get('/', modern(async function(req, res, next) {
  await new Promise(r => setTimeout(r, 10));
  res.send('async function');
}));

const res = yield request(app)
  .get('/')
  .endAsync();
res.text.should.match(/async/);

the async function will be called & the rejected value will be passed to next automatically

normal function

const app = express();
app.get('/', modern((req, res, next) => {
  res.send('normal function');
}));

const res = yield request(app)
  .get('/')
  .endAsync();

res.text.should.match(/normal/);

the modern function does nothing on normal function.

Changelog

CHANGELOG.md

License

the MIT License http://magicdawn.mit-license.org

changelog

CHANGELOG

v0.3.0 2016-05-01

  • add router.param support

v0.2.0 Unknown Date

  • Unknown

v0.1.0 2016-3-26

  • It's available for using now.

v0.0.1 Unknown Date

  • empty. just take the package