Skip to main content
Version: 3.17

degraphql

描述#

degraphql 插件支持通过将 GraphQL 查询映射到 HTTP 端点,使用普通 HTTP 请求与上游 GraphQL 服务进行通信。

属性#

名称类型必选项描述
querystring发送到上游的 GraphQL 查询。
operation_namestring操作名称,仅在查询中存在多个操作时需要。
variablesarray[string]GraphQL 查询中使用的变量名称,从请求体或查询字符串中提取。

示例#

以下示例演示了如何针对不同场景配置 degraphql

note

你可以这样从 config.yaml 中获取 admin_key 并存入环境变量:

admin_key=$(yq '.deployment.admin.admin_key[0].key' conf/config.yaml | sed 's/"//g')

以下示例使用 Pokemon GraphQL API 作为上游 GraphQL 服务器。

转换基本查询#

以下示例演示如何转换如下简单 GraphQL 查询:

query {
getAllPokemon {
key
color
}
}

按如下方式创建一个带有 degraphql 插件的路由:

curl "http://127.0.0.1:9180/apisix/admin/routes" -X PUT \
-H "X-API-KEY: ${admin_key}" \
-d '{
"id": "degraphql-route",
"methods": ["POST"],
"uri": "/v8",
"upstream": {
"type": "roundrobin",
"nodes": {
"graphqlpokemon.favware.tech": 1
},
"scheme": "https",
"pass_host": "node"
},
"plugins": {
"degraphql": {
"query": "{\n getAllPokemon {\n key\n color\n }\n}"
}
}
}'

向路由发送请求以验证:

curl "http://127.0.0.1:9080/v8" -X POST

你应该会看到类似以下内容的响应:

{
"data": {
"getAllPokemon": [
{ "key": "pokestarsmeargle", "color": "White" },
{ "key": "pokestarufo", "color": "White" },
{ "key": "pokestarufo2", "color": "White" },
...
{ "key": "terapagosstellar", "color": "Blue" },
{ "key": "pecharunt", "color": "Purple" }
]
}
}

转换带变量的查询#

以下示例演示如何转换带有变量的 GraphQL 查询:

query ($pokemon: PokemonEnum!) {
getPokemon(
pokemon: $pokemon
) {
color
species
}
}

variables:
{
"pokemon": "pikachu"
}

按如下方式创建一个带有 degraphql 插件的路由:

curl "http://127.0.0.1:9180/apisix/admin/routes" -X PUT \
-H "X-API-KEY: ${admin_key}" \
-d '{
"id": "degraphql-route",
"uri": "/v8",
"upstream": {
"type": "roundrobin",
"nodes": {
"graphqlpokemon.favware.tech": 1
},
"scheme": "https",
"pass_host": "node"
},
"plugins": {
"degraphql": {
"query": "query ($pokemon: PokemonEnum!) {\n getPokemon(\n pokemon: $pokemon\n ) {\n color\n species\n }\n}\n",
"variables": ["pokemon"]
}
}
}'

向路由发送 POST 请求,将变量放在请求体中:

curl "http://127.0.0.1:9080/v8" -X POST \
-d '{
"pokemon": "pikachu"
}'

你应该会看到类似以下内容的响应:

{
"data": {
"getPokemon": {
"color": "Yellow",
"species": "pikachu"
}
}
}

你也可以通过 GET 请求的 URL 查询字符串传递变量:

curl "http://127.0.0.1:9080/v8?pokemon=pikachu"

你应该会看到与上述相同的响应。