backport of commit e07a8a2d51

pull/4479/head
Michael Li 2 years ago
parent 7c0bcce5de
commit 69a2dde922

@ -0,0 +1,18 @@
{
"storage": {
"file": {
"path": "/vault/file"
}
},
"listener": [
{
"tcp": {
"address": "0.0.0.0:8200",
"tls_disable": true
}
}
],
"default_lease_ttl": "168h",
"max_lease_ttl": "720h",
"ui": true
}

@ -32,11 +32,6 @@ variable "container_name" {
type = string
default = "vault"
}
variable "vault_token" {
description = "Vault Root Token"
type = string
default = "boundarytok"
}
variable "vault_port" {
description = "External Port to use"
type = string
@ -49,15 +44,18 @@ resource "docker_image" "vault" {
}
resource "docker_container" "vault" {
image = docker_image.vault.image_id
name = var.container_name
env = [
"VAULT_DEV_ROOT_TOKEN_ID=${var.vault_token}"
]
image = docker_image.vault.image_id
name = var.container_name
command = ["vault", "server", "-config", "/vault/config.d/config.json"]
ports {
internal = 8200
external = var.vault_port
}
mounts {
type = "bind"
source = "${abspath(path.module)}/config"
target = "/vault/config.d"
}
capabilities {
add = ["IPC_LOCK"]
}
@ -69,6 +67,7 @@ resource "docker_container" "vault" {
}
}
resource "enos_local_exec" "check_address" {
depends_on = [
docker_container.vault
@ -77,14 +76,51 @@ resource "enos_local_exec" "check_address" {
inline = ["timeout 10s bash -c 'until curl http://0.0.0.0:${var.vault_port}; do sleep 2; done'"]
}
resource "enos_local_exec" "check_health" {
resource "enos_local_exec" "init_vault" {
depends_on = [
enos_local_exec.check_address
]
environment = {
VAULT_ADDR = "http://0.0.0.0:${var.vault_port}"
VAULT_TOKEN = var.vault_token
VAULT_ADDR = "http://0.0.0.0:${var.vault_port}"
VAULT_SKIP_VERIFY = true
}
inline = ["vault operator init -format json"]
}
locals {
vault_init = jsondecode(enos_local_exec.init_vault.stdout)
unseal_keys = local.vault_init["unseal_keys_b64"]
root_token = local.vault_init["root_token"]
}
resource "enos_local_exec" "unseal_vault" {
depends_on = [
enos_local_exec.init_vault
]
environment = {
VAULT_ADDR = "http://0.0.0.0:${var.vault_port}"
VAULT_SKIP_VERIFY = true
}
# By default, vault requires 3 keys to unseal
count = 3
inline = [
"vault operator unseal ${local.unseal_keys[count.index]}"
]
}
resource "enos_local_exec" "check_health" {
depends_on = [
enos_local_exec.init_vault
]
environment = {
VAULT_ADDR = "http://0.0.0.0:${var.vault_port}"
VAULT_TOKEN = local.root_token
VAULT_SKIP_VERIFY = true
}
inline = ["timeout 10s bash -c 'until vault status; do sleep 2; done'"]
@ -99,7 +135,7 @@ output "address_internal" {
}
output "token" {
value = var.vault_token
value = local.root_token
}
output "port" {

Loading…
Cancel
Save