This is the new AWS CloudFormation Template Reference Guide. Please update your bookmarks and links. For help getting started with CloudFormation, see the AWS CloudFormation User Guide.
AWS::ApiGatewayV2::DomainName
The AWS::ApiGatewayV2::DomainName resource specifies a custom domain
                  name for your API in Amazon API Gateway (API Gateway). 
You can use a custom domain name to provide a URL that's more intuitive and easier to recall. For more information about using custom domain names, see Set up Custom Domain Name for an API in API Gateway in the API Gateway Developer Guide.
Syntax
To declare this entity in your AWS CloudFormation template, use the following syntax:
JSON
{ "Type" : "AWS::ApiGatewayV2::DomainName", "Properties" : { "DomainName" :String, "DomainNameConfigurations" :[ DomainNameConfiguration, ... ], "MutualTlsAuthentication" :MutualTlsAuthentication, "RoutingMode" :String, "Tags" :{} }Key:Value, ...}
YAML
Type: AWS::ApiGatewayV2::DomainName Properties: DomainName:StringDomainNameConfigurations:- DomainNameConfigurationMutualTlsAuthentication:MutualTlsAuthenticationRoutingMode:StringTags:Key:Value
Properties
- DomainName
- 
                    The custom domain name for your API in Amazon API Gateway. Uppercase letters and the underscore ( _) character are not supported.Required: Yes Type: String Update requires: Replacement 
- DomainNameConfigurations
- 
                    The domain name configurations. Required: No Type: Array of DomainNameConfiguration Update requires: No interruption 
- MutualTlsAuthentication
- 
                    The mutual TLS authentication configuration for a custom domain name. Required: No Type: MutualTlsAuthentication Update requires: No interruption 
- RoutingMode
- 
                    The routing mode API Gateway uses to route traffic to your APIs. Required: No Type: String Allowed values: API_MAPPING_ONLY | ROUTING_RULE_THEN_API_MAPPING | ROUTING_RULE_ONLYUpdate requires: No interruption 
- 
                    The collection of tags associated with a domain name. Required: No Type: Object of String Pattern: .*Update requires: No interruption 
Return values
Ref
When you pass the logical ID of this resource to the intrinsic Ref function, Ref returns the domain name, such as
                        example.mydomain.com.
For more information about using the Ref function, see Ref.
Fn::GetAtt
The Fn::GetAtt intrinsic function returns a value for a specified attribute of this type. The following are the available attributes and sample return values.
For more information about using the Fn::GetAtt intrinsic function, see Fn::GetAtt.
- DomainNameArn
- 
                            Represents an Amazon Resource Name (ARN). 
- RegionalDomainName
- 
                            The domain name associated with the regional endpoint for this custom domain name. You set up this association by adding a DNS record that points the custom domain name to this regional domain name. 
- RegionalHostedZoneId
- 
                            The region-specific Amazon Route 53 Hosted Zone ID of the regional endpoint. 
Examples
Domain name creation example
The following example creates a DomainName resource
                              called MyDomainName.
JSON
{ "MyDomainName": { "Type": "AWS::ApiGatewayV2::DomainName", "Properties": { "DomainName": "mydomainame.us-east-1.com", "DomainNameConfigurations": [ { "EndpointType": "REGIONAL", "CertificateArn": "arn:aws:acm:us-east-1:123456789012:certificate/1a2b3c4d-aaaa-aaaa-aaaa-1a2b3c4d5e6f", "CertificateName": "testCertificate" } ] } } }
YAML
MyDomainName: Type: 'AWS::ApiGatewayV2::DomainName' Properties: DomainName: mydomainame.us-east-1.com DomainNameConfigurations: - EndpointType: REGIONAL CertificateArn: >- arn:aws:acm:us-east-1:123456789012:certificate/1a2b3c4d-aaaa-aaaa-aaaa-1a2b3c4d5e6f CertificateName: testCertificate
Domain name with routing mode creation example
The following example creates a DomainName resource with the RoutingMode parameter of ROUTING_RULES_ONLY.
JSON
{ "Resources": { "TestDomainName": { "Type": "AWS::ApiGatewayV2::DomainName", "Properties": { "DomainName": "mydomainame.example.com", "DomainNameConfigurations": [ { "EndpointType": "REGIONAL", "CertificateArn": "arn:aws:acm:us-east-1:111122223333:certificate/fb1b9770-a305-495d-aefb-27e5e101ff3", "SecurityPolicy": "TLS_1_2" } ], "RoutingMode": "ROUTING_RULE_ONLY" } } } }
YAML
Resources: TestDomainName: Type: AWS::ApiGatewayV2::DomainName Properties: DomainName: mydomainame.example.com DomainNameConfigurations: - EndpointType: REGIONAL CertificateArn: arn:aws:acm:us-east-1:111122223333:certificate/fb1b9770-a305-495d-aefb-27e5e101ff3 SecurityPolicy: TLS_1_2 RoutingMode: "ROUTING_RULE_ONLY"
See also
- 
                    CreateDomainName in the Amazon API Gateway Version 2 API Reference