aboutsummaryrefslogtreecommitdiffstats
path: root/doc/src/manual/cowboy_stream.init.asciidoc
blob: addf9bc77ed1cb90269983918b7489f6a8e4cbd3 (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
70
71
72
73
74
75
76
77
78
79
80
= cowboy_stream:init(3)

== Name

cowboy_stream:init - Initialize a stream

== Description

[source,erlang]
----
init(StreamID, Req, Opts) -> {Commands, State}

StreamID :: cowboy_stream:stream_id()
Req      :: cowboy_req:req()
Opts     :: cowboy:opts()
Commands :: cowboy_stream:commands()
State    - opaque
----

Initialize a stream.

This function must be called by all stream handlers. It will
initialize the next configured stream handler.

== Arguments

StreamID::

The stream ID.

Req::

The Req object.

Opts::

The protocol options.

Commands::

The commands to be executed.

State::

The state for the next stream handler.

== Return value

A list of commands and an opaque state is returned.

The list of commands returned should be included in the
commands returned from the current stream handler. It
can be modified if necessary.

The state should be stored in the current stream
handler's state and passed to `cowboy_stream` when
necessary. The state should be treated as opaque.

== Changelog

* *2.0*: Function introduced.

== Examples

.Initialize the next stream handler
[source,erlang]
----
init(StreamID, Req, Opts) ->
    MyCommands = my_commands(),
    {Commands, Next} = cowboy_stream:init(StreamID, Req, Opts),
    {MyCommands ++ Commands, #state{next=Next}}.
----

== See also

link:man:cowboy_stream(3)[cowboy_stream(3)],
link:man:cowboy_stream:data(3)[cowboy_stream:data(3)],
link:man:cowboy_stream:info(3)[cowboy_stream:info(3)],
link:man:cowboy_stream:terminate(3)[cowboy_stream:terminate(3)],
link:man:cowboy_stream:early_error(3)[cowboy_stream:early_error(3)]