aboutsummaryrefslogtreecommitdiffstats
path: root/doc/src/manual/cowboy_req.set_resp_header.asciidoc
blob: 86d29a141deb3488386aa2fbb9ba01e4820accd2 (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
= cowboy_req:set_resp_header(3)

== Name

cowboy_req:set_resp_header - Set a response header

== Description

[source,erlang]
----
set_resp_header(Name, Value, Req :: cowboy_req:req())
	-> Req

Name  :: binary()  %% lowercase; case insensitive
Value :: iodata()  %% case depends on header
----

Set a header to be sent with the response.

The header name must be given as a lowercase binary string.
While header names are case insensitive, Cowboy requires them
to be given as lowercase to function properly.

Cowboy does not allow duplicate header names. Headers set
by this function may be overwritten by those set from the
reply functions.

Use link:man:cowboy_req:set_resp_cookie(3)[cowboy_req:set_resp_cookie(3)]
instead of this function to set cookies.

== Arguments

Name::

Header name as a lowercase binary string.

Value::

Header value.

Req::

The Req object.

== Return value

A new Req object is returned.

The returned Req object must be used from that point onward,
otherwise the header will not be sent in the response.

== Changelog

* *1.0*: Function introduced.

== Examples

.Set a header in the response
[source,erlang]
----
Req = cowboy_req:set_resp_header(<<"allow">>, "GET", Req0).
----

.Construct a header using iolists
[source,erlang]
----
Req = cowboy_req:set_resp_header(<<"allow">>,
    [allowed_methods(), ", OPTIONS"], Req0).
----

== See also

link:man:cowboy_req(3)[cowboy_req(3)],
link:man:cowboy_req:set_resp_cookie(3)[cowboy_req:set_resp_cookie(3)],
link:man:cowboy_req:set_resp_headers(3)[cowboy_req:set_resp_headers(3)],
link:man:cowboy_req:has_resp_header(3)[cowboy_req:has_resp_header(3)],
link:man:cowboy_req:resp_header(3)[cowboy_req:resp_header(3)],
link:man:cowboy_req:resp_headers(3)[cowboy_req:resp_headers(3)],
link:man:cowboy_req:delete_resp_header(3)[cowboy_req:delete_resp_header(3)],
link:man:cowboy_req:reply(3)[cowboy_req:reply(3)],
link:man:cowboy_req:stream_reply(3)[cowboy_req:stream_reply(3)]