express-ming
Version:
Transform an express response (or make until no good)
90 lines (51 loc) • 3.24 kB
Markdown
# express-ming [](https://travis-ci.org/richardschneider/express-ming)
Middleware for express responses.
This package allows synchronous and asynchronous transformation of an express response. This is a similar concept to the express middleware for a request but for a response. Note that the middleware is executed in LIFO order. It is implemented by monkey patching (hooking) the `res.end` or `res.json` methods.
## Getting started [](https://badge.fury.io/js/express-ming)
$ npm install express-ming --save
Then in your middleware
var ming = require('express-ming');
module.exports = ming.json(my_transform);
## Usage
Sample middleware (redact.js) to remove classified information.
````javascript
'use strict';
const ming = require('express-ming');
/* Remove any classified information from the response. */
function redact(body, req, res) {
if (body.secret) body.secret = '****';
// ...
return body;
}
exports = ming.json(redact);
````
then add to your `app.js` file (before the route handling middleware)
````javascript
app.use(require('./redact'))
````
and [*That's all folks!*](https://www.youtube.com/watch?v=gBzJGckMYO4)
See the mocha [tests](https://github.com/richardschneider/express-ming/tree/master/test) for some more examples.
## Reference
### ming.json(fn, [options])
Transform the JSON body of the response.
`fn(json, req, res)` receives the JSON as an object, the `req` and `res`. It returns the modified body. If `undefined` is returned (i.e. nothing) then the original JSON is assumed to be modified. If `null` is returned, then a 204 No Content HTTP status is returned to client.
### ming.jsonAsync(fn, [options])
Asynchronously transform the JSON body of the response.
`fn(json, req, res)` receives the JSON as an object, the `req` and `res`. It returns a promise to a modified body. The promise returns an `object.` If it is `null` then a 204 No Content is sent to the client.
### ming.headers(fn)
Transform the HTTP headers of the response.
`fn(req, res)` receives the `req` and `res`. It should modify the header(s) and then return.
### ming.headersAsync(fn)
Asynchronously transform the HTTP headers of the response.
`fn(req, res)` receives the `req` and `res`. It returns a `promise` to modify the header(s).
### Notes
* when `ming.json*` receives a scalar value then the `content-type` is switched `text-plain`.
* when `ming.json*` detects that a response has been sent, it will abort.
* sending a response while in `ming.headers*` is **undefined behaviour** and will most likely result in an error.
### options
- `mingError`, when `true` the minger function is always invoked. When `false` (the default) the minger function is only invoked when the response is not in error.
## Exception handling
`ming` catches any exception (synchronous, asynchronous or Promise reject) and sends an HTTP 500 response with the exception message. This is done by `ming.onError(err, req, res)`, feel free to redefine it to your needs.
# License
The MIT license
Copyright © 2015 Richard Schneider (makaretu@gmail.com)