aboutsummaryrefslogtreecommitdiffstats
path: root/doc/src/manual/gun.options.asciidoc
blob: 964c6019dfec9e4608f133d5a06319f1fb8140c8 (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
81
82
83
= gun:options(3)

== Name

gun:options - Query the capabilities of the server or a resource

== Description

[source,erlang]
----
options(ConnPid, Path)
    -> options(ConnPid, Path, [], #{}).

options(ConnPid, Path, Headers)
    -> options(ConnPid, Path, Headers, #{})

options(ConnPid, Path, Headers, ReqOpts)
    -> StreamRef

ConnPid   :: pid()
Path      :: iodata()
Headers   :: gun:req_headers()
ReqOpts   :: gun:req_opts()
StreamRef :: gun:stream_ref()
----

Query the capabilities of the server or a resource.

The special path `"*"` can be used to obtain information about
the server as a whole. Any other path will return information
about that resource specifically.

== Arguments

ConnPid::

The pid of the Gun connection process.

Path::

Path to the resource.

Headers::

Additional request headers.

ReqOpts::

Request options.

== Return value

A reference that identifies the newly created stream is
returned. It is this reference that must be passed in
subsequent calls and will be received in messages related
to this new stream.

== Changelog

* *1.0*: Function introduced.

== Examples

.Query the capabilities of the server
[source,erlang]
----
StreamRef = gun:options(ConnPid, "*").
----

.Query the capabilities of a resource
[source,erlang]
----
StreamRef = gun:options(ConnPid, "/articles").
----

== See also

link:man:gun(3)[gun(3)],
link:man:gun:await(3)[gun:await(3)],
link:man:gun:await_body(3)[gun:await_body(3)],
link:man:gun_inform(3)[gun_inform(3)],
link:man:gun_response(3)[gun_response(3)],
link:man:gun_data(3)[gun_data(3)]