In this final section, you’ll switch gears and detect drift. Drift occurs when the infrastructure deployed in the cloud is different from what was defined in the IaC template. You call what the infrastructure should be the “state” saved in files locally or in Terraform Cloud. For example, if the infrastructure in AWS may have different configurations than the Terraform template defined.
This usually occurs during a major incident, where DevOps and SRE teams make manual changes to quickly solve the problem, such as opening up ports to larger CIDR blocks or turning off HTTPS to find the problem, or if there are knowledge or access control gaps that make fixing an issue in the cloud directly the easier option. If these aren’t reverted, they present security issues and it weakens the benefits of using IaC.
Make sure you’ve applied the Terraform resources from the Test Pull Request section.
Confirm in your AWS console that your new S3 bucket is up. Go to the S3 console and confirm that there is a new bucket running.
Next, let’s add a tag and encryption to the S3 bucket. Select the bucket and go to “Properties.” Next to “Tags” click “Edit.” Add a tag with the key
drift and value
Then, next to “Default encryption click “Edit.” Select “Enable” and “Amazon S3 key,” then “Save changes.”
Bridgecrew scans your cloud configurations periodically, but to speed up the process, you can use the following API call in your terminal with your Bridgecrew API key from the earlier steps.
curl -X POST -H "Authorization: $YOUR_BC_API_KEY" https://www.bridgecrew.cloud/api/v1/scans/integrations
That will force start a scan of your environment that will find misconfigurations and identify drift from your Terraform state. After a few moments, head back over to the Projects page of Bridgecrew. Select your repository (
<organization>/terragoat) and filter by “Drift.” Here you can see the difference in AWS versus the state saved in Terraform Cloud or your VCS.
You found drift! From here, you can either run
terraform apply to bring your cloud resources back in line with the state saved locally or in Terraform Cloud, or make the changes to your Terraform templates to match the changes made in production and update the state in Terraform Cloud. Alternatively, in the Projects page, you will find Fix Drift that will open a pull request on your behalf to make the change to match code to cloud.