为GraphQL中的所有查询添加架构指令

时间:2019-01-10 06:57:29

标签: graphql apollo graphql-js apollo-server express-graphql

  1. 是否有一种方法可以通过针对所有查询和变异覆盖SchemaDirectiveVisitor 的方法之一来添加架构指令??例如,检查指令中的身份验证令牌。最好不为定义的每个查询/突变添加一次。
  2. 如果是,应重写以下哪种方法,以及如何重写?我找不到如何覆盖每个示例的示例。

    • visitSchema(schema: GraphQLSchema)
    • visitScalar(scalar: GraphQLScalarType)
    • visitObject(object: GraphQLObjectType)
    • visitFieldDefinition(field: GraphQLField<any, any>)
    • visitArgumentDefinition(argument: GraphQLArgument)
    • visitInterface(iface: GraphQLInterfaceType)
    • visitUnion(union: GraphQLUnionType)
    • visitEnum(type: GraphQLEnumType)
    • visitEnumValue(value: GraphQLEnumValue)
    • visitInputObject(object: GraphQLInputObjectType)
    • visitInputFieldDefinition(field: GraphQLInputField)

根据我的直觉,visitObject(object: GraphQLObjectType)type Query,因为GraphQLObjectType

  1. DirectiveLocation到底是什么?是对象还是查询/突变?

1 个答案:

答案 0 :(得分:1)

要访问对象(对,查询是对的),请使用visitObject,对于特定的api结束(查询中的任何方法),请使用visitFieldDefinition 我已经通过以下方式实现了

class authDirective extends SchemaDirectiveVisitor {
    visitObject(type) {
        this.ensureFieldsWrapped(type);
        type._requiredAuthRole = this.args.requires;
    }

    visitFieldDefinition(field, details) {
        this.ensureFieldsWrapped(details.objectType);
        field._requiredAuthRole = this.args.requires;
    }
    ensureFieldsWrapped(objectType){
        const fields = objectType.getFields();
        //your logic to resolve directive
    }
}
module.exports = authDirective;

在graphQL shema中

directive @authorization(requires: Role) on OBJECT | FIELD_DEFINITION

在schema-builder或服务器中,包括

resolvers,
schemaDirectives: {
    authorization: authDirective
}