如何从 GraphQL 模式生成 GraphQL 操作

Dav*_*ave 4 typescript graphql apollo-client graphql-codegen

我正在寻找一种在使用 GraphQL 时使开发人员工作流程更高效的方法。

目前,graphql-code-generator用于从前端的 GraphQL 服务器生成类型。

这很好,但这只是生成类型。为了生成突变、查询和订阅的方法,我需要为前端项目中的每个操作创建一个 GraphQL 文档,例如:

file addPost.graphql

mutation addPost {
...
}
...
Run Code Online (Sandbox Code Playgroud)

我发现必须创建一个额外的addPost.graphql来生成该方法有点多余,因为它已经在我的 GraphQL 服务器上声明。

是否有插件/配置可以生成我可以在我的项目中使用的这些方法,而无需手动创建额外的 GraphQL 文档?

这是我的 GraphQL 生成器 yml 文件

# graphql-generator.yml
overwrite: true
schema: https://localhost:8088/query
documents: ./libs/**/*.graphql          <----- generating these *.graphql files would be great! 
generates:
  libs/graphql/src/lib/generated/graphql.ts:
    plugins:
      - "typescript"
      - "typescript-resolvers"
      - "typescript-operations"
      - "typescript-apollo-angular"
  ./graphql.schema.json:
    plugins:
      - "introspection"

Run Code Online (Sandbox Code Playgroud)

Dot*_*mha 5

GraphQL 的核心概念之一是能够允许组件或任何其他消费者选择他们需要的字段,而不是由其他东西(后端开发人员/服务器/代码)来决定。

此外,基于 GraphQL 模式生成操作很棘手 - 由于图的性质,您无法在没有一组约束的情况下真正生成它(例如:要达到什么嵌套级别?如何处理循环链接?该怎么做?你在争论的情况下?如果架构改变怎么办?等等)

GraphQL Code Generator 没有这样做,因为我们认为使用 GraphQL 层的开发人员应该决定字段。

在我们开发的其他一些解决方案中,我们需要这样的工具来生成选择集,但有一些预定义的约束。这个评论总结了它并提供了一个生成这些的代码示例:https : //github.com/dotansimha/graphql-code-generator/discussions/2349#discussioncomment-15754

如果您愿意,您可以将它们生成到一个文件中,然后将其提供给 codegen,或者您可以在您的项目中创建一个自定义文档加载器来动态创建它(https://graphql-code-generator.com/docs/getting -started/documents-field#custom-document-loader )