1 Star 1 Fork 0

Hyperledger Fabric 国密 / fabric

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
query_executer_combiner.go 2.75 KB
一键复制 编辑 原始数据 按行查看 历史
Jtyoui 提交于 2021-07-22 15:59 . 国密
/*
Copyright IBM Corp. All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package queryutil
import (
"gitee.com/hyperledger-fabric-gm/fabric/common/flogging"
commonledger "gitee.com/hyperledger-fabric-gm/fabric/common/ledger"
"gitee.com/hyperledger-fabric-gm/fabric/core/ledger/kvledger/txmgmt/statedb"
)
var logger = flogging.MustGetLogger("util")
//go:generate counterfeiter -o mock/query_executer.go -fake-name QueryExecuter . QueryExecuter
// QueryExecuter encapsulates query functions
type QueryExecuter interface {
GetState(namespace, key string) (*statedb.VersionedValue, error)
GetStateRangeScanIterator(namespace, startKey, endKey string) (statedb.ResultsIterator, error)
}
// QECombiner combines the query results from one or more underlying 'queryExecuters'
// In case, the same key is returned by multiple 'queryExecuters', the first 'queryExecuter'
// in the input is considered having the latest state of the key
type QECombiner struct {
QueryExecuters []QueryExecuter // actual executers in decending order of priority
}
// GetState implements function in the interface ledger.SimpleQueryExecutor
func (c *QECombiner) GetState(namespace string, key string) ([]byte, error) {
var vv *statedb.VersionedValue
var val []byte
var err error
for _, qe := range c.QueryExecuters {
if vv, err = qe.GetState(namespace, key); err != nil {
return nil, err
}
if vv != nil {
if !vv.IsDelete() {
val = vv.Value
}
break
}
}
return val, nil
}
// GetStateRangeScanIterator implements function in the interface ledger.SimpleQueryExecutor
func (c *QECombiner) GetStateRangeScanIterator(namespace string, startKey string, endKey string) (commonledger.ResultsIterator, error) {
var itrs []statedb.ResultsIterator
for _, qe := range c.QueryExecuters {
itr, err := qe.GetStateRangeScanIterator(namespace, startKey, endKey)
if err != nil {
for _, itr := range itrs {
itr.Close()
}
return nil, err
}
itrs = append(itrs, itr)
}
itrCombiner, err := newItrCombiner(namespace, itrs)
if err != nil {
return nil, err
}
return itrCombiner, nil
}
// UpdateBatchBackedQueryExecuter wraps an update batch for providing functions in the interface 'queryExecuter'
type UpdateBatchBackedQueryExecuter struct {
UpdateBatch *statedb.UpdateBatch
}
// GetState implements function in interface 'queryExecuter'
func (qe *UpdateBatchBackedQueryExecuter) GetState(ns, key string) (*statedb.VersionedValue, error) {
return qe.UpdateBatch.Get(ns, key), nil
}
// GetStateRangeScanIterator implements function in interface 'queryExecuter'
func (qe *UpdateBatchBackedQueryExecuter) GetStateRangeScanIterator(namespace, startKey, endKey string) (statedb.ResultsIterator, error) {
return qe.UpdateBatch.GetRangeScanIterator(namespace, startKey, endKey), nil
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/hyperledger-fabric-gm/fabric.git
git@gitee.com:hyperledger-fabric-gm/fabric.git
hyperledger-fabric-gm
fabric
fabric
v1.4.9

搜索帮助

344bd9b3 5694891 D2dac590 5694891