Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/eidam/personal-zero-trust-hashicorp-vault
Cloudflare for Teams + HashiCorp Vault = Zero Trust Love
https://github.com/eidam/personal-zero-trust-hashicorp-vault
cloudflare cloudflared google-cloud hashicorp hashicorp-terraform hashicorp-vault terraform vault zero-trust
Last synced: 4 months ago
JSON representation
Cloudflare for Teams + HashiCorp Vault = Zero Trust Love
- Host: GitHub
- URL: https://github.com/eidam/personal-zero-trust-hashicorp-vault
- Owner: eidam
- License: gpl-3.0
- Created: 2021-08-07T19:57:12.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2021-08-09T12:34:46.000Z (over 3 years ago)
- Last Synced: 2024-09-27T18:41:51.179Z (4 months ago)
- Topics: cloudflare, cloudflared, google-cloud, hashicorp, hashicorp-terraform, hashicorp-vault, terraform, vault, zero-trust
- Language: HCL
- Homepage:
- Size: 31.3 KB
- Stars: 46
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Personal Zero-Trust HashiCorp Vault
Secrets are hard, especially for local development. This is why I took two of my favorite products
([Cloudflare For Teams](https://www.cloudflare.com/teams/) and [HashiCorp Vault](https://www.vaultproject.io/))
and used them together to come up with a Zero-Trust Vault deployment that is easy to use from any of my workstations.The focus was to achieve fast deployment and easy maintenance. Terraform takes care of the full deployment, and the full stack is deployed with two `terraform apply` commands, everything is configured and ready to go within minutes.
## TLDR Stack
- **Terraform** putting everything together ❤️
- **Cloudflare for Teams**
- **Cloudflare Tunnel** _(exposing Vault, SSH to internet)_
- **Cloudflare Access**
- Vault UI _(generic Cloudflare Access app)_
- SSH Web Terminal _(SSH access to GCE instance)_
- JWT Auth backend _(Vault auth)_
- **Cloudflare WARP** to private network (through Tunnel)
- **Google Cloud Platform**
- **GCE Instance** _(with deny-all incoming traffic)_
- **GCS Bucket** _(Vault storage)_
- **Secret Manager** _(Cloudflare Tunnel credentials store)_
- _(optional)_ **KMS** _(for Vault auto-unseal)_## Estimated Costs
### Cloudflare
Free. _(for up to 50 users)_### Google Cloud Platform
I cannot tell the exact GCP costs of this stack yet, but there is a Free Tier for the default machine type.If you want to change the region, just note that only some regions are eligible for the [GCP Free Tier](https://cloud.google.com/free/docs/gcp-free-tier).
## Deployment
The deployment process consists of two steps. The first one (Infra) is to deploy the Zero-Trust stack and the second one is configuring the Vault itself.
### 1. Pre-requisities
In order to deploy this stack, make sure you have:
- Terraform version 1.0+
- [Google Cloud SDK](https://cloud.google.com/sdk/docs/install) setup and [authenticated](https://cloud.google.com/sdk/docs/authorizing) to a GCP project
- Its recommended creating a new GCP project, with following APIs enabled
- https://console.developers.google.com/apis/api/compute.googleapis.com/overview
- https://console.developers.google.com/apis/api/secretmanager.googleapis.com/overview
- _(optional - if auto-unseal is desired - **additional costs!**)_ https://console.developers.google.com/apis/api/cloudkms.googleapis.com/overview- Google Storage Bucket for Terraform state
- Manually create a GCS bucket in your GCP project, name it e.g. `tf-state-vault-my-project-id`
- Cloudflare Account with Cloudflare for Teams enabled### 2. Infra
Please refer to [infra folder](./infra/)### 3. Vault configuration
Please refer to [vault-config folder](./vault-config/)## Couple of notes
- Cloudflare Teams tunnels IP routes are Terraformed using REST provider, this will be changed to official cloudflare provider once supported.
- OIDC auth flow or automatic WARP auth to get the JWT token would be better, this will be implemented if and once supported.
- Why? You may ask. The next step is to configure my local development to load ENV variables based on the project directory.