Terraform module to create Route53 resource on AWS for create api gateway with it's basic elements.
We eat, drink, sleep and most importantly love DevOps. We are working towards strategies for standardizing architecture while ensuring security for the infrastructure. We are strong believer of the philosophy Bigger problems are always solved by breaking them into smaller manageable problems. Resonating with microservices architecture, it is considered best-practice to run database, cluster, storage in smaller connected yet manageable pieces within the infrastructure.
This module is basically combination of Terraform open source and includes automatation tests and examples. It also helps to create and improve your infrastructure with minimalistic code instead of maintaining the whole infrastructure code yourself.
We have fifty plus terraform modules. A few of them are comepleted and are available for open source usage while a few others are in progress.
This module has a few dependencies:
- Terraform 1.x.x
- Go
- github.com/stretchr/testify/assert
- github.com/gruntwork-io/terratest/modules/terraform
IMPORTANT: Since the master
branch used in source
varies based on new modifications, we suggest that you use the release versions here.
Here are examples of how you can use this module in your inventory structure:
module "api-gateway" {
source = "clouddrove/api-gateway/aws"
version = "0.15.0"
name = "api-gateway"
environment = "test"
label_order = ["name", "environment"]
enabled = true
# Api Gateway Resource
path_parts = ["mytestresource", "mytestresource1"]
# Api Gateway Method
method_enabled = true
http_methods = ["GET", "GET"]
# Api Gateway Integration
integration_types = ["MOCK", "AWS_PROXY"]
integration_http_methods = ["POST", "POST"]
uri = ["", "arn:aws:apigateway:eu-west-1:lambda:path/2015-03-31/functions/arn:aws:lambda:eu-west-1:xxxxxxxxxx:function:test/invocations"]
integration_request_parameters = [{
"integration.request.header.X-Authorization" = "'static'"
}, {}]
request_templates = [{
"application/xml" = <<EOF
{
"body" : $input.json('$')
}
EOF
}, {}]
# Api Gateway Method Response
status_codes = [200, 200]
response_models = [{ "application/json" = "Empty" }, {}]
response_parameters = [{ "method.response.header.X-Some-Header" = true }, {}]
# Api Gateway Integration Response
integration_response_parameters = [{ "method.response.header.X-Some-Header" = "integration.response.header.X-Some-Other-Header" }, {}]
response_templates = [{
"application/xml" = <<EOF
#set($inputRoot = $input.path('$'))
<?xml version="1.0" encoding="UTF-8"?>
<message>
$inputRoot.body
</message>
EOF
}, {}]
# Api Gateway Deployment
deployment_enabled = true
stage_name = "deploy"
# Api Gateway Stage
stage_enabled = true
stage_names = ["qa", "dev"]
}
module "api-gateway" {
source = "clouddrove/api-gateway/aws"
version = "0.14.0"
name = "api-gateway"
environment = "test"
label_order = ["name", "environment"]
enabled = true
# Api Gateway Resource
path_parts = ["mytestresource", "mytestresource1"]
# Api Gateway Method
method_enabled = true
http_methods = ["GET", "GET"]
# Api Gateway Integration
integration_types = ["MOCK", "AWS_PROXY"]
integration_http_methods = ["POST", "POST"]
uri = ["", "arn:aws:apigateway:eu-west-1:lambda:path/2015-03-31/functions/arn:aws:lambda:eu-west-1:xxxxxxxxxx:function:test/invocations"]
integration_request_parameters = [{
"integration.request.header.X-Authorization" = "'static'"
}, {}]
request_templates = [{
"application/xml" = <<EOF
{
"body" : $input.json('$')
}
EOF
}, {}]
# Api Gateway Method Response
status_codes = [200, 200]
response_models = [{ "application/json" = "Empty" }, {}]
response_parameters = [{ "method.response.header.X-Some-Header" = true }, {}]
# Api Gateway Integration Response
integration_response_parameters = [{ "method.response.header.X-Some-Header" = "integration.response.header.X-Some-Other-Header" }, {}]
response_templates = [{
"application/xml" = <<EOF
#set($inputRoot = $input.path('$'))
<?xml version="1.0" encoding="UTF-8"?>
<message>
$inputRoot.body
</message>
EOF
}, {}]
# Api Gateway Deployment
deployment_enabled = true
stage_name = "deploy"
# Api Gateway Stage
stage_enabled = true
stage_names = ["qa", "dev"]
# Api Gateway Client Certificate
cert_enabled = true
cert_description = "clouddrove"
# Api Gateway Authorizer
authorizer_count = 2
authorizer_names = ["test", "test1"]
authorizer_uri = ["arn:aws:apigateway:eu-west-1:lambda:path/2015-03-31/functions/arn:aws:lambda:eu-west-1:xxxxxxxxxx:function:test/invocations", "arn:aws:apigateway:eu-west-1:lambda:path/2015-03-31/functions/arn:aws:lambda:eu-west-1:xxxxxxxxxx:function:test/invocations"]
authorizer_credentials = ["arn:aws:iam::xxxxxxxxxx:role/lambda-role", "arn:aws:iam::xxxxxxxxxx:role/lambda-role"]
identity_sources = ["method.request.header.Authorization", "method.request.header.Authorization"]
identity_validation_expressions = ["sfdgfhghrfdsdas", ""]
authorizer_types = ["TOKEN", "REQUEST"]
# Api Gateway Gateway Response
gateway_response_count = 2
response_types = ["UNAUTHORIZED", "RESOURCE_NOT_FOUND"]
gateway_status_codes = ["401", "404"]
# Api Gateway Model
model_count = 2
model_names = ["test", "test1"]
content_types = ["application/json", "application/json"]
# Api Gateway Api Key
key_count = 2
key_names = ["test", "test1"]
}
Name | Description | Type | Default | Required |
---|---|---|---|---|
api_key_requireds | Specify if the method requires an API key. | list(any) |
[] |
no |
api_key_source | The source of the API key for requests. Valid values are HEADER (default) and AUTHORIZER. | string |
"HEADER" |
no |
api_log_enabled | Whether to enable log for rest api. | bool |
false |
no |
api_policy | The policy document. | any |
null |
no |
attributes | Additional attributes (e.g. 1 ). |
list(any) |
[] |
no |
authorization_scopes | The authorization scopes used when the authorization is COGNITO_USER_POOLS. | list(any) |
[] |
no |
authorizations | The type of authorization used for the method (NONE, CUSTOM, AWS_IAM, COGNITO_USER_POOLS). | list(any) |
[] |
no |
authorizer_count | Number of count to create Authorizers for api. | number |
0 |
no |
authorizer_credentials | The credentials required for the authorizer. To specify an IAM Role for API Gateway to assume, use the IAM Role ARN. | list(any) |
[] |
no |
authorizer_ids | The authorizer id to be used when the authorization is CUSTOM or COGNITO_USER_POOLS. | list(any) |
[] |
no |
authorizer_names | The name of the authorizer. | list(any) |
[] |
no |
authorizer_result_ttl_in_seconds | The TTL of cached authorizer results in seconds. Defaults to 300. | list(any) |
[] |
no |
authorizer_types | The type of the authorizer. Possible values are TOKEN for a Lambda function using a single authorization token submitted in a custom header, REQUEST for a Lambda function using incoming request parameters, or COGNITO_USER_POOLS for using an Amazon Cognito user pool. Defaults to TOKEN. | list(any) |
[] |
no |
authorizer_uri | The authorizer's Uniform Resource Identifier (URI). This must be a well-formed Lambda function URI in the form of arn:aws:apigateway:{region}:lambda:path/{service_api}, e.g. arn:aws:apigateway:us-west-2:lambda:path/2015-03-31/functions/arn:aws:lambda:us-west-2:012345678912:function:my-function/invocations. | list(any) |
[] |
no |
binary_media_types | The list of binary media types supported by the RestApi. By default, the RestApi supports only UTF-8-encoded text payloads. | list(any) |
[ |
no |
cache_cluster_enableds | Specifies whether a cache cluster is enabled for the stage. | list(any) |
[] |
no |
cache_cluster_sizes | The size of the cache cluster for the stage, if enabled. Allowed values include 0.5, 1.6, 6.1, 13.5, 28.4, 58.2, 118 and 237. | list(any) |
[] |
no |
cache_key_parameters | A list of cache key parameters for the integration. | list(any) |
[] |
no |
cache_namespaces | The integration's cache namespace. | list(any) |
[] |
no |
cert_description | The description of the client certificate. | string |
"" |
no |
cert_enabled | Whether to create client certificate. | bool |
false |
no |
client_certificate_ids | The identifier of a client certificate for the stage | list(any) |
[] |
no |
connection_ids | The id of the VpcLink used for the integration. Required if connection_type is VPC_LINK. | list(any) |
[] |
no |
connection_types | The integration input's connectionType. Valid values are INTERNET (default for connections through the public routable internet), and VPC_LINK (for private connections between API Gateway and a network load balancer in a VPC). | list(any) |
[] |
no |
content_handlings | Specifies how to handle request payload content type conversions. Supported values are CONVERT_TO_BINARY and CONVERT_TO_TEXT. If this property is not defined, the request payload will be passed through from the method request to integration request without modification, provided that the passthroughBehaviors is configured to support payload pass-through. | list(any) |
[] |
no |
content_types | The content type of the model. | list(any) |
[] |
no |
credentials | The credentials required for the integration. For AWS integrations, 2 options are available. To specify an IAM Role for Amazon API Gateway to assume, use the role's ARN. To require that the caller's identity be passed through from the request, specify the string arn:aws:iam::*:user/*. | list(any) |
[] |
no |
deploy_description | The description of the deployment. | string |
"" |
no |
deployment_enabled | Whether to deploy rest api. | bool |
false |
no |
description | The description of the REST API | string |
"" |
no |
descriptions | The description of the stage. | list(any) |
[] |
no |
destination_arns | ARN of the log group to send the logs to. Automatically removes trailing :* if present. | list(any) |
[] |
no |
documentation_versions | The version of the associated API documentation. | list(any) |
[] |
no |
enabled | Whether to create rest api. | bool |
false |
no |
enableds | Specifies whether the API key can be used by callers. Defaults to true. | list(any) |
[] |
no |
environment | Environment (e.g. prod , dev , staging ). |
string |
"https://registry.terraform.io/modules/clouddrove/api-gateway/aws" |
no |
formats | The formatting and values recorded in the logs. | list(any) |
[] |
no |
gateway_response_count | Number of count to create Gateway Response for api. | number |
0 |
no |
gateway_response_parameters | A map specifying the templates used to transform the response body. | list(any) |
[] |
no |
gateway_response_templates | A map specifying the parameters (paths, query strings and headers) of the Gateway Response. | list(any) |
[] |
no |
gateway_status_codes | The HTTP status code of the Gateway Response. | list(any) |
[] |
no |
http_methods | The HTTP Method (GET, POST, PUT, DELETE, HEAD, OPTIONS, ANY). | list(any) |
[] |
no |
identity_sources | The source of the identity in an incoming request. Defaults to method.request.header.Authorization. For REQUEST type, this may be a comma-separated list of values, including headers, query string parameters and stage variables - e.g. "method.request.header.SomeHeaderName,method.request.querystring.SomeQueryStringName". | list(any) |
[] |
no |
identity_validation_expressions | A validation expression for the incoming identity. For TOKEN type, this value should be a regular expression. The incoming token from the client is matched against this expression, and will proceed if the token matches. If the token doesn't match, the client receives a 401 Unauthorized response. | list(any) |
[] |
no |
integration_http_methods | The integration HTTP method (GET, POST, PUT, DELETE, HEAD, OPTIONs, ANY, PATCH) specifying how API Gateway will interact with the back end. Required if type is AWS, AWS_PROXY, HTTP or HTTP_PROXY. Not all methods are compatible with all AWS integrations. e.g. Lambda function can only be invoked via POST. | list(any) |
[] |
no |
integration_request_parameters | A map of request query string parameters and headers that should be passed to the backend responder. For example: request_parameters = { "integration.request.header.X-Some-Other-Header" = "method.request.header.X-Some-Header" }. | list(any) |
[] |
no |
integration_response_parameters | A map of response parameters that can be read from the backend response. For example: response_parameters = { "method.response.header.X-Some-Header" = "integration.response.header.X-Some-Other-Header" }. | list(any) |
[] |
no |
integration_types | The integration input's type. Valid values are HTTP (for HTTP backends), MOCK (not calling any real backend), AWS (for AWS services), AWS_PROXY (for Lambda proxy integration) and HTTP_PROXY (for HTTP proxy integration). An HTTP or HTTP_PROXY integration with a connection_type of VPC_LINK is referred to as a private integration and uses a VpcLink to connect API Gateway to a network load balancer of a VPC. | list(any) |
[] |
no |
key_count | Number of count to create key for api gateway. | number |
0 |
no |
key_descriptions | The API key description. Defaults to "Managed by Terraform". | list(any) |
[] |
no |
key_names | The name of the API key. | list(any) |
[] |
no |
label_order | Label order, e.g. name ,application . |
list(any) |
[] |
no |
managedby | ManagedBy, eg 'CloudDrove'. | string |
"hello@clouddrove.com" |
no |
method_enabled | Whether to create stage for rest api. | bool |
false |
no |
minimum_compression_size | Minimum response size to compress for the REST API. Integer between -1 and 10485760 (10MB). Setting a value greater than -1 will enable compression, -1 disables compression (default). | number |
-1 |
no |
model_count | Number of count to create Model for api. | number |
0 |
no |
model_descriptions | The description of the model. | list(any) |
[] |
no |
model_names | The name of the model. | list(any) |
[] |
no |
model_schemas | The schema of the model in a JSON form. | list |
[] |
no |
name | Name (e.g. app or cluster ). |
string |
"" |
no |
passthrough_behaviors | The integration passthrough behavior (WHEN_NO_MATCH, WHEN_NO_TEMPLATES, NEVER). Required if request_templates is used. | list(any) |
[] |
no |
path_parts | The last path segment of this API resource. | list(any) |
[] |
no |
provider_arns | required for type COGNITO_USER_POOLS) A list of the Amazon Cognito user pool ARNs. Each element is of this format: arn:aws:cognito-idp:{region}:{account_id}:userpool/{user_pool_id}. | list(any) |
[] |
no |
repository | Terraform current module repo | string |
"https://github.com/clouddrove/terraform-aws-api-gateway" |
no |
request_models | A map of the API models used for the request's content type where key is the content type (e.g. application/json) and value is either Error, Empty (built-in models) or aws_api_gateway_model's name. | list(any) |
[] |
no |
request_parameters | A map of request query string parameters and headers that should be passed to the integration. For example: request_parameters = {"method.request.header.X-Some-Header" = true "method.request.querystring.some-query-param" = true} would define that the header X-Some-Header and the query string some-query-param must be provided in the request. | list(any) |
[] |
no |
request_templates | A map of the integration's request templates. | list(any) |
[] |
no |
request_validator_ids | The ID of a aws_api_gateway_request_validator. | list(any) |
[] |
no |
response_content_handlings | Specifies how to handle request payload content type conversions. Supported values are CONVERT_TO_BINARY and CONVERT_TO_TEXT. If this property is not defined, the response payload will be passed through from the integration response to the method response without modification. | list(any) |
[] |
no |
response_models | A map of the API models used for the response's content type. | list(any) |
[] |
no |
response_parameters | A map of response parameters that can be sent to the caller. For example: response_parameters = { "method.response.header.X-Some-Header" = true } would define that the header X-Some-Header can be provided on the response. | list(any) |
[] |
no |
response_templates | A map specifying the templates used to transform the integration response body. | list(any) |
[] |
no |
response_types | The response type of the associated GatewayResponse. | list(any) |
[] |
no |
schemas | The schema of the model in a JSON form. | list(any) |
[] |
no |
stage_description | The description of the stage. | string |
"" |
no |
stage_enabled | Whether to create stage for rest api. | bool |
false |
no |
stage_name | The name of the stage. If the specified stage already exists, it will be updated to point to the new deployment. If the stage does not exist, a new one will be created and point to this deployment. | string |
"" |
no |
stage_names | The name of the stage. | list(any) |
[] |
no |
stage_variables | A map that defines the stage variables. | list(any) |
[] |
no |
status_codes | The HTTP status code. | list(any) |
[] |
no |
tags | Additional tags (e.g. map(BusinessUnit ,XYZ ). |
map(any) |
{} |
no |
target_arns | The list of network load balancer arns in the VPC targeted by the VPC link. Currently AWS only supports 1 target. | list(any) |
[] |
no |
timeout_milliseconds | Custom timeout between 50 and 29,000 milliseconds. The default value is 29,000 milliseconds. | list(any) |
[] |
no |
types | Whether to create rest api. | list(any) |
[ |
no |
uri | The input's URI. Required if type is AWS, AWS_PROXY, HTTP or HTTP_PROXY. For HTTP integrations, the URI must be a fully formed, encoded HTTP(S) URL according to the RFC-3986 specification . For AWS integrations, the URI should be of the form arn:aws:apigateway:{region}:{subdomain.service|service}:{path|action}/{service_api}. region, subdomain and service are used to determine the right endpoint. e.g. arn:aws:apigateway:eu-west-1:lambda:path/2015-03-31/functions/arn:aws:lambda:eu-west-1:012345678901:function:my-func/invocations. | list(any) |
[] |
no |
values | The value of the API key. If not specified, it will be automatically generated by AWS on creation. | list(any) |
[] |
no |
variables | A map that defines variables for the stage. | map(any) |
{} |
no |
vpc_endpoint_ids | Set of VPC Endpoint identifiers. It is only supported for PRIVATE endpoint type. | list(string) |
[ |
no |
vpc_link_count | Number of count to create VPC Link for api. | number |
0 |
no |
vpc_link_descriptions | The description of the VPC link. | list(any) |
[] |
no |
vpc_link_names | The name used to label and identify the VPC link. | list(any) |
[] |
no |
xray_tracing_enabled | A mapping of tags to assign to the resource. | list(any) |
[] |
no |
Name | Description |
---|---|
execution_arn | The Execution ARN of the REST API. |
id | The ID of the REST API. |
tags | A mapping of tags to assign to the resource. |
In this module testing is performed with terratest and it creates a small piece of infrastructure, matches the output like ARN, ID and Tags name etc and destroy infrastructure in your AWS account. This testing is written in GO, so you need a GO environment in your system.
You need to run the following command in the testing folder:
go test -run Test
If you come accross a bug or have any feedback, please log it in our issue tracker, or feel free to drop us an email at hello@clouddrove.com.
If you have found it worth your time, go ahead and give us a ★ on our GitHub!
At CloudDrove, we offer expert guidance, implementation support and services to help organisations accelerate their journey to the cloud. Our services include docker and container orchestration, cloud migration and adoption, infrastructure automation, application modernisation and remediation, and performance engineering.
We are The Cloud Experts!
We ❤️ Open Source and you can check out our other modules to get help with your new Cloud ideas.