agent: |
wZRHaLKb9bYv4xlqU240Evaluate Block Public Access settings for each S3 bucket in the region us-east-2.
Evaluate Block Public Access settings for each S3 bucket in the region us-east-2.
There was a problem that the LLM was not able to address. Please rephrase your prompt and try again.
This script evaluates Block Public Access settings for each S3 bucket in the specified region and flags them as NON_COMPLIANT or COMPLIANT.
inputs
outputs
import boto3
import json
def evaluate_bucket_public_access(bucket_names, region_name):
s3_client = boto3.client('s3',
region_name=region_name,
aws_access_key_id=getEnvVar('AWS_ACCESS_KEY_ID'),
aws_secret_access_key=getEnvVar('AWS_SECRET_ACCESS_KEY'))
compliance_status = {}
for bucket_name in bucket_names:
try:
# Check Block Public Access settings
block_public_access = s3_client.get_bucket_policy_status(Bucket=bucket_name)
is_public = block_public_access['PolicyStatus']['IsPublic']
if is_public:
compliance_status[bucket_name] = 'NON_COMPLIANT'
else:
compliance_status[bucket_name] = 'COMPLIANT'
except s3_client.exceptions.ClientError as e:
error_code = e.response['Error']['Code']
if error_code == 'NoSuchBucketPolicy':
compliance_status[bucket_name] = 'COMPLIANT'
else:
compliance_status[bucket_name] = f'ERROR: {str(e)}'
print(json.dumps(compliance_status, indent=4, default=str))
return compliance_status
bucket_compliance_status = evaluate_bucket_public_access(bucket_names, region_name)
copied