使用Apollo Federated GraphQL,是否可以对外部实体的值进行排序/分页?

问题描述

是否可以将查询输入中的字段标记为需要由其他服务扩展的字段?

使用federation-demo来说明我的问题,但要保持简单一点。仅拥有一个帐户服务和一个评论服务,并向用户添加一个karma字段,便可以根据用户业障来过滤评论

帐户服务,向用户添加了业障整数:

  extend type Query {
    me: User
  }
  type User @key(fields: "id") {
    id: ID!
    name: String
    username: String
    karma: Int!
  }

评论服务,添加评论查询

  extend type Query {
    reviews(minKarma: Int): [Review!]!
  }
  type Review @key(fields: "id") {
    id: ID!
    body: String
    author: User @provides(fields: "username")
    product: Product
  }
  extend type User @key(fields: "id") {
    id: ID! @external
    username: String @external
    karma: Int! @external
    reviews: [Review]
  }
  extend type Product @key(fields: "upc") {
    upc: String! @external
    reviews: [Review]
  }

在我的Query.reviews解析器中,我想过滤掉任何review.author.karma小于指定的minKarma的评论

如何告诉网关在Query输入中指定minKarma时,我希望首先查询Account服务,并将用户的表示形式传递到Reviews服务中,而每个用户的业力都附加到以作者的身份审阅,以便我可以进行过滤?

回到本文顶部的问题,我是否可以将minKarma字段标记为需要User.karma

解决方法

这也是困扰我的问题。