aboutsummaryrefslogblamecommitdiffstats
path: root/doc/src/manual/ranch.recv_proxy_header.asciidoc
blob: 0536e3d5eea03342fd9d30428f01d60af87c7efb (plain) (tree)




















































                                                             
                                   
















                                                                
= ranch:recv_proxy_header(3)

== Name

ranch:recv_proxy_header - Receive the PROXY protocol header

== Description

[source,erlang]
----
recv_proxy_header(ranch:ref(), timeout())
    -> {ok, ranch_proxy_header:proxy_info()}
     | {error, Reason :: atom()}
     | {error, protocol_error, HumanReadable :: atom()}
----

Receive the PROXY protocol header.

This function must be called before `ranch:handshake/1,2`
on newly accepted connections to read and parse the PROXY
protocol header, if any.

== Arguments

Ref::

The listener name.

Timeout::

Receive timeout in milliseconds.

== Return value

An `ok` tuple is returned containing PROXY header information
on success.

An `error` 2-tuple is returned when a socket error occurs.

An `error` 3-tuple is returned when a protocol error occurs
and Ranch was not able to parse the PROXY header information.
The third element contains a human-readable description of
the error.

== Changelog

* *1.7*: Function introduced.

== Examples

.Receive the PROXY protocol header
[source,erlang]
----
start_link(Ref, Transport, Opts) ->
    Pid = proc_lib:spawn_link(?MODULE, init,
        [Ref, Transport, Opts]),
    {ok, Pid}.

init(Ref, Transport, Opts) ->
    {ok, ProxyInfo} = ranch:recv_proxy_header(Ref, 1000),
    {ok, Socket} = ranch:handshake(Ref),
    loop(#state{ref=Ref, socket=Socket, transport=Transport,
        proxy_info=ProxyInfo, opts=Opts}).
----

== See also

link:man:ranch:start_listener(3)[ranch:start_listener(3)],
link:man:ranch:handshake(3)[ranch:handshake(3)],
link:man:ranch:remove_connection(3)[ranch:remove_connection(3)],
link:man:ranch(3)[ranch(3)]