mirror of
				https://github.com/optim-enterprises-bv/vault.git
				synced 2025-10-30 18:17:55 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			61 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright (c) HashiCorp, Inc.
 | |
| // SPDX-License-Identifier: MPL-2.0
 | |
| 
 | |
| package api
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"fmt"
 | |
| )
 | |
| 
 | |
| type KVv1 struct {
 | |
| 	c         *Client
 | |
| 	mountPath string
 | |
| }
 | |
| 
 | |
| // Get returns a secret from the KV v1 secrets engine.
 | |
| func (kv *KVv1) Get(ctx context.Context, secretPath string) (*KVSecret, error) {
 | |
| 	pathToRead := fmt.Sprintf("%s/%s", kv.mountPath, secretPath)
 | |
| 
 | |
| 	secret, err := kv.c.Logical().ReadWithContext(ctx, pathToRead)
 | |
| 	if err != nil {
 | |
| 		return nil, fmt.Errorf("error encountered while reading secret at %s: %w", pathToRead, err)
 | |
| 	}
 | |
| 	if secret == nil {
 | |
| 		return nil, fmt.Errorf("%w: at %s", ErrSecretNotFound, pathToRead)
 | |
| 	}
 | |
| 
 | |
| 	return &KVSecret{
 | |
| 		Data:            secret.Data,
 | |
| 		VersionMetadata: nil,
 | |
| 		Raw:             secret,
 | |
| 	}, nil
 | |
| }
 | |
| 
 | |
| // Put inserts a key-value secret (e.g. {"password": "Hashi123"}) into the
 | |
| // KV v1 secrets engine.
 | |
| //
 | |
| // If the secret already exists, it will be overwritten.
 | |
| func (kv *KVv1) Put(ctx context.Context, secretPath string, data map[string]interface{}) error {
 | |
| 	pathToWriteTo := fmt.Sprintf("%s/%s", kv.mountPath, secretPath)
 | |
| 
 | |
| 	_, err := kv.c.Logical().WriteWithContext(ctx, pathToWriteTo, data)
 | |
| 	if err != nil {
 | |
| 		return fmt.Errorf("error writing secret to %s: %w", pathToWriteTo, err)
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // Delete deletes a secret from the KV v1 secrets engine.
 | |
| func (kv *KVv1) Delete(ctx context.Context, secretPath string) error {
 | |
| 	pathToDelete := fmt.Sprintf("%s/%s", kv.mountPath, secretPath)
 | |
| 
 | |
| 	_, err := kv.c.Logical().DeleteWithContext(ctx, pathToDelete)
 | |
| 	if err != nil {
 | |
| 		return fmt.Errorf("error deleting secret at %s: %w", pathToDelete, err)
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 | 
