mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
Fix backwards compatibility without providing prefix since boto3 does more parameter validation than boto (#45308)
Use .get() instead of assuming a rule has a Transitions or Filter key (both of which are optional)
This commit is contained in:
parent
71c4355d58
commit
8b341619ae
2 changed files with 7 additions and 6 deletions
|
@ -207,7 +207,7 @@ def create_lifecycle_rule(client, module):
|
||||||
noncurrent_version_transition_days = module.params.get("noncurrent_version_transition_days")
|
noncurrent_version_transition_days = module.params.get("noncurrent_version_transition_days")
|
||||||
noncurrent_version_transitions = module.params.get("noncurrent_version_transitions")
|
noncurrent_version_transitions = module.params.get("noncurrent_version_transitions")
|
||||||
noncurrent_version_storage_class = module.params.get("noncurrent_version_storage_class")
|
noncurrent_version_storage_class = module.params.get("noncurrent_version_storage_class")
|
||||||
prefix = module.params.get("prefix")
|
prefix = module.params.get("prefix") or ""
|
||||||
rule_id = module.params.get("rule_id")
|
rule_id = module.params.get("rule_id")
|
||||||
status = module.params.get("status")
|
status = module.params.get("status")
|
||||||
storage_class = module.params.get("storage_class")
|
storage_class = module.params.get("storage_class")
|
||||||
|
@ -280,7 +280,9 @@ def create_lifecycle_rule(client, module):
|
||||||
if current_lifecycle_rules:
|
if current_lifecycle_rules:
|
||||||
# If rule ID exists, use that for comparison otherwise compare based on prefix
|
# If rule ID exists, use that for comparison otherwise compare based on prefix
|
||||||
for existing_rule in current_lifecycle_rules:
|
for existing_rule in current_lifecycle_rules:
|
||||||
if rule['Filter']['Prefix'] == existing_rule['Filter']['Prefix']:
|
if rule.get('ID') == existing_rule.get('ID') and rule['Filter']['Prefix'] != existing_rule.get('Filter', {}).get('Prefix', ''):
|
||||||
|
existing_rule.pop('ID')
|
||||||
|
elif rule_id is None and rule['Filter']['Prefix'] == existing_rule.get('Filter', {}).get('Prefix', ''):
|
||||||
existing_rule.pop('ID')
|
existing_rule.pop('ID')
|
||||||
if rule.get('ID') == existing_rule.get('ID'):
|
if rule.get('ID') == existing_rule.get('ID'):
|
||||||
changed_, appended_ = update_or_append_rule(rule, existing_rule, purge_transitions, lifecycle_configuration)
|
changed_, appended_ = update_or_append_rule(rule, existing_rule, purge_transitions, lifecycle_configuration)
|
||||||
|
@ -361,9 +363,9 @@ def merge_transitions(updated_rule, updating_rule):
|
||||||
# in updating_rule to updated_rule
|
# in updating_rule to updated_rule
|
||||||
updated_transitions = {}
|
updated_transitions = {}
|
||||||
updating_transitions = {}
|
updating_transitions = {}
|
||||||
for transition in updated_rule['Transitions']:
|
for transition in updated_rule.get('Transitions', []):
|
||||||
updated_transitions[transition['StorageClass']] = transition
|
updated_transitions[transition['StorageClass']] = transition
|
||||||
for transition in updating_rule['Transitions']:
|
for transition in updating_rule.get('Transitions', []):
|
||||||
updating_transitions[transition['StorageClass']] = transition
|
updating_transitions[transition['StorageClass']] = transition
|
||||||
for storage_class, transition in updating_transitions.items():
|
for storage_class, transition in updating_transitions.items():
|
||||||
if updated_transitions.get(storage_class) is None:
|
if updated_transitions.get(storage_class) is None:
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
s3_lifecycle:
|
s3_lifecycle:
|
||||||
name: "{{ resource_prefix }}-testbucket-ansible"
|
name: "{{ resource_prefix }}-testbucket-ansible"
|
||||||
expiration_days: 300
|
expiration_days: 300
|
||||||
prefix: /pre
|
prefix: ''
|
||||||
<<: *aws_connection_info
|
<<: *aws_connection_info
|
||||||
register: output
|
register: output
|
||||||
|
|
||||||
|
@ -42,7 +42,6 @@
|
||||||
s3_lifecycle:
|
s3_lifecycle:
|
||||||
name: "{{ resource_prefix }}-testbucket-ansible"
|
name: "{{ resource_prefix }}-testbucket-ansible"
|
||||||
expiration_days: 300
|
expiration_days: 300
|
||||||
prefix: /pre
|
|
||||||
<<: *aws_connection_info
|
<<: *aws_connection_info
|
||||||
register: output
|
register: output
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue