A Vault backend for Terraform implemented as an HTTP server.
Built using FastAPI.
Install with pip (recommended):
pip3 install -r requirements.txt
You can also install with Poetry:
poetry install
Install dependencies with Poetry:
poetry install
poetry run ruff format .
poetry run ruff check .
poetry run pytest
poetry run mypy . --strict
poetry run python -m src
poetry shell
python -m src
This will run the backend with Vault defaults.
Please refer to python -m src --help
for configuration options.
Example configuration, assuming of the backend to be
hosted at https://example.com
:
terraform {
backend "http" {
address = "https://example.com/v1/state/<path>"
lock_address = "https://example.com/v1/lock/<path>"
unlock_address = "https://example.com/v1/lock/<path>"
lock_method = "POST"
unlock_method = "DELETE"
}
}
<path>
is the path to use within the configured mountpoint.
NOTE:
For local testing or an otherwise non-TLS setup, you might need to use skip_cert_verification = true
.
Refer to the Terraform documentation for additional options.
To authenticate to the Vault backend, you need to send your VAULT_TOKEN
with your
Terraform invocations. How do we do this? By passing it through HTTP Basic Auth:
$ export TF_HTTP_USERNAME="${VAULT_TOKEN:?}"
$ terraform apply
More info on Vault authentication can be found at Vault's official documentation.