Returning Errors
This guide could use some improvement.
You can help! Please fork the absinthe repository, edit
guides/errors.md
, and submit a pull request.
One or more errors for a field can be returned in a single {:error, error_value}
tuple.
error_value
can be:
- A simple error message string.
- A map containing
:message
key, plus any additional serializable metadata. - A keyword list containing a
:message
key, plus any additional serializable metadata. - A list containing multiple of any/all of these.
- Any other value compatible with
to_string/1
.
Basic Errors
A simple error message:
{:error, "Something bad happened"}
Multiple error messages:
{:error, ["Something bad", "Even worse"]}
Single custom errors (note the required :message
keys):
{:error, message: "Unknown user", code: 21}
{:error, %{message: "A database error occurred", details: format_db_error(some_value)}}
Three errors of mixed types:
{:error, ["Simple message", [message: "A keyword list error", code: 1], %{message: "A map error"}]}
Generic handler for interoperability with errors from other libraries:
{:error, :foo}
{:error, 1.0}
{:error, 2}
Ecto.Changeset Errors
You may want to look at the Absinthe ErrorPayload package.