Sindbad~EG File Manager

Current Path : /home/infinitibizsol/.trash/node_modules.5/express-unless/
Upload File :
Current File : /home/infinitibizsol/.trash/node_modules.5/express-unless/README.md

Conditionally skip a middleware when a condition is met.

## Install

    npm i express-unless --save

## Usage

With existing middlewares:

```javascript
var { unless } = require("express-unless");

var static = express.static(__dirname + "/public");
static.unless = unless;

app.use(static.unless({ method: "OPTIONS" }));
```

If you are authoring a middleware you can support unless as follow:

```javascript
var { unless } = require("express-unless");

module.exports = function (middlewareOptions) {
  var mymid = function (req, res, next) {};

  mymid.unless = unless;

  return mymid;
};
```

## Current options

- `method` it could be an string or an array of strings. If the request method match the middleware will not run.
- `path` it could be an string, a regexp or an array of any of those. It also could be an array of object which is url and methods key-pairs. If the request path or path and method match, the middleware will not run. Check [Examples](#examples) for usage.
- `ext` it could be an string or an array of strings. If the request path ends with one of these extensions the middleware will not run.
- `custom` it must be a function that accepts `req` and returns `true` / `false`. If the function returns true for the given request, the middleware will not run.
- `useOriginalUrl` it should be `true` or `false`, default is `true`. if false, `path` will match against `req.url` instead of `req.originalUrl`. Please refer to [Express API](http://expressjs.com/4x/api.html#request) for the difference between `req.url` and `req.originalUrl`.

## Examples

Require authentication for every request unless the path is index.html.

```javascript
app.use(
  requiresAuth.unless({
    path: ["/index.html", { url: "/", methods: ["GET", "PUT"] }],
  })
);
```

Avoid a fstat for request to routes doesnt end with a given extension.

```javascript
app.use(
  static.unless(function (req) {
    var ext = url.parse(req.originalUrl).pathname.substr(-4);
    return !~[".jpg", ".html", ".css", ".js"].indexOf(ext);
  })
);
```

## License

MIT 2014 - Jose Romaniello

Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists