代码拉取完成,页面将自动刷新
/*
Copyright IBM Corp. 2017 All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package mocks
import (
"bytes"
"errors"
"fmt"
"time"
mockpolicies "github.com/hyperledger/fabric/common/mocks/policies"
"github.com/hyperledger/fabric/common/policies"
"github.com/hyperledger/fabric/msp"
mspproto "github.com/hyperledger/fabric/protos/msp"
"github.com/hyperledger/fabric/protoutil"
"github.com/stretchr/testify/mock"
)
type ChannelPolicyManagerGetter struct{}
func (c *ChannelPolicyManagerGetter) Manager(channelID string) (policies.Manager, bool) {
return &mockpolicies.Manager{Policy: &mockpolicies.Policy{Err: nil}}, false
}
type ChannelPolicyManagerGetterWithManager struct {
Managers map[string]policies.Manager
}
func (c *ChannelPolicyManagerGetterWithManager) Manager(channelID string) (policies.Manager, bool) {
return c.Managers[channelID], true
}
type ChannelPolicyManager struct {
Policy policies.Policy
}
func (m *ChannelPolicyManager) GetPolicy(id string) (policies.Policy, bool) {
return m.Policy, true
}
func (m *ChannelPolicyManager) Manager(path []string) (policies.Manager, bool) {
panic("Not implemented")
}
type Policy struct {
Deserializer msp.IdentityDeserializer
}
// Evaluate takes a set of SignedData and evaluates whether this set of signatures satisfies the policy
func (m *Policy) Evaluate(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)
}
type DeserializersManager struct {
LocalDeserializer msp.IdentityDeserializer
ChannelDeserializers map[string]msp.IdentityDeserializer
}
func (m *DeserializersManager) Deserialize(raw []byte) (*mspproto.SerializedIdentity, error) {
return &mspproto.SerializedIdentity{Mspid: "mock", IdBytes: raw}, nil
}
func (m *DeserializersManager) GetLocalMSPIdentifier() string {
return "mock"
}
func (m *DeserializersManager) GetLocalDeserializer() msp.IdentityDeserializer {
return m.LocalDeserializer
}
func (m *DeserializersManager) GetChannelDeserializers() map[string]msp.IdentityDeserializer {
return m.ChannelDeserializers
}
type IdentityDeserializerWithExpiration struct {
*IdentityDeserializer
Expiration time.Time
}
func (d *IdentityDeserializerWithExpiration) DeserializeIdentity(serializedIdentity []byte) (msp.Identity, error) {
id, err := d.IdentityDeserializer.DeserializeIdentity(serializedIdentity)
if err != nil {
return nil, err
}
id.(*Identity).expirationDate = d.Expiration
return id, nil
}
type IdentityDeserializer struct {
Identity []byte
Msg []byte
mock.Mock
}
func (d *IdentityDeserializer) DeserializeIdentity(serializedIdentity []byte) (msp.Identity, error) {
fmt.Printf("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 &Identity{Msg: d.Msg}, nil
}
return nil, errors.New("Invalid Identity")
}
func (d *IdentityDeserializer) IsWellFormed(identity *mspproto.SerializedIdentity) error {
if len(d.ExpectedCalls) == 0 {
return nil
}
return d.Called(identity).Error(0)
}
type Identity struct {
expirationDate time.Time
Msg []byte
}
func (id *Identity) Anonymous() bool {
panic("implement me")
}
func (id *Identity) ExpiresAt() time.Time {
return id.expirationDate
}
func (id *Identity) SatisfiesPrincipal(*mspproto.MSPPrincipal) error {
return nil
}
func (id *Identity) GetIdentifier() *msp.IdentityIdentifier {
return &msp.IdentityIdentifier{Mspid: "mock", Id: "mock"}
}
func (id *Identity) GetMSPIdentifier() string {
return "mock"
}
func (id *Identity) Validate() error {
return nil
}
func (id *Identity) GetOrganizationalUnits() []*msp.OUIdentifier {
return nil
}
func (id *Identity) 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 *Identity) Serialize() ([]byte, error) {
return []byte("cert"), nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。