AppSync + DynamoDB:按所有者过滤

时间:2019-06-10 21:10:04

标签: amazon-dynamodb aws-appsync resolver dynamodb-queries

我正在尝试为按所有者过滤的扫描编写解析器模板。

这是我到目前为止尝试过的(这是我的请求模板):

#set( $identityValue = $util.defaultIfNull($ctx.identity.claims.get("username"),
$util.defaultIfNull($ctx.identity.claims.get("cognito:username"), "___xamznone____")) )
#set( $ScanRequest = {
"version": "2017-02-28",
  "operation": "Scan",
  "filter": {
    "expression": "owner = :owner",
    "expressionValues": {
      ":owner": { "S": $identityValue }
    }
  }
} )
$util.toJson($ScanRequest)

此模板失败,因为owner是保留关键字。但是,我不知道如何使用AppSync处理reserved words

您如何使用AppSync处理保留字?还有比我的硬编码更好的写此扫描的方法吗?

1 个答案:

答案 0 :(得分:1)

所以我在对其进行硬编码时解决了它:

#set( $identityValue = $util.defaultIfNull($ctx.identity.claims.get("username"),
$util.defaultIfNull($ctx.identity.claims.get("cognito:username"), "___xamznone____")) )
#set( $ScanRequest = {
"version": "2017-02-28",
  "operation": "Scan",
  "filter": {
    "expression": "#owner = :owner",
    "expressionValues": {
      ":owner": { "S": $identityValue }
    },
    "expressionNames": {
      "#owner": "owner"
    }
  }
} )
$util.toJson($ScanRequest)

如果某人可以提出一个非硬编码的答案,例如动态设置过滤器,如下所示:

#if( $context.args.filter )
  #set( $ListRequest.filter = $util.parseJson("$util.transform.toDynamoDBFilterExpression($ctx.args.filter)") )
#end

虽然仍按所有者过滤,但我很乐意接受该答案。