-
Notifications
You must be signed in to change notification settings - Fork 88
Using middleware
Each incoming request passes through the middleware stack configured for your server. If the built-in stack (described in the table below) does not meet your needs you can supply your own using --stack
.
If you do not supply a custom stack via the --stack
option the following default stack will be used. It is designed to cater for typical web development.
Name | Description |
---|---|
↓ Basic Auth | Password-protect a server using Basic Authentication |
↓ Body Parser | Parses the request body, making ctx.request.body available to downstream middleware. |
↓ Request Monitor | Feeds traffic information to the --verbose output. |
↓ Log | Outputs an access log or stats view to the console. |
↓ Cors | Support for setting Cross-Origin Resource Sharing (CORS) headers |
↓ Json | Pretty-prints JSON responses. |
↓ Rewrite | URL Rewriting. Use to re-route requests to local or remote destinations. |
↓ Blacklist | Forbid access to sensitive or private resources |
↓ Conditional Get | Support for HTTP Conditional requests. |
↓ Mime | Customise the mime-type returned with any static resource. |
↓ Compress | Compress responses using gzip. |
↓ SPA | Support for Single Page Applications. |
↓ Static | Serves static files. |
↓ Index | Serves directory listings. |
Local-web-server uses Koa for its middleware stack. See here for a guide explaining how Koa middleware works, why middleware order is significant etc. See here for the ctx
object documentation.
A personalised stack can be created by passing middleware module names or paths to --stack
. If all you need is to serve static files, the following command is all you need.
$ ws --stack lws-static
Serving at http://mbp.local:8000, http://127.0.0.1:8000, http://192.168.0.100:8000
You may now browse any file in the current folder, e.g. http://127.0.0.1:8000/README.md.
If you installed a third-party middleware module into your project you may include it using the same syntax.
$ npm install another-middleware --save-dev
$ ws --stack another-middleware
Serving at http://mbp.local:8000, http://127.0.0.1:8000, http://192.168.0.100:8000
If your project includes the source for a middleware module you may include it by file name.
$ ws --stack ./lib/another-middleware.js
Serving at http://mbp.local:8000, http://127.0.0.1:8000, http://192.168.0.100:8000
Middleware order is significant. An incoming request is processed by each middleware in turn, in the order they were supplied to --stack
. For example, if you are using a middleware which processes the body of a request then it must be placed downstream of the middleware which parses the body of a request (typically lws-body-parser
). If you are experiencing unexpected issues with your stack, double-check middleware is supplied in the correct order.
Each middleware module may define command-line options. For example, the lws-static
module defines several command-line options - you can view them with this command:
$ ws --stack lws-static --help
Within the output you will find details of the middleware options:
Your preferred stack can be written to the config file like this.
module.exports = {
stack: [ 'spa', 'static', 'index' ]
}
If you need reminding of the built-in middleware modules names (in order to pass one or more of them to --stack
), you can print them with this command.
$ ws --default-stack
[ 'lws-body-parser',
'lws-request-monitor',
'lws-log',
'lws-cors',
'lws-json',
'lws-rewrite',
'lws-blacklist',
'lws-conditional-get',
'lws-mime',
'lws-compress',
'lws-spa',
'lws-static',
'lws-index' ]
If you have a requirement not covered by the built-in middleware you can add your own.