Struct dynamic_graphql::dynamic::Object
source · pub struct Object { /* private fields */ }
Expand description
A GraphQL object type
Examples
use async_graphql::{dynamic::*, value, Value};
let query = Object::new("Query").field(Field::new("value", TypeRef::named_nn(TypeRef::STRING), |ctx| {
FieldFuture::new(async move { Ok(Some(Value::from("abc"))) })
}));
let schema = Schema::build(query.type_name(), None, None)
.register(query)
.finish()?;
assert_eq!(
schema
.execute("{ value }")
.await
.into_result()
.unwrap()
.data,
value!({ "value": "abc" })
);
Implementations§
source§impl Object
impl Object
sourcepub fn description(self, description: impl Into<String>) -> Object
pub fn description(self, description: impl Into<String>) -> Object
Set the description
sourcepub fn extends(self) -> Object
pub fn extends(self) -> Object
Indicates that an object or interface definition is an extension of another definition of that same type.
Indicate that an object type’s field is allowed to be resolved by multiple subgraphs
sourcepub fn inaccessible(self) -> Object
pub fn inaccessible(self) -> Object
Indicate that an enum is not accessible from a supergraph when using Apollo Federation
Reference: https://www.apollographql.com/docs/federation/federated-types/federated-directives/#inaccessible
Arbitrary string metadata that will be propagated to the supergraph when using Apollo Federation. This attribute is repeatable
sourcepub fn key(self, fields: impl Into<String>) -> Object
pub fn key(self, fields: impl Into<String>) -> Object
Add an entity key
Examples
use async_graphql::{dynamic::*, Value};
let obj = Object::new("MyObj")
.field(Field::new("a", TypeRef::named(TypeRef::INT), |_| {
FieldFuture::new(async move { Ok(Some(Value::from(10))) })
}))
.field(Field::new("b", TypeRef::named(TypeRef::INT), |_| {
FieldFuture::new(async move { Ok(Some(Value::from(20))) })
}))
.field(Field::new("c", TypeRef::named(TypeRef::INT), |_| {
FieldFuture::new(async move { Ok(Some(Value::from(30))) })
}))
.key("a b")
.key("c");