ApiGatewayV1
Reference doc for the `sst.aws.ApiGatewayV1` component.
The ApiGatewayV1
component lets you add an Amazon API Gateway REST API to your app.
Create the API
Add routes
Configure the routes
You can configure the route.
Configure the route handler
You can configure the route handler function.
Default props for all routes
You can use the transform
to set some default props for all your routes. For example,
instead of setting the memory
for each route.
You can set it through the transform
.
With this we set the memory
if it’s not overridden by the route.
Constructor
Parameters
-
name
string
-
args?
ApiGatewayV1Args
-
opts?
ComponentResourceOptions
ApiGatewayV1Args
accessLog?
Type Input
<
Object
>
Default {retention: “1 month”}
Configure the API Gateway logs in CloudWatch. By default, access logs are enabled and kept for 1 month.
accessLog.retention?
Type Input
<
“
1 day
”
|
“
3 days
”
|
“
5 days
”
|
“
1 week
”
|
“
2 weeks
”
|
“
1 month
”
|
“
2 months
”
|
“
3 months
”
|
“
4 months
”
|
“
5 months
”
|
“
6 months
”
|
“
1 year
”
|
“
13 months
”
|
“
18 months
”
|
“
2 years
”
|
“
3 years
”
|
“
5 years
”
|
“
6 years
”
|
“
7 years
”
|
“
8 years
”
|
“
9 years
”
|
“
10 years
”
|
“
forever
”
>
Default 1 month
The duration the API Gateway logs are kept in CloudWatch.
cors?
Type Input
<
boolean
>
Default true
Enable the CORS (Cross-origin resource sharing) settings for your REST API.
Disable CORS.
domain?
Type Input
<
string
|
Object
>
Set a custom domain for your REST API.
Automatically manages domains hosted on AWS Route 53, Cloudflare, and Vercel. For other
providers, you’ll need to pass in a cert
that validates domain ownership and add the
DNS records.
By default this assumes the domain is hosted on Route 53.
For domains hosted on Cloudflare.
domain.cert?
Type Input
<
string
>
The ARN of an ACM (AWS Certificate Manager) certificate that proves ownership of the domain. By default, a certificate is created and validated automatically.
To manually set up a domain on an unsupported provider, you’ll need to:
- Validate that you own the domain by creating an ACM certificate. You can either validate it by setting a DNS record or by verifying an email sent to the domain owner.
- Once validated, set the certificate ARN as the
cert
and setdns
tofalse
. - Add the DNS records in your provider to point to the API Gateway URL.
domain.dns?
Type Input
<
false
|
sst.aws.dns
|
sst.cloudflare.dns
|
sst.vercel.dns
>
Default sst.aws.dns
The DNS provider to use for the domain. Defaults to the AWS.
Takes an adapter that can create the DNS records on the provider. This can automate validating the domain and setting up the DNS routing.
Supports Route 53, Cloudflare, and Vercel adapters. For other providers, you’ll need
to set dns
to false
and pass in a certificate validating ownership via cert
.
Specify the hosted zone ID for the Route 53 domain.
Use a domain hosted on Cloudflare, needs the Cloudflare provider.
Use a domain hosted on Vercel, needs the Vercel provider.
domain.name
Type Input
<
string
>
The custom domain you want to use.
Can also include subdomains based on the current stage.
domain.nameId?
Type Input
<
string
>
Use an existing API Gateway domain name.
By default, a new API Gateway domain name is created. If you’d like to use an existing
domain name, set the nameId
to the ID of the domain name and do not pass in name
.
domain.path?
Type Input
<
string
>
The base mapping for the custom domain. This adds a suffix to the URL of the API.
Given the following base path and domain name.
The full URL of the API will be https://api.example.com/v1/
.
By default there is no base path, so if the name
is api.example.com
, the full URL will be https://api.example.com
.
endpoint?
Type Input
<
Object
>
Default {type: “edge”}
Configure the API Gateway REST API endpoint.
By default, it’s an edge
endpoint, meaning that a CloudFront distribution is created
for the API. This could help in cases where requests are geographically distributed.
On the other hand, regional
endpoints are deployed in a specific AWS region and are
intended to be accessed directly by clients within or near that region.
And a private
endpoints allow access to the API only from within a specified
Amazon VPC (Virtual Private Cloud) using VPC endpoints. These endpoints do not expose
the API to the public internet.
To create a regional endpoint.
And to create a private endpoint.
endpoint.type
Type “
edge
”
|
“
regional
”
|
“
private
”
The type of the API Gateway REST API endpoint.
endpoint.vpcEndpointIds?
Type Input
<
Input
<
string
>
[]
>
The VPC endpoint IDs for the private
endpoint.
transform?
Type Object
Transform how this component creates its underlying resources.
transform.accessLog?
Type LogGroupArgs
|
(
args
:
LogGroupArgs
,
opts
:
ComponentResourceOptions
,
name
:
string
)
=>
void
Transform the CloudWatch LogGroup resource used for access logs.
transform.api?
Type RestApiArgs
|
(
args
:
RestApiArgs
,
opts
:
ComponentResourceOptions
,
name
:
string
)
=>
void
Transform the API Gateway REST API resource.
transform.deployment?
Type DeploymentArgs
|
(
args
:
DeploymentArgs
,
opts
:
ComponentResourceOptions
,
name
:
string
)
=>
void
Transform the API Gateway REST API deployment resource.
transform.domainName?
Type DomainNameArgs
|
(
args
:
DomainNameArgs
,
opts
:
ComponentResourceOptions
,
name
:
string
)
=>
void
Transform the API Gateway REST API domain name resource.
transform.route?
Type Object
Transform the routes. This is called for every route that is added.
You can use this to set any default props for all the routes and their handler function. Like the other transforms, you can either pass in an object or a callback.
Here we are setting a default memory of 2048 MB
for our routes.
Defaulting to IAM auth for all our routes.
transform.route.args?
Type ApiGatewayV1RouteArgs
|
(
args
:
ApiGatewayV1RouteArgs
,
opts
:
ComponentResourceOptions
,
name
:
string
)
=>
void
Transform the arguments for the route.
transform.route.handler?
Type FunctionArgs
|
(
args
:
FunctionArgs
,
opts
:
ComponentResourceOptions
,
name
:
string
)
=>
void
Transform the handler function of the route.
transform.stage?
Type StageArgs
|
(
args
:
StageArgs
,
opts
:
ComponentResourceOptions
,
name
:
string
)
=>
void
Transform the API Gateway REST API stage resource.
Properties
nodes
Type Object
The underlying resources this component creates.
nodes.api
Type RestApi
The Amazon API Gateway REST API
nodes.logGroup
Type undefined
|
LogGroup
The CloudWatch LogGroup for the access logs.
nodes.stage
Type undefined
|
Stage
The Amazon API Gateway REST API stage
nodes.domainName
Type Output
<
DomainName
>
The API Gateway REST API domain name.
url
Type Output
<
string
>
The URL of the API.
SDK
Use the SDK in your runtime to interact with your infrastructure.
Links
This is accessible through the Resource
object in the SDK.
-
url
string
The URL of the API.
Methods
addAuthorizer
Parameters
- Configure the authorizer.
Returns ApiGatewayV1Authorizer
Add an authorizer to the API Gateway REST API.
Add a Lambda token authorizer.
Add a Lambda REQUEST authorizer.
Add a Cognito User Pool authorizer.
Customize the authorizer.
deploy
Returns void
Create a deployment for the API Gateway REST API.
Due to the way API Gateway V1 is created internally, you’ll need to call this method after you’ve added all your routes.
route
Parameters
The path for the route.route
string
The function that’ll be invoked.handler
Input
<
string
|
FunctionArgs
|
“arn:aws:lambda:${string}”
>
Configure the route.args?
ApiGatewayV1RouteArgs
Returns ApiGatewayV1LambdaRoute
Add a route to the API Gateway REST API. The route is a combination of an HTTP method and a path, {METHOD} /{path}
.
A method could be one of GET
, POST
, PUT
, DELETE
, PATCH
, HEAD
, OPTIONS
, or ANY
. Here ANY
matches any HTTP method.
The path can be a combination of
- Literal segments,
/notes
,/notes/new
, etc. - Parameter segments,
/notes/{noteId}
,/notes/{noteId}/attachments/{attachmentId}
, etc. - Greedy segments,
/{proxy+}
,/notes/{proxy+}
, etc. The{proxy+}
segment is a greedy segment that matches all child paths. It needs to be at the end of the path.
When a request comes in, the API Gateway will look for the most specific match.
Add a simple route.
Match any HTTP method.
Add a default route.
Add a parameterized route.
Add a greedy route.
Enable auth for a route.
Customize the route handler.
Or pass in the ARN of an existing Lambda function.
routeIntegration
Parameters
The path for the route.route
string
The integration configuration.integration
ApiGatewayV1IntegrationArgs
Configure the route.args?
ApiGatewayV1RouteArgs
Returns ApiGatewayV1IntegrationRoute
Add a custom integration to the API Gateway REST API.
Learn more about integrations for REST APIs.
Add a route to trigger a Step Functions state machine execution.
ApiGatewayV1AuthorizerArgs
identitySource?
Type Input
<
string
>
Default “method.request.header.Authorization”
Specifies where to extract the authorization token from the request.
name
Type string
The name of the authorizer.
requestFunction?
Type Input
<
string
|
FunctionArgs
>
The Lambda request authorizer function. Takes the handler path or the function args.
tokenFunction?
Type Input
<
string
|
FunctionArgs
>
The Lambda token authorizer function. Takes the handler path or the function args.
transform?
Type Object
Transform how this component creates its underlying resources.
transform.authorizer?
Type AuthorizerArgs
|
(
args
:
AuthorizerArgs
,
opts
:
ComponentResourceOptions
,
name
:
string
)
=>
void
Transform the API Gateway authorizer resource.
ttl?
Type Input
<
number
>
Default 300
Time to live for cached authorizer results in seconds.
userPools?
Type Input
<
Input
<
string
>
[]
>
A list of user pools used as the authorizer.
Where userPool
is:
ApiGatewayV1DomainArgs
cert?
Type Input
<
string
>
The ARN of an ACM (AWS Certificate Manager) certificate that proves ownership of the domain. By default, a certificate is created and validated automatically.
To manually set up a domain on an unsupported provider, you’ll need to:
- Validate that you own the domain by creating an ACM certificate. You can either validate it by setting a DNS record or by verifying an email sent to the domain owner.
- Once validated, set the certificate ARN as the
cert
and setdns
tofalse
. - Add the DNS records in your provider to point to the API Gateway URL.
dns?
Type Input
<
false
|
sst.aws.dns
|
sst.cloudflare.dns
|
sst.vercel.dns
>
Default sst.aws.dns
The DNS provider to use for the domain. Defaults to the AWS.
Takes an adapter that can create the DNS records on the provider. This can automate validating the domain and setting up the DNS routing.
Supports Route 53, Cloudflare, and Vercel adapters. For other providers, you’ll need
to set dns
to false
and pass in a certificate validating ownership via cert
.
Specify the hosted zone ID for the Route 53 domain.
Use a domain hosted on Cloudflare, needs the Cloudflare provider.
Use a domain hosted on Vercel, needs the Vercel provider.
name
Type Input
<
string
>
The custom domain you want to use.
Can also include subdomains based on the current stage.
nameId?
Type Input
<
string
>
Use an existing API Gateway domain name.
By default, a new API Gateway domain name is created. If you’d like to use an existing
domain name, set the nameId
to the ID of the domain name and do not pass in name
.
path?
Type Input
<
string
>
The base mapping for the custom domain. This adds a suffix to the URL of the API.
Given the following base path and domain name.
The full URL of the API will be https://api.example.com/v1/
.
By default there is no base path, so if the name
is api.example.com
, the full URL will be https://api.example.com
.
ApiGatewayV1IntegrationArgs
credentials?
Type Input
<
string
>
The credentials to use to call the AWS service.
integrationHttpMethod?
Type Input
<
“
GET
”
|
“
POST
”
|
“
PUT
”
|
“
DELETE
”
|
“
HEAD
”
|
“
OPTIONS
”
|
“
ANY
”
|
“
PATCH
”
>
The HTTP method to use to call the integration.
passthroughBehavior?
Type Input
<
“
when-no-match
”
|
“
never
”
|
“
when-no-templates
”
>
The passthrough behavior to use to call the integration.
Required if requestTemplates
is set.
requestParameters?
Type Input
<
Record
<
string
, Input
<
string
>
>
>
Map of request query string parameters and headers that should be passed to the backend responder.
requestTemplates?
Type Input
<
Record
<
string
, Input
<
string
>
>
>
Map of the integration’s request templates.
type
Type Input
<
“
aws
”
|
“
http
”
|
“
aws-proxy
”
|
“
mock
”
|
“
http-proxy
”
>
The type of the API Gateway REST API integration.
uri?
Type Input
<
string
>
The URI of the API Gateway REST API integration.
ApiGatewayV1RouteArgs
auth?
Type Input
<
false
|
Object
>
-
cognito?
Input
<
Object
>
Default false
Enable auth for your REST API. By default, auth is disabled.
auth.cognito?
Type Input
<
Object
>
Enable Cognito User Pool authorization for a given API route.
You can configure JWT auth.
Where myAuthorizer
is:
auth.cognito.authorizer
Type Input
<
string
>
Authorizer ID of the Cognito User Pool authorizer.
auth.cognito.scopes?
Type Input
<
Input
<
string
>
[]
>
Defines the permissions or access levels that the authorization token grants.
auth.custom?
Type Input
<
string
>
Enable custom Lambda authorization for a given API route. Pass in the authorizer ID.
Where myAuthorizer
is:
auth.iam?
Type Input
<
boolean
>
Enable IAM authorization for a given API route.
When IAM auth is enabled, clients need to use Signature Version 4 to sign their requests with their AWS credentials.
transform?
Type Object
Transform how this component creates its underlying resources.
transform.integration?
Type IntegrationArgs
|
(
args
:
IntegrationArgs
,
opts
:
ComponentResourceOptions
,
name
:
string
)
=>
void
Transform the API Gateway REST API integration resource.
transform.method?
Type MethodArgs
|
(
args
:
MethodArgs
,
opts
:
ComponentResourceOptions
,
name
:
string
)
=>
void
Transform the API Gateway REST API method resource.