implement vault template function for kv engine; add docs

This commit is contained in:
Megan Marsh 2018-08-16 16:10:35 -07:00
parent dfaf624f4c
commit 174098ba29
2 changed files with 37 additions and 5 deletions

View File

@ -204,6 +204,8 @@ func funcGenConsul(ctx *Context) interface{} {
if value == "" { if value == "" {
return "", fmt.Errorf("value is empty at path %s", k) return "", fmt.Errorf("value is empty at path %s", k)
} }
return value, nil
} }
} }
@ -234,13 +236,20 @@ func funcGenVault(ctx *Context) interface{} {
return "", errors.New(fmt.Sprintf("Vault Secret does not exist at the given path.")) return "", errors.New(fmt.Sprintf("Vault Secret does not exist at the given path."))
} }
data := secret.Data["data"] data, ok := secret.Data["data"]
if data == nil { if !ok {
// maybe ths is v1, not v2 kv store
value, ok := secret.Data[key]
if ok {
return value.(string), nil
}
// neither v1 nor v2 proudced a valid value
return "", errors.New(fmt.Sprintf("Vault data was empty at the "+ return "", errors.New(fmt.Sprintf("Vault data was empty at the "+
"given path. Warnings: %s", strings.Join(secret.Warnings, "; "))) "given path. Warnings: %s", strings.Join(secret.Warnings, "; ")))
} }
value := secret.Data["data"].(map[string]interface{})[key].(string) value := data.(map[string]interface{})[key].(string)
return value, nil return value, nil
} }
} }

View File

@ -122,12 +122,35 @@ your template as user variables. the `vault` function is available *only*
within the default value of a user variable, allowing you to default a user within the default value of a user variable, allowing you to default a user
variable to an environment variable. variable to an environment variable.
An example is shown below: An example of using a v2 kv engine:
If you store a value in vault using `vault kv put secret/hello foo=world`, you
can access it using the following template engine:
```json ```json
{ {
"variables": { "variables": {
"my_secret": "{{ vault `/secret/data/foo` `bar`}}" "my_secret": "{{ vault `/secret/data/hello` `foo`}}"
}
}
```
which will assign "my_secret": "world"
An example of using a v1 kv engine:
If you store a value in vault using:
```
vault secrets enable -version=1 -path=secrets kv
vault kv put secrets/hello foo=world
```
You can access it using the following template engine:
```
{
"variables": {
"VAULT_SECRETY_SECRET": "{{ vault `secrets/hello` `foo`}}"
} }
} }
``` ```