Files

42 lines
981 B
Go

package vault
import (
"context"
"fmt"
"time"
vault "github.com/hashicorp/vault-client-go"
)
func ReadKVv2(addr, token, mountPath, key string) (map[string]any, error) {
ctx, cancel := context.WithTimeout(context.Background(), 30*time.Second)
defer cancel()
client, err := vault.New(
vault.WithAddress(addr),
vault.WithRequestTimeout(30*time.Second),
)
if err != nil {
return nil, fmt.Errorf("vault new: %w", err)
}
if err := client.SetToken(token); err != nil {
return nil, fmt.Errorf("set token: %w", err)
}
resp, err := client.Secrets.KvV2Read(ctx, key, vault.WithMountPath(mountPath))
if err != nil {
return nil, err
}
if resp == nil || resp.Data.Data == nil {
return nil, fmt.Errorf("vault: empty response for %s/%s", mountPath, key)
}
return resp.Data.Data, nil
}
// tiny typed error
type ErrNotFound string
func (e ErrNotFound) Error() string {
return "vault: secret not found at " + string(e)
}