refactor: Vault client functions to return client instance and improve error handling

This commit is contained in:
SoXX 2025-01-05 22:41:15 +01:00
parent 8a5b7394b1
commit a43491e07d
2 changed files with 97 additions and 13 deletions

View File

@ -53,7 +53,7 @@ func main() {
var ctx = context.Background() var ctx = context.Background()
// Set up the logger based on the configuration // Set up the logger based on the configuration
utils.SetupLogger(otterCage.LogLevel, otterCage.LogFormat) utils.SetupLogger("TRACE", otterCage.LogFormat)
ctx, span := tracer.Start(ctx, "main") ctx, span := tracer.Start(ctx, "main")
defer span.End() defer span.End()
@ -62,8 +62,49 @@ func main() {
ginRouter := setupRouter(ctx) ginRouter := setupRouter(ctx)
token := vault.GetJWTToken("b7dc7146-88ce-47ba-98c1-ea8184a49be1", "Ni49FqnH_GIi0EIfneuIxDNKm", "https://laughing-banach-ptdsgdxqjf.projects.oryapis.com/oauth2/token") // TODO: Groups are not generated via the roles, this needs to be fixed
vault.VaultWithJWT(ctx, "", token)
/*
# roles for application
vault write -address "http://localhost:8200" auth/jwt/role/manager \
role_type="jwt" \
bound_subject="b7dc7146-88ce-47ba-98c1-ea8184a49be1" \
allowed_redirect_uris="http://localhost:8250/oidc/callback" \
user_claim="client_id" \
groups_claim="/ext/roles" \
token_type="batch"
*/
/*
# ACL policies
path "e621.net/*" {
capabilities = [ "create", "update", "list" ]
}
path "e621.net/*" {
capabilities = [ "read" ]
}
*/
token := vault.GetJWTToken("b7dc7146-88ce-47ba-98c1-ea8184a49be1",
"Ni49FqnH_GIi0EIfneuIxDNKm",
"https://laughing-banach-ptdsgdxqjf.projects.oryapis.com/oauth2/token")
log.WithField("token", token).Trace("API Token")
client := vault.VaultWithJWT(ctx, "manager", token)
secret := vault.SecretData[vault.E621]{
UserID: "1",
UserSourceID: "2",
Secret: vault.E621{
APIKey: "test",
},
}
err := vault.WritingAPIKeyToVault[vault.E621](ctx, client, secret)
if err != nil {
log.WithError(err).Panic("cant write API key to vault")
}
server := &http.Server{ server := &http.Server{
Addr: ":8080", Addr: ":8080",

View File

@ -2,8 +2,10 @@ package vault
import ( import (
"context" "context"
"encoding/json"
"fmt" "fmt"
"golang.org/x/oauth2/clientcredentials" "golang.org/x/oauth2/clientcredentials"
"net/http"
"time" "time"
"github.com/hashicorp/vault-client-go" "github.com/hashicorp/vault-client-go"
@ -31,7 +33,7 @@ func GetJWTToken(clientID string, clientSecret string, tokenURL string) string {
return token.AccessToken return token.AccessToken
} }
func VaultWithJWT(ctx context.Context, roles string, jwt string) { func VaultWithJWT(ctx context.Context, roles string, jwt string) *vault.Client {
// prepare a client with the given base address // prepare a client with the given base address
client, err := vault.New( client, err := vault.New(
@ -39,7 +41,7 @@ func VaultWithJWT(ctx context.Context, roles string, jwt string) {
vault.WithRequestTimeout(30*time.Second), vault.WithRequestTimeout(30*time.Second),
) )
if err != nil { if err != nil {
log.Fatal(err) log.Panic(err)
} }
request := schema.JwtLoginRequest{ request := schema.JwtLoginRequest{
@ -49,16 +51,18 @@ func VaultWithJWT(ctx context.Context, roles string, jwt string) {
resp, err := client.Auth.JwtLogin(ctx, request) resp, err := client.Auth.JwtLogin(ctx, request)
if err != nil { if err != nil {
log.Fatal(resp, err) log.Panic(resp, err)
} }
err = client.SetToken(resp.Auth.ClientToken) err = client.SetToken(resp.Auth.ClientToken)
if err != nil { if err != nil {
log.Fatal(err) log.Panic(err)
} }
return client
} }
func VaultWithToken() { func VaultWithUserPass(ctx context.Context, username, password string) *vault.Client {
// prepare a client with the given base address // prepare a client with the given base address
client, err := vault.New( client, err := vault.New(
@ -66,7 +70,41 @@ func VaultWithToken() {
vault.WithRequestTimeout(30*time.Second), vault.WithRequestTimeout(30*time.Second),
) )
if err != nil { if err != nil {
log.Fatal(err) log.Panic(err)
}
client.SetRequestCallbacks(func(req *http.Request) {
log.Println("REQUEST:", *req.URL)
})
request := schema.UserpassLoginRequest{
Password: password,
}
// authenticate with a root token (insecure)
resp, err := client.Auth.UserpassLogin(ctx, username, request)
if err != nil {
log.WithError(err).Panic("Problem logging in with username and password")
}
err = client.SetToken(resp.Auth.ClientToken)
if err != nil {
log.Panic(err)
}
return client
}
func VaultWithToken(token string) *vault.Client {
// prepare a client with the given base address
client, err := vault.New(
vault.WithAddress("http://localhost:8200"),
vault.WithRequestTimeout(30*time.Second),
)
if err != nil {
log.Panic(err)
} }
//client.SetRequestCallbacks(func(req *http.Request) { //client.SetRequestCallbacks(func(req *http.Request) {
@ -74,9 +112,11 @@ func VaultWithToken() {
//}) //})
// authenticate with a root token (insecure) // authenticate with a root token (insecure)
if err := client.SetToken("hvs.XD2NNAznvWucjo7B8RhtXpQZ"); err != nil { if err := client.SetToken(token); err != nil {
log.Fatal(err) log.Panic(err)
} }
return client
} }
// WritingAPIKeyToVault writes the API key to a Vault using the given secret data. // WritingAPIKeyToVault writes the API key to a Vault using the given secret data.
@ -102,7 +142,10 @@ func WritingAPIKeyToVault[T SecretDataTypes](ctx context.Context, client *vault.
_, err = client.Secrets.KvV2Write(ctx, secretData.UserSourceID, request, vault.WithMountPath(secretData.Secret.GetMountPath())) _, err = client.Secrets.KvV2Write(ctx, secretData.UserSourceID, request, vault.WithMountPath(secretData.Secret.GetMountPath()))
if err != nil { if err != nil {
log.Fatal(err) daaata, _ := json.Marshal(client)
log.Trace(string(daaata))
log.WithField("mount_path", secretData.Secret.GetMountPath()).Panic(err)
} }
return nil return nil
@ -123,7 +166,7 @@ func WritingAPIKeyToVault[T SecretDataTypes](ctx context.Context, client *vault.
func ReadingApiKeyFromVault[T SecretDataTypes](ctx context.Context, client *vault.Client, secretData *SecretData[T]) error { func ReadingApiKeyFromVault[T SecretDataTypes](ctx context.Context, client *vault.Client, secretData *SecretData[T]) error {
data, err := client.Secrets.KvV2Read(ctx, secretData.UserSourceID, vault.WithMountPath(secretData.Secret.GetMountPath())) data, err := client.Secrets.KvV2Read(ctx, secretData.UserSourceID, vault.WithMountPath(secretData.Secret.GetMountPath()))
if err != nil { if err != nil {
log.Fatal(err) log.Panic(err)
} }
secret, err := MapToSecret[T](data.Data.Data) secret, err := MapToSecret[T](data.Data.Data)