Skip to main content

AWS API Gateway: Validating Requests With Models

Additional Resources

📘 json-schema.org

📘 json-schema.org: Understanding JSON Schema

Intro

Models in API Gateway are a schema for data that we can use to compare our HTTP requests against. They are useful for validating the data coming into and out of your API.

The models are written in a JSON specification called JSON Schema (see links above).

We are creating a dummy application that will compare various pieces of data that users submit such as age, height & income.

Creating A Model

We will start by creating a new model in API Gateway

create new model

CompareData.json
{
"$schema": "http://json-schema.org/draft-04/schema#",
"title": "CompareData",
"type": "object",
"properties": {
"age": {"type": "integer"},
"height": {"type": "integer"},
"income": {"type": "integer"}
},
"required": ["age", "height", "income"]
}

⚠️ Object keys in models are Case Sensitive. If you use age in the model, a request with Age will not validate.

We can see that this model is very simple. We just have a couple of required headers, and then we list the data type for our various pieces of data. Right now they are all numbers, although later we may add some strings and booleans.

Then we list off which pieces of the data we require for the request to validate against the model. Which right now is all three of them.

Using A Model

Now that we have our first model, we need to attach it to a resource method. Let's start by going into the Method Request of our post method and adding the model there.

method request

select the model

We then need to indicate that we would like to validate incoming requests.

validate body

Currently we just want to validate the body of the request.

Validation Behavior

There are some important things to note about validation behavior. To start with the property keys in the model are case sensitive, so age, height & income must match exactly. Not Age, Height & Income.

Secondly the way we have the model set up right now, we are just listing things that are required, meaning that the request will be rejected if we don't include all three of those items. However the model will not be rejected if there are additional items in the request.

This behavior could of course be modified by changing the model.

Update Mapping Template

Now that we have used a model to validate the body of our HTTP request in the Method Request section, we can head back over to the Integration Request > Mapping Templates section, and there AWS will have an auto-generated template for us with the name of the Model we created.

auto generated mapping template

Although we obviously don't want 42 to be the value of everything that we send to Lambda, so we need to replace that with the value we want. Kudos to Amazon for the Hitchhikers reference though.

Instead we map these keys to the input like so.

mapping_template
#set($inputRoot = $input.path('$'))
{
"age" : $inputRoot.age,
"height" : $inputRoot.height,
"income" : $inputRoot.income
}

If you are unfamiliar with the concept of mapping templates we introduced that here:

Ncoughlin: AWS API Gateway Request Data > Body Mapping Templates

This auto-generated template also works in the Integration Response section.

Recent Work

Free desktop AI Chat client, designed for developers and businesses. Unlocks advanced model settings only available in the API. Includes quality of life features like custom syntax highlighting.

Learn More
slide-6
slide-5
slide-2
slide-1
slide-3
slide-4
Technologies Used
TypeScript
Electron
React

BidBear

bidbear.io

Bidbear is a report automation tool. It downloads Amazon Seller and Advertising reports, daily, to a private database. It then merges and formats the data into beautiful, on demand, exportable performance reports.

Learn More
slide-1
slide-2
slide-5
slide-3
slide-4

Technologies Used

Front End
JavaScript
Docker
React
Redux
Vite
Next
Docusaurus
Stripe
Sentry
D3
React-Flow
TipTap
Back End
JavaScript
Python
AWS CognitoCognito
AWS API GatewayAPI Gateway
AWS LambdaLambda
AWS AthenaAthena
AWS GlueGlue
AWS Step FunctionsStep Functions
AWS SQSSQS
AWS DynamoDBDynamo DB
AWS S3S3
AWS CloudwatchCloudWatch
AWS CloudFrontCloudFront
AWS Route 53Route 53
AWS EventBridgeEventBridge