fabric-samples/off_chain_data/application-go/parser/namespaceReadWriteSet.go
Stanislav Jakuschevskij fd1a1fc38b
Add first batch of pull request rework
- update Application section in README
- remove param name in app.go
- add error checks in processor/block.go
- move vars from model to transact logic
- move newAsset to transact
- use ID for well-known initialisms
- move randomelement, randomnint and differentelement to transact
- remove AssertDefined
- blockTxIdsJoinedByComma: use standard library to join elements
- return nil, instead of []byte{}
- remove go routine in listen.go
- move cache to parser
- inline processor in listen.go
- move store to main package
- move util to main package
- fixed failing cache issue
- fixed staticcheck issues
- removed cache function, implemented caching in the structs and methods

Signed-off-by: Stanislav Jakuschevskij <stas@two-giants.com>
2025-02-24 13:14:48 +01:00

35 lines
930 B
Go

package parser
import (
"fmt"
"github.com/hyperledger/fabric-protos-go-apiv2/ledger/rwset"
"github.com/hyperledger/fabric-protos-go-apiv2/ledger/rwset/kvrwset"
"google.golang.org/protobuf/proto"
)
type NamespaceReadWriteSet struct {
nsReadWriteSet *rwset.NsReadWriteSet
cachedReadWriteSet *kvrwset.KVRWSet
}
func parseNamespaceReadWriteSet(nsRwSet *rwset.NsReadWriteSet) *NamespaceReadWriteSet {
return &NamespaceReadWriteSet{nsRwSet, nil}
}
func (p *NamespaceReadWriteSet) Namespace() string {
return p.nsReadWriteSet.GetNamespace()
}
func (p *NamespaceReadWriteSet) ReadWriteSet() (*kvrwset.KVRWSet, error) {
if p.cachedReadWriteSet != nil {
return p.cachedReadWriteSet, nil
}
p.cachedReadWriteSet = &kvrwset.KVRWSet{}
if err := proto.Unmarshal(p.nsReadWriteSet.GetRwset(), p.cachedReadWriteSet); err != nil {
return nil, fmt.Errorf("in ReadWriteSet: %w", err)
}
return p.cachedReadWriteSet, nil
}