[][src]Derive Macro async_graphql::GQLInputObject

#[derive(GQLInputObject)]
{
    // Attributes available to this derive:
    #[field]
    #[graphql]
}

Define a GraphQL input object

You can also derive this.

See also the Book.

Macro parameters

AttributedescriptionTypeOptional
nameObject namestringY
descObject descriptionstringY

Field parameters

AttributedescriptionTypeOptional
nameField namestringY
descField descriptionstringY
defaultUse Default::default for default valuenoneY
defaultArgument default valueliteralY
default_withExpression to generate default valuecode stringY
validatorInput value validatorInputValueValidatorY
flattenSimilar to serde (flatten)booleanY

Examples

use async_graphql::*;

#[derive(GQLInputObject)]
struct MyInputObject {
    a: i32,
    #[field(default = 10)]
    b: i32,
}

struct QueryRoot;

#[GQLObject]
impl QueryRoot {
    #[field(desc = "value")]
    async fn value(&self, input: MyInputObject) -> i32 {
        input.a * input.b
    }
}

async_std::task::block_on(async move {
    let schema = Schema::new(QueryRoot, EmptyMutation, EmptySubscription);
    let res = schema.execute(r#"
    {
        value1: value(input:{a:9, b:3})
        value2: value(input:{a:9})
    }"#).await.into_result().unwrap().data;
    assert_eq!(res, serde_json::json!({ "value1": 27, "value2": 90 }));
});