Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hashicorp/terraform-provider-vault
Terraform Vault provider
https://github.com/hashicorp/terraform-provider-vault
terraform terraform-provider vault
Last synced: 7 days ago
JSON representation
Terraform Vault provider
- Host: GitHub
- URL: https://github.com/hashicorp/terraform-provider-vault
- Owner: hashicorp
- License: mpl-2.0
- Created: 2017-06-05T20:54:13.000Z (over 7 years ago)
- Default Branch: main
- Last Pushed: 2025-01-03T22:24:45.000Z (19 days ago)
- Last Synced: 2025-01-08T13:07:41.779Z (14 days ago)
- Topics: terraform, terraform-provider, vault
- Language: Go
- Homepage: https://www.terraform.io/docs/providers/vault/
- Size: 21.7 MB
- Stars: 468
- Watchers: 228
- Forks: 548
- Open Issues: 430
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
- Support: .github/SUPPORT.md
Awesome Lists containing this project
README
Terraform Provider
==================- Website: https://www.terraform.io
- [![Gitter chat](https://badges.gitter.im/hashicorp-terraform/Lobby.png)](https://gitter.im/hashicorp-terraform/Lobby)
- Mailing list: [Google Groups](http://groups.google.com/group/terraform-tool)Maintainers
-----------This provider plugin is maintained by the Vault team at [HashiCorp](https://www.hashicorp.com/).
Best Practices
--------------We recommend that you avoid placing secrets in your Terraform config or state file wherever possible, and if placed there, you take steps to reduce and manage your risk. We have created a practical guide on how to do this with our opensource versions in Best Practices for Using HashiCorp Terraform with HashiCorp Vault:
[![Best Practices for Using HashiCorp Terraform with HashiCorp Vault](https://img.youtube.com/vi/fOybhcbuxJ0/0.jpg)](https://www.youtube.com/watch?v=fOybhcbuxJ0)
This webinar walks you through how to protect secrets when using Terraform with Vault. Additional security measures are available in paid Terraform versions as well.
Requirements
------------- [Terraform](https://www.terraform.io/downloads.html) 0.12.x and above, we recommend using the latest stable release whenever possible.
- [Go](https://golang.org/doc/install) 1.20 (to build the provider plugin)Building The Provider
---------------------Clone repository to: `$GOPATH/src/github.com/hashicorp/terraform-provider-vault`
```sh
$ mkdir -p $GOPATH/src/github.com/hashicorp; cd $GOPATH/src/github.com/hashicorp
$ git clone [email protected]:hashicorp/terraform-provider-vault
```Enter the provider directory and build the provider
```sh
$ cd $GOPATH/src/github.com/hashicorp/terraform-provider-vault
$ make build
```Developing the Provider
---------------------------If you wish to work on the provider, you'll first need [Go](http://www.golang.org) installed on your machine (version 1.20+ is *required*). You'll also need to correctly setup a [GOPATH](http://golang.org/doc/code.html#GOPATH), as well as adding `$GOPATH/bin` to your `$PATH`.
To compile the provider, run `make build`. This will build the provider and put the provider binary in the `$GOPATH/bin` directory.
```sh
$ make build
...
$ $GOPATH/bin/terraform-provider-vault
...
```In order to test the provider, you can simply run `make test`.
```sh
$ make test
```In order to run the full suite of Acceptance tests, you will need the following:
*Note:* Acceptance tests create real resources, and often cost money to run.
1. An instance of Vault running to run the tests against
2. The following environment variables are set:
- `VAULT_ADDR` - location of Vault
- `VAULT_TOKEN` - token used to query Vault. These tests do not attempt to read `~/.vault-token`.
3. The following environment variables may need to be set depending on which acceptance tests you wish to run.
There may be additional variables for specific tests. Consult the specific test(s) for more information.
- `AWS_ACCESS_KEY_ID`
- `AWS_SECRET_ACCESS_KEY`
- `GOOGLE_CREDENTIALS` the contents of a GCP creds JSON, alternatively read from `GOOGLE_CREDENTIALS_FILE`
- `RMQ_CONNECTION_URI`
- `RMQ_USERNAME`
- `RMQ_PASSWORD`
- `ARM_SUBSCRIPTION_ID`
- `ARM_TENANT_ID`
- `ARM_CLIENT_ID`
- `ARM_CLIENT_SECRET`
- `ARM_RESOURCE_GROUP`
4. Run `make testacc`If you wish to run specific tests, use the `TESTARGS` environment variable:
```sh
TESTARGS="--run DataSourceAWSAccessCredentials" make testacc
```Using a local development build
----------------------It's possible to use a local build of the Vault provider with Terraform directly.
This is useful when testing the provider outside the acceptance test framework.Configure Terraform to use the development build of the provider.
> **warning**: backup your `~/.terraformrc` before running this command:
```shell
cat > ~/.terraformrc <