async-graphql 1.6.2

The GraphQL server library implemented by rust
Documentation
mod rules;
mod utils;
mod visitor;
mod visitors;

use crate::error::RuleErrors;
use crate::registry::Registry;
use crate::{CacheControl, Result};
use graphql_parser::query::Document;
use visitor::{visit, VisitorContext, VisitorNil};

pub struct CheckResult {
    pub cache_control: CacheControl,
    pub complexity: usize,
    pub depth: usize,
}

pub fn check_rules(registry: &Registry, doc: &Document) -> Result<CheckResult> {
    let mut ctx = VisitorContext::new(registry, doc);
    let mut cache_control = CacheControl::default();
    let mut complexity = 0;
    let mut depth = 0;

    let mut visitor = VisitorNil
        .with(rules::ArgumentsOfCorrectType::default())
        .with(rules::DefaultValuesOfCorrectType)
        .with(rules::FieldsOnCorrectType)
        .with(rules::FragmentsOnCompositeTypes)
        .with(rules::KnownArgumentNames::default())
        .with(rules::NoFragmentCycles::default())
        .with(rules::KnownFragmentNames)
        .with(rules::KnownTypeNames)
        .with(rules::LoneAnonymousOperation::default())
        .with(rules::NoUndefinedVariables::default())
        .with(rules::NoUnusedFragments::default())
        .with(rules::NoUnusedVariables::default())
        .with(rules::UniqueArgumentNames::default())
        .with(rules::UniqueFragmentNames::default())
        .with(rules::UniqueOperationNames::default())
        .with(rules::UniqueVariableNames::default())
        .with(rules::VariablesAreInputTypes)
        .with(rules::VariableInAllowedPosition::default())
        .with(rules::ScalarLeafs)
        .with(rules::NoComposeLeafs)
        .with(rules::PossibleFragmentSpreads::default())
        .with(rules::ProvidedNonNullArguments)
        .with(rules::KnownDirectives::default())
        .with(rules::OverlappingFieldsCanBeMerged)
        .with(rules::UploadFile)
        .with(visitors::CacheControlCalculate {
            cache_control: &mut cache_control,
        })
        .with(visitors::ComplexityCalculate {
            complexity: &mut complexity,
        })
        .with(visitors::DepthCalculate::new(&mut depth));

    visit(&mut visitor, &mut ctx, doc);
    if !ctx.errors.is_empty() {
        return Err(RuleErrors { errors: ctx.errors }.into());
    }
    Ok(CheckResult {
        cache_control,
        complexity,
        depth: depth as usize,
    })
}