/
cc_info_provider.go
50 lines (40 loc) · 1.58 KB
/
cc_info_provider.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
//此源码被清华学神尹成大魔王专业翻译分析并修改
//尹成QQ77025077
//尹成微信18510341407
//尹成所在QQ群721929980
//尹成邮箱 yinc13@mails.tsinghua.edu.cn
//尹成毕业于清华大学,微软区块链领域全球最有价值专家
//https://mvp.microsoft.com/zh-cn/PublicProfile/4033620
/*
版权所有IBM公司。保留所有权利。
SPDX许可证标识符:Apache-2.0
**/
package ccprovider
import (
"bytes"
"fmt"
"github.com/golang/protobuf/proto"
"github.com/hyperledger/fabric/core/common/sysccprovider"
)
//如果部署了具有给定名称和版本的链代码,is chaincode deployed将返回true。
func IsChaincodeDeployed(chainid, ccName, ccVersion string, ccHash []byte, sccp sysccprovider.SystemChaincodeProvider) (bool, error) {
qe, err := sccp.GetQueryExecutorForLedger(chainid)
if err != nil {
return false, fmt.Errorf("Could not retrieve QueryExecutor for channel %s, error %s", chainid, err)
}
defer qe.Done()
//我们正在将LSCC表结构的细节泄漏到代码的其他部分,这很糟糕。
chaincodeDataBytes, err := qe.GetState("lscc", ccName)
if err != nil {
return false, fmt.Errorf("Could not retrieve state for chaincode %s on channel %s, error %s", ccName, chainid, err)
}
if chaincodeDataBytes == nil {
return false, nil
}
chaincodeData := &ChaincodeData{}
err = proto.Unmarshal(chaincodeDataBytes, chaincodeData)
if err != nil {
return false, fmt.Errorf("Unmarshalling ChaincodeQueryResponse failed, error %s", err)
}
return chaincodeData.CCVersion() == ccVersion && bytes.Equal(chaincodeData.Hash(), ccHash), nil
}