1 Star 0 Fork 0

peter / fabric

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
disseminator.go 744 Bytes
一键复制 编辑 原始数据 按行查看 历史
/*
Copyright IBM Corp All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package etcdraft
import (
"sync"
"github.com/hyperledger/fabric-protos-go/orderer"
)
// Disseminator piggybacks cluster metadata, if any, to egress messages.
type Disseminator struct {
RPC
l sync.Mutex
sent map[uint64]bool
metadata []byte
}
func (d *Disseminator) SendConsensus(dest uint64, msg *orderer.ConsensusRequest) error {
d.l.Lock()
defer d.l.Unlock()
if !d.sent[dest] && len(d.metadata) != 0 {
msg.Metadata = d.metadata
d.sent[dest] = true
}
return d.RPC.SendConsensus(dest, msg)
}
func (d *Disseminator) UpdateMetadata(m []byte) {
d.l.Lock()
defer d.l.Unlock()
d.sent = make(map[uint64]bool)
d.metadata = m
}
1
https://gitee.com/peter_code_git/fabric.git
git@gitee.com:peter_code_git/fabric.git
peter_code_git
fabric
fabric
v2.1.1

搜索帮助