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?

2 Risposte
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
TECNICO DI SUPPORTO
Isha_K
con risposta 2 anni fa
profile picture
ESPERTO
verificato 14 giorni fa
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
      `),
    });
con risposta 2 anni fa

Accesso non effettuato. Accedi per postare una risposta.

Una buona risposta soddisfa chiaramente la domanda, fornisce un feedback costruttivo e incoraggia la crescita professionale del richiedente.

Linee guida per rispondere alle domande