aws_api_gateway_domain_name resource
Use the aws_api_gateway_domain_name
InSpec audit resource to test the properties of a single specific AWS API Gateway domain name.
For additional information, including parameters and properties, see the AWS documentation on AWS APIGateway DomainName.
Installation
This resource is available in the Chef InSpec AWS resource pack.
See the Chef InSpec documentation on cloud platforms for information on configuring your AWS environment for InSpec and creating an InSpec profile that uses the InSpec AWS resource pack.
Syntax
Ensure that the domain name exists.
describe aws_api_gateway_domain_name(domain_name: 'DOMAIN_NAME') do
it { should exist }
end
Parameters
domain_name
(required)- The custom domain name as an API hostname. For example, my-api.example.com.
Properties
domain_name
- The custom domain name as an API hostname. For example, my-api.example.com.
Field:
domain_name
certificate_name
- The certificate name used by the edge-optimized endpoint for this domain name.
Field:
certificate_name
certificate_arn
- The reference to an AWS-managed certificate for use by the edge-optimized endpoint for this domain name. AWS Certificate Manager is the only supported source.
Field:
certificate_arn
certificate_upload_date
- The timestamp when the certificate used by the edge-optimized endpoint for this domain name is uploaded.
Field:
certificate_upload_date
regional_domain_name
- The domain name associated with the regional endpoint for this custom domain name. You can set up this association by adding a DNS record that points the custom domain name to this regional domain name. The regional domain name is returned by API Gateway when creating a regional endpoint.
Field:
regional_domain_name
regional_hosted_zone_id
- The region-specific Amazon Route 53 Hosted Zone ID of the regional endpoint. For more information, see Set up a Regional Custom Domain Name and AWS Regions and Endpoints for API Gateway.
Field:
regional_hosted_zone_id
regional_certificate_name
- The certificate name used for validating the regional domain name.
Field:
regional_certificate_name
regional_certificate_arn
- The reference to an AWS-managed certificate that is used to validate the regional domain name. AWS Certificate Manager is the only supported source.
Field:
regional_certificate_arn
distribution_domain_name
- The Amazon CloudFront distribution domain name associated with this custom domain name for an edge-optimized endpoint. You can set up this association when adding a DNS record pointing the custom domain name to this distribution name. For more information about CloudFront distributions, see the Amazon CloudFront documentation.
Field:
distribution_domain_name
distribution_hosted_zone_id
- The region-agnostic Amazon Route 53 Hosted Zone ID of the edge-optimized endpoint. The valid value is
Z2FDTNDATAQYW2
for all the regions. Field:
distribution_hosted_zone_id
endpoint_configuration_types
- A list of the endpoint types of the domain name. The valid values are
EDGE
for edge-optimized API setup, most suitable for mobile applications;REGIONAL
for regional API endpoint setup, most suitable for calling from AWS Region; andPRIVATE
for private APIs. Field:
endpoint_configuration.types
endpoint_configuration_vpc_endpoint_ids
- A list of VpcEndpointIds of an API (RestApi) against which to create Route53 ALIASes. It is only supported for the
PRIVATE
endpoint type. Field:
endpoint_configuration.vpc_endpoint_ids
domain_name_status
- The status of the domain name migration. The valid values are
AVAILABLE
andUPDATING
. If the status isUPDATING
, the domain cannot be modified further until the existing operation is complete. If it isAVAILABLE
, the domain can be updated. Field:
domain_name_status
domain_name_status_message
- An optional text message containing detailed information about the status of the domain name migration.
Field:
domain_name_status_message
security_policy
- The Transport Layer Security (TLS) version and cipher suite for this domain name. The valid values are
TLS_1_0
andTLS_1_2
. Field:
security_policy
tags
- The collection of tags.
Field:
tags
mutual_tls_authentication.truststore_uri
- An Amazon S3 URL that specifies the truststore for mutual TLS authentication. For example,
s3://bucket-name/key-name
. The truststore can contain certificates from public or private certificate authorities. To update the truststore, upload a new version to S3 and update your custom domain name to use the new version. To update the truststore, you must have permission to access the S3 object. Field:
mutual_tls_authentication.truststore_uri
mutual_tls_authentication.truststore_version
- The version of the S3 object that contains your truststore. To specify a version, you must have versioning enabled for the S3 bucket.
Field:
mutual_tls_authentication.truststore_version
mutual_tls_authentication_truststore_warnings
- A list of warnings that API Gateway returns while processing your truststore. Invalid certificates produce warnings. Mutual TLS is still enabled, but some clients might not be able to access your API. To resolve warnings, upload a new truststore to S3 and update your domain name to use the new version.
Field:
mutual_tls_authentication.truststore_warnings
ownership_verification_certificate_arn
- The ARN of the public certificate issued by ACM to validate ownership of your custom domain.
Field:
ownership_verification_certificate_arn
Examples
Test to ensure the domain name is available
describe aws_api_gateway_domain_name(domain_name: 'DOMAIN_NAME') do
its('domain_name') { should eq 'DOMAIN_NAME' }
end
Test to ensure a regional hosted zone ID is available
describe aws_api_gateway_domain_name(domain_name: 'DOMAIN_NAME') do
its('regional_hosted_zone_id') { should eq 'REGIONAL_HOSTED_ZONE_ID' }
end
Test to ensure the domain name status is AVAILABLE
describe aws_api_gateway_domain_name(domain_name: 'DOMAIN_NAME') do
its('domain_name_status') { should eq 'AVAILABLE' }
end
Matchers
This InSpec audit resource has the following special matchers. For a full list of available matchers, please visit our Universal Matchers page.
The control passes if the get
method returns at least one result.
exist
Use should
to test that the entity exists.
describe aws_api_gateway_domain_name(domain_name: 'DOMAIN_NAME') do
it { should exist }
end
Use should_not
to test that the entity does not exist.
describe aws_api_gateway_domain_name(domain_name: 'DOMAIN_NAME') do
it { should_not exist }
end
AWS Permissions
Your Principal will need the APIGateway:Client:DomainName
action with Effect
set to Allow
.