aboutsummaryrefslogtreecommitdiffstats
path: root/doc/src/manual/gun_upgrade.asciidoc
blob: eaea701041c0c78c2daa3c51c145e5a226c1aedc (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
= gun_upgrade(3)

== Name

gun_upgrade - Successful protocol upgrade

== Description

[source,erlang]
----
{gun_upgrade, ConnPid, StreamRef, Protocols, Headers}

ConnPid   :: pid()
StreamRef :: gun:stream_ref()
Protocols :: [<<"websocket">>]
Headers   :: [{binary(), binary()}]
----

Successful protocol upgrade.

This message informs the relevant process that the server
accepted to upgrade to one or more protocols given in the
original request.

The exact semantics of this message depend on the original
protocol. HTTP/1.1 upgrades apply to the entire connection.
HTTP/2 uses a different mechanism which allows switching
specific streams to a different protocol.

Gun currently only supports upgrading HTTP/1.1 connections
to the Websocket protocol.

== Elements

ConnPid::

The pid of the Gun connection process.

StreamRef::

Identifier of the stream that resulted in an upgrade.

Protocols::

List of protocols this stream was upgraded to.

Headers::

Headers sent with the upgrade response.

== Changelog

* *1.0*: Message introduced.

== Examples

.Receive a gun_upgrade message in a gen_server
[source,erlang]
----
handle_info({gun_upgrade, ConnPid, _StreamRef,
             _Protocols, _Headers},
            State=#state{conn_pid=ConnPid}) ->
    %% Do something.
    {noreply, State}.
----

== See also

link:man:gun(3)[gun(3)],
link:man:gun:ws_upgrade(3)[gun:ws_upgrade(3)],
link:man:gun:ws_send(3)[gun:ws_send(3)],
link:man:gun_ws(3)[gun_ws(3)]