async-graphql/docs/en/src/error_handling.md

814 B

Error handling

Resolve can return a FieldResult, which has the following definition:

type FieldResult<T> = std::result::Result<T, FieldError>;

Any Error that implements std::fmt::Display can be converted to FieldError and you can extend the error message.

The following example shows how to parse an input string to an integer. When parsing fails, it will return an error and attach an error message. See the Error Extensions section of this book for more details.

use async_graphql::*;

struct Query;

#[Object]
impl Query {
    #[field]
    async fn parse_with_extensions(&self, input: String) -> FieldResult<i32> {
        Ok("234a"
            .parse()
            .map_err(|err: ParseIntError| err.extend_with(|_| json!({"code": 400})))?)
    }
}