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/b97bb/b97bb56c9b6c01b4467ed51a7fa9759a5467e08b" alt=""
#
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/4a84b/4a84b12c2514ce8d2b006de90b2bf4d169882a30" alt=""
data:image/s3,"s3://crabby-images/73bcd/73bcde5ccbdada93e1e44fb267ca77e29ad6d93e" alt=""
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/325a6/325a607c3fa1813f70c8c4e9d57b365ab072b1aa" alt=""
#
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/2c0c0/2c0c0e60d821c70ea2ff3df96c07523110517cb0" alt=""
- In the CORS configuration page do the following:
- Add
rid,fdi-version,anti-csrf,st-auth-mode
to the existingAccess-Control-Allow-Headers
- Set
Access-Control-Allow-Origin
to'^{form_websiteDomain}'
- Set
Access-Control-Allow-Credentials
to'true'
. Don't miss out on those quotes else it won't get configured correctly.
- Add
data:image/s3,"s3://crabby-images/cb099/cb099432f9357680d850fdc12e1b4dd7770fb23e" alt=""
#
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
.
note
Update apiBasePath
and apiGatewayPath
in the Lambda configuration if they have changed post API Gateway configuration.