1
0
Fork 0
mirror of https://github.com/Luzifer/korvike.git synced 2025-01-08 20:11:30 +00:00

Compare commits

..

No commits in common. "2cc2bee14a1b7613f4da70603184f86822831834" and "3354a2931120d4aecfcdb68986deac4ca46206a3" have entirely different histories.

4 changed files with 43 additions and 71 deletions

View file

@ -1,19 +1,3 @@
# 1.0.0 / 2024-02-29
* Breaking: Add sprig functions, replace some internal ones
* Replace old build-system
**Breaking changes:**
- Function `env` no longer takes a default, use `env "MYVAR" | default "..."`
- Function `file` no longer takes a default, use `file "[filename]" | default "..."`
- Function `now` returns `time.Time`, use `now | date "[format]"`
- Function `split` now has reversed parameters `split <sep> <str>`
- Function `vault` no longet takes a default, use `vault "key" "field" | default "..."`
- Removed function `b64decode`, use `b64dec`
- Removed function `b64encode`, use `b64enc`
- Removed function `hash`, use `sha1sum` / `sha256sum` / `sha512sum`
# 0.13.0 / 2022-03-30 # 0.13.0 / 2022-03-30
* Add basic string manipulation `join` and `split` * Add basic string manipulation `join` and `split`

View file

@ -4,7 +4,7 @@
# Luzifer / korvike # Luzifer / korvike
`korvike` is the Finnish translation to the word "replacer" and that is what it does: It takes a Go template and executes it. `korvike` is the finnish translation to the word "replacer" and that is what it does: It takes a Go template and executes it.
## Available functions ## Available functions
@ -16,8 +16,8 @@ Starting with `v1.0.0` Korvike is based on the [sprig functions collection](http
$ echo "{{ .foo }}" | korvike -v foo=bar $ echo "{{ .foo }}" | korvike -v foo=bar
bar bar
``` ```
- `{{ file <file name> }}` / `{{ mustFile <file name> }}` - `{{ file <file name> [default value] }}`
Read a file and place it inside the template, `file` returns an empty string on error, `mustFile` an error Read a file and place it inside the template
```console ```console
$ echo "Hello World" > hello $ echo "Hello World" > hello
$ echo '{{ file "hello" }}' | korvike $ echo '{{ file "hello" }}' | korvike
@ -43,8 +43,8 @@ Starting with `v1.0.0` Korvike is based on the [sprig functions collection](http
$ echo '{{ urlescape "Hellö Wörld@Golang" }}' | korvike $ echo '{{ urlescape "Hellö Wörld@Golang" }}' | korvike
Hell%C3%B6+W%C3%B6rld%40Golang Hell%C3%B6+W%C3%B6rld%40Golang
``` ```
- `{{ vault <path> <key> }}` / `{{ mustVault <path> <key> }}` - `{{ vault <path> <key> [default value] }}`
Read a key from Vault using `VAULT_ADDR` and `VAULT_TOKEN` environment variables (or `~/.vault-token` file) for authentication. `vault` returns an empty string on error, `mustVault` an error Read a key from Vault using `VAULT_ADDR` and `VAULT_TOKEN` environment variables (or `~/.vault-token` file) for authentication.
```console ```console
$ vault write secret/test foo=bar $ vault write secret/test foo=bar
$ echo '{{ vault "secret/test" "foo" }}' | korvike $ echo '{{ vault "secret/test" "foo" }}' | korvike

View file

@ -1,27 +1,21 @@
package functions package functions
import ( import (
"fmt"
"os" "os"
) )
func init() { func init() {
registerFunction("file", func(name string) string { registerFunction("file", func(name string, v ...string) string {
fc, err := tplReadFile(name) defaultValue := ""
if err != nil { if len(v) > 0 {
return "" defaultValue = v[0]
} }
return fc if _, err := os.Stat(name); err == nil {
//#nosec:G304 // Intended to load custom file
if rawValue, err := os.ReadFile(name); err == nil {
return string(rawValue)
}
}
return defaultValue
}) })
registerFunction("mustFile", tplReadFile)
}
func tplReadFile(name string) (string, error) {
rawValue, err := os.ReadFile(name) //#nosec:G304 // Intended to load custom file
if err != nil {
return "", fmt.Errorf("reading file: %w", err)
}
return string(rawValue), nil
} }

View file

@ -10,42 +10,36 @@ import (
) )
func init() { func init() {
registerFunction("mustVault", tplVaultKeyFetch) registerFunction("vault", func(name string, v ...string) (interface{}, error) {
registerFunction("vault", func(name string, key string) string {
v, err := tplVaultKeyFetch(name, key)
if err != nil {
return ""
}
return v
})
}
func tplVaultKeyFetch(name string, key string) (string, error) {
if name == "" { if name == "" {
return "", fmt.Errorf("path is not set") return nil, fmt.Errorf("path is not set")
} }
if key == "" { if len(v) < 1 {
return "", fmt.Errorf("key is not set") return nil, fmt.Errorf("key is not set")
} }
client, err := vaultClientFromEnvOrFile() client, err := vaultClientFromEnvOrFile()
if err != nil { if err != nil {
return "", err return nil, err
} }
secret, err := client.Logical().Read(name) secret, err := client.Logical().Read(name)
if err != nil { if err != nil {
return "", fmt.Errorf("reading secret: %s", err) return nil, fmt.Errorf("reading secret: %s", err)
} }
if secret != nil && secret.Data != nil { if secret != nil && secret.Data != nil {
if val, ok := secret.Data[key].(string); ok { if val, ok := secret.Data[v[0]]; ok {
return val, nil return val, nil
} }
} }
return "", fmt.Errorf("requested value %q in key %q was not found in Vault and no default was set", key, name) if len(v) < 2 { //nolint:gomnd
return nil, fmt.Errorf("requested value %q in key %q was not found in Vault and no default was set", v[0], name)
}
return v[1], nil
})
} }
func vaultClientFromEnvOrFile() (*api.Client, error) { func vaultClientFromEnvOrFile() (*api.Client, error) {