refactor: Vault client functions to return client instance and improve error handling
This commit is contained in:
parent
8a5b7394b1
commit
a43491e07d
@ -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",
|
||||||
|
@ -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)
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func VaultWithToken() {
|
return client
|
||||||
|
}
|
||||||
|
|
||||||
|
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)
|
||||||
|
Loading…
Reference in New Issue
Block a user