# Accept header(s) for Erlang/Elixir #
[data:image/s3,"s3://crabby-images/16982/169820653bd252738d38a917e5108c5955feb46f" alt="Hex.pm"](https://hex.pm/packages/accept)
[data:image/s3,"s3://crabby-images/a0174/a0174249ec8097838303631d607b0f390d28f842" alt="Hex.pm"](https://hex.pm/packages/accept)
[data:image/s3,"s3://crabby-images/9b6db/9b6db7b2704213e584cc9930ef42bd36a0019b92" alt="Hex Docs"](https://hexdocs.pm/accept/)
[data:image/s3,"s3://crabby-images/39289/39289ae43132044165a7323e670ceb488a1fa848" alt="GitHub Actions"](https://github.com/prometheus-erl/accept/actions/workflows/ci.yml)
[data:image/s3,"s3://crabby-images/6ae15/6ae1588ddea75c561fd1c2967822fd47b0c2c771" alt="Codecov"](https://codecov.io/github/prometheus-erl/accept)
## TOC
- [Accept](#accept-header)
- [Accept-Encoding](#accept-encoding-header)
- [Contributing](#contributing)
- [License](#license)
## Headers
### Accept
[RFC](https://tools.ietf.org/html/rfc7231#section-5.3.2)
#### Parsing
```erlang
1> accept_header:parse("text/*;q=0.3, text/html;q=0.7, text/html;level=1,"
"text/html;level=2;q=0.4, */*;q=0.5").
[{media_range,"text","*",0.3,[]},
{media_range,"text","html",0.7,[]},
{media_range,"text","html",1,[{"level","1"}]},
{media_range,"text","html",0.4,[{"level","2"}]},
{media_range,"*","*",0.5,[]}]
```
#### Content Negotiation
```erlang
2> accept_header:negotiate("text/*;q=0.3, text/html;q=0.7, text/html;level=1,"
"text/html;level=2;q=0.4, */*;q=0.5",
["text/html;level=2", "text/html;level-3"]).
"text/html;level-3"
```
`"text/html;level-3"` returned because `"text/html;level=2"` matches to
`text/html;level=2;q=0.4` with score 0.4 and most specific match for
`"text/html;level-3"` is `text/html;q=0.7` with score 0.7.
```erlang
3> accept_header:negotiate("application/xml,application/xhtml+xml,"
3> "text/html;q=0.9,text/plain;q=0.8,image/png,image/*;q=0.9,*/*;q=0.5",
3> ["text/n3",
3> "application/rdf+xml"]).
"text/n3"
```
Negotiate preserves user-defined order for equally scored alternatives.
### Accept-Encoding
[RFC](https://tools.ietf.org/html/rfc7231#section-5.3.4)
#### Parsing
```erlang
1> accept_encoding_header:parse("gzip;q=1.0, identity; q=0.5, *;q=0").
[{content_coding,"gzip",1.0,[]},
{content_coding,"identity",0.5,[]},
{content_coding,"*",0,[]}]
```
#### Content Negotiation
```erlang
1> accept_encoding_header:negotiate("compress, gzip",
1> ["identity", "compress"]).
"compress"
2> accept_encoding_header:negotiate("gzip;q=1.0, identity; q=0.5, *;q=0",
2> ["identity", "sdc", "gzip", "compress"]).
"gzip"
3> accept_encoding_header:negotiate("compress, gzip, *;q=0",
3> ["qwe"]).
undefined
```
Negotiate preserves user-defined order for equally scored alternatives.