首页 文章

在AWS AppSync查询中返回嵌套的JSON

提问于
浏览
0

一般来说,我对AppSync(和GraphQL)都很陌生,但在将解析器连接到DynamoDB表时,我遇到了一个奇怪的问题 . 具体来说,我们有一个嵌套的Map结构,用于任意构造的项目属性之一(其复杂性和形式取决于父项的类型) - 有点像这样:

"item" : {
    "name": "something",
    "country": "somewhere",
    "data" : {
        "nest-level-1a": {
            "attr1a" : "foo",
            "attr1b" : "bar",
            "nest-level-2" : {
                "attr2a": "something else",
                "attr2b": [
                    "some list element",
                    "and another, for good measure"
                ]
            }
        }
    },
    "cardType": "someType"
}

我们附带的GraphQL类型如下:

type Item {
    name: String!
    country: String!
    cardType: String!
    data: AWSJSON!  ## note: it was originally String!
}

当我们查询该项时,我们得到以下响应:

{
    "data": {
        "genericItemQuery": {
            "name": "info/en/usa/bra/visa",
            "country": "USA:BRA",
            "cardType": "visa",
            "data": "{\"tourist\":{\"reqs\":{\"sourceURL\":\"https://travel.state.gov/content/passports/en/country/brazil.html\",\"visaFree\":false,\"type\":\"eVisa required\",\"stayLimit\":\"30 days from date of entry\"},\"pages\":\"One page per stamp required\"}}"
}}}

问题是我们似乎无法让 Item.data 字段解析器返回一个JSON对象(即使我们在一般的Query解析器上附加一个单独的字段级解析器) . 它总是返回一个String,奇怪的是,如果我们将预期的字段类型更改为String !,响应将用 = 替换数据中的所有 : . 我们已经使用我们的响应解析器尝试了所有内容,包括像How return JSON object from DynamoDB with appsync?这样的建议,但我们完全陷入了困境 .

在上述帖子中没有任何建议工作之后,我们当前的查询响应解析器已恢复为标准响应:

## 'Before' response mapping template on genericItemQuery query; same result as the 'After' listed below **
#set($result = $ctx.result)
#set($result.data = $util.parseJson($ctx.result.data))
$util.toJson($result)

## 'After' response mapping template **
$util.toJson($ctx.result)

我们试图避免在 data 中需要包含每个嵌套级别的支持类型的情况(因为它根据父项类型进行更改,并且在我给它的示例的情况下可以有三个或四个层),我们认为将模式类型更改为 AWSJSON! 就可以了 . 但是,我没有办法绕过重建我们的基础架构 . 任何相反的建议都会有所帮助!

附:我已经在CloudWatch日志中注意到 context.result.data 响应字段下存在相应的JSON响应,但不知何故还有以下 transformedTemplate (我再次发现非常不寻常,因为我们没有应用任何映射模板,除非将结果转换为有效的JSON):

"arn": ...
"transformedTemplate": "{data={tourist={reqs={sourceURL=https://travel.state.gov/content/passports/en/country/brazil.html, visaFree=false, type=eVisa required, stayLimit=30 days from date of entry}, pages=One page per stamp required}}, resIds=USA:BRA, cardType=visa, id=info/en/usa/bra/visa}",
"context": ...

对这个冗长的问题道歉,但我很难过 .

2 回答

  • 0

    您可以尝试为包含所有可能字段的数据字段创建一个类型,然后将字段解析为对应于父类型的字段,或者您可以尝试实现graphQL interfaces

  • 0

    AWSJSON是一种JSON字符串类型,因此您将始终返回一个字符串值(这是您的类型定义必须遵守的值) .

相关问题