mirror of
https://github.com/optim-enterprises-bv/vault.git
synced 2025-10-30 18:17:55 +00:00
vault: Support sub-views
This commit is contained in:
@@ -21,6 +21,12 @@ func NewBarrierView(barrier SecurityBarrier, prefix string) *BarrierView {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// SubView constructs a nested sub-view using the given prefix
|
||||||
|
func (v *BarrierView) SubView(prefix string) *BarrierView {
|
||||||
|
sub := v.expandKey(prefix)
|
||||||
|
return &BarrierView{barrier: v.barrier, prefix: sub}
|
||||||
|
}
|
||||||
|
|
||||||
// Put is used to insert or update an entry
|
// Put is used to insert or update an entry
|
||||||
func (v *BarrierView) Put(entry *Entry) error {
|
func (v *BarrierView) Put(entry *Entry) error {
|
||||||
nested := &Entry{
|
nested := &Entry{
|
||||||
|
|||||||
@@ -67,3 +67,65 @@ func TestBarrierView(t *testing.T) {
|
|||||||
t.Fatalf("root test missing")
|
t.Fatalf("root test missing")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestBarrierView_SubView(t *testing.T) {
|
||||||
|
_, barrier, _ := mockBarrier(t)
|
||||||
|
root := NewBarrierView(barrier, "foo/")
|
||||||
|
view := root.SubView("bar/")
|
||||||
|
|
||||||
|
// List should have no visibility
|
||||||
|
keys, err := view.List("")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
if len(keys) != 0 {
|
||||||
|
t.Fatalf("bad: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get should have no visibility
|
||||||
|
out, err := view.Get("test")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
if out != nil {
|
||||||
|
t.Fatalf("bad: %v", out)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Try to put the same entry via the view
|
||||||
|
entry := &Entry{Key: "test", Value: []byte("test")}
|
||||||
|
if err := view.Put(entry); err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check it is nested
|
||||||
|
out, err = barrier.Get("foo/bar/test")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
if out == nil {
|
||||||
|
t.Fatalf("missing nested foo/bar/test")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check for visibility in root
|
||||||
|
out, err = root.Get("bar/test")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
if out == nil {
|
||||||
|
t.Fatalf("missing nested bar/test")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Delete nested
|
||||||
|
if err := view.Delete("test"); err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check the nested key
|
||||||
|
out, err = barrier.Get("foo/bar/test")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
if out != nil {
|
||||||
|
t.Fatalf("nested foo/bar/test should be gone")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user