Firewall
A firewall defines the behavior of a firewall, the main VPC where the firewall is used, the Availability Zones where the firewall can be used, and one subnet to use for a firewall endpoint within each of the Availability Zones. The Availability Zones are defined implicitly in the subnet specifications.
In addition to the firewall endpoints that you define in this Firewall specification, you can create firewall endpoints in VpcEndpointAssociation resources for any VPC, in any Availability Zone where the firewall is already in use. 
The status of the firewall, for example whether it's ready to filter network traffic, is provided in the corresponding FirewallStatus. You can retrieve both the firewall and firewall status by calling DescribeFirewall.
Contents
- FirewallId
- 
               The unique identifier for the firewall. Type: String Length Constraints: Fixed length of 36. Pattern: ^([0-9a-f]{8})-([0-9a-f]{4}-){3}([0-9a-f]{12})$Required: Yes 
- FirewallPolicyArn
- 
               The Amazon Resource Name (ARN) of the firewall policy. The relationship of firewall to firewall policy is many to one. Each firewall requires one firewall policy association, and you can use the same firewall policy for multiple firewalls. Type: String Length Constraints: Minimum length of 1. Maximum length of 256. Pattern: ^arn:aws.*Required: Yes 
- SubnetMappings
- 
               The primary public subnets that Network Firewall is using for the firewall. Network Firewall creates a firewall endpoint in each subnet. Create a subnet mapping for each Availability Zone where you want to use the firewall. These subnets are all defined for a single, primary VPC, and each must belong to a different Availability Zone. Each of these subnets establishes the availability of the firewall in its Availability Zone. In addition to these subnets, you can define other endpoints for the firewall in VpcEndpointAssociationresources. You can define these additional endpoints for any VPC, and for any of the Availability Zones where the firewall resource already has a subnet mapping. VPC endpoint associations give you the ability to protect multiple VPCs using a single firewall, and to define multiple firewall endpoints for a VPC in a single Availability Zone.Type: Array of SubnetMapping objects Required: Yes 
- VpcId
- 
               The unique identifier of the VPC where the firewall is in use. Type: String Length Constraints: Minimum length of 1. Maximum length of 128. Pattern: ^vpc-[0-9a-f]+$Required: Yes 
- AvailabilityZoneChangeProtection
- 
               A setting indicating whether the firewall is protected against changes to its Availability Zone configuration. When set to TRUE, you must first disable this protection before adding or removing Availability Zones.Type: Boolean Required: No 
- AvailabilityZoneMappings
- 
               The Availability Zones where the firewall endpoints are created for a transit gateway-attached firewall. Each mapping specifies an Availability Zone where the firewall processes traffic. Type: Array of AvailabilityZoneMapping objects Required: No 
- DeleteProtection
- 
               A flag indicating whether it is possible to delete the firewall. A setting of TRUEindicates that the firewall is protected against deletion. Use this setting to protect against accidentally deleting a firewall that is in use. When you create a firewall, the operation initializes this flag toTRUE.Type: Boolean Required: No 
- Description
- 
               A description of the firewall. Type: String Length Constraints: Maximum length of 512. Pattern: ^.*$Required: No 
- EnabledAnalysisTypes
- 
               An optional setting indicating the specific traffic analysis types to enable on the firewall. Type: Array of strings Valid Values: TLS_SNI | HTTP_HOSTRequired: No 
- EncryptionConfiguration
- 
               A complex type that contains the AWS KMS encryption configuration settings for your firewall. Type: EncryptionConfiguration object Required: No 
- FirewallArn
- 
               The Amazon Resource Name (ARN) of the firewall. Type: String Length Constraints: Minimum length of 1. Maximum length of 256. Pattern: ^arn:aws.*Required: No 
- FirewallName
- 
               The descriptive name of the firewall. You can't change the name of a firewall after you create it. Type: String Length Constraints: Minimum length of 1. Maximum length of 128. Pattern: ^[a-zA-Z0-9-]+$Required: No 
- FirewallPolicyChangeProtection
- 
               A setting indicating whether the firewall is protected against a change to the firewall policy association. Use this setting to protect against accidentally modifying the firewall policy for a firewall that is in use. When you create a firewall, the operation initializes this setting to TRUE.Type: Boolean Required: No 
- NumberOfAssociations
- 
               The number of VpcEndpointAssociationresources that use this firewall.Type: Integer Required: No 
- SubnetChangeProtection
- 
               A setting indicating whether the firewall is protected against changes to the subnet associations. Use this setting to protect against accidentally modifying the subnet associations for a firewall that is in use. When you create a firewall, the operation initializes this setting to TRUE.Type: Boolean Required: No 
- Tags
- 
               
               Type: Array of Tag objects Array Members: Minimum number of 1 item. Maximum number of 200 items. Required: No 
- TransitGatewayId
- 
               The unique identifier of the transit gateway associated with this firewall. This field is only present for transit gateway-attached firewalls. Type: String Length Constraints: Minimum length of 1. Maximum length of 128. Pattern: ^tgw-[0-9a-z]+$Required: No 
- TransitGatewayOwnerAccountId
- 
               The AWS account ID that owns the transit gateway. This may be different from the firewall owner's account ID when using a shared transit gateway. Type: String Length Constraints: Fixed length of 12. Pattern: ^\d{12}$Required: No 
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following: