在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
开源软件名称(OpenSource Name):Khan/genqlient开源软件地址(OpenSource Url):https://github.com/Khan/genqlient开源编程语言(OpenSource Language):Go 99.9%开源软件介绍(OpenSource Introduction):genqlient: a truly type-safe Go GraphQL clientWhat is genqlient?genqlient is a Go library to easily generate type-safe code to query a GraphQL API. It takes advantage of the fact that both GraphQL and Go are typed languages to ensure at compile-time that your code is making a valid GraphQL query and using the result correctly, all with a minimum of boilerplate. genqlient provides:
How do I use genqlient?You can download and run genqlient the usual way: How can I help?genqlient welcomes contributions! Check out the (Contribution Guidelines), or file an issue on GitHub. Why another GraphQL client?Most common Go GraphQL clients have you write code something like this: query := `query GetUser($id: ID!) { user(id: $id) { name } }`
variables := map[string]interface{}{"id": "123"}
var resp struct {
Me struct {
Name graphql.String
}
}
client.Query(ctx, query, &resp, variables)
fmt.Println(query.Me.Name)
// Output: Luke Skywalker This code works, but it has a few problems:
These problems aren't a big deal in a small application, but for serious production-grade tools they're not ideal. And they should be entirely avoidable: GraphQL and Go are both typed languages; and GraphQL servers expose their schema in a standard, machine-readable format. We should be able to simply write a query and have that automatically validated against the schema and turned into a Go struct which we can use in our code. In fact, there's already good prior art to do this sort of thing: 99designs/gqlgen is a popular server library that generates types, and Apollo has a codegen tool to generate similar client-types for several other languages. (See docs/DESIGN.md for more prior art.) genqlient fills that gap: you just specify the query, and it generates type-safe helpers, validated against the schema, that make the query. |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论