fetcher v0.4.0 Fetcher View Source
Fetcher is a library to extract multiple values at once from big/nested data structures, while validating them and getting back meaningful errors.
Do I need Fetcher?
Fetcher is a low level library. A tool to put under your belt when you have data structures and the need to extract values while doing some sort of validation.
A suitable context could be a controller, where you get a map of user provided parameters, and you want to extract and validate some of them, and, in case of an error, getting back which fields are missing and send a meaningful error to the client.
Examples
data = %{foo: "bar", baz: "qux"}
# Nothing fancy here
Fetcher.fetch(data, [:foo]) # {:ok, %{foo: "bar"}}
# Multimple keys
Fetcher.fetch(data, [:foo, :baz]) # {:ok, %{foo: "bar", baz: "qux"}}
# Wrong key
Fetcher.fetch(data, [:foo, :qux]) # {:error, "the field 'qux' is missing"}
Link to this section Summary
Functions
extracts the given selector
from the source
Link to this section Types
Link to this section Functions
extracts the given selector
from the source
.
Possible options:
- all: (boolean) true to return all errored fields, false to return only the first one encountered.
- fail_check: (a function that returns a boolean) tells fetcher how to consider not valid a field based on its value. Normally fetcher consider not valid only if the field is not present at all. While a null field is ok.
Returns {:ok, result}
or {:error, error}
Examples
iex> Elixir.Fetcher.fetch(%{"a" => 1}, ["a"])
{:ok, %{"a" => 1}}
iex> Elixir.Fetcher.fetch(%{"a" => 1, "b" => 2}, ["a"])
{:ok, %{"a" => 1}}
iex> Elixir.Fetcher.fetch(%{"a" => 1, "b" => 2}, ["a", "b"])
{:ok, %{"a" => 1, "b" => 2}}
iex> Elixir.Fetcher.fetch(%{"a" => 1, "b" => 2}, ["a", "b", "c"])
{:error, "the field 'c' is missing"}
iex> Elixir.Fetcher.fetch(%{a: 1, b: 2}, [:a, :b])
{:ok, %{a: 1, b: 2}}
iex> Elixir.Fetcher.fetch(%{a: 1, b: 2}, [:c, :d])
{:error, "the field 'c' is missing"}
iex> Elixir.Fetcher.fetch(%{a: 1, b: 2}, [:c, :d], all: true)
{:error, ["the field 'c' is missing", "the field 'd' is missing"]}
iex> Elixir.Fetcher.fetch(%{a: 1, b: nil}, [:a, :b], fail_check: &is_nil/1)
{:error, "the field 'b' is missing"}