mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-07-19 19:30:22 -07:00
Aws waf region (#48953)
* Add waiter for AWSRegional * Add support for WAF Regional * Add support for regional waf web acl * Remove set_trace, pep formatting * Add paginator for regional_waf * Change name of param for waf_regional This is more in line with how AWS refers to the service. Additional changes made to how client is called. Used ternary to reduce if statements * Change parameter name to waf_regional * Add support for removal waf regional condition * Change parameter from cloudfront to waf_regional * Added state: absent waf rule * Remove set_trace * Add integration tests for waf regional * WIP: adding region parameter to tests * Add support for waf facts module * Add region to waf regional integration tests * Update security policy for waf regional testing * Add type to documentation for waf_regional param
This commit is contained in:
parent
32620b7e00
commit
c8e179fbf1
8 changed files with 758 additions and 28 deletions
|
@ -47,8 +47,14 @@ options:
|
|||
purge_conditions:
|
||||
description:
|
||||
- Whether or not to remove conditions that are not passed when updating `conditions`.
|
||||
default: False
|
||||
default: false
|
||||
type: bool
|
||||
waf_regional:
|
||||
description: Whether to use waf_regional module. Defaults to false
|
||||
default: false
|
||||
required: no
|
||||
type: bool
|
||||
version_added: "2.9"
|
||||
'''
|
||||
|
||||
EXAMPLES = '''
|
||||
|
@ -127,8 +133,8 @@ except ImportError:
|
|||
from ansible.module_utils.aws.core import AnsibleAWSModule
|
||||
from ansible.module_utils.ec2 import boto3_conn, get_aws_connection_info, ec2_argument_spec
|
||||
from ansible.module_utils.ec2 import camel_dict_to_snake_dict
|
||||
from ansible.module_utils.aws.waf import run_func_with_change_token_backoff, list_rules_with_backoff, MATCH_LOOKUP
|
||||
from ansible.module_utils.aws.waf import get_web_acl_with_backoff, list_web_acls_with_backoff
|
||||
from ansible.module_utils.aws.waf import run_func_with_change_token_backoff, list_rules_with_backoff, list_regional_rules_with_backoff, MATCH_LOOKUP
|
||||
from ansible.module_utils.aws.waf import get_web_acl_with_backoff, list_web_acls_with_backoff, list_regional_web_acls_with_backoff
|
||||
|
||||
|
||||
def get_rule_by_name(client, module, name):
|
||||
|
@ -145,8 +151,21 @@ def get_rule(client, module, rule_id):
|
|||
|
||||
|
||||
def list_rules(client, module):
|
||||
if client.__class__.__name__ == 'WAF':
|
||||
try:
|
||||
return list_rules_with_backoff(client)
|
||||
except (botocore.exceptions.ClientError, botocore.exceptions.BotoCoreError) as e:
|
||||
module.fail_json_aws(e, msg='Could not list WAF rules')
|
||||
elif client.__class__.__name__ == 'WAFRegional':
|
||||
try:
|
||||
return list_regional_rules_with_backoff(client)
|
||||
except (botocore.exceptions.ClientError, botocore.exceptions.BotoCoreError) as e:
|
||||
module.fail_json_aws(e, msg='Could not list WAF Regional rules')
|
||||
|
||||
|
||||
def list_regional_rules(client, module):
|
||||
try:
|
||||
return list_rules_with_backoff(client)
|
||||
return list_regional_rules_with_backoff(client)
|
||||
except (botocore.exceptions.ClientError, botocore.exceptions.BotoCoreError) as e:
|
||||
module.fail_json_aws(e, msg='Could not list WAF rules')
|
||||
|
||||
|
@ -260,7 +279,10 @@ def ensure_rule_present(client, module):
|
|||
def find_rule_in_web_acls(client, module, rule_id):
|
||||
web_acls_in_use = []
|
||||
try:
|
||||
all_web_acls = list_web_acls_with_backoff(client)
|
||||
if client.__class__.__name__ == 'WAF':
|
||||
all_web_acls = list_web_acls_with_backoff(client)
|
||||
elif client.__class__.__name__ == 'WAFRegional':
|
||||
all_web_acls = list_regional_web_acls_with_backoff(client)
|
||||
except (botocore.exceptions.ClientError, botocore.exceptions.BotoCoreError) as e:
|
||||
module.fail_json_aws(e, msg='Could not list Web ACLs')
|
||||
for web_acl in all_web_acls:
|
||||
|
@ -297,15 +319,16 @@ def main():
|
|||
metric_name=dict(),
|
||||
state=dict(default='present', choices=['present', 'absent']),
|
||||
conditions=dict(type='list'),
|
||||
purge_conditions=dict(type='bool', default=False)
|
||||
purge_conditions=dict(type='bool', default=False),
|
||||
waf_regional=dict(type='bool', default=False),
|
||||
),
|
||||
)
|
||||
module = AnsibleAWSModule(argument_spec=argument_spec)
|
||||
state = module.params.get('state')
|
||||
|
||||
region, ec2_url, aws_connect_kwargs = get_aws_connection_info(module, boto3=True)
|
||||
client = boto3_conn(module, conn_type='client', resource='waf', region=region, endpoint=ec2_url, **aws_connect_kwargs)
|
||||
|
||||
resource = 'waf' if not module.params['waf_regional'] else 'waf-regional'
|
||||
client = boto3_conn(module, conn_type='client', resource=resource, region=region, endpoint=ec2_url, **aws_connect_kwargs)
|
||||
if state == 'present':
|
||||
(changed, results) = ensure_rule_present(client, module)
|
||||
else:
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue