代码拉取完成,页面将自动刷新
/*
Copyright IBM Corp. All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package mocks
import (
"bytes"
"errors"
"fmt"
"time"
mspproto "github.com/hyperledger/fabric-protos-go/msp"
"github.com/hyperledger/fabric/common/policies"
"github.com/hyperledger/fabric/msp"
"github.com/hyperledger/fabric/protoutil"
)
type MockChannelPolicyManagerGetter struct {
Managers map[string]policies.Manager
}
func (c *MockChannelPolicyManagerGetter) Manager(channelID string) policies.Manager {
return c.Managers[channelID]
}
type MockChannelPolicyManager struct {
MockPolicy policies.Policy
}
func (m *MockChannelPolicyManager) GetPolicy(id string) (policies.Policy, bool) {
return m.MockPolicy, true
}
func (m *MockChannelPolicyManager) Manager(path []string) (policies.Manager, bool) {
panic("Not implemented")
}
type MockPolicy struct {
Deserializer msp.IdentityDeserializer
}
// EvaluateSignedData takes a set of SignedData and evaluates whether this set of signatures satisfies the policy
func (m *MockPolicy) EvaluateSignedData(signatureSet []*protoutil.SignedData) error {
fmt.Printf("Evaluate [%s], [% x], [% x]\n", string(signatureSet[0].Identity), string(signatureSet[0].Data), string(signatureSet[0].Signature))
identity, err := m.Deserializer.DeserializeIdentity(signatureSet[0].Identity)
if err != nil {
return err
}
return identity.Verify(signatureSet[0].Data, signatureSet[0].Signature)
}
// EvaluateIdentities takes an array of identities and evaluates whether
// they satisfy the policy
func (m *MockPolicy) EvaluateIdentities(identities []msp.Identity) error {
return nil
}
type MockIdentityDeserializer struct {
Identity []byte
Msg []byte
}
func (d *MockIdentityDeserializer) DeserializeIdentity(serializedIdentity []byte) (msp.Identity, error) {
fmt.Printf("[DeserializeIdentity] id : [%s], [%s]\n", string(serializedIdentity), string(d.Identity))
if bytes.Equal(d.Identity, serializedIdentity) {
fmt.Printf("GOT : [%s], [%s]\n", string(serializedIdentity), string(d.Identity))
return &MockIdentity{identity: d.Identity, msg: d.Msg}, nil
}
return nil, errors.New("Invalid Identity")
}
func (d *MockIdentityDeserializer) IsWellFormed(_ *mspproto.SerializedIdentity) error {
return nil
}
type MockIdentity struct {
identity []byte
msg []byte
}
func (id *MockIdentity) Anonymous() bool {
panic("implement me")
}
func (id *MockIdentity) SatisfiesPrincipal(p *mspproto.MSPPrincipal) error {
fmt.Printf("[SatisfiesPrincipal] id : [%s], [%s]\n", string(id.identity), string(p.Principal))
if !bytes.Equal(id.identity, p.Principal) {
return fmt.Errorf("Different identities [% x]!=[% x]", id.identity, p.Principal)
}
return nil
}
func (id *MockIdentity) ExpiresAt() time.Time {
return time.Time{}
}
func (id *MockIdentity) GetIdentifier() *msp.IdentityIdentifier {
return &msp.IdentityIdentifier{Mspid: "mock", Id: "mock"}
}
func (id *MockIdentity) GetMSPIdentifier() string {
return "mock"
}
func (id *MockIdentity) Validate() error {
return nil
}
func (id *MockIdentity) GetOrganizationalUnits() []*msp.OUIdentifier {
return nil
}
func (id *MockIdentity) Verify(msg []byte, sig []byte) error {
fmt.Printf("VERIFY [% x], [% x], [% x]\n", string(id.msg), string(msg), string(sig))
if bytes.Equal(id.msg, msg) {
if bytes.Equal(msg, sig) {
return nil
}
}
return errors.New("Invalid Signature")
}
func (id *MockIdentity) Serialize() ([]byte, error) {
return []byte("cert"), nil
}
type MockMSPPrincipalGetter struct {
Principal []byte
}
func (m *MockMSPPrincipalGetter) Get(role string) (*mspproto.MSPPrincipal, error) {
return &mspproto.MSPPrincipal{Principal: m.Principal}, nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。