PutPolicy
Creates an AWS Firewall Manager policy.
A Firewall Manager policy is specific to the individual policy type. If you want to enforce multiple policy types across accounts, you can create multiple policies. You can create more than one policy for each type.
If you add a new account to an organization that you created with AWS Organizations, Firewall Manager automatically applies the policy to the resources in that account that are within scope of the policy.
Firewall Manager provides the following types of policies:
-
AWS WAF policy - This policy applies AWS WAF web ACL protections to specified accounts and resources.
-
Shield Advanced policy - This policy applies Shield Advanced protection to specified accounts and resources.
-
Security Groups policy - This type of policy gives you control over security groups that are in use throughout your organization in AWS Organizations and lets you enforce a baseline set of rules across your organization.
-
Network ACL policy - This type of policy gives you control over the network ACLs that are in use throughout your organization in AWS Organizations and lets you enforce a baseline set of first and last network ACL rules across your organization.
-
Network Firewall policy - This policy applies Network Firewall protection to your organization's VPCs.
-
DNS Firewall policy - This policy applies Amazon Route 53 Resolver DNS Firewall protections to your organization's VPCs.
-
Third-party firewall policy - This policy applies third-party firewall protections. Third-party firewalls are available by subscription through the AWS Marketplace console at AWS Marketplace
. -
Palo Alto Networks Cloud NGFW policy - This policy applies Palo Alto Networks Cloud Next Generation Firewall (NGFW) protections and Palo Alto Networks Cloud NGFW rulestacks to your organization's VPCs.
-
Fortigate CNF policy - This policy applies Fortigate Cloud Native Firewall (CNF) protections. Fortigate CNF is a cloud-centered solution that blocks Zero-Day threats and secures cloud infrastructures with industry-leading advanced threat prevention, smart web application firewalls (WAF), and API protection.
-
Request Syntax
{
"Policy": {
"DeleteUnusedFMManagedResources": boolean
,
"ExcludeMap": {
"string
" : [ "string
" ]
},
"ExcludeResourceTags": boolean
,
"IncludeMap": {
"string
" : [ "string
" ]
},
"PolicyDescription": "string
",
"PolicyId": "string
",
"PolicyName": "string
",
"PolicyStatus": "string
",
"PolicyUpdateToken": "string
",
"RemediationEnabled": boolean
,
"ResourceSetIds": [ "string
" ],
"ResourceTagLogicalOperator": "string
",
"ResourceTags": [
{
"Key": "string
",
"Value": "string
"
}
],
"ResourceType": "string
",
"ResourceTypeList": [ "string
" ],
"SecurityServicePolicyData": {
"ManagedServiceData": "string
",
"PolicyOption": {
"NetworkAclCommonPolicy": {
"NetworkAclEntrySet": {
"FirstEntries": [
{
"CidrBlock": "string
",
"Egress": boolean
,
"IcmpTypeCode": {
"Code": number
,
"Type": number
},
"Ipv6CidrBlock": "string
",
"PortRange": {
"From": number
,
"To": number
},
"Protocol": "string
",
"RuleAction": "string
"
}
],
"ForceRemediateForFirstEntries": boolean
,
"ForceRemediateForLastEntries": boolean
,
"LastEntries": [
{
"CidrBlock": "string
",
"Egress": boolean
,
"IcmpTypeCode": {
"Code": number
,
"Type": number
},
"Ipv6CidrBlock": "string
",
"PortRange": {
"From": number
,
"To": number
},
"Protocol": "string
",
"RuleAction": "string
"
}
]
}
},
"NetworkFirewallPolicy": {
"FirewallDeploymentModel": "string
"
},
"ThirdPartyFirewallPolicy": {
"FirewallDeploymentModel": "string
"
}
},
"Type": "string
"
}
},
"TagList": [
{
"Key": "string
",
"Value": "string
"
}
]
}
Request Parameters
For information about the parameters that are common to all actions, see Common Parameters.
The request accepts the following data in JSON format.
Response Syntax
{
"Policy": {
"DeleteUnusedFMManagedResources": boolean,
"ExcludeMap": {
"string" : [ "string" ]
},
"ExcludeResourceTags": boolean,
"IncludeMap": {
"string" : [ "string" ]
},
"PolicyDescription": "string",
"PolicyId": "string",
"PolicyName": "string",
"PolicyStatus": "string",
"PolicyUpdateToken": "string",
"RemediationEnabled": boolean,
"ResourceSetIds": [ "string" ],
"ResourceTagLogicalOperator": "string",
"ResourceTags": [
{
"Key": "string",
"Value": "string"
}
],
"ResourceType": "string",
"ResourceTypeList": [ "string" ],
"SecurityServicePolicyData": {
"ManagedServiceData": "string",
"PolicyOption": {
"NetworkAclCommonPolicy": {
"NetworkAclEntrySet": {
"FirstEntries": [
{
"CidrBlock": "string",
"Egress": boolean,
"IcmpTypeCode": {
"Code": number,
"Type": number
},
"Ipv6CidrBlock": "string",
"PortRange": {
"From": number,
"To": number
},
"Protocol": "string",
"RuleAction": "string"
}
],
"ForceRemediateForFirstEntries": boolean,
"ForceRemediateForLastEntries": boolean,
"LastEntries": [
{
"CidrBlock": "string",
"Egress": boolean,
"IcmpTypeCode": {
"Code": number,
"Type": number
},
"Ipv6CidrBlock": "string",
"PortRange": {
"From": number,
"To": number
},
"Protocol": "string",
"RuleAction": "string"
}
]
}
},
"NetworkFirewallPolicy": {
"FirewallDeploymentModel": "string"
},
"ThirdPartyFirewallPolicy": {
"FirewallDeploymentModel": "string"
}
},
"Type": "string"
}
},
"PolicyArn": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
The following data is returned in JSON format by the service.
Errors
For information about the errors that are common to all actions, see Common Errors.
- InternalErrorException
-
The operation failed because of a system problem, even though the request was valid. Retry your request.
HTTP Status Code: 400
- InvalidInputException
-
The parameters of the request were invalid.
HTTP Status Code: 400
- InvalidOperationException
-
The operation failed because there was nothing to do or the operation wasn't possible. For example, you might have submitted an
AssociateAdminAccount
request for an account ID that was already set as the AWS Firewall Manager administrator. Or you might have tried to access a Region that's disabled by default, and that you need to enable for the Firewall Manager administrator account and for AWS Organizations before you can access it.HTTP Status Code: 400
- InvalidTypeException
-
The value of the
Type
parameter is invalid.HTTP Status Code: 400
- LimitExceededException
-
The operation exceeds a resource limit, for example, the maximum number of
policy
objects that you can create for an AWS account. For more information, see Firewall Manager Limits in the AWS WAF Developer Guide.HTTP Status Code: 400
- ResourceNotFoundException
-
The specified resource was not found.
HTTP Status Code: 400
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following: