Set up API Gateway
#
1) Create a REST API GatewayWe will be using AWS API Gateway to create a REST API that will be used to communicate with our Lambda functions.
data:image/s3,"s3://crabby-images/7f2d3/7f2d3e9495ecd01f244916dfda5483d49aae09bd" alt="Create API gateway step UI"
#
2) Set up auth routesCreate a /auth
resource and then /auth/{proxy+}
resources. This will act as a catch-all for all supertokens auth routes. Enable CORS while creating the proxy resource.
data:image/s3,"s3://crabby-images/11adf/11adf66bbc0dfc42f43f76e3cae1b5c5ca35fb6d" alt="Create proxy route step UI"
data:image/s3,"s3://crabby-images/79fb1/79fb158355c94f3443ff7e6a0fec0d1edc22398d" alt="Route creation complete step UI"
ANY
method of the proxy resource#
3) Attach lambda to the Click on the "ANY" method and then "Integration" to configure the lambda function. Check Lambda proxy integration and then select your lambda function.
data:image/s3,"s3://crabby-images/886a1/886a1a5b14a2c1f0a891e3d9d8f8e1c512534279" alt="Configure lambda integration UI"
important
Ensure that the Lambda proxy integration toggle is turned on.
#
4) Enable CORS for the proxy pathClick on the {proxy+}
resource and then "Enable CORS" button to open the CORS configuration page.
data:image/s3,"s3://crabby-images/693c5/693c531805a00b2cd18039edcd608adaaf5beefe" alt="Enable CORS for the proxy path UI"
- In the CORS configuration page do the following:
- Select the 'Default 4XX' and 'Default 5XX' checkboxes under Gateway responses
- Select the 'OPTIONS' checkbox under Methods
- Add
rid,fdi-version,anti-csrf,st-auth-mode
to the existingAccess-Control-Allow-Headers
- Set
Access-Control-Allow-Origin
to'<YOUR_WEBSITE_DOMAIN>'
- Select
Access-Control-Allow-Credentials
checkbox
data:image/s3,"s3://crabby-images/ecc4f/ecc4ffb89bc2843b6c3ba892b3d57d09c0620d4e" alt="CORS configuration page"
#
4) Deploy the API GatewayClick the Deploy API button in the top right corner to deploy the API. During deployment, you'll be prompted to create a stage; for this tutorial, name the stage dev
. After deployment, you will receive your Invoke URL
.
important
Update apiDomain
, apiBasePath
, and apiGatewayPath
in both Lambda configuration and your frontend config if they have changed post API Gateway configuration.