Updated book for master ***NO_CI***
This commit is contained in:
parent
3fda1ed1ed
commit
ffa36e19f7
5 changed files with 40 additions and 40 deletions
|
@ -1414,7 +1414,7 @@ use juniper::{graphql_interface, GraphQLObject};
|
||||||
trait Character {
|
trait Character {
|
||||||
fn id(&self) -> &str;
|
fn id(&self) -> &str;
|
||||||
|
|
||||||
#[graphql_interface(ignore)] // or `#[graphql_interface(skip)]`, your choice
|
#[graphql(ignore)] // or `#[graphql(skip)]`, your choice
|
||||||
fn ignored(&self) -> u32 { 0 }
|
fn ignored(&self) -> u32 { 0 }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1447,26 +1447,26 @@ use juniper::graphql_interface;
|
||||||
/// This doc is absent in GraphQL schema.
|
/// This doc is absent in GraphQL schema.
|
||||||
trait Character {
|
trait Character {
|
||||||
// Renames the field in GraphQL schema.
|
// Renames the field in GraphQL schema.
|
||||||
#[graphql_interface(name = "myId")]
|
#[graphql(name = "myId")]
|
||||||
// Deprecates the field in GraphQL schema.
|
// Deprecates the field in GraphQL schema.
|
||||||
// Usual Rust `#[deprecated]` attribute is supported too as field deprecation,
|
// Usual Rust `#[deprecated]` attribute is supported too as field deprecation,
|
||||||
// but `deprecated` attribute argument takes precedence over it, if specified.
|
// but `deprecated` attribute argument takes precedence over it, if specified.
|
||||||
#[graphql_interface(deprecated = "Do not use it.")]
|
#[graphql(deprecated = "Do not use it.")]
|
||||||
// Describes the field in GraphQL schema.
|
// Describes the field in GraphQL schema.
|
||||||
#[graphql_interface(description = "ID of my own character.")]
|
#[graphql(description = "ID of my own character.")]
|
||||||
// Usual Rust docs are supported too as field description,
|
// Usual Rust docs are supported too as field description,
|
||||||
// but `description` attribute argument takes precedence over them, if specified.
|
// but `description` attribute argument takes precedence over them, if specified.
|
||||||
/// This description is absent in GraphQL schema.
|
/// This description is absent in GraphQL schema.
|
||||||
fn id(
|
fn id(
|
||||||
&self,
|
&self,
|
||||||
// Renames the argument in GraphQL schema.
|
// Renames the argument in GraphQL schema.
|
||||||
#[graphql_interface(name = "myNum")]
|
#[graphql(name = "myNum")]
|
||||||
// Describes the argument in GraphQL schema.
|
// Describes the argument in GraphQL schema.
|
||||||
#[graphql_interface(description = "ID number of my own character.")]
|
#[graphql(description = "ID number of my own character.")]
|
||||||
// Specifies the default value for the argument.
|
// Specifies the default value for the argument.
|
||||||
// The concrete value may be omitted, and the `Default::default` one
|
// The concrete value may be omitted, and the `Default::default` one
|
||||||
// will be used in such case.
|
// will be used in such case.
|
||||||
#[graphql_interface(default = 5)]
|
#[graphql(default = 5)]
|
||||||
num: i32,
|
num: i32,
|
||||||
) -> &str;
|
) -> &str;
|
||||||
}
|
}
|
||||||
|
@ -1491,7 +1491,7 @@ trait Character { // while still can be specified via `Context =
|
||||||
fn id(&self, context: &Database) -> Option<&str>;
|
fn id(&self, context: &Database) -> Option<&str>;
|
||||||
|
|
||||||
// Otherwise, you may mark it explicitly as a context argument.
|
// Otherwise, you may mark it explicitly as a context argument.
|
||||||
fn name(&self, #[graphql_interface(context)] db: &Database) -> Option<&str>;
|
fn name(&self, #[graphql(context)] db: &Database) -> Option<&str>;
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(GraphQLObject)]
|
#[derive(GraphQLObject)]
|
||||||
|
@ -1538,7 +1538,7 @@ trait Character<S: ScalarValue> {
|
||||||
// Otherwise, you may mark it explicitly as an executor argument.
|
// Otherwise, you may mark it explicitly as an executor argument.
|
||||||
async fn name<'b>(
|
async fn name<'b>(
|
||||||
&'b self,
|
&'b self,
|
||||||
#[graphql_interface(executor)] another: &Executor<'_, '_, (), S>,
|
#[graphql(executor)] another: &Executor<'_, '_, (), S>,
|
||||||
) -> &'b str
|
) -> &'b str
|
||||||
where
|
where
|
||||||
S: Send + Sync;
|
S: Send + Sync;
|
||||||
|
@ -1550,7 +1550,7 @@ struct Human {
|
||||||
id: String,
|
id: String,
|
||||||
name: String,
|
name: String,
|
||||||
}
|
}
|
||||||
#[graphql_interface(Scalar = S)]
|
#[graphql_interface(scalar = S)]
|
||||||
impl<S: ScalarValue> Character<S> for Human {
|
impl<S: ScalarValue> Character<S> for Human {
|
||||||
async fn id<'a>(&self, executor: &'a Executor<'_, '_, (), S>) -> &'a str
|
async fn id<'a>(&self, executor: &'a Executor<'_, '_, (), S>) -> &'a str
|
||||||
where
|
where
|
||||||
|
@ -1581,12 +1581,12 @@ struct Database {
|
||||||
}
|
}
|
||||||
impl juniper::Context for Database {}
|
impl juniper::Context for Database {}
|
||||||
|
|
||||||
#[graphql_interface(for = [Human, Droid], Context = Database)]
|
#[graphql_interface(for = [Human, Droid], context = Database)]
|
||||||
#[graphql_interface(on Droid = get_droid)] // enables downcasting `Droid` via `get_droid()` function
|
#[graphql_interface(on Droid = get_droid)] // enables downcasting `Droid` via `get_droid()` function
|
||||||
trait Character {
|
trait Character {
|
||||||
fn id(&self) -> &str;
|
fn id(&self) -> &str;
|
||||||
|
|
||||||
#[graphql_interface(downcast)] // makes method a downcast to `Human`, not a field
|
#[graphql(downcast)] // makes method a downcast to `Human`, not a field
|
||||||
// NOTICE: The method signature may optionally contain `&Database` context argument.
|
// NOTICE: The method signature may optionally contain `&Database` context argument.
|
||||||
fn as_human(&self) -> Option<&Human> {
|
fn as_human(&self) -> Option<&Human> {
|
||||||
None
|
None
|
||||||
|
@ -1636,7 +1636,7 @@ fn get_droid<'db>(ch: &CharacterValue, db: &'db Database) -> Op
|
||||||
use juniper::{graphql_interface, DefaultScalarValue, GraphQLObject};
|
use juniper::{graphql_interface, DefaultScalarValue, GraphQLObject};
|
||||||
|
|
||||||
#[graphql_interface(for = [Human, Droid])]
|
#[graphql_interface(for = [Human, Droid])]
|
||||||
#[graphql_interface(Scalar = DefaultScalarValue)] // removing this line will fail compilation
|
#[graphql_interface(scalar = DefaultScalarValue)] // removing this line will fail compilation
|
||||||
trait Character {
|
trait Character {
|
||||||
fn id(&self) -> &str;
|
fn id(&self) -> &str;
|
||||||
}
|
}
|
||||||
|
@ -1647,7 +1647,7 @@ struct Human {
|
||||||
id: String,
|
id: String,
|
||||||
home_planet: String,
|
home_planet: String,
|
||||||
}
|
}
|
||||||
#[graphql_interface(Scalar = DefaultScalarValue)]
|
#[graphql_interface(scalar = DefaultScalarValue)]
|
||||||
impl Character for Human {
|
impl Character for Human {
|
||||||
fn id(&self) -> &str {
|
fn id(&self) -> &str {
|
||||||
&self.id
|
&self.id
|
||||||
|
@ -1660,7 +1660,7 @@ struct Droid {
|
||||||
id: String,
|
id: String,
|
||||||
primary_function: String,
|
primary_function: String,
|
||||||
}
|
}
|
||||||
#[graphql_interface(Scalar = DefaultScalarValue)]
|
#[graphql_interface(scalar = DefaultScalarValue)]
|
||||||
impl Character for Droid {
|
impl Character for Droid {
|
||||||
fn id(&self) -> &str {
|
fn id(&self) -> &str {
|
||||||
&self.id
|
&self.id
|
||||||
|
@ -2123,7 +2123,7 @@ struct Database {
|
||||||
}
|
}
|
||||||
impl juniper::Context for Database {}
|
impl juniper::Context for Database {}
|
||||||
|
|
||||||
#[graphql_union(Context = Database)]
|
#[graphql_union(context = Database)]
|
||||||
trait Character {
|
trait Character {
|
||||||
// NOTICE: The method signature may optionally contain `&Context`.
|
// NOTICE: The method signature may optionally contain `&Context`.
|
||||||
fn as_human<'db>(&self, ctx: &'db Database) -> Option<&'db Human> { None }
|
fn as_human<'db>(&self, ctx: &'db Database) -> Option<&'db Human> { None }
|
||||||
|
@ -2165,7 +2165,7 @@ struct Droid {
|
||||||
trait Character {
|
trait Character {
|
||||||
fn as_human(&self) -> Option<&Human> { None }
|
fn as_human(&self) -> Option<&Human> { None }
|
||||||
fn as_droid(&self) -> Option<&Droid> { None }
|
fn as_droid(&self) -> Option<&Droid> { None }
|
||||||
#[graphql_union(ignore)] // or `#[graphql_union(skip)]`, your choice
|
#[graphql(ignore)] // or `#[graphql(skip)]`, your choice
|
||||||
fn id(&self) -> &str;
|
fn id(&self) -> &str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2207,13 +2207,13 @@ struct Database {
|
||||||
}
|
}
|
||||||
impl juniper::Context for Database {}
|
impl juniper::Context for Database {}
|
||||||
|
|
||||||
#[graphql_union(Context = Database)]
|
#[graphql_union(context = Database)]
|
||||||
#[graphql_union(
|
#[graphql_union(
|
||||||
on Human = DynCharacter::get_human,
|
on Human = DynCharacter::get_human,
|
||||||
on Droid = get_droid,
|
on Droid = get_droid,
|
||||||
)]
|
)]
|
||||||
trait Character {
|
trait Character {
|
||||||
#[graphql_union(ignore)] // or `#[graphql_union(skip)]`, your choice
|
#[graphql(ignore)] // or `#[graphql(skip)]`, your choice
|
||||||
fn id(&self) -> &str;
|
fn id(&self) -> &str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -276,7 +276,7 @@ use juniper::{graphql_interface, GraphQLObject};
|
||||||
trait Character {
|
trait Character {
|
||||||
fn id(&self) -> &str;
|
fn id(&self) -> &str;
|
||||||
|
|
||||||
#[graphql_interface(ignore)] // or `#[graphql_interface(skip)]`, your choice
|
#[graphql(ignore)] // or `#[graphql(skip)]`, your choice
|
||||||
fn ignored(&self) -> u32 { 0 }
|
fn ignored(&self) -> u32 { 0 }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -309,26 +309,26 @@ use juniper::graphql_interface;
|
||||||
/// This doc is absent in GraphQL schema.
|
/// This doc is absent in GraphQL schema.
|
||||||
trait Character {
|
trait Character {
|
||||||
// Renames the field in GraphQL schema.
|
// Renames the field in GraphQL schema.
|
||||||
#[graphql_interface(name = "myId")]
|
#[graphql(name = "myId")]
|
||||||
// Deprecates the field in GraphQL schema.
|
// Deprecates the field in GraphQL schema.
|
||||||
// Usual Rust `#[deprecated]` attribute is supported too as field deprecation,
|
// Usual Rust `#[deprecated]` attribute is supported too as field deprecation,
|
||||||
// but `deprecated` attribute argument takes precedence over it, if specified.
|
// but `deprecated` attribute argument takes precedence over it, if specified.
|
||||||
#[graphql_interface(deprecated = "Do not use it.")]
|
#[graphql(deprecated = "Do not use it.")]
|
||||||
// Describes the field in GraphQL schema.
|
// Describes the field in GraphQL schema.
|
||||||
#[graphql_interface(description = "ID of my own character.")]
|
#[graphql(description = "ID of my own character.")]
|
||||||
// Usual Rust docs are supported too as field description,
|
// Usual Rust docs are supported too as field description,
|
||||||
// but `description` attribute argument takes precedence over them, if specified.
|
// but `description` attribute argument takes precedence over them, if specified.
|
||||||
/// This description is absent in GraphQL schema.
|
/// This description is absent in GraphQL schema.
|
||||||
fn id(
|
fn id(
|
||||||
&self,
|
&self,
|
||||||
// Renames the argument in GraphQL schema.
|
// Renames the argument in GraphQL schema.
|
||||||
#[graphql_interface(name = "myNum")]
|
#[graphql(name = "myNum")]
|
||||||
// Describes the argument in GraphQL schema.
|
// Describes the argument in GraphQL schema.
|
||||||
#[graphql_interface(description = "ID number of my own character.")]
|
#[graphql(description = "ID number of my own character.")]
|
||||||
// Specifies the default value for the argument.
|
// Specifies the default value for the argument.
|
||||||
// The concrete value may be omitted, and the `Default::default` one
|
// The concrete value may be omitted, and the `Default::default` one
|
||||||
// will be used in such case.
|
// will be used in such case.
|
||||||
#[graphql_interface(default = 5)]
|
#[graphql(default = 5)]
|
||||||
num: i32,
|
num: i32,
|
||||||
) -> &str;
|
) -> &str;
|
||||||
}
|
}
|
||||||
|
@ -353,7 +353,7 @@ trait Character { // while still can be specified via `Context =
|
||||||
fn id(&self, context: &Database) -> Option<&str>;
|
fn id(&self, context: &Database) -> Option<&str>;
|
||||||
|
|
||||||
// Otherwise, you may mark it explicitly as a context argument.
|
// Otherwise, you may mark it explicitly as a context argument.
|
||||||
fn name(&self, #[graphql_interface(context)] db: &Database) -> Option<&str>;
|
fn name(&self, #[graphql(context)] db: &Database) -> Option<&str>;
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(GraphQLObject)]
|
#[derive(GraphQLObject)]
|
||||||
|
@ -400,7 +400,7 @@ trait Character<S: ScalarValue> {
|
||||||
// Otherwise, you may mark it explicitly as an executor argument.
|
// Otherwise, you may mark it explicitly as an executor argument.
|
||||||
async fn name<'b>(
|
async fn name<'b>(
|
||||||
&'b self,
|
&'b self,
|
||||||
#[graphql_interface(executor)] another: &Executor<'_, '_, (), S>,
|
#[graphql(executor)] another: &Executor<'_, '_, (), S>,
|
||||||
) -> &'b str
|
) -> &'b str
|
||||||
where
|
where
|
||||||
S: Send + Sync;
|
S: Send + Sync;
|
||||||
|
@ -412,7 +412,7 @@ struct Human {
|
||||||
id: String,
|
id: String,
|
||||||
name: String,
|
name: String,
|
||||||
}
|
}
|
||||||
#[graphql_interface(Scalar = S)]
|
#[graphql_interface(scalar = S)]
|
||||||
impl<S: ScalarValue> Character<S> for Human {
|
impl<S: ScalarValue> Character<S> for Human {
|
||||||
async fn id<'a>(&self, executor: &'a Executor<'_, '_, (), S>) -> &'a str
|
async fn id<'a>(&self, executor: &'a Executor<'_, '_, (), S>) -> &'a str
|
||||||
where
|
where
|
||||||
|
@ -443,12 +443,12 @@ struct Database {
|
||||||
}
|
}
|
||||||
impl juniper::Context for Database {}
|
impl juniper::Context for Database {}
|
||||||
|
|
||||||
#[graphql_interface(for = [Human, Droid], Context = Database)]
|
#[graphql_interface(for = [Human, Droid], context = Database)]
|
||||||
#[graphql_interface(on Droid = get_droid)] // enables downcasting `Droid` via `get_droid()` function
|
#[graphql_interface(on Droid = get_droid)] // enables downcasting `Droid` via `get_droid()` function
|
||||||
trait Character {
|
trait Character {
|
||||||
fn id(&self) -> &str;
|
fn id(&self) -> &str;
|
||||||
|
|
||||||
#[graphql_interface(downcast)] // makes method a downcast to `Human`, not a field
|
#[graphql(downcast)] // makes method a downcast to `Human`, not a field
|
||||||
// NOTICE: The method signature may optionally contain `&Database` context argument.
|
// NOTICE: The method signature may optionally contain `&Database` context argument.
|
||||||
fn as_human(&self) -> Option<&Human> {
|
fn as_human(&self) -> Option<&Human> {
|
||||||
None
|
None
|
||||||
|
@ -498,7 +498,7 @@ fn get_droid<'db>(ch: &CharacterValue, db: &'db Database) -> Op
|
||||||
use juniper::{graphql_interface, DefaultScalarValue, GraphQLObject};
|
use juniper::{graphql_interface, DefaultScalarValue, GraphQLObject};
|
||||||
|
|
||||||
#[graphql_interface(for = [Human, Droid])]
|
#[graphql_interface(for = [Human, Droid])]
|
||||||
#[graphql_interface(Scalar = DefaultScalarValue)] // removing this line will fail compilation
|
#[graphql_interface(scalar = DefaultScalarValue)] // removing this line will fail compilation
|
||||||
trait Character {
|
trait Character {
|
||||||
fn id(&self) -> &str;
|
fn id(&self) -> &str;
|
||||||
}
|
}
|
||||||
|
@ -509,7 +509,7 @@ struct Human {
|
||||||
id: String,
|
id: String,
|
||||||
home_planet: String,
|
home_planet: String,
|
||||||
}
|
}
|
||||||
#[graphql_interface(Scalar = DefaultScalarValue)]
|
#[graphql_interface(scalar = DefaultScalarValue)]
|
||||||
impl Character for Human {
|
impl Character for Human {
|
||||||
fn id(&self) -> &str {
|
fn id(&self) -> &str {
|
||||||
&self.id
|
&self.id
|
||||||
|
@ -522,7 +522,7 @@ struct Droid {
|
||||||
id: String,
|
id: String,
|
||||||
primary_function: String,
|
primary_function: String,
|
||||||
}
|
}
|
||||||
#[graphql_interface(Scalar = DefaultScalarValue)]
|
#[graphql_interface(scalar = DefaultScalarValue)]
|
||||||
impl Character for Droid {
|
impl Character for Droid {
|
||||||
fn id(&self) -> &str {
|
fn id(&self) -> &str {
|
||||||
&self.id
|
&self.id
|
||||||
|
|
|
@ -415,7 +415,7 @@ struct Database {
|
||||||
}
|
}
|
||||||
impl juniper::Context for Database {}
|
impl juniper::Context for Database {}
|
||||||
|
|
||||||
#[graphql_union(Context = Database)]
|
#[graphql_union(context = Database)]
|
||||||
trait Character {
|
trait Character {
|
||||||
// NOTICE: The method signature may optionally contain `&Context`.
|
// NOTICE: The method signature may optionally contain `&Context`.
|
||||||
fn as_human<'db>(&self, ctx: &'db Database) -> Option<&'db Human> { None }
|
fn as_human<'db>(&self, ctx: &'db Database) -> Option<&'db Human> { None }
|
||||||
|
@ -457,7 +457,7 @@ struct Droid {
|
||||||
trait Character {
|
trait Character {
|
||||||
fn as_human(&self) -> Option<&Human> { None }
|
fn as_human(&self) -> Option<&Human> { None }
|
||||||
fn as_droid(&self) -> Option<&Droid> { None }
|
fn as_droid(&self) -> Option<&Droid> { None }
|
||||||
#[graphql_union(ignore)] // or `#[graphql_union(skip)]`, your choice
|
#[graphql(ignore)] // or `#[graphql(skip)]`, your choice
|
||||||
fn id(&self) -> &str;
|
fn id(&self) -> &str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -499,13 +499,13 @@ struct Database {
|
||||||
}
|
}
|
||||||
impl juniper::Context for Database {}
|
impl juniper::Context for Database {}
|
||||||
|
|
||||||
#[graphql_union(Context = Database)]
|
#[graphql_union(context = Database)]
|
||||||
#[graphql_union(
|
#[graphql_union(
|
||||||
on Human = DynCharacter::get_human,
|
on Human = DynCharacter::get_human,
|
||||||
on Droid = get_droid,
|
on Droid = get_droid,
|
||||||
)]
|
)]
|
||||||
trait Character {
|
trait Character {
|
||||||
#[graphql_union(ignore)] // or `#[graphql_union(skip)]`, your choice
|
#[graphql(ignore)] // or `#[graphql(skip)]`, your choice
|
||||||
fn id(&self) -> &str;
|
fn id(&self) -> &str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue