Supporting tools for working with terraform code.
Project description
tfmate
Documentation: https://tfmate-ads.readthedocs.org
tfmate is a command line interface and Python library for analyzing Terraform configurations and state files. It provides powerful tools for understanding your infrastructure as code, including configuration analysis, AWS service discovery, and state file inspection.
Features
- Configuration Analysis: Analyze Terraform configuration files to understand providers, backends, and version constraints
- AWS Service Discovery: List and filter AWS services from botocore definitions
- State File Inspection: Extract Terraform version and metadata from state files
- Multiple Output Formats: Support for JSON, table, and text output formats
- Flexible Configuration: Customizable through configuration files and environment variables
Installation
tfmate supports Python 3.10+.
To install from PyPI:
pip install tfmate
To install using uv:
sh -c "$(curl -fsSL https://astral.sh/uv/install)"
uv tool install tfmate
Ensure you have ./local/bin in your PATH, since that's where uv puts the
executable.
Quick Start
# Get help
tfmate --help
# Analyze Terraform configuration
tfmate analyze config
# List AWS services
tfmate aws services
# Get Terraform version from state
tfmate terraform version
# Use JSON output for scripting
tfmate --output json analyze config
Usage Examples
Analyze Terraform Configuration
# Analyze current directory
tfmate analyze config
# Analyze specific directory with detailed info
tfmate analyze config --directory ./infrastructure --show-providers --show-backend
# Output as JSON for scripting
tfmate --output json analyze config > config.json
AWS Service Discovery
# List all AWS services
tfmate aws services
# List only service names
tfmate aws services --names-only
# Filter services by pattern
tfmate aws services --filter-name "ec2*" --sort-by name
State File Operations
# Get Terraform version from state
tfmate terraform version
# Get version from specific directory
tfmate terraform version --directory ./infrastructure
# Use explicit state file (local only)
tfmate terraform version --state-file ./terraform.tfstate
Documentation
For detailed documentation, visit: https://tfmate.readthedocs.org
Development
To set up a development environment:
# Clone the repository
git clone https://github.com/cmalek/terraform-common-modules.git
cd tfmate
# Create virtual environment
python -m venv .venv
source .venv/bin/activate # On Windows: .venv\Scripts\activate
# Install in development mode
pip install -e .
# Run tests
pytest
Contributing
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tfmate-0.1.1.tar.gz.
File metadata
- Download URL: tfmate-0.1.1.tar.gz
- Upload date:
- Size: 36.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9f262da0444b30185dc9e756085ee76489ce4de7aa2021e38d33e02d3d2d480a
|
|
| MD5 |
fb4c18c52e95f12d90310b4999590451
|
|
| BLAKE2b-256 |
f1372c3fddf03dd709da36628bcb165f4d91bee018e6d6888f3ee5c5b291792f
|
File details
Details for the file tfmate-0.1.1-py3-none-any.whl.
File metadata
- Download URL: tfmate-0.1.1-py3-none-any.whl
- Upload date:
- Size: 45.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
03b5632b84e7d7f8fab815ba766b08d4592cb1c9b3148f9a2d73db63d795d1f9
|
|
| MD5 |
922b597aa5d748798c72d80c52250353
|
|
| BLAKE2b-256 |
9e89bfd269c40fa15f62e35b14b3583ba7887a01e7f934bc29f73f432910c152
|