Build Status
Barracuda
Barracuda is to your http client what Plug is to your web services.
For backend processing of HTTP requests we got Plug. There does not seem to be anything similar to write clients that access RESTful resources. We have plenty of http clients but they all work in different ways and there is no simple way of applying cross-cutting logic in a uniform manner to any/all of them.
Barracuda is a library that offers an easy way to generate RESTful clients for a service and easily apply cross-cutting logic.
defmodule Github do
@moduledoc """
Github client.
"""
use Barracuda.Client, adapter: Barracuda.Http.Adapter,
otp_app: :barracuda
require Logger
call :user_repos,
path: "/users/{:username}/repos",
verb: :get,
required: [:username],
required_headers: ["accept"],
doc: ~S"""
Lists all repos for the user
""",
expect: 200
endis github client that will fetch user's repositories and can be used as so:
Github.user_repos username: "ashneyderman"this client needs additional configuration. Since client is part of :barracuda application, config for it might look like this:
config :barracuda, Github,
base_url: "https://api.github.com"Installation
If available in Hex, the package can be installed as:
-
Add
barracudato your list of dependencies inmix.exs:
```elixir
def deps do
[{:barracuda, "~> 0.4.0"}]
end
```-
Ensure
barracudais started before your application:
```elixir
def application do
[applications: [:barracuda]]
end
```Acknowledgements
The original idea and draft implementation is due to Kevin Montuori