agent: |
rcxf5yuj0SXCrkBHOBUlCheck each S3 bucket for default encryption settings and identify buckets without default encryption enabled.
Check each S3 bucket for default encryption settings and identify buckets without default encryption enabled.
There was a problem that the LLM was not able to address. Please rephrase your prompt and try again.
This script checks each S3 bucket for default encryption settings and identifies buckets without default encryption enabled.
inputs
outputs
import boto3
# Initialize boto3 client for S3
s3_client = boto3.client('s3',
aws_access_key_id=getEnvVar('AWS_ACCESS_KEY_ID'),
aws_secret_access_key=getEnvVar('AWS_SECRET_ACCESS_KEY'),
region_name='us-east-2')
non_compliant_buckets = []
for bucket_name in bucket_names:
try:
# Check if default encryption is enabled
encryption = s3_client.get_bucket_encryption(Bucket=bucket_name)
rules = encryption['ServerSideEncryptionConfiguration']['Rules']
if not rules:
non_compliant_buckets.append(bucket_name)
except s3_client.exceptions.ClientError as e:
# If the error is because the bucket does not have encryption enabled
if e.response['Error']['Code'] == 'ServerSideEncryptionConfigurationNotFoundError':
non_compliant_buckets.append(bucket_name)
print("Non-compliant buckets:", non_compliant_buckets)
copied