This is a small project that shows how to use the API Gateway to simply add two numbers together. The entered numbers are added together using a Lambda function and the numbers, and sum are added to a DynamoDB table.
I have created a CloudFormation template that can be found in my GitLab repo.
Creating the Template
The easiest and quickest way to test is to copy the template, save the CloudFormation template locally, and then upload the file to the CloudFormation service.
The default region to run this is eu-west-2, however this can be modified.
Once the template has finished creating all the resources, there will be a URL for the API gateway in the Outputs tab of the CloudFormation stack. This is the API gateway public URL that can be used to GET all the numbers in the DynamoDB table or to send a POST request to have the two numbers created.
Testing
Now that all the resources have been created, the first method can be tested. I will test the GET method that will get all the sums that have been added to the table. As it has just been setup, there is nothing but an empty list to return, which is the output below.
0 1 2 3 |
% curl https://j7hgnsfoq6.execute-api.us-east-1.amazonaws.com/Prod/sums []% |
Sending a POST request to add two numbers together will add the sum to the DynamoDB table, and then another GET request can be made to see sums that have been made.
0 1 2 3 4 5 6 |
curl -X POST \ https://j7hgnsfoq6.execute-api.us-east-1.amazonaws.com/Prod/add \ -H 'Content-Type: application/json' \ -d '{"num1": 26, "num2": 1}' {"id": 1, "num1": 26.0, "num2": 1.0, "sum": 27.0, "timestamp": "2024-11-25T21:36:08.899957", "db_message": "Result saved to DynamoDB"}% |
0 1 2 3 |
curl https://j7hgnsfoq6.execute-api.us-east-1.amazonaws.com/Prod/sums [{"current_value": 1.0, "id": 0.0}, {"sum": 27.0, "id": 1.0, "num2": 1.0, "num1": 26.0, "timestamp": "2024-11-25T21:36:08.899957"}]% |
After adding some more numbers, there is more data in the table.
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
[ { "current_value": 3.0, "id": 0.0 }, { "sum": 27.0, "id": 1.0, "num2": 1.0, "num1": 26.0, "timestamp": "2024-11-25T21:36:08.899957" }, { "sum": 100.0, "id": 2.0, "num2": 50.0, "num1": 50.0, "timestamp": "2024-11-25T22:37:10.139637" }, { "sum": 20567.0, "id": 3.0, "num2": 20500.0, "num1": 67.0, "timestamp": "2024-11-25T22:37:31.086341" } ] |