driftctl

Measures infrastructure as code coverage, and tracks infrastructure drift.
IaC: Terraform. Cloud providers: AWS, GitHub, Azure, GCP.
:warning: This tool is still in beta state and will evolve in the future with potential breaking changes :warning:

Packaging status Packaging status
## Why driftctl ? Infrastructure drift is a blind spot and a source of potential security issues. Drift can have multiple causes: from team members creating or updating infrastructure through the web console without backporting changes to Terraform, to unexpected actions from authenticated apps and services. You can't efficiently improve what you don't track. We track coverage for unit tests, why not infrastructure as code coverage? Spot discrepancies as they happen: driftctl is a free and open-source CLI that warns of infrastructure drifts and fills in the missing piece in your DevSecOps toolbox. ## Features - **Scan** cloud provider and map resources with IaC code - Analyze diffs, and warn about drift and unwanted unmanaged resources - Allow users to **ignore** resources - Multiple output formats ## Links **[Get Started](https://driftctl.com/product/quick-tutorial/)** **[Documentation](https://docs.driftctl.com)** **[Installation](https://docs.driftctl.com/installation)** **[Discord](https://discord.gg/7zHQ8r2PgP)** ## Contribute To learn more about compiling driftctl and contributing, please refer to the [contribution guidelines](.github/CONTRIBUTING.md) and the [contributing guide](docs/README.md) for technical details. This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification and is brought to you by these [awesome contributors](CONTRIBUTORS.md). Build with ❤️️ from 🇫🇷 🇬🇧 🇯🇵 🇬🇷 🇸🇪 🇺🇸 🇷🇪 🇨🇦 🇮🇱 ## Helping you get started We have 30 min slots for 1:1 [tech discussions and overviews](https://calendly.com/stephanejourdan/30min) twice a day to help you get started and collect users feedback. Feel free to book a slot. ## Security notice All Terraform state and Terraform files in this repository are for unit test purposes only. No running code attempts to access these resources (except to create and destroy them, in the case of acceptance tests). They are just opaque strings.