diff options
Diffstat (limited to 'doc/src')
-rw-r--r-- | doc/src/manual/cowboy_app.asciidoc | 71 |
1 files changed, 59 insertions, 12 deletions
diff --git a/doc/src/manual/cowboy_app.asciidoc b/doc/src/manual/cowboy_app.asciidoc index 2213bd1..933834f 100644 --- a/doc/src/manual/cowboy_app.asciidoc +++ b/doc/src/manual/cowboy_app.asciidoc @@ -2,24 +2,71 @@ == Name -cowboy - Small, fast, modular HTTP server. +cowboy - HTTP server for Erlang/OTP + +== Description + +Cowboy is an HTTP server for Erlang/OTP with support for the +HTTP/1.1, HTTP/2 and Websocket protocols. + +Cowboy aims to provide a complete HTTP stack. This includes +the implementation of the HTTP RFCs but also any directly +related standards, like Websocket or Server-Sent Events. + +== Modules + +Functions: + +* link:man:cowboy(3)[cowboy(3)] - Listener management +* link:man:cowboy_req(3)[cowboy_req(3)] - Request and response +* link:man:cowboy_router(3)[cowboy_router(3)] - Router middleware + +// @todo What about cowboy_constraints? + +Protocols: + +* link:man:cowboy_http(3)[cowboy_http(3)] - HTTP/1.1 protocol +* link:man:cowboy_http2(3)[cowboy_http2(3)] - HTTP/2 protocol +* link:man:cowboy_websocket(3)[cowboy_websocket(3)] - Websocket protocol + +Behaviors: + +* link:man:cowboy_handler(3)[cowboy_handler(3)] - Handler middleware and behavior +* link:man:cowboy_loop(3)[cowboy_loop(3)] - Loop handler behavior +* link:man:cowboy_middleware(3)[cowboy_middleware(3)] - Middleware behavior +* link:man:cowboy_rest(3)[cowboy_rest(3)] - REST handler behavior +* link:man:cowboy_stream(3)[cowboy_stream(3)] - Stream behavior +* link:man:cowboy_sub_protocol(3)[cowboy_sub_protocol(3)] - Sub protocol behavior + +Handlers: + +* link:man:cowboy_static(3)[cowboy_static(3)] - Static file handler + +// @todo What about cowboy_stream_h? == Dependencies -The `cowboy` application uses the Erlang applications `ranch` -for listening and accepting TCP connections, `crypto` for -establishing Websocket connections, and `cowlib` for parsing and -building messages for Web protocols. These dependencies must -be loaded for the `cowboy` application to work. In an embedded -environment this means that they need to be started with the -`application:start/{1,2}` function before the `cowboy` -application is started. +* link:man:ranch(7)[ranch(7)] - Socket acceptor pool for TCP protocols +* link:man:cowlib(7)[cowlib(7)] - Support library for manipulating Web protocols +* ssl - Secure communication over sockets +* crypto - Crypto functions -The `cowboy` application also uses the Erlang applications -`asn1`, `public_key` and `ssl` when listening for HTTPS connections. -These are started automatically if they weren't before. +// @todo Explicitly depend on ssl. + +All these applications must be started before the `cowboy` +application. To start Cowboy and all dependencies at once: + +[source,erlang] +---- +{ok, _} = application:ensure_all_started(cowboy). +---- == Environment The `cowboy` application does not define any application environment configuration parameters. + +== See also + +link:man:ranch(7)[ranch(7)], +link:man:cowlib(7)[cowlib(7)] |