Bandit (Bandit v0.4.9) View Source
Bandit is an HTTP server for Plug apps.
As an HTTP server, Bandit's primary goal is to act as 'glue' between client connections managed by Thousand Island and application code defined via the Plug API. As such there really isn't a whole lot of user-visible surface area to Bandit, and as a consequence the API documentation presented here is somewhat sparse. This is by design! Bandit is intended to 'just work' in almost all cases; the only thought users typically have to put into Bandit comes in the choice of which options (if any) they would like to change when starting a Bandit server. The sparseness of the Bandit API should not be taken as an indicator of the comprehensiveness or robustness of the project.
Basic Usage
Usage of Bandit is very straightforward. Assuming you have a Plug module implemented already, you can
host it within Bandit by adding something similar to the following to your application's
Application.start/2
function:
def start(_type, _args) do
children = [
{Bandit, plug: MyApp.MyPlug, scheme: :http, options: [port: 4000]}
]
opts = [strategy: :one_for_one, name: MyApp.Supervisor]
Supervisor.start_link(children, opts)
end
Writing Plug Applications
For details about writing Plug based applications, consult the excellent Plug documentation for plenty of examples & tips to get started. Note that while Bandit supports the complete Plug API & should work correctly with any Plug-based application you may write, it does not currently support Phoenix applications due to our lack of support for WebSocket connections. Early support for Phoenix will be coming to Bandit in the 0.4.x release series (likely Q4'21), with full support landing in the 0.7.x release series (likely Q1'22).
Config Options
Bandit takes a number of options at startup:
plug
: The plug to handle connections. Can be specified asMyPlug
or{MyPlug, plug_opts}
scheme
: One of:http
or:https
. If:https
is specified, you will need to specifycertfile
andkeyfile
in thetransport_options
subsection ofoptions
.read_timeout
: How long to wait for data from the client before timing out and closing the connection, specified in milliseconds. Defaults to 60_000options
: Options to pass toThousandIsland
. For an exhaustive list of options see theThousandIsland
documentation, however some common options are:port
: The port to bind to. Defaults to 4000num_acceptors
: The number of acceptor processes to run. This is mostly a performance tuning knob and can usually be left at the default value of 10transport_module
: The name of the module which provides basic socket functions. This overrides any value set forscheme
and is intended for cases where control over the socket at a fundamental level is needed.transport_options
: A keyword list of options to be passed into the transport socket's listen function
Setting up an HTTPS Server
By far the most common stumbling block encountered with configuration involves setting up an HTTPS server. Bandit is comparatively easy to set up in this regard, with a working example looking similar to the following:
def start(_type, _args) do
bandit_options = [
port: 4000,
transport_options: [
certfile: Path.join(__DIR__, "path/to/cert.pem"),
keyfile: Path.join(__DIR__, "path/to/key.pem")
]
]
children = [
{Bandit, plug: MyApp.MyPlug, scheme: :https, options: bandit_options}
]
opts = [strategy: :one_for_one, name: MyApp.Supervisor]
Supervisor.start_link(children, opts)
end
Link to this section Summary
Link to this section Types
Specs
A Plug definition
Link to this section Functions
Specs
child_spec(keyword()) :: Supervisor.child_spec()