带有dynamodb解析器的AWS AppSync条件更新

时间:2018-07-30 16:40:57

标签: database amazon-web-services amazon-dynamodb aws-appsync

尝试使用Appsync dynamodb解析器有条件地更新dynamodb中的项目。在通过“应用同步查询”面板测试条件更新时,即使提供了错误的用户名,操作也会继续进行,并使用price和ModifyDate的新值更新数据库。这是解析器的代码:

{
    "version" : "2017-02-28",
    "operation" : "UpdateItem",
    "key" : {
        "id": $util.dynamodb.toDynamoDBJson($ctx.args.input.id)
    },
    "update" : {
        "expression" : "SET price = :price, modificationDate = :newDate",
        "expressionValues": {
            ":price" : { "N": $context.arguments.input.price },
            ":newDate": $util.dynamodb.toDynamoDBJson($util.time.nowISO8601())
        }
    },
    "condition" : {
        "expression"       : "username = :expectedOwner",
        "expressionValues" : {
            ":expectedOwner" : { "S" : "${context.identity.username}" }
        }
    }
}

条件表达式中是否有错误?

1 个答案:

答案 0 :(得分:0)

在我的头顶上,您的映射模板看起来正确。需要检查的几件事:

->更改"id": $util.dynamodb.toDynamoDBJson($ctx.args.input.id)-> "id": $util.dynamodb.toStringJson($ctx.args.input.id)

->以下是使用Cognito用户池身份验证与条件检查一起使用的映射模板的示例。 Cognito身份/ AWS IAM也应该相同。

 {
     "version" : "2017-02-28",
     "operation" : "UpdateItem",
     "key" : {
        "id": $util.dynamodb.toStringJson($ctx.args.id)
      },
      "update" : {
          "expression" : "SET title = :title, modificationDate = :newDate, content = :content",
          "expressionValues": {
             ":title" : $util.dynamodb.toStringJson($ctx.args.title),
             ":newDate": $util.dynamodb.toStringJson($util.time.nowISO8601()),
             ":content": $util.dynamodb.toStringJson($ctx.args.content)
          }
      },
      "condition" : {
         "expression"       : "#sub = :expectedOwner",
         "expressionNames"  : { "#sub": "sub" },
         "expressionValues" : {
            ":expectedOwner" : { "S" : "${context.identity.sub}" }
         }
      }
}