609648de4f
The original reason for the split was physical's dependencies, but those haven't been onerous for a long time. Meanwhile it's a totally separate implementation so we could be getting faulty results from tests. Get rid of it and use the unified physical/inmem.
68 lines
1.5 KiB
Go
68 lines
1.5 KiB
Go
package logical
|
|
|
|
import (
|
|
"context"
|
|
"sync"
|
|
|
|
"github.com/hashicorp/vault/physical"
|
|
"github.com/hashicorp/vault/physical/inmem"
|
|
)
|
|
|
|
// InmemStorage implements Storage and stores all data in memory. It is
|
|
// basically a straight copy of physical.Inmem, but it prevents backends from
|
|
// having to load all of physical's dependencies (which are legion) just to
|
|
// have some testing storage.
|
|
type InmemStorage struct {
|
|
underlying physical.Backend
|
|
once sync.Once
|
|
}
|
|
|
|
func (s *InmemStorage) Get(ctx context.Context, key string) (*StorageEntry, error) {
|
|
s.once.Do(s.init)
|
|
|
|
entry, err := s.underlying.Get(ctx, key)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if entry == nil {
|
|
return nil, nil
|
|
}
|
|
return &StorageEntry{
|
|
Key: entry.Key,
|
|
Value: entry.Value,
|
|
SealWrap: entry.SealWrap,
|
|
}, nil
|
|
}
|
|
|
|
func (s *InmemStorage) Put(ctx context.Context, entry *StorageEntry) error {
|
|
s.once.Do(s.init)
|
|
|
|
return s.underlying.Put(ctx, &physical.Entry{
|
|
Key: entry.Key,
|
|
Value: entry.Value,
|
|
SealWrap: entry.SealWrap,
|
|
})
|
|
}
|
|
|
|
func (s *InmemStorage) Delete(ctx context.Context, key string) error {
|
|
s.once.Do(s.init)
|
|
|
|
return s.underlying.Delete(ctx, key)
|
|
}
|
|
|
|
func (s *InmemStorage) List(ctx context.Context, prefix string) ([]string, error) {
|
|
s.once.Do(s.init)
|
|
|
|
return s.underlying.List(ctx, prefix)
|
|
}
|
|
|
|
func (s *InmemStorage) Underlying() *inmem.InmemBackend {
|
|
s.once.Do(s.init)
|
|
|
|
return s.underlying.(*inmem.InmemBackend)
|
|
}
|
|
|
|
func (s *InmemStorage) init() {
|
|
s.underlying, _ = inmem.NewInmem(nil, nil)
|
|
}
|