[#51] policy: Support Get and ListByPrefix methods #51
2 changed files with 2 additions and 20 deletions
|
@ -68,22 +68,10 @@ func RemoveChainsByPrefix(entity Kind, entityName string, name string) {
|
||||||
// ListChains lists all chains for the namespace by prefix.
|
// ListChains lists all chains for the namespace by prefix.
|
||||||
// container may be empty.
|
// container may be empty.
|
||||||
func ListChains(namespace, container, name string) [][]byte {
|
func ListChains(namespace, container, name string) [][]byte {
|
||||||
ctx := storage.GetReadOnlyContext()
|
result := ListChainsByPrefix(Namespace, namespace, name)
|
||||||
|
|
||||||
var result [][]byte
|
|
||||||
|
|
||||||
prefixNs := storageKey(Namespace, namespace, name)
|
|
||||||
it := storage.Find(ctx, prefixNs, storage.ValuesOnly)
|
|
||||||
for iterator.Next(it) {
|
|
||||||
result = append(result, iterator.Value(it).([]byte))
|
|
||||||
}
|
|
||||||
|
|
||||||
if container != "" {
|
if container != "" {
|
||||||
prefixCnr := storageKey(Container, container, name)
|
result = append(result, ListChainsByPrefix(Container, container, name)...)
|
||||||
it = storage.Find(ctx, prefixCnr, storage.ValuesOnly)
|
|
||||||
for iterator.Next(it) {
|
|
||||||
result = append(result, iterator.Value(it).([]byte))
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
|
@ -89,12 +89,6 @@ func checkChainsByPrefix(t *testing.T, e *neotest.ContractInvoker, kind byte, en
|
||||||
func checksChainsOnStack(t *testing.T, s *vm.Stack, expected [][]byte) {
|
func checksChainsOnStack(t *testing.T, s *vm.Stack, expected [][]byte) {
|
||||||
require.Equal(t, 1, s.Len())
|
require.Equal(t, 1, s.Len())
|
||||||
|
|
||||||
if len(expected) == 0 {
|
|
||||||
_, ok := s.Pop().Item().(stackitem.Null)
|
|
||||||
require.True(t, ok)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
var actual [][]byte
|
var actual [][]byte
|
||||||
arr := s.Pop().Array()
|
arr := s.Pop().Array()
|
||||||
for i := range arr {
|
for i := range arr {
|
||||||
|
|
Loading…
Reference in a new issue