# httpc
<a href="https://github.com/gleam-lang/httpc/releases"><img src="https://img.shields.io/github/release/gleam-lang/httpc" alt="GitHub release"></a>
<a href="https://discord.gg/Fm8Pwmy"><img src="https://img.shields.io/discord/768594524158427167?color=blue" alt="Discord chat"></a>

Bindings to Erlang's built in HTTP client, `httpc`.
```rust
import gleam/httpc
import gleam/http.{Get}
import gleam/should
pub fn main() {
  // Prepare a HTTP request record
  let req = http.default_req()
    |> http.set_method(Get)
    |> http.set_host("test-api.service.hmrc.gov.uk")
    |> http.set_path("/hello/world")
    |> http.prepend_req_header("accept", "application/vnd.hmrc.1.0+json")
  // Send the HTTP request to the server
  try resp = httpc.send(req)
  // We get a response record back
  resp.status
  |> should.equal(200)
  resp
  |> http.get_resp_header("content-type")
  |> should.equal(Ok("application/json"))
  resp.body
  |> should.equal("{\"message\":\"Hello World\"}")
  Ok(resp)
}
```
## Installation
This package can be installed by adding `gleam_httpc` to your `rebar.config`
dependencies:
```erlang
{deps, [
    gleam_httpc
]}.
```
You may also need to add the `gleam_httpc` OTP application to your `.app.src`
file, depending on how you run your program.
```erlang
{applications, [
    kernel,
    stdlib,
    ssl,
    inets,
    gleam_stdlib,
    gleam_httpc
]},
```