Skip to main content

lacework-global-50

2.1.5 Configure S3 Buckets with 'Block public access (bucket settings)' (Automated)

Profile Applicability

• Level 1

Description

Amazon S3 provides Block public access (bucket settings) and Block public access (account settings) to help you manage public access to Amazon S3 resources. By default, S3 buckets and objects have public access turned off. However, an Identity and Access Management (IAM) principal with sufficient S3 permissions can enable public access at the bucket and/or object level. While enabled, Block public access (bucket settings) prevents an individual bucket, and its contained objects, from becoming publicly accessible. Similarly, Block public access (account settings) prevents all buckets, and contained objects, from becoming publicly accessible across the entire account.

Rationale

Amazon S3 Block public access (bucket settings) prevents the accidental or malicious public exposure of data contained within the respective bucket(s).

Amazon S3 Block public access (account settings) prevents the accidental or malicious public exposure of data contained within all buckets of the respective AWS account.

Whether blocking public access to all or some buckets is an organizational decision that should be based on data sensitivity, least privilege, and use case.

Impact

When you apply Block Public Access settings to an account, the settings apply to all AWS Regions globally. The settings might not take effect in all Regions immediately or simultaneously, but they eventually propagate to all Regions.

Audit

If utilizing Block Public Access (bucket settings)

From Console

  1. Login to AWS Management Console and open the Amazon S3 console using https://console.aws.amazon.com/s3/
  2. Select the Check box next to the Bucket.
  3. Click on 'Edit public access settings'.
  4. Ensure that block public access settings are set appropriately for this bucket
  5. Repeat for all the buckets in your AWS account.

From Command Line

  1. List all of the S3 Buckets
aws s3 ls
  1. Find the public access setting on that bucket
aws s3api get-public-access-block --bucket <name-of-the-bucket>

Output if Block Public access is enabled:

{
"PublicAccessBlockConfiguration": {
"BlockPublicAcls": true,
"IgnorePublicAcls": true,
"BlockPublicPolicy": true,
"RestrictPublicBuckets": true
}
}

If the output reads false for the separate configuration settings then proceed to the remediation.

If utilizing Block Public Access (account settings)

From Console

  1. Login to AWS Management Console and open the Amazon S3 console using https://console.aws.amazon.com/s3/
  2. Choose Block public access (account settings)
  3. Ensure that block public access settings are set appropriately for your AWS account.

From Command Line

To check Public access settings for this account status, run the following command, aws s3control get-public-access-block --account-id <ACCT_ID> --region <REGION_NAME>

Output if Block Public access is enabled:

{
"PublicAccessBlockConfiguration": {
"IgnorePublicAcls": true,
"BlockPublicPolicy": true,
"BlockPublicAcls": true,
"RestrictPublicBuckets": true
}
}

If the output reads false for the separate configuration settings then proceed to the remediation.

Remediation

If utilizing Block Public Access (bucket settings)

From Console

  1. Login to AWS Management Console and open the Amazon S3 console using https://console.aws.amazon.com/s3/.
  2. Select the Check box next to the Bucket.
  3. Click 'Edit public access settings'.
  4. Click 'Block all public access'.
  5. Repeat for all the buckets in your AWS account that contain sensitive data.

From Command Line

  1. List all of the S3 Buckets:
aws s3 ls
  1. Set the Block Public Access to true on that bucket:
aws s3api put-public-access-block --bucket <name-of-bucket> --public-access-block-configuration "BlockPublicAcls=true,IgnorePublicAcls=true,BlockPublicPolicy=true,RestrictPublicBuckets=true"

If utilizing Block Public Access (account settings)

From Console

  1. Login to AWS Management Console and open the Amazon S3 console using https://console.aws.amazon.com/s3/.
  2. Choose Block Public Access (account settings).
  3. Choose Edit to change the block public access settings for all the buckets in your AWS account.
  4. Choose the settings you want to change, and then choose Save. For details about each setting, pause on the information icons.
  5. When asked for confirmation, enter confirm. Then Click Confirm to save your changes.

From Command Line

To set Block Public access settings for this account, run the following command:

aws s3control put-public-access-block
--public-access-block-configuration BlockPublicAcls=true, IgnorePublicAcls=true,
BlockPublicPolicy=true, RestrictPublicBuckets=true
--account-id <value>

References

https://docs.aws.amazon.com/AmazonS3/latest/user-guide/block-public-access-account.html