7
votes

I'm trying to insert a record into DynamoDB invoking "Pre sign-up" trigger of Cognito User Pool.

Lambda function is pretty simple for testing purposes but there is always an error in client application on AWSCognito.CognitoIdentityServiceProvider.CognitoUserPool.signUp call

Use case 1

Lambda body:

console.log('Received event:', JSON.stringify(event, null, 2));

Result:

InvalidLambdaResponseException: Invalid lambda function output : Invalid JSON

Use case 2

Lambda body:

callback("null", "success");

Result:

InvalidLambdaResponseException: Invalid lambda function output : Invalid JSON

Use case 3

Lambda body:

new AWS.DynamoDB.DocumentClient().put(params, callback);

Result:

InvalidLambdaResponseException: Invalid cognito sign in version. Version should be 1

So, any ideas what might be wrong?

Could the latest error might be related to the beta status of Cognito User Pool?

P.S. I will provide more details if needed. Thanks in advance.

3
You need return the same event in the callback, as well said @user1268855 callback(null, event); in my case I don't return null as string.Jose Carlos Ramos Carmenates

3 Answers

10
votes

You are doing this in node.js and the error indicates you are not returning the service expected event source.

You should call context.done() when your lambda function finishes execution. Also, in any of the trigger sources which Cognito User Pool service generates, you can only edit the "response" part of the the source. For example, "autoConfirmUser" flag in PreSignUp trigger source.

Look at the examples in our developer guide for more details on this.

9
votes

@user3479125 To do the same in python just return an event as is, or with modifications in datasets.

This code is supposed to run between the mobile device and cognito, so it can modify the event and it should return it back, so Sync event will finish successfully.

Some more explanations here

-6
votes

Try returning callback("null", event);

This should solve your problem.