Network ACL Inbound Terraform Module
This Terraform Module launches is a simple helper for adding inbound rules to a Network ACL. Network ACLs can be a bit tricky to work with because they are stateless, which means that opening an inbound port is often not enough; you also need to open ephemeral outbound ports which your services use to respond. This can be very easy to forget, so this module adds not only the inbound ports to an ACL, but also the ephemeral outbound ports for return traffic.
See the network-acl-outbound module for the analogous version of this module, but for opening outbound ports.
What's a Network ACL?
Network ACLs provide an extra layer of network security, similar to a security group. Whereas a security group controls what inbound and outbound traffic is allowed for a specific resource (e.g. a single EC2 instance), a network ACL controls what inbound and outbound traffic is allowed for an entire subnet.
Sample Usage
- Terraform
- Terragrunt
# ------------------------------------------------------------------------------------------------------
# DEPLOY GRUNTWORK'S NETWORK-ACL-INBOUND MODULE
# ------------------------------------------------------------------------------------------------------
module "network_acl_inbound" {
source = "git::git@github.com:gruntwork-io/terraform-aws-vpc.git//modules/network-acl-inbound?ref=v0.26.24"
# ----------------------------------------------------------------------------------------------------
# REQUIRED VARIABLES
# ----------------------------------------------------------------------------------------------------
# The number to use for the egress rule that will be added. Each egress rule
# in a network ACL must have a unique rule number.
egress_rule_number = <number>
# A list of CIDR blocks from which inbound connections should be allowed to
# var.inbound_ports
inbound_cidr_blocks = <list(string)>
# Allow all inbound traffic on ports between var.inbound_from_port and
# var.inbound_to_port, inclusive
inbound_from_port = <number>
# Allow all inbound traffic on ports between var.inbound_from_port and
# var.inbound_to_port, inclusive
inbound_to_port = <number>
# The starting number to use for ingress rules that are added. Each ingress
# rule in a network ACL must have a unique rule number.
ingress_rule_number = <number>
# The id of the network ACL to which the new rules should be attached
network_acl_id = <string>
# The number of CIDR blocks in var.inbound_cidr_blocks. We should be able to
# compute this automatically, but due to a Terraform limitation, we can't:
# https://github.com/hashicorp/terraform/issues/14677#issuecomment-302772685
num_inbound_cidr_blocks = <number>
# The protocol (e.g. TCP). If you set this value to -1 or 'all', any protocol
# and any port is allowed (so the from_port and to_port settings are
# ignored!).
protocol = <string>
# ----------------------------------------------------------------------------------------------------
# OPTIONAL VARIABLES
# ----------------------------------------------------------------------------------------------------
# If you set this variable to false, this module will not create any
# resources. This is used as a workaround because Terraform does not allow you
# to use the 'count' parameter on modules. By using this parameter, you can
# optionally create or not create the resources within this module.
create_resources = true
# Return traffic will be allowed on all ports between var.ephemeral_from_port
# and var.ephemeral_to_port, inclusive, from var.inbound_cidr_blocks
ephemeral_from_port = 1024
# Return traffic will be allowed on all ports between var.ephemeral_from_port
# and var.ephemeral_to_port, inclusive, from var.inbound_cidr_blocks
ephemeral_to_port = 65535
# The list of ports to exclude from the inbound rules. This is useful for
# adhering to certain compliance standards like CIS that explicitly deny any
# allow rule for administrative ports. This can not be set if protocol is
# icmp.
exclude_ports = []
# The ICMP code. Required if specifying ICMP for the protocol. Note: If the
# value of icmp_type is -1 , the icmp_code must also be set to -1 (wildcard
# ICMP code).
icmp_code = null
# The ICMP type. Required if specifying icmp for the protocol. When type set
# to -1 this results in a wildcard ICMP type
icmp_type = null
}
# ------------------------------------------------------------------------------------------------------
# DEPLOY GRUNTWORK'S NETWORK-ACL-INBOUND MODULE
# ------------------------------------------------------------------------------------------------------
terraform {
source = "git::git@github.com:gruntwork-io/terraform-aws-vpc.git//modules/network-acl-inbound?ref=v0.26.24"
}
inputs = {
# ----------------------------------------------------------------------------------------------------
# REQUIRED VARIABLES
# ----------------------------------------------------------------------------------------------------
# The number to use for the egress rule that will be added. Each egress rule
# in a network ACL must have a unique rule number.
egress_rule_number = <number>
# A list of CIDR blocks from which inbound connections should be allowed to
# var.inbound_ports
inbound_cidr_blocks = <list(string)>
# Allow all inbound traffic on ports between var.inbound_from_port and
# var.inbound_to_port, inclusive
inbound_from_port = <number>
# Allow all inbound traffic on ports between var.inbound_from_port and
# var.inbound_to_port, inclusive
inbound_to_port = <number>
# The starting number to use for ingress rules that are added. Each ingress
# rule in a network ACL must have a unique rule number.
ingress_rule_number = <number>
# The id of the network ACL to which the new rules should be attached
network_acl_id = <string>
# The number of CIDR blocks in var.inbound_cidr_blocks. We should be able to
# compute this automatically, but due to a Terraform limitation, we can't:
# https://github.com/hashicorp/terraform/issues/14677#issuecomment-302772685
num_inbound_cidr_blocks = <number>
# The protocol (e.g. TCP). If you set this value to -1 or 'all', any protocol
# and any port is allowed (so the from_port and to_port settings are
# ignored!).
protocol = <string>
# ----------------------------------------------------------------------------------------------------
# OPTIONAL VARIABLES
# ----------------------------------------------------------------------------------------------------
# If you set this variable to false, this module will not create any
# resources. This is used as a workaround because Terraform does not allow you
# to use the 'count' parameter on modules. By using this parameter, you can
# optionally create or not create the resources within this module.
create_resources = true
# Return traffic will be allowed on all ports between var.ephemeral_from_port
# and var.ephemeral_to_port, inclusive, from var.inbound_cidr_blocks
ephemeral_from_port = 1024
# Return traffic will be allowed on all ports between var.ephemeral_from_port
# and var.ephemeral_to_port, inclusive, from var.inbound_cidr_blocks
ephemeral_to_port = 65535
# The list of ports to exclude from the inbound rules. This is useful for
# adhering to certain compliance standards like CIS that explicitly deny any
# allow rule for administrative ports. This can not be set if protocol is
# icmp.
exclude_ports = []
# The ICMP code. Required if specifying ICMP for the protocol. Note: If the
# value of icmp_type is -1 , the icmp_code must also be set to -1 (wildcard
# ICMP code).
icmp_code = null
# The ICMP type. Required if specifying icmp for the protocol. When type set
# to -1 this results in a wildcard ICMP type
icmp_type = null
}