Domain Name Args
Registers a custom domain name for use with AWS API Gateway. Additional information about this functionality can be found in the API Gateway Developer Guide. This resource just establishes ownership of and the TLS settings for a particular domain name. An API can be attached to a particular path under the registered domain name using the aws.apigateway.BasePathMapping resource. API Gateway domains can be defined as either 'edge-optimized' or 'regional'. In an edge-optimized configuration, API Gateway internally creates and manages a CloudFront distribution to route requests on the given hostname. In addition to this resource it's necessary to create a DNS record corresponding to the given domain name which is an alias (either Route53 alias or traditional CNAME) to the Cloudfront domain name exported in the cloudfront_domain_name attribute. In a regional configuration, API Gateway does not create a CloudFront distribution to route requests to the API, though a distribution can be created if needed. In either case, it is necessary to create a DNS record corresponding to the given domain name which is an alias (either Route53 alias or traditional CNAME) to the regional domain name exported in the regional_domain_name attribute.
Note: API Gateway requires the use of AWS Certificate Manager (ACM) certificates instead of Identity and Access Management (IAM) certificates in regions that support ACM. Regions that support ACM can be found in the Regions and Endpoints Documentation. To import an existing private key and certificate into ACM or request an ACM certificate, see the
aws.acm.Certificateresource. Note: Theaws.apigateway.DomainNameresource expects dependency on theaws.acm.CertificateValidationas only verified certificates can be used. This can be made either explicitly by adding thedepends_on = [aws_acm_certificate_validation.cert]attribute. Or implicitly by referring certificate ARN from the validation resource where it will be available after the resource creation:regional_certificate_arn = aws_acm_certificate_validation.cert.certificate_arn.
Example Usage
Edge Optimized (ACM Certificate)
import * as pulumi from "@pulumi/pulumi";
import * as aws from "@pulumi/aws";
const example = new aws.apigateway.DomainName("example", {
certificateArn: exampleAwsAcmCertificateValidation.certificateArn,
domainName: "api.example.com",
});
// Example DNS record using Route53.
// Route53 is not specifically required; any DNS host can be used.
const exampleRecord = new aws.route53.Record("example", {
name: example.domainName,
type: aws.route53.RecordType.A,
zoneId: exampleAwsRoute53Zone.id,
aliases: [{
evaluateTargetHealth: true,
name: example.cloudfrontDomainName,
zoneId: example.cloudfrontZoneId,
}],
});import pulumi
import pulumi_aws as aws
example = aws.apigateway.DomainName("example",
certificate_arn=example_aws_acm_certificate_validation["certificateArn"],
domain_name="api.example.com")
# Example DNS record using Route53.
# Route53 is not specifically required; any DNS host can be used.
example_record = aws.route53.Record("example",
name=example.domain_name,
type=aws.route53.RecordType.A,
zone_id=example_aws_route53_zone["id"],
aliases=[aws.route53.RecordAliasArgs(
evaluate_target_health=True,
name=example.cloudfront_domain_name,
zone_id=example.cloudfront_zone_id,
)])using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Aws = Pulumi.Aws;
return await Deployment.RunAsync(() =>
{
var example = new Aws.ApiGateway.DomainName("example", new()
{
CertificateArn = exampleAwsAcmCertificateValidation.CertificateArn,
Domain = "api.example.com",
});
// Example DNS record using Route53.
// Route53 is not specifically required; any DNS host can be used.
var exampleRecord = new Aws.Route53.Record("example", new()
{
Name = example.Domain,
Type = Aws.Route53.RecordType.A,
ZoneId = exampleAwsRoute53Zone.Id,
Aliases = new[]
{
new Aws.Route53.Inputs.RecordAliasArgs
{
EvaluateTargetHealth = true,
Name = example.CloudfrontDomainName,
ZoneId = example.CloudfrontZoneId,
},
},
});
});package main
import (
"github.com/pulumi/pulumi-aws/sdk/v6/go/aws/apigateway"
"github.com/pulumi/pulumi-aws/sdk/v6/go/aws/route53"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
example, err := apigateway.NewDomainName(ctx, "example", &apigateway.DomainNameArgs{
CertificateArn: pulumi.Any(exampleAwsAcmCertificateValidation.CertificateArn),
DomainName: pulumi.String("api.example.com"),
})
if err != nil {
return err
}
// Example DNS record using Route53.
// Route53 is not specifically required; any DNS host can be used.
_, err = route53.NewRecord(ctx, "example", &route53.RecordArgs{
Name: example.DomainName,
Type: pulumi.String(route53.RecordTypeA),
ZoneId: pulumi.Any(exampleAwsRoute53Zone.Id),
Aliases: route53.RecordAliasArray{
&route53.RecordAliasArgs{
EvaluateTargetHealth: pulumi.Bool(true),
Name: example.CloudfrontDomainName,
ZoneId: example.CloudfrontZoneId,
},
},
})
if err != nil {
return err
}
return nil
})
}package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.aws.apigateway.DomainName;
import com.pulumi.aws.apigateway.DomainNameArgs;
import com.pulumi.aws.route53.Record;
import com.pulumi.aws.route53.RecordArgs;
import com.pulumi.aws.route53.inputs.RecordAliasArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
var example = new DomainName("example", DomainNameArgs.builder()
.certificateArn(exampleAwsAcmCertificateValidation.certificateArn())
.domainName("api.example.com")
.build());
// Example DNS record using Route53.
// Route53 is not specifically required; any DNS host can be used.
var exampleRecord = new Record("exampleRecord", RecordArgs.builder()
.name(example.domainName())
.type("A")
.zoneId(exampleAwsRoute53Zone.id())
.aliases(RecordAliasArgs.builder()
.evaluateTargetHealth(true)
.name(example.cloudfrontDomainName())
.zoneId(example.cloudfrontZoneId())
.build())
.build());
}
}resources:
example:
type: aws:apigateway:DomainName
properties:
certificateArn: ${exampleAwsAcmCertificateValidation.certificateArn}
domainName: api.example.com
# Example DNS record using Route53.
# Route53 is not specifically required; any DNS host can be used.
exampleRecord:
type: aws:route53:Record
name: example
properties:
name: ${example.domainName}
type: A
zoneId: ${exampleAwsRoute53Zone.id}
aliases:
- evaluateTargetHealth: true
name: ${example.cloudfrontDomainName}
zoneId: ${example.cloudfrontZoneId}Regional (ACM Certificate)
import * as pulumi from "@pulumi/pulumi";
import * as aws from "@pulumi/aws";
const example = new aws.apigateway.DomainName("example", {
domainName: "api.example.com",
regionalCertificateArn: exampleAwsAcmCertificateValidation.certificateArn,
endpointConfiguration: {
types: "REGIONAL",
},
});
// Example DNS record using Route53.
// Route53 is not specifically required; any DNS host can be used.
const exampleRecord = new aws.route53.Record("example", {
name: example.domainName,
type: aws.route53.RecordType.A,
zoneId: exampleAwsRoute53Zone.id,
aliases: [{
evaluateTargetHealth: true,
name: example.regionalDomainName,
zoneId: example.regionalZoneId,
}],
});import pulumi
import pulumi_aws as aws
example = aws.apigateway.DomainName("example",
domain_name="api.example.com",
regional_certificate_arn=example_aws_acm_certificate_validation["certificateArn"],
endpoint_configuration=aws.apigateway.DomainNameEndpointConfigurationArgs(
types="REGIONAL",
))
# Example DNS record using Route53.
# Route53 is not specifically required; any DNS host can be used.
example_record = aws.route53.Record("example",
name=example.domain_name,
type=aws.route53.RecordType.A,
zone_id=example_aws_route53_zone["id"],
aliases=[aws.route53.RecordAliasArgs(
evaluate_target_health=True,
name=example.regional_domain_name,
zone_id=example.regional_zone_id,
)])using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Aws = Pulumi.Aws;
return await Deployment.RunAsync(() =>
{
var example = new Aws.ApiGateway.DomainName("example", new()
{
Domain = "api.example.com",
RegionalCertificateArn = exampleAwsAcmCertificateValidation.CertificateArn,
EndpointConfiguration = new Aws.ApiGateway.Inputs.DomainNameEndpointConfigurationArgs
{
Types = "REGIONAL",
},
});
// Example DNS record using Route53.
// Route53 is not specifically required; any DNS host can be used.
var exampleRecord = new Aws.Route53.Record("example", new()
{
Name = example.Domain,
Type = Aws.Route53.RecordType.A,
ZoneId = exampleAwsRoute53Zone.Id,
Aliases = new[]
{
new Aws.Route53.Inputs.RecordAliasArgs
{
EvaluateTargetHealth = true,
Name = example.RegionalDomainName,
ZoneId = example.RegionalZoneId,
},
},
});
});package main
import (
"github.com/pulumi/pulumi-aws/sdk/v6/go/aws/apigateway"
"github.com/pulumi/pulumi-aws/sdk/v6/go/aws/route53"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
example, err := apigateway.NewDomainName(ctx, "example", &apigateway.DomainNameArgs{
DomainName: pulumi.String("api.example.com"),
RegionalCertificateArn: pulumi.Any(exampleAwsAcmCertificateValidation.CertificateArn),
EndpointConfiguration: &apigateway.DomainNameEndpointConfigurationArgs{
Types: pulumi.String("REGIONAL"),
},
})
if err != nil {
return err
}
// Example DNS record using Route53.
// Route53 is not specifically required; any DNS host can be used.
_, err = route53.NewRecord(ctx, "example", &route53.RecordArgs{
Name: example.DomainName,
Type: pulumi.String(route53.RecordTypeA),
ZoneId: pulumi.Any(exampleAwsRoute53Zone.Id),
Aliases: route53.RecordAliasArray{
&route53.RecordAliasArgs{
EvaluateTargetHealth: pulumi.Bool(true),
Name: example.RegionalDomainName,
ZoneId: example.RegionalZoneId,
},
},
})
if err != nil {
return err
}
return nil
})
}package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.aws.apigateway.DomainName;
import com.pulumi.aws.apigateway.DomainNameArgs;
import com.pulumi.aws.apigateway.inputs.DomainNameEndpointConfigurationArgs;
import com.pulumi.aws.route53.Record;
import com.pulumi.aws.route53.RecordArgs;
import com.pulumi.aws.route53.inputs.RecordAliasArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
var example = new DomainName("example", DomainNameArgs.builder()
.domainName("api.example.com")
.regionalCertificateArn(exampleAwsAcmCertificateValidation.certificateArn())
.endpointConfiguration(DomainNameEndpointConfigurationArgs.builder()
.types("REGIONAL")
.build())
.build());
// Example DNS record using Route53.
// Route53 is not specifically required; any DNS host can be used.
var exampleRecord = new Record("exampleRecord", RecordArgs.builder()
.name(example.domainName())
.type("A")
.zoneId(exampleAwsRoute53Zone.id())
.aliases(RecordAliasArgs.builder()
.evaluateTargetHealth(true)
.name(example.regionalDomainName())
.zoneId(example.regionalZoneId())
.build())
.build());
}
}resources:
example:
type: aws:apigateway:DomainName
properties:
domainName: api.example.com
regionalCertificateArn: ${exampleAwsAcmCertificateValidation.certificateArn}
endpointConfiguration:
types: REGIONAL
# Example DNS record using Route53.
# Route53 is not specifically required; any DNS host can be used.
exampleRecord:
type: aws:route53:Record
name: example
properties:
name: ${example.domainName}
type: A
zoneId: ${exampleAwsRoute53Zone.id}
aliases:
- evaluateTargetHealth: true
name: ${example.regionalDomainName}
zoneId: ${example.regionalZoneId}Import
Using pulumi import, import API Gateway domain names using their name. For example:
$ pulumi import aws:apigateway/domainName:DomainName example dev.example.comConstructors
Functions
Properties
Certificate for the CA that issued the certificate, along with any intermediate CA certificates required to create an unbroken chain to a certificate trusted by the intended API clients. Only valid for EDGE endpoint configuration type. Conflicts with certificate_arn, regional_certificate_arn, and regional_certificate_name.
ARN for an AWS-managed certificate. AWS Certificate Manager is the only supported source. Used when a regional domain name is desired. Conflicts with certificate_arn, certificate_name, certificate_body, certificate_chain, and certificate_private_key. When uploading a certificate, the following arguments are supported: