aboutsummaryrefslogtreecommitdiffstats
path: root/doc/src/manual/cowboy_handler.asciidoc
blob: 28ac3112f65bd6f32f4363988fb0d09d6bfe2f73 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
= cowboy_handler(3)

== Name

cowboy_handler - Plain HTTP handlers

== Description

The `cowboy_handler` middleware executes the handler selected
by the router or any other preceding middleware.

This middleware takes the handler module and initial state
from the `handler` and `handler_opts` environment values,
respectively. On completion, it adds a `result` value to
the middleware environment, containing the return value
of the `terminate/3` callback (if defined) and `ok` otherwise.

This module also defines a callback interface for handling
HTTP requests.

== Callbacks

Plain HTTP handlers implement the following interface:

[source,erlang]
----
init(Req, State) -> {ok, Req, State}

terminate(Reason, Req, State) -> ok  %% optional

Req        :: cowboy_req:req()
State      :: any()
Reason     :: normal
            | {crash, error | exit | throw, any()}
----

These two callbacks are common to all handlers.

Plain HTTP handlers do all their work in the `init/2`
callback. Returning `ok` terminates the handler. If no
response is sent, Cowboy will send a `204 No Content`.

The optional `terminate/3` callback will ultimately be called
with the reason for the termination of the handler.
Cowboy will terminate the process right after this. There
is no need to perform any cleanup in this callback.

The following terminate reasons are defined for plain HTTP
handlers:

normal::
    The connection was closed normally.

{crash, Class, Reason}::
    A crash occurred in the handler. `Class` and `Reason` can be
    used to obtain more information about the crash. The function
    `erlang:get_stacktrace/0` can also be called to obtain the
    stacktrace of the process when the crash occurred.

== Exports

The following function should be called by modules implementing
custom handlers to execute the optional terminate callback:

* link:man:cowboy_handler:terminate(3)[cowboy_handler:terminate(3)] - Terminate the handler

== See also

link:man:cowboy(7)[cowboy(7)]