Appsync created with CDK, Query not showing results

0

I created an AppSync API via the console, referencing an existing table. It works well (query list returns all the table records)

I then created an AppSync API via CDK. I copied into my project the schema from the console version. I defined the table. I added a Resolver for the "query list"

I see the datasource and schema in the cdk version if API. From the console I run the list query. The response is: { "data": { "listMyTables": { "nextToken": null, "items": null } } }

I see in the CloudwatchLogs the full table has been retrieved. Perhaps there is some "mapping" between the schema.graphql and the cdk parameters, so the information can populate the "items" in the response?

asked 2 years ago613 views
2 Answers
0

Hello,

I understand that you have created AppSync API using CDK, which is returning null response for listMyTables query.

Here is a blogpost example on creating AppSync API, using CDK:

https://aws.amazon.com/blogs/mobile/building-scalable-graphql-apis-on-aws-with-cdk-and-aws-appsync/

In order to troubleshoot this issue, we require details that are specific to AppSync API deployment in your account. We need to evaluate schema definition, resolver, data source, permissions and AppSync logs for your API. Please open a support case with AWS, including these details, using this link

AWS
SUPPORT ENGINEER
Isha_K
answered 2 years ago
profile picture
EXPERT
reviewed 5 months ago
0

Thank you Isha. I opened a support case and received a helpful answer. I ended up having to provide more detail in my resolver. I copied the code that was generated in the "console" created api, and pasted it in like below. With this change, the API functioned as expected:

change from this:

datasource.createResolver({
        typeName: 'Query',
        fieldName: 'listCctSharedCallRoutingGlobalDbs',
        requestMappingTemplate: MappingTemplate.dynamoDbScanTable(),
        responseMappingTemplate: MappingTemplate.dynamoDbResultList(),
      });

to this:

datasource.createResolver({
      typeName: 'Query',
      fieldName: 'listCctSharedCallRoutingGlobalDbs',
      requestMappingTemplate: MappingTemplate.fromString(`
      #set( $ListRequest = {
        "version": "2018-05-29"
      } )
      #if( $context.args.nextToken )
        #set( $ListRequest.nextToken = $context.args.nextToken )
      #end
      #if( $context.args.limit )
        #set( $ListRequest.limit = $context.args.limit )
      #end
      $util.qr($ListRequest.put("operation", "Scan"))
      $util.toJson($ListRequest)
    `),
      responseMappingTemplate: MappingTemplate.fromString(`
      #if( $ctx.error)
        $util.error($ctx.error.message, $ctx.error.type)
      #else
        $util.toJson($ctx.result)
      #end
      `),
    });
answered 2 years ago

You are not logged in. Log in to post an answer.

A good answer clearly answers the question and provides constructive feedback and encourages professional growth in the question asker.

Guidelines for Answering Questions