Skip to content

Commit

Permalink
s3_bucket_info - add support for bucket versioning in bucket_facts
Browse files Browse the repository at this point in the history
  • Loading branch information
abikouo committed Dec 11, 2023
1 parent c0e2ab6 commit 2a1d771
Show file tree
Hide file tree
Showing 4 changed files with 42 additions and 18 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
---
minor_changes:
- s3_bucket_info - add parameter ``bucket_versioning`` to return the versioning state of a bucket ().
52 changes: 34 additions & 18 deletions plugins/modules/s3_bucket_info.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,70 +36,77 @@
- You can limit buckets by using the I(name) or I(name_filter) option.
suboptions:
bucket_accelerate_configuration:
description: Retrive S3 accelerate configuration.
description: Retrieve S3 accelerate configuration.
type: bool
default: False
bucket_location:
description: Retrive S3 bucket location.
description: Retrieve S3 bucket location.
type: bool
default: False
bucket_replication:
description: Retrive S3 bucket replication.
description: Retrieve S3 bucket replication.
type: bool
default: False
bucket_acl:
description: Retrive S3 bucket ACLs.
description: Retrieve S3 bucket ACLs.
type: bool
default: False
bucket_logging:
description: Retrive S3 bucket logging.
description: Retrieve S3 bucket logging.
type: bool
default: False
bucket_request_payment:
description: Retrive S3 bucket request payment.
description: Retrieve S3 bucket request payment.
type: bool
default: False
bucket_tagging:
description: Retrive S3 bucket tagging.
description: Retrieve S3 bucket tagging.
type: bool
default: False
bucket_cors:
description: Retrive S3 bucket CORS configuration.
description: Retrieve S3 bucket CORS configuration.
type: bool
default: False
bucket_notification_configuration:
description: Retrive S3 bucket notification configuration.
description: Retrieve S3 bucket notification configuration.
type: bool
default: False
bucket_encryption:
description: Retrive S3 bucket encryption.
description: Retrieve S3 bucket encryption.
type: bool
default: False
bucket_ownership_controls:
description:
- Retrive S3 ownership controls.
- Retrieve S3 ownership controls.
type: bool
default: False
bucket_website:
description: Retrive S3 bucket website.
description: Retrieve S3 bucket website.
type: bool
default: False
bucket_policy:
description: Retrive S3 bucket policy.
description: Retrieve S3 bucket policy.
type: bool
default: False
bucket_policy_status:
description: Retrive S3 bucket policy status.
description: Retrieve S3 bucket policy status.
type: bool
default: False
bucket_lifecycle_configuration:
description: Retrive S3 bucket lifecycle configuration.
description: Retrieve S3 bucket lifecycle configuration.
type: bool
default: False
public_access_block:
description: Retrive S3 bucket public access block.
description: Retrieve S3 bucket public access block.
type: bool
default: False
bucket_versioning:
description:
- Retrieve the versioning state of a bucket.
- To retrieve the versioning state of a bucket, you must be the bucket owner.
type: bool
default: False
version_added: 7.1.0
type: dict
version_added: 1.4.0
transform_location:
Expand Down Expand Up @@ -396,6 +403,14 @@
returned: always
type: str
sample: https
bucket_versioning:
description:
- The versioning state of the bucket.
- This will also specifies whether MFA delete is enabled in the bucket versioning configuration.
if only the bucket has been configured with MFA delete.
returned: when I(bucket_facts=true) and I(bucket_versioning=true)
type: dict
sample: { 'Status': 'Enabled' }
"""

try:
Expand Down Expand Up @@ -448,10 +463,10 @@ def get_bucket_list(module, connection, name="", name_filter=""):

def get_buckets_facts(connection, buckets, requested_facts, transform_location):
"""
Retrive additional information about S3 buckets
Retrieve additional information about S3 buckets
"""
full_bucket_list = []
# Iterate over all buckets and append retrived facts to bucket
# Iterate over all buckets and append Retrieved facts to bucket
for bucket in buckets:
bucket.update(get_bucket_details(connection, bucket["name"], requested_facts, transform_location))
full_bucket_list.append(bucket)
Expand Down Expand Up @@ -568,6 +583,7 @@ def main():
bucket_tagging=dict(type="bool", default=False),
bucket_website=dict(type="bool", default=False),
public_access_block=dict(type="bool", default=False),
bucket_versioning=dict(type="bool", default=False),
),
),
transform_location=dict(type="bool", default=False),
Expand Down
4 changes: 4 additions & 0 deletions tests/integration/targets/s3_bucket_info/tasks/basic.yml
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
bucket_tagging: true
bucket_website: true
public_access_block: true
bucket_versioning: true
transform_location: true
register: bucket_list
- name: Assert that buckets list contains requested bucket facts
Expand All @@ -48,6 +49,7 @@
- item.bucket_tagging is defined
- item.bucket_website is defined
- item.public_access_block is defined
- item.bucket_versioning is defined
loop: "{{ bucket_list.buckets }}"
loop_control:
label: "{{ item.name }}"
Expand All @@ -64,6 +66,8 @@
- item.bucket_tagging["lowercase spaced"] == 'hello cruel world'
- item.bucket_tagging["Title Case"] == 'Hello Cruel World'
- item.bucket_location.LocationConstraint == aws_region
- item.bucket_versioning.Status is defined
- item.bucket_versioning.MFADelete is undefined
loop: "{{ bucket_list.buckets }}"
loop_control:
label: "{{ item.name }}"
1 change: 1 addition & 0 deletions tests/integration/targets/s3_bucket_info/tasks/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
amazon.aws.s3_bucket:
name: "{{ item }}"
state: present
versioning: true
tags:
lowercase spaced: hello cruel world
Title Case: Hello Cruel World
Expand Down

0 comments on commit 2a1d771

Please sign in to comment.