Conformance Packs

Deploy Components for Lab

In this lab, we will be deploying Amazon S3 Operational Best Practices with remediation actions conformance pack in an AWS Account. This pack contains following AWS Config Rules.

  • S3BucketPublicReadProhibited with Remediation Action
  • S3BucketPublicWriteProhibited with Remediation Action
  • S3BucketReplicationEnabled
  • S3BucketSSLRequestsOnly
  • S3BucketServerSideEncryptionEnabled with Remediation Action
  • S3BucketLoggingEnabled with Remediation Action

Prerequisites

We will create prerequisite resources required for “Amazon S3 Operational Best Practices with Remediation Actions” conformance pack. This includes a service-linked role for Conformance Packs, a remediation action role, and an S3 logging bucket.

Important: deploying this Conformance Pack can disrupt access to data if installed in a production environment. Never deploy these conformance packs without proper testing in a safe test environment first!

Before proceeding, you must create a CloudFormation Stack that includes the resources required for this lab. Click here to deploy this Stack into your account:

Create Stack

Enter a stack name, and keep the settings with default values. Click through all the way to Create stack.

Deploy Conformance Pack

Before we can deploy the conformance pack, we will need to edit it. Conformance packs that AWS provides represent collated best practices, however they are not “one size fits all” and need some massaging before being leveraged.

  1. First download the conformance pack template from this link.

  2. Next edit this file so we can make it usable with your lab environment. You will need to replace the <Account-Id> entries with the proper account number for your account (without dashes). You will find this entry on these lines:

    • 43
    • 80
    • 139
    • 179
  3. Go to the Config Console, and then click on Conformance packs.

  4. Click on Deploy conformance pack on the top right of the page.

Deploy Conformance Pack

  1. Under template details, select Upload template, and then select the Upload a template. Click Choose file, upload your modified template, and finallly click Next.

  2. Give the conformance pack a name that is meaningful to you.

  3. This conformance pack will require a parameter to function. Click Add parameter and then add a new key called S3TargetBucketNameForEnableLogging.

    • The value for this will be the name of the s3serversideloggingbucket created by the CloudFormation stack you deployed in the prerequisites. Copy the name of the bucket into the value field.
  4. Click Next, and finally click Deploy conformance pack.

Conformance Pack 2

View Compliance Remediation

We will check compliance status for each rule in conformance pack and associated resources. Conformance Packs can also be deployed to an AWS Organizations; however, in the interest of time it will only be discussed during this lab.

  1. Once the conformance pack is deployed, click on conformance pack name to drill down into details. You can view list of rules and their compliance status.

Conformance Pack 3

  1. Click on a rule name to see rule details.
  2. Expand Resources in Scope section to see resources in scope and their compliance status. If there are any existing non-compliant resources, you can manually remediate them or wait for auto-remediation to complete.

Conformance Pack 4

  1. To see auto-remediation in action on a new resource, create a new S3 bucket using S3 Console. AWS Config will discover the resource and mark it as non-compliant if it is not following S3 best practices.
  2. Go back to conformance pack details and select a rule with remediation action.
  3. Expand Resources in Scope section to see newly created resource with its compliance status. If the resource is non-compliant, the auto-remediation action will apply to resource within few minutes.
  4. Refresh the page to see updated resource compliance status.

End of Lab Exercises

Thank you for using this lab.