Documentation ¶
Index ¶
- Variables
- func RegisterDeliverServer(s *grpc.Server, srv DeliverServer)
- func RegisterEndorserServer(s *grpc.Server, srv EndorserServer)
- func RegisterEventsServer(s *grpc.Server, srv EventsServer)
- type ACLs
- type APIResource
- type AnchorPeer
- type AnchorPeers
- type ChaincodeAction
- func (*ChaincodeAction) Descriptor() ([]byte, []int)
- func (m *ChaincodeAction) GetChaincodeId() *ChaincodeID
- func (m *ChaincodeAction) GetEvents() []byte
- func (m *ChaincodeAction) GetResponse() *Response
- func (m *ChaincodeAction) GetResults() []byte
- func (*ChaincodeAction) ProtoMessage()
- func (m *ChaincodeAction) Reset()
- func (m *ChaincodeAction) String() string
- type ChaincodeActionPayload
- func (*ChaincodeActionPayload) Descriptor() ([]byte, []int)
- func (m *ChaincodeActionPayload) GetAction() *ChaincodeEndorsedAction
- func (m *ChaincodeActionPayload) GetChaincodeProposalPayload() []byte
- func (*ChaincodeActionPayload) ProtoMessage()
- func (m *ChaincodeActionPayload) Reset()
- func (m *ChaincodeActionPayload) String() string
- type ChaincodeDeploymentSpec
- func (*ChaincodeDeploymentSpec) Descriptor() ([]byte, []int)
- func (m *ChaincodeDeploymentSpec) GetChaincodeSpec() *ChaincodeSpec
- func (m *ChaincodeDeploymentSpec) GetCodePackage() []byte
- func (m *ChaincodeDeploymentSpec) GetExecEnv() ChaincodeDeploymentSpec_ExecutionEnvironment
- func (*ChaincodeDeploymentSpec) ProtoMessage()
- func (m *ChaincodeDeploymentSpec) Reset()
- func (m *ChaincodeDeploymentSpec) String() string
- type ChaincodeDeploymentSpec_ExecutionEnvironment
- type ChaincodeEndorsedAction
- func (*ChaincodeEndorsedAction) Descriptor() ([]byte, []int)
- func (m *ChaincodeEndorsedAction) GetEndorsements() []*Endorsement
- func (m *ChaincodeEndorsedAction) GetProposalResponsePayload() []byte
- func (*ChaincodeEndorsedAction) ProtoMessage()
- func (m *ChaincodeEndorsedAction) Reset()
- func (m *ChaincodeEndorsedAction) String() string
- type ChaincodeEvent
- func (*ChaincodeEvent) Descriptor() ([]byte, []int)
- func (m *ChaincodeEvent) GetChaincodeId() string
- func (m *ChaincodeEvent) GetEventName() string
- func (m *ChaincodeEvent) GetPayload() []byte
- func (m *ChaincodeEvent) GetTxId() string
- func (*ChaincodeEvent) ProtoMessage()
- func (m *ChaincodeEvent) Reset()
- func (m *ChaincodeEvent) String() string
- type ChaincodeHeaderExtension
- func (*ChaincodeHeaderExtension) Descriptor() ([]byte, []int)
- func (m *ChaincodeHeaderExtension) GetChaincodeId() *ChaincodeID
- func (m *ChaincodeHeaderExtension) GetPayloadVisibility() []byte
- func (*ChaincodeHeaderExtension) ProtoMessage()
- func (m *ChaincodeHeaderExtension) Reset()
- func (m *ChaincodeHeaderExtension) String() string
- type ChaincodeID
- type ChaincodeInfo
- func (*ChaincodeInfo) Descriptor() ([]byte, []int)
- func (m *ChaincodeInfo) GetEscc() string
- func (m *ChaincodeInfo) GetId() []byte
- func (m *ChaincodeInfo) GetInput() string
- func (m *ChaincodeInfo) GetName() string
- func (m *ChaincodeInfo) GetPath() string
- func (m *ChaincodeInfo) GetVersion() string
- func (m *ChaincodeInfo) GetVscc() string
- func (*ChaincodeInfo) ProtoMessage()
- func (m *ChaincodeInfo) Reset()
- func (m *ChaincodeInfo) String() string
- type ChaincodeInput
- type ChaincodeInvocationSpec
- type ChaincodeProposalPayload
- func (*ChaincodeProposalPayload) Descriptor() ([]byte, []int)
- func (m *ChaincodeProposalPayload) GetInput() []byte
- func (m *ChaincodeProposalPayload) GetTransientMap() map[string][]byte
- func (*ChaincodeProposalPayload) ProtoMessage()
- func (m *ChaincodeProposalPayload) Reset()
- func (m *ChaincodeProposalPayload) String() string
- type ChaincodeQueryResponse
- type ChaincodeReg
- type ChaincodeSpec
- func (*ChaincodeSpec) Descriptor() ([]byte, []int)
- func (m *ChaincodeSpec) GetChaincodeId() *ChaincodeID
- func (m *ChaincodeSpec) GetInput() *ChaincodeInput
- func (m *ChaincodeSpec) GetTimeout() int32
- func (m *ChaincodeSpec) GetType() ChaincodeSpec_Type
- func (*ChaincodeSpec) ProtoMessage()
- func (m *ChaincodeSpec) Reset()
- func (m *ChaincodeSpec) String() string
- type ChaincodeSpec_Type
- type ChannelInfo
- type ChannelQueryResponse
- type ConfidentialityLevel
- type DeliverClient
- type DeliverResponse
- func (*DeliverResponse) Descriptor() ([]byte, []int)
- func (m *DeliverResponse) GetBlock() *common.Block
- func (m *DeliverResponse) GetFilteredBlock() *FilteredBlock
- func (m *DeliverResponse) GetStatus() common.Status
- func (m *DeliverResponse) GetType() isDeliverResponse_Type
- func (*DeliverResponse) ProtoMessage()
- func (m *DeliverResponse) Reset()
- func (m *DeliverResponse) String() string
- func (*DeliverResponse) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, ...)
- type DeliverResponse_Block
- type DeliverResponse_FilteredBlock
- type DeliverResponse_Status
- type DeliverServer
- type Deliver_DeliverClient
- type Deliver_DeliverFilteredClient
- type Deliver_DeliverFilteredServer
- type Deliver_DeliverServer
- type Endorsement
- type EndorserClient
- type EndorserServer
- type Event
- func (*Event) Descriptor() ([]byte, []int)
- func (m *Event) GetBlock() *common.Block
- func (m *Event) GetChaincodeEvent() *ChaincodeEvent
- func (m *Event) GetCreator() []byte
- func (m *Event) GetEvent() isEvent_Event
- func (m *Event) GetFilteredBlock() *FilteredBlock
- func (m *Event) GetRegister() *Register
- func (m *Event) GetRejection() *Rejection
- func (m *Event) GetTimestamp() *google_protobuf1.Timestamp
- func (m *Event) GetTlsCertHash() []byte
- func (m *Event) GetUnregister() *Unregister
- func (*Event) ProtoMessage()
- func (m *Event) Reset()
- func (m *Event) String() string
- func (*Event) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, ...)
- type EventType
- type Event_Block
- type Event_ChaincodeEvent
- type Event_FilteredBlock
- type Event_Register
- type Event_Rejection
- type Event_Unregister
- type EventsClient
- type EventsServer
- type Events_ChatClient
- type Events_ChatServer
- type FilteredBlock
- func (*FilteredBlock) Descriptor() ([]byte, []int)
- func (m *FilteredBlock) GetChannelId() string
- func (m *FilteredBlock) GetFilteredTransactions() []*FilteredTransaction
- func (m *FilteredBlock) GetNumber() uint64
- func (*FilteredBlock) ProtoMessage()
- func (m *FilteredBlock) Reset()
- func (m *FilteredBlock) String() string
- type FilteredChaincodeAction
- type FilteredTransaction
- func (*FilteredTransaction) Descriptor() ([]byte, []int)
- func (m *FilteredTransaction) GetData() isFilteredTransaction_Data
- func (m *FilteredTransaction) GetTransactionActions() *FilteredTransactionActions
- func (m *FilteredTransaction) GetTxValidationCode() TxValidationCode
- func (m *FilteredTransaction) GetTxid() string
- func (m *FilteredTransaction) GetType() common.HeaderType
- func (*FilteredTransaction) ProtoMessage()
- func (m *FilteredTransaction) Reset()
- func (m *FilteredTransaction) String() string
- func (*FilteredTransaction) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, ...)
- type FilteredTransactionActions
- type FilteredTransaction_TransactionActions
- type Interest
- func (*Interest) Descriptor() ([]byte, []int)
- func (m *Interest) GetChainID() string
- func (m *Interest) GetChaincodeRegInfo() *ChaincodeReg
- func (m *Interest) GetEventType() EventType
- func (m *Interest) GetRegInfo() isInterest_RegInfo
- func (*Interest) ProtoMessage()
- func (m *Interest) Reset()
- func (m *Interest) String() string
- func (*Interest) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, ...)
- type Interest_ChaincodeRegInfo
- type LifecycleEvent
- type PeerEndpoint
- type PeerID
- type ProcessedTransaction
- func (*ProcessedTransaction) Descriptor() ([]byte, []int)
- func (m *ProcessedTransaction) GetTransactionEnvelope() *common.Envelope
- func (m *ProcessedTransaction) GetValidationCode() int32
- func (*ProcessedTransaction) ProtoMessage()
- func (m *ProcessedTransaction) Reset()
- func (m *ProcessedTransaction) String() string
- type Proposal
- type ProposalResponse
- func (*ProposalResponse) Descriptor() ([]byte, []int)
- func (m *ProposalResponse) GetEndorsement() *Endorsement
- func (m *ProposalResponse) GetPayload() []byte
- func (m *ProposalResponse) GetResponse() *Response
- func (m *ProposalResponse) GetTimestamp() *google_protobuf1.Timestamp
- func (m *ProposalResponse) GetVersion() int32
- func (*ProposalResponse) ProtoMessage()
- func (m *ProposalResponse) Reset()
- func (m *ProposalResponse) String() string
- type ProposalResponsePayload
- func (*ProposalResponsePayload) Descriptor() ([]byte, []int)
- func (m *ProposalResponsePayload) GetExtension() []byte
- func (m *ProposalResponsePayload) GetProposalHash() []byte
- func (*ProposalResponsePayload) ProtoMessage()
- func (m *ProposalResponsePayload) Reset()
- func (m *ProposalResponsePayload) String() string
- type Register
- type Rejection
- type Response
- type SignedChaincodeDeploymentSpec
- func (*SignedChaincodeDeploymentSpec) Descriptor() ([]byte, []int)
- func (m *SignedChaincodeDeploymentSpec) GetChaincodeDeploymentSpec() []byte
- func (m *SignedChaincodeDeploymentSpec) GetInstantiationPolicy() []byte
- func (m *SignedChaincodeDeploymentSpec) GetOwnerEndorsements() []*Endorsement
- func (*SignedChaincodeDeploymentSpec) ProtoMessage()
- func (m *SignedChaincodeDeploymentSpec) Reset()
- func (m *SignedChaincodeDeploymentSpec) String() string
- type SignedEvent
- type SignedProposal
- type SignedTransaction
- type Transaction
- type TransactionAction
- type TxValidationCode
- type Unregister
Constants ¶
This section is empty.
Variables ¶
var ChaincodeDeploymentSpec_ExecutionEnvironment_name = map[int32]string{
0: "DOCKER",
1: "SYSTEM",
}
var ChaincodeDeploymentSpec_ExecutionEnvironment_value = map[string]int32{
"DOCKER": 0,
"SYSTEM": 1,
}
var ChaincodeSpec_Type_name = map[int32]string{
0: "UNDEFINED",
1: "GOLANG",
2: "NODE",
3: "CAR",
4: "JAVA",
}
var ChaincodeSpec_Type_value = map[string]int32{
"UNDEFINED": 0,
"GOLANG": 1,
"NODE": 2,
"CAR": 3,
"JAVA": 4,
}
var ConfidentialityLevel_name = map[int32]string{
0: "PUBLIC",
1: "CONFIDENTIAL",
}
var ConfidentialityLevel_value = map[string]int32{
"PUBLIC": 0,
"CONFIDENTIAL": 1,
}
var EventType_name = map[int32]string{
0: "REGISTER",
1: "BLOCK",
2: "CHAINCODE",
3: "REJECTION",
4: "FILTEREDBLOCK",
}
var EventType_value = map[string]int32{
"REGISTER": 0,
"BLOCK": 1,
"CHAINCODE": 2,
"REJECTION": 3,
"FILTEREDBLOCK": 4,
}
var TxValidationCode_name = map[int32]string{
0: "VALID",
1: "NIL_ENVELOPE",
2: "BAD_PAYLOAD",
3: "BAD_COMMON_HEADER",
4: "BAD_CREATOR_SIGNATURE",
5: "INVALID_ENDORSER_TRANSACTION",
6: "INVALID_CONFIG_TRANSACTION",
7: "UNSUPPORTED_TX_PAYLOAD",
8: "BAD_PROPOSAL_TXID",
9: "DUPLICATE_TXID",
10: "ENDORSEMENT_POLICY_FAILURE",
11: "MVCC_READ_CONFLICT",
12: "PHANTOM_READ_CONFLICT",
13: "UNKNOWN_TX_TYPE",
14: "TARGET_CHAIN_NOT_FOUND",
15: "MARSHAL_TX_ERROR",
16: "NIL_TXACTION",
17: "EXPIRED_CHAINCODE",
18: "CHAINCODE_VERSION_CONFLICT",
19: "BAD_HEADER_EXTENSION",
20: "BAD_CHANNEL_HEADER",
21: "BAD_RESPONSE_PAYLOAD",
22: "BAD_RWSET",
23: "ILLEGAL_WRITESET",
254: "NOT_VALIDATED",
255: "INVALID_OTHER_REASON",
}
var TxValidationCode_value = map[string]int32{
"VALID": 0,
"NIL_ENVELOPE": 1,
"BAD_PAYLOAD": 2,
"BAD_COMMON_HEADER": 3,
"BAD_CREATOR_SIGNATURE": 4,
"INVALID_ENDORSER_TRANSACTION": 5,
"INVALID_CONFIG_TRANSACTION": 6,
"UNSUPPORTED_TX_PAYLOAD": 7,
"BAD_PROPOSAL_TXID": 8,
"DUPLICATE_TXID": 9,
"ENDORSEMENT_POLICY_FAILURE": 10,
"MVCC_READ_CONFLICT": 11,
"PHANTOM_READ_CONFLICT": 12,
"UNKNOWN_TX_TYPE": 13,
"TARGET_CHAIN_NOT_FOUND": 14,
"MARSHAL_TX_ERROR": 15,
"NIL_TXACTION": 16,
"EXPIRED_CHAINCODE": 17,
"CHAINCODE_VERSION_CONFLICT": 18,
"BAD_HEADER_EXTENSION": 19,
"BAD_CHANNEL_HEADER": 20,
"BAD_RESPONSE_PAYLOAD": 21,
"BAD_RWSET": 22,
"ILLEGAL_WRITESET": 23,
"NOT_VALIDATED": 254,
"INVALID_OTHER_REASON": 255,
}
Functions ¶
func RegisterDeliverServer ¶
func RegisterDeliverServer(s *grpc.Server, srv DeliverServer)
func RegisterEndorserServer ¶
func RegisterEndorserServer(s *grpc.Server, srv EndorserServer)
func RegisterEventsServer ¶
func RegisterEventsServer(s *grpc.Server, srv EventsServer)
Types ¶
type ACLs ¶
type ACLs struct {
Acls map[string]*APIResource `` /* 128-byte string literal not displayed */
}
ACLs provides mappings for resources in a channel. APIResource encpasulates reference to a policy used to determine ACL for the resource
func (*ACLs) Descriptor ¶
func (*ACLs) GetAcls ¶
func (m *ACLs) GetAcls() map[string]*APIResource
func (*ACLs) ProtoMessage ¶
func (*ACLs) ProtoMessage()
type APIResource ¶
type APIResource struct {
PolicyRef string `protobuf:"bytes,1,opt,name=policy_ref,json=policyRef" json:"policy_ref,omitempty"`
}
APIResource represents an API resource in the peer whose ACL is determined by the policy_ref field
func (*APIResource) Descriptor ¶
func (*APIResource) Descriptor() ([]byte, []int)
func (*APIResource) GetPolicyRef ¶
func (m *APIResource) GetPolicyRef() string
func (*APIResource) ProtoMessage ¶
func (*APIResource) ProtoMessage()
func (*APIResource) Reset ¶
func (m *APIResource) Reset()
func (*APIResource) String ¶
func (m *APIResource) String() string
type AnchorPeer ¶
type AnchorPeer struct { // DNS host name of the anchor peer Host string `protobuf:"bytes,1,opt,name=host" json:"host,omitempty"` // The port number Port int32 `protobuf:"varint,2,opt,name=port" json:"port,omitempty"` }
AnchorPeer message structure which provides information about anchor peer, it includes host name, port number and peer certificate.
func (*AnchorPeer) Descriptor ¶
func (*AnchorPeer) Descriptor() ([]byte, []int)
func (*AnchorPeer) GetHost ¶
func (m *AnchorPeer) GetHost() string
func (*AnchorPeer) GetPort ¶
func (m *AnchorPeer) GetPort() int32
func (*AnchorPeer) ProtoMessage ¶
func (*AnchorPeer) ProtoMessage()
func (*AnchorPeer) Reset ¶
func (m *AnchorPeer) Reset()
func (*AnchorPeer) String ¶
func (m *AnchorPeer) String() string
type AnchorPeers ¶
type AnchorPeers struct {
AnchorPeers []*AnchorPeer `protobuf:"bytes,1,rep,name=anchor_peers,json=anchorPeers" json:"anchor_peers,omitempty"`
}
AnchorPeers simply represents list of anchor peers which is used in ConfigurationItem
func (*AnchorPeers) Descriptor ¶
func (*AnchorPeers) Descriptor() ([]byte, []int)
func (*AnchorPeers) GetAnchorPeers ¶
func (m *AnchorPeers) GetAnchorPeers() []*AnchorPeer
func (*AnchorPeers) ProtoMessage ¶
func (*AnchorPeers) ProtoMessage()
func (*AnchorPeers) Reset ¶
func (m *AnchorPeers) Reset()
func (*AnchorPeers) String ¶
func (m *AnchorPeers) String() string
type ChaincodeAction ¶
type ChaincodeAction struct { // This field contains the read set and the write set produced by the // chaincode executing this invocation. Results []byte `protobuf:"bytes,1,opt,name=results,proto3" json:"results,omitempty"` // This field contains the events generated by the chaincode executing this // invocation. Events []byte `protobuf:"bytes,2,opt,name=events,proto3" json:"events,omitempty"` // This field contains the result of executing this invocation. Response *Response `protobuf:"bytes,3,opt,name=response" json:"response,omitempty"` // This field contains the ChaincodeID of executing this invocation. Endorser // will set it with the ChaincodeID called by endorser while simulating proposal. // Committer will validate the version matching with latest chaincode version. // Adding ChaincodeID to keep version opens up the possibility of multiple // ChaincodeAction per transaction. ChaincodeId *ChaincodeID `protobuf:"bytes,4,opt,name=chaincode_id,json=chaincodeId" json:"chaincode_id,omitempty"` }
ChaincodeAction contains the actions the events generated by the execution of the chaincode.
func (*ChaincodeAction) Descriptor ¶
func (*ChaincodeAction) Descriptor() ([]byte, []int)
func (*ChaincodeAction) GetChaincodeId ¶
func (m *ChaincodeAction) GetChaincodeId() *ChaincodeID
func (*ChaincodeAction) GetEvents ¶
func (m *ChaincodeAction) GetEvents() []byte
func (*ChaincodeAction) GetResponse ¶
func (m *ChaincodeAction) GetResponse() *Response
func (*ChaincodeAction) GetResults ¶
func (m *ChaincodeAction) GetResults() []byte
func (*ChaincodeAction) ProtoMessage ¶
func (*ChaincodeAction) ProtoMessage()
func (*ChaincodeAction) Reset ¶
func (m *ChaincodeAction) Reset()
func (*ChaincodeAction) String ¶
func (m *ChaincodeAction) String() string
type ChaincodeActionPayload ¶
type ChaincodeActionPayload struct { // This field contains the bytes of the ChaincodeProposalPayload message from // the original invocation (essentially the arguments) after the application // of the visibility function. The main visibility modes are "full" (the // entire ChaincodeProposalPayload message is included here), "hash" (only // the hash of the ChaincodeProposalPayload message is included) or // "nothing". This field will be used to check the consistency of // ProposalResponsePayload.proposalHash. For the CHAINCODE type, // ProposalResponsePayload.proposalHash is supposed to be H(ProposalHeader || // f(ChaincodeProposalPayload)) where f is the visibility function. ChaincodeProposalPayload []byte `` /* 135-byte string literal not displayed */ // The list of actions to apply to the ledger Action *ChaincodeEndorsedAction `protobuf:"bytes,2,opt,name=action" json:"action,omitempty"` }
ChaincodeActionPayload is the message to be used for the TransactionAction's payload when the Header's type is set to CHAINCODE. It carries the chaincodeProposalPayload and an endorsed action to apply to the ledger.
func (*ChaincodeActionPayload) Descriptor ¶
func (*ChaincodeActionPayload) Descriptor() ([]byte, []int)
func (*ChaincodeActionPayload) GetAction ¶
func (m *ChaincodeActionPayload) GetAction() *ChaincodeEndorsedAction
func (*ChaincodeActionPayload) GetChaincodeProposalPayload ¶
func (m *ChaincodeActionPayload) GetChaincodeProposalPayload() []byte
func (*ChaincodeActionPayload) ProtoMessage ¶
func (*ChaincodeActionPayload) ProtoMessage()
func (*ChaincodeActionPayload) Reset ¶
func (m *ChaincodeActionPayload) Reset()
func (*ChaincodeActionPayload) String ¶
func (m *ChaincodeActionPayload) String() string
type ChaincodeDeploymentSpec ¶
type ChaincodeDeploymentSpec struct { ChaincodeSpec *ChaincodeSpec `protobuf:"bytes,1,opt,name=chaincode_spec,json=chaincodeSpec" json:"chaincode_spec,omitempty"` CodePackage []byte `protobuf:"bytes,3,opt,name=code_package,json=codePackage,proto3" json:"code_package,omitempty"` ExecEnv ChaincodeDeploymentSpec_ExecutionEnvironment `` /* 133-byte string literal not displayed */ }
Specify the deployment of a chaincode. TODO: Define `codePackage`.
func (*ChaincodeDeploymentSpec) Descriptor ¶
func (*ChaincodeDeploymentSpec) Descriptor() ([]byte, []int)
func (*ChaincodeDeploymentSpec) GetChaincodeSpec ¶
func (m *ChaincodeDeploymentSpec) GetChaincodeSpec() *ChaincodeSpec
func (*ChaincodeDeploymentSpec) GetCodePackage ¶
func (m *ChaincodeDeploymentSpec) GetCodePackage() []byte
func (*ChaincodeDeploymentSpec) GetExecEnv ¶
func (m *ChaincodeDeploymentSpec) GetExecEnv() ChaincodeDeploymentSpec_ExecutionEnvironment
func (*ChaincodeDeploymentSpec) ProtoMessage ¶
func (*ChaincodeDeploymentSpec) ProtoMessage()
func (*ChaincodeDeploymentSpec) Reset ¶
func (m *ChaincodeDeploymentSpec) Reset()
func (*ChaincodeDeploymentSpec) String ¶
func (m *ChaincodeDeploymentSpec) String() string
type ChaincodeDeploymentSpec_ExecutionEnvironment ¶
type ChaincodeDeploymentSpec_ExecutionEnvironment int32
const ( ChaincodeDeploymentSpec_DOCKER ChaincodeDeploymentSpec_ExecutionEnvironment = 0 ChaincodeDeploymentSpec_SYSTEM ChaincodeDeploymentSpec_ExecutionEnvironment = 1 )
func (ChaincodeDeploymentSpec_ExecutionEnvironment) EnumDescriptor ¶
func (ChaincodeDeploymentSpec_ExecutionEnvironment) EnumDescriptor() ([]byte, []int)
func (ChaincodeDeploymentSpec_ExecutionEnvironment) String ¶
func (x ChaincodeDeploymentSpec_ExecutionEnvironment) String() string
type ChaincodeEndorsedAction ¶
type ChaincodeEndorsedAction struct { // This is the bytes of the ProposalResponsePayload message signed by the // endorsers. Recall that for the CHAINCODE type, the // ProposalResponsePayload's extenstion field carries a ChaincodeAction ProposalResponsePayload []byte `` /* 132-byte string literal not displayed */ // The endorsement of the proposal, basically the endorser's signature over // proposalResponsePayload Endorsements []*Endorsement `protobuf:"bytes,2,rep,name=endorsements" json:"endorsements,omitempty"` }
ChaincodeEndorsedAction carries information about the endorsement of a specific proposal
func (*ChaincodeEndorsedAction) Descriptor ¶
func (*ChaincodeEndorsedAction) Descriptor() ([]byte, []int)
func (*ChaincodeEndorsedAction) GetEndorsements ¶
func (m *ChaincodeEndorsedAction) GetEndorsements() []*Endorsement
func (*ChaincodeEndorsedAction) GetProposalResponsePayload ¶
func (m *ChaincodeEndorsedAction) GetProposalResponsePayload() []byte
func (*ChaincodeEndorsedAction) ProtoMessage ¶
func (*ChaincodeEndorsedAction) ProtoMessage()
func (*ChaincodeEndorsedAction) Reset ¶
func (m *ChaincodeEndorsedAction) Reset()
func (*ChaincodeEndorsedAction) String ¶
func (m *ChaincodeEndorsedAction) String() string
type ChaincodeEvent ¶
type ChaincodeEvent struct { ChaincodeId string `protobuf:"bytes,1,opt,name=chaincode_id,json=chaincodeId" json:"chaincode_id,omitempty"` TxId string `protobuf:"bytes,2,opt,name=tx_id,json=txId" json:"tx_id,omitempty"` EventName string `protobuf:"bytes,3,opt,name=event_name,json=eventName" json:"event_name,omitempty"` Payload []byte `protobuf:"bytes,4,opt,name=payload,proto3" json:"payload,omitempty"` }
ChaincodeEvent is used for events and registrations that are specific to chaincode string type - "chaincode"
func (*ChaincodeEvent) Descriptor ¶
func (*ChaincodeEvent) Descriptor() ([]byte, []int)
func (*ChaincodeEvent) GetChaincodeId ¶
func (m *ChaincodeEvent) GetChaincodeId() string
func (*ChaincodeEvent) GetEventName ¶
func (m *ChaincodeEvent) GetEventName() string
func (*ChaincodeEvent) GetPayload ¶
func (m *ChaincodeEvent) GetPayload() []byte
func (*ChaincodeEvent) GetTxId ¶
func (m *ChaincodeEvent) GetTxId() string
func (*ChaincodeEvent) ProtoMessage ¶
func (*ChaincodeEvent) ProtoMessage()
func (*ChaincodeEvent) Reset ¶
func (m *ChaincodeEvent) Reset()
func (*ChaincodeEvent) String ¶
func (m *ChaincodeEvent) String() string
type ChaincodeHeaderExtension ¶
type ChaincodeHeaderExtension struct { // The PayloadVisibility field controls to what extent the Proposal's payload // (recall that for the type CHAINCODE, it is ChaincodeProposalPayload // message) field will be visible in the final transaction and in the ledger. // Ideally, it would be configurable, supporting at least 3 main visibility // modes: // 1. all bytes of the payload are visible; // 2. only a hash of the payload is visible; // 3. nothing is visible. // Notice that the visibility function may be potentially part of the ESCC. // In that case it overrides PayloadVisibility field. Finally notice that // this field impacts the content of ProposalResponsePayload.proposalHash. PayloadVisibility []byte `protobuf:"bytes,1,opt,name=payload_visibility,json=payloadVisibility,proto3" json:"payload_visibility,omitempty"` // The ID of the chaincode to target. ChaincodeId *ChaincodeID `protobuf:"bytes,2,opt,name=chaincode_id,json=chaincodeId" json:"chaincode_id,omitempty"` }
ChaincodeHeaderExtension is the Header's extentions message to be used when the Header's type is CHAINCODE. This extensions is used to specify which chaincode to invoke and what should appear on the ledger.
func (*ChaincodeHeaderExtension) Descriptor ¶
func (*ChaincodeHeaderExtension) Descriptor() ([]byte, []int)
func (*ChaincodeHeaderExtension) GetChaincodeId ¶
func (m *ChaincodeHeaderExtension) GetChaincodeId() *ChaincodeID
func (*ChaincodeHeaderExtension) GetPayloadVisibility ¶
func (m *ChaincodeHeaderExtension) GetPayloadVisibility() []byte
func (*ChaincodeHeaderExtension) ProtoMessage ¶
func (*ChaincodeHeaderExtension) ProtoMessage()
func (*ChaincodeHeaderExtension) Reset ¶
func (m *ChaincodeHeaderExtension) Reset()
func (*ChaincodeHeaderExtension) String ¶
func (m *ChaincodeHeaderExtension) String() string
type ChaincodeID ¶
type ChaincodeID struct { // deploy transaction will use the path Path string `protobuf:"bytes,1,opt,name=path" json:"path,omitempty"` // all other requests will use the name (really a hashcode) generated by // the deploy transaction Name string `protobuf:"bytes,2,opt,name=name" json:"name,omitempty"` // user friendly version name for the chaincode Version string `protobuf:"bytes,3,opt,name=version" json:"version,omitempty"` }
ChaincodeID contains the path as specified by the deploy transaction that created it as well as the hashCode that is generated by the system for the path. From the user level (ie, CLI, REST API and so on) deploy transaction is expected to provide the path and other requests are expected to provide the hashCode. The other value will be ignored. Internally, the structure could contain both values. For instance, the hashCode will be set when first generated using the path
func (*ChaincodeID) Descriptor ¶
func (*ChaincodeID) Descriptor() ([]byte, []int)
func (*ChaincodeID) GetName ¶
func (m *ChaincodeID) GetName() string
func (*ChaincodeID) GetPath ¶
func (m *ChaincodeID) GetPath() string
func (*ChaincodeID) GetVersion ¶
func (m *ChaincodeID) GetVersion() string
func (*ChaincodeID) ProtoMessage ¶
func (*ChaincodeID) ProtoMessage()
func (*ChaincodeID) Reset ¶
func (m *ChaincodeID) Reset()
func (*ChaincodeID) String ¶
func (m *ChaincodeID) String() string
type ChaincodeInfo ¶
type ChaincodeInfo struct { Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` Version string `protobuf:"bytes,2,opt,name=version" json:"version,omitempty"` // the path as specified by the install/instantiate transaction Path string `protobuf:"bytes,3,opt,name=path" json:"path,omitempty"` // the chaincode function upon instantiation and its arguments. This will be // blank if the query is returning information about installed chaincodes. Input string `protobuf:"bytes,4,opt,name=input" json:"input,omitempty"` // the name of the ESCC for this chaincode. This will be // blank if the query is returning information about installed chaincodes. Escc string `protobuf:"bytes,5,opt,name=escc" json:"escc,omitempty"` // the name of the VSCC for this chaincode. This will be // blank if the query is returning information about installed chaincodes. Vscc string `protobuf:"bytes,6,opt,name=vscc" json:"vscc,omitempty"` // the chaincode unique id. // computed as: H( // H(name || version) || // H(CodePackage) // ) Id []byte `protobuf:"bytes,7,opt,name=id,proto3" json:"id,omitempty"` }
ChaincodeInfo contains general information about an installed/instantiated chaincode
func (*ChaincodeInfo) Descriptor ¶
func (*ChaincodeInfo) Descriptor() ([]byte, []int)
func (*ChaincodeInfo) GetEscc ¶
func (m *ChaincodeInfo) GetEscc() string
func (*ChaincodeInfo) GetId ¶
func (m *ChaincodeInfo) GetId() []byte
func (*ChaincodeInfo) GetInput ¶
func (m *ChaincodeInfo) GetInput() string
func (*ChaincodeInfo) GetName ¶
func (m *ChaincodeInfo) GetName() string
func (*ChaincodeInfo) GetPath ¶
func (m *ChaincodeInfo) GetPath() string
func (*ChaincodeInfo) GetVersion ¶
func (m *ChaincodeInfo) GetVersion() string
func (*ChaincodeInfo) GetVscc ¶
func (m *ChaincodeInfo) GetVscc() string
func (*ChaincodeInfo) ProtoMessage ¶
func (*ChaincodeInfo) ProtoMessage()
func (*ChaincodeInfo) Reset ¶
func (m *ChaincodeInfo) Reset()
func (*ChaincodeInfo) String ¶
func (m *ChaincodeInfo) String() string
type ChaincodeInput ¶
type ChaincodeInput struct { Args [][]byte `protobuf:"bytes,1,rep,name=args,proto3" json:"args,omitempty"` Decorations map[string][]byte `` /* 149-byte string literal not displayed */ }
Carries the chaincode function and its arguments. UnmarshalJSON in transaction.go converts the string-based REST/JSON input to the []byte-based current ChaincodeInput structure.
func (*ChaincodeInput) Descriptor ¶
func (*ChaincodeInput) Descriptor() ([]byte, []int)
func (*ChaincodeInput) GetArgs ¶
func (m *ChaincodeInput) GetArgs() [][]byte
func (*ChaincodeInput) GetDecorations ¶
func (m *ChaincodeInput) GetDecorations() map[string][]byte
func (*ChaincodeInput) ProtoMessage ¶
func (*ChaincodeInput) ProtoMessage()
func (*ChaincodeInput) Reset ¶
func (m *ChaincodeInput) Reset()
func (*ChaincodeInput) String ¶
func (m *ChaincodeInput) String() string
type ChaincodeInvocationSpec ¶
type ChaincodeInvocationSpec struct {
ChaincodeSpec *ChaincodeSpec `protobuf:"bytes,1,opt,name=chaincode_spec,json=chaincodeSpec" json:"chaincode_spec,omitempty"`
}
Carries the chaincode function and its arguments.
func (*ChaincodeInvocationSpec) Descriptor ¶
func (*ChaincodeInvocationSpec) Descriptor() ([]byte, []int)
func (*ChaincodeInvocationSpec) GetChaincodeSpec ¶
func (m *ChaincodeInvocationSpec) GetChaincodeSpec() *ChaincodeSpec
func (*ChaincodeInvocationSpec) ProtoMessage ¶
func (*ChaincodeInvocationSpec) ProtoMessage()
func (*ChaincodeInvocationSpec) Reset ¶
func (m *ChaincodeInvocationSpec) Reset()
func (*ChaincodeInvocationSpec) String ¶
func (m *ChaincodeInvocationSpec) String() string
type ChaincodeProposalPayload ¶
type ChaincodeProposalPayload struct { // Input contains the arguments for this invocation. If this invocation // deploys a new chaincode, ESCC/VSCC are part of this field. // This is usually a marshaled ChaincodeInvocationSpec Input []byte `protobuf:"bytes,1,opt,name=input,proto3" json:"input,omitempty"` // TransientMap contains data (e.g. cryptographic material) that might be used // to implement some form of application-level confidentiality. The contents // of this field are supposed to always be omitted from the transaction and // excluded from the ledger. TransientMap map[string][]byte `` /* 151-byte string literal not displayed */ }
ChaincodeProposalPayload is the Proposal's payload message to be used when the Header's type is CHAINCODE. It contains the arguments for this invocation.
func (*ChaincodeProposalPayload) Descriptor ¶
func (*ChaincodeProposalPayload) Descriptor() ([]byte, []int)
func (*ChaincodeProposalPayload) GetInput ¶
func (m *ChaincodeProposalPayload) GetInput() []byte
func (*ChaincodeProposalPayload) GetTransientMap ¶
func (m *ChaincodeProposalPayload) GetTransientMap() map[string][]byte
func (*ChaincodeProposalPayload) ProtoMessage ¶
func (*ChaincodeProposalPayload) ProtoMessage()
func (*ChaincodeProposalPayload) Reset ¶
func (m *ChaincodeProposalPayload) Reset()
func (*ChaincodeProposalPayload) String ¶
func (m *ChaincodeProposalPayload) String() string
type ChaincodeQueryResponse ¶
type ChaincodeQueryResponse struct {
Chaincodes []*ChaincodeInfo `protobuf:"bytes,1,rep,name=chaincodes" json:"chaincodes,omitempty"`
}
ChaincodeQueryResponse returns information about each chaincode that pertains to a query in lscc.go, such as GetChaincodes (returns all chaincodes instantiated on a channel), and GetInstalledChaincodes (returns all chaincodes installed on a peer)
func (*ChaincodeQueryResponse) Descriptor ¶
func (*ChaincodeQueryResponse) Descriptor() ([]byte, []int)
func (*ChaincodeQueryResponse) GetChaincodes ¶
func (m *ChaincodeQueryResponse) GetChaincodes() []*ChaincodeInfo
func (*ChaincodeQueryResponse) ProtoMessage ¶
func (*ChaincodeQueryResponse) ProtoMessage()
func (*ChaincodeQueryResponse) Reset ¶
func (m *ChaincodeQueryResponse) Reset()
func (*ChaincodeQueryResponse) String ¶
func (m *ChaincodeQueryResponse) String() string
type ChaincodeReg ¶
type ChaincodeReg struct { ChaincodeId string `protobuf:"bytes,1,opt,name=chaincode_id,json=chaincodeId" json:"chaincode_id,omitempty"` EventName string `protobuf:"bytes,2,opt,name=event_name,json=eventName" json:"event_name,omitempty"` }
ChaincodeReg is used for registering chaincode Interests when EventType is CHAINCODE
func (*ChaincodeReg) Descriptor ¶
func (*ChaincodeReg) Descriptor() ([]byte, []int)
func (*ChaincodeReg) GetChaincodeId ¶
func (m *ChaincodeReg) GetChaincodeId() string
func (*ChaincodeReg) GetEventName ¶
func (m *ChaincodeReg) GetEventName() string
func (*ChaincodeReg) ProtoMessage ¶
func (*ChaincodeReg) ProtoMessage()
func (*ChaincodeReg) Reset ¶
func (m *ChaincodeReg) Reset()
func (*ChaincodeReg) String ¶
func (m *ChaincodeReg) String() string
type ChaincodeSpec ¶
type ChaincodeSpec struct { Type ChaincodeSpec_Type `protobuf:"varint,1,opt,name=type,enum=protos.ChaincodeSpec_Type" json:"type,omitempty"` ChaincodeId *ChaincodeID `protobuf:"bytes,2,opt,name=chaincode_id,json=chaincodeId" json:"chaincode_id,omitempty"` Input *ChaincodeInput `protobuf:"bytes,3,opt,name=input" json:"input,omitempty"` Timeout int32 `protobuf:"varint,4,opt,name=timeout" json:"timeout,omitempty"` }
Carries the chaincode specification. This is the actual metadata required for defining a chaincode.
func (*ChaincodeSpec) Descriptor ¶
func (*ChaincodeSpec) Descriptor() ([]byte, []int)
func (*ChaincodeSpec) GetChaincodeId ¶
func (m *ChaincodeSpec) GetChaincodeId() *ChaincodeID
func (*ChaincodeSpec) GetInput ¶
func (m *ChaincodeSpec) GetInput() *ChaincodeInput
func (*ChaincodeSpec) GetTimeout ¶
func (m *ChaincodeSpec) GetTimeout() int32
func (*ChaincodeSpec) GetType ¶
func (m *ChaincodeSpec) GetType() ChaincodeSpec_Type
func (*ChaincodeSpec) ProtoMessage ¶
func (*ChaincodeSpec) ProtoMessage()
func (*ChaincodeSpec) Reset ¶
func (m *ChaincodeSpec) Reset()
func (*ChaincodeSpec) String ¶
func (m *ChaincodeSpec) String() string
type ChaincodeSpec_Type ¶
type ChaincodeSpec_Type int32
const ( ChaincodeSpec_UNDEFINED ChaincodeSpec_Type = 0 ChaincodeSpec_GOLANG ChaincodeSpec_Type = 1 ChaincodeSpec_NODE ChaincodeSpec_Type = 2 ChaincodeSpec_CAR ChaincodeSpec_Type = 3 ChaincodeSpec_JAVA ChaincodeSpec_Type = 4 )
func (ChaincodeSpec_Type) EnumDescriptor ¶
func (ChaincodeSpec_Type) EnumDescriptor() ([]byte, []int)
func (ChaincodeSpec_Type) String ¶
func (x ChaincodeSpec_Type) String() string
type ChannelInfo ¶
type ChannelInfo struct {
ChannelId string `protobuf:"bytes,1,opt,name=channel_id,json=channelId" json:"channel_id,omitempty"`
}
ChannelInfo contains general information about channels
func (*ChannelInfo) Descriptor ¶
func (*ChannelInfo) Descriptor() ([]byte, []int)
func (*ChannelInfo) GetChannelId ¶
func (m *ChannelInfo) GetChannelId() string
func (*ChannelInfo) ProtoMessage ¶
func (*ChannelInfo) ProtoMessage()
func (*ChannelInfo) Reset ¶
func (m *ChannelInfo) Reset()
func (*ChannelInfo) String ¶
func (m *ChannelInfo) String() string
type ChannelQueryResponse ¶
type ChannelQueryResponse struct {
Channels []*ChannelInfo `protobuf:"bytes,1,rep,name=channels" json:"channels,omitempty"`
}
ChannelQueryResponse returns information about each channel that pertains to a query in lscc.go, such as GetChannels (returns all channels for a given peer)
func (*ChannelQueryResponse) Descriptor ¶
func (*ChannelQueryResponse) Descriptor() ([]byte, []int)
func (*ChannelQueryResponse) GetChannels ¶
func (m *ChannelQueryResponse) GetChannels() []*ChannelInfo
func (*ChannelQueryResponse) ProtoMessage ¶
func (*ChannelQueryResponse) ProtoMessage()
func (*ChannelQueryResponse) Reset ¶
func (m *ChannelQueryResponse) Reset()
func (*ChannelQueryResponse) String ¶
func (m *ChannelQueryResponse) String() string
type ConfidentialityLevel ¶
type ConfidentialityLevel int32
Confidentiality Levels
const ( ConfidentialityLevel_PUBLIC ConfidentialityLevel = 0 ConfidentialityLevel_CONFIDENTIAL ConfidentialityLevel = 1 )
func (ConfidentialityLevel) EnumDescriptor ¶
func (ConfidentialityLevel) EnumDescriptor() ([]byte, []int)
func (ConfidentialityLevel) String ¶
func (x ConfidentialityLevel) String() string
type DeliverClient ¶
type DeliverClient interface { // deliver first requires an Envelope of type ab.DELIVER_SEEK_INFO with Payload data as a marshaled orderer.SeekInfo message, // then a stream of block replies is received. Deliver(ctx context.Context, opts ...grpc.CallOption) (Deliver_DeliverClient, error) // deliver first requires an Envelope of type ab.DELIVER_SEEK_INFO with Payload data as a marshaled orderer.SeekInfo message, // then a stream of **filtered** block replies is received. DeliverFiltered(ctx context.Context, opts ...grpc.CallOption) (Deliver_DeliverFilteredClient, error) }
func NewDeliverClient ¶
func NewDeliverClient(cc *grpc.ClientConn) DeliverClient
type DeliverResponse ¶
type DeliverResponse struct { // Types that are valid to be assigned to Type: // *DeliverResponse_Status // *DeliverResponse_Block // *DeliverResponse_FilteredBlock Type isDeliverResponse_Type `protobuf_oneof:"Type"` }
DeliverResponse
func (*DeliverResponse) Descriptor ¶
func (*DeliverResponse) Descriptor() ([]byte, []int)
func (*DeliverResponse) GetBlock ¶
func (m *DeliverResponse) GetBlock() *common.Block
func (*DeliverResponse) GetFilteredBlock ¶
func (m *DeliverResponse) GetFilteredBlock() *FilteredBlock
func (*DeliverResponse) GetStatus ¶
func (m *DeliverResponse) GetStatus() common.Status
func (*DeliverResponse) GetType ¶
func (m *DeliverResponse) GetType() isDeliverResponse_Type
func (*DeliverResponse) ProtoMessage ¶
func (*DeliverResponse) ProtoMessage()
func (*DeliverResponse) Reset ¶
func (m *DeliverResponse) Reset()
func (*DeliverResponse) String ¶
func (m *DeliverResponse) String() string
func (*DeliverResponse) XXX_OneofFuncs ¶
func (*DeliverResponse) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{})
XXX_OneofFuncs is for the internal use of the proto package.
type DeliverResponse_Block ¶
type DeliverResponse_FilteredBlock ¶
type DeliverResponse_FilteredBlock struct {
FilteredBlock *FilteredBlock `protobuf:"bytes,3,opt,name=filtered_block,json=filteredBlock,oneof"`
}
type DeliverResponse_Status ¶
type DeliverServer ¶
type DeliverServer interface { // deliver first requires an Envelope of type ab.DELIVER_SEEK_INFO with Payload data as a marshaled orderer.SeekInfo message, // then a stream of block replies is received. Deliver(Deliver_DeliverServer) error // deliver first requires an Envelope of type ab.DELIVER_SEEK_INFO with Payload data as a marshaled orderer.SeekInfo message, // then a stream of **filtered** block replies is received. DeliverFiltered(Deliver_DeliverFilteredServer) error }
type Deliver_DeliverClient ¶
type Deliver_DeliverClient interface { Send(*common.Envelope) error Recv() (*DeliverResponse, error) grpc.ClientStream }
type Deliver_DeliverFilteredClient ¶
type Deliver_DeliverFilteredClient interface { Send(*common.Envelope) error Recv() (*DeliverResponse, error) grpc.ClientStream }
type Deliver_DeliverFilteredServer ¶
type Deliver_DeliverFilteredServer interface { Send(*DeliverResponse) error Recv() (*common.Envelope, error) grpc.ServerStream }
type Deliver_DeliverServer ¶
type Deliver_DeliverServer interface { Send(*DeliverResponse) error Recv() (*common.Envelope, error) grpc.ServerStream }
type Endorsement ¶
type Endorsement struct { // Identity of the endorser (e.g. its certificate) Endorser []byte `protobuf:"bytes,1,opt,name=endorser,proto3" json:"endorser,omitempty"` // Signature of the payload included in ProposalResponse concatenated with // the endorser's certificate; ie, sign(ProposalResponse.payload + endorser) Signature []byte `protobuf:"bytes,2,opt,name=signature,proto3" json:"signature,omitempty"` }
An endorsement is a signature of an endorser over a proposal response. By producing an endorsement message, an endorser implicitly "approves" that proposal response and the actions contained therein. When enough endorsements have been collected, a transaction can be generated out of a set of proposal responses. Note that this message only contains an identity and a signature but no signed payload. This is intentional because endorsements are supposed to be collected in a transaction, and they are all expected to endorse a single proposal response/action (many endorsements over a single proposal response)
func (*Endorsement) Descriptor ¶
func (*Endorsement) Descriptor() ([]byte, []int)
func (*Endorsement) GetEndorser ¶
func (m *Endorsement) GetEndorser() []byte
func (*Endorsement) GetSignature ¶
func (m *Endorsement) GetSignature() []byte
func (*Endorsement) ProtoMessage ¶
func (*Endorsement) ProtoMessage()
func (*Endorsement) Reset ¶
func (m *Endorsement) Reset()
func (*Endorsement) String ¶
func (m *Endorsement) String() string
type EndorserClient ¶
type EndorserClient interface {
ProcessProposal(ctx context.Context, in *SignedProposal, opts ...grpc.CallOption) (*ProposalResponse, error)
}
func NewEndorserClient ¶
func NewEndorserClient(cc *grpc.ClientConn) EndorserClient
type EndorserServer ¶
type EndorserServer interface {
ProcessProposal(context.Context, *SignedProposal) (*ProposalResponse, error)
}
type Event ¶
type Event struct { // Types that are valid to be assigned to Event: // *Event_Register // *Event_Block // *Event_ChaincodeEvent // *Event_Rejection // *Event_Unregister // *Event_FilteredBlock Event isEvent_Event `protobuf_oneof:"Event"` // Creator of the event, specified as a certificate chain Creator []byte `protobuf:"bytes,6,opt,name=creator,proto3" json:"creator,omitempty"` // Timestamp of the client - used to mitigate replay attacks Timestamp *google_protobuf1.Timestamp `protobuf:"bytes,8,opt,name=timestamp" json:"timestamp,omitempty"` // If mutual TLS is employed, this represents // the hash of the client's TLS certificate TlsCertHash []byte `protobuf:"bytes,9,opt,name=tls_cert_hash,json=tlsCertHash,proto3" json:"tls_cert_hash,omitempty"` }
Event is used by
- consumers (adapters) to send Register
- producer to advertise supported types and events
func (*Event) Descriptor ¶
func (*Event) GetChaincodeEvent ¶
func (m *Event) GetChaincodeEvent() *ChaincodeEvent
func (*Event) GetCreator ¶
func (*Event) GetFilteredBlock ¶
func (m *Event) GetFilteredBlock() *FilteredBlock
func (*Event) GetRegister ¶
func (*Event) GetRejection ¶
func (*Event) GetTimestamp ¶
func (m *Event) GetTimestamp() *google_protobuf1.Timestamp
func (*Event) GetTlsCertHash ¶
func (*Event) GetUnregister ¶
func (m *Event) GetUnregister() *Unregister
func (*Event) ProtoMessage ¶
func (*Event) ProtoMessage()
type Event_Block ¶
type Event_ChaincodeEvent ¶
type Event_ChaincodeEvent struct {
ChaincodeEvent *ChaincodeEvent `protobuf:"bytes,3,opt,name=chaincode_event,json=chaincodeEvent,oneof"`
}
type Event_FilteredBlock ¶
type Event_FilteredBlock struct {
FilteredBlock *FilteredBlock `protobuf:"bytes,7,opt,name=filtered_block,json=filteredBlock,oneof"`
}
type Event_Register ¶
type Event_Register struct {
Register *Register `protobuf:"bytes,1,opt,name=register,oneof"`
}
type Event_Rejection ¶
type Event_Rejection struct {
Rejection *Rejection `protobuf:"bytes,4,opt,name=rejection,oneof"`
}
type Event_Unregister ¶
type Event_Unregister struct {
Unregister *Unregister `protobuf:"bytes,5,opt,name=unregister,oneof"`
}
type EventsClient ¶
type EventsClient interface { // event chatting using Event Chat(ctx context.Context, opts ...grpc.CallOption) (Events_ChatClient, error) }
func NewEventsClient ¶
func NewEventsClient(cc *grpc.ClientConn) EventsClient
type EventsServer ¶
type EventsServer interface { // event chatting using Event Chat(Events_ChatServer) error }
type Events_ChatClient ¶
type Events_ChatClient interface { Send(*SignedEvent) error Recv() (*Event, error) grpc.ClientStream }
type Events_ChatServer ¶
type Events_ChatServer interface { Send(*Event) error Recv() (*SignedEvent, error) grpc.ServerStream }
type FilteredBlock ¶
type FilteredBlock struct { ChannelId string `protobuf:"bytes,1,opt,name=channel_id,json=channelId" json:"channel_id,omitempty"` Number uint64 `protobuf:"varint,2,opt,name=number" json:"number,omitempty"` FilteredTransactions []*FilteredTransaction `protobuf:"bytes,4,rep,name=filtered_transactions,json=filteredTransactions" json:"filtered_transactions,omitempty"` }
FilteredBlock is sent by producers and contains minimal information about the block.
func (*FilteredBlock) Descriptor ¶
func (*FilteredBlock) Descriptor() ([]byte, []int)
func (*FilteredBlock) GetChannelId ¶
func (m *FilteredBlock) GetChannelId() string
func (*FilteredBlock) GetFilteredTransactions ¶
func (m *FilteredBlock) GetFilteredTransactions() []*FilteredTransaction
func (*FilteredBlock) GetNumber ¶
func (m *FilteredBlock) GetNumber() uint64
func (*FilteredBlock) ProtoMessage ¶
func (*FilteredBlock) ProtoMessage()
func (*FilteredBlock) Reset ¶
func (m *FilteredBlock) Reset()
func (*FilteredBlock) String ¶
func (m *FilteredBlock) String() string
type FilteredChaincodeAction ¶
type FilteredChaincodeAction struct {
ChaincodeEvent *ChaincodeEvent `protobuf:"bytes,1,opt,name=chaincode_event,json=chaincodeEvent" json:"chaincode_event,omitempty"`
}
FilteredChaincodeAction is a minimal set of information about an action within a transaction.
func (*FilteredChaincodeAction) Descriptor ¶
func (*FilteredChaincodeAction) Descriptor() ([]byte, []int)
func (*FilteredChaincodeAction) GetChaincodeEvent ¶
func (m *FilteredChaincodeAction) GetChaincodeEvent() *ChaincodeEvent
func (*FilteredChaincodeAction) ProtoMessage ¶
func (*FilteredChaincodeAction) ProtoMessage()
func (*FilteredChaincodeAction) Reset ¶
func (m *FilteredChaincodeAction) Reset()
func (*FilteredChaincodeAction) String ¶
func (m *FilteredChaincodeAction) String() string
type FilteredTransaction ¶
type FilteredTransaction struct { Txid string `protobuf:"bytes,1,opt,name=txid" json:"txid,omitempty"` Type common.HeaderType `protobuf:"varint,2,opt,name=type,enum=common.HeaderType" json:"type,omitempty"` TxValidationCode TxValidationCode `` /* 134-byte string literal not displayed */ // Types that are valid to be assigned to Data: // *FilteredTransaction_TransactionActions Data isFilteredTransaction_Data `protobuf_oneof:"Data"` }
FilteredTransaction is a minimal set of information about a transaction within a block.
func (*FilteredTransaction) Descriptor ¶
func (*FilteredTransaction) Descriptor() ([]byte, []int)
func (*FilteredTransaction) GetData ¶
func (m *FilteredTransaction) GetData() isFilteredTransaction_Data
func (*FilteredTransaction) GetTransactionActions ¶
func (m *FilteredTransaction) GetTransactionActions() *FilteredTransactionActions
func (*FilteredTransaction) GetTxValidationCode ¶
func (m *FilteredTransaction) GetTxValidationCode() TxValidationCode
func (*FilteredTransaction) GetTxid ¶
func (m *FilteredTransaction) GetTxid() string
func (*FilteredTransaction) GetType ¶
func (m *FilteredTransaction) GetType() common.HeaderType
func (*FilteredTransaction) ProtoMessage ¶
func (*FilteredTransaction) ProtoMessage()
func (*FilteredTransaction) Reset ¶
func (m *FilteredTransaction) Reset()
func (*FilteredTransaction) String ¶
func (m *FilteredTransaction) String() string
func (*FilteredTransaction) XXX_OneofFuncs ¶
func (*FilteredTransaction) XXX_OneofFuncs() (func(msg proto.Message, b *proto.Buffer) error, func(msg proto.Message, tag, wire int, b *proto.Buffer) (bool, error), func(msg proto.Message) (n int), []interface{})
XXX_OneofFuncs is for the internal use of the proto package.
type FilteredTransactionActions ¶
type FilteredTransactionActions struct {
ChaincodeActions []*FilteredChaincodeAction `protobuf:"bytes,1,rep,name=chaincode_actions,json=chaincodeActions" json:"chaincode_actions,omitempty"`
}
FilteredTransactionActions is a wrapper for array of TransactionAction message from regular block
func (*FilteredTransactionActions) Descriptor ¶
func (*FilteredTransactionActions) Descriptor() ([]byte, []int)
func (*FilteredTransactionActions) GetChaincodeActions ¶
func (m *FilteredTransactionActions) GetChaincodeActions() []*FilteredChaincodeAction
func (*FilteredTransactionActions) ProtoMessage ¶
func (*FilteredTransactionActions) ProtoMessage()
func (*FilteredTransactionActions) Reset ¶
func (m *FilteredTransactionActions) Reset()
func (*FilteredTransactionActions) String ¶
func (m *FilteredTransactionActions) String() string
type FilteredTransaction_TransactionActions ¶
type FilteredTransaction_TransactionActions struct {
TransactionActions *FilteredTransactionActions `protobuf:"bytes,4,opt,name=transaction_actions,json=transactionActions,oneof"`
}
type Interest ¶
type Interest struct { EventType EventType `protobuf:"varint,1,opt,name=event_type,json=eventType,enum=protos.EventType" json:"event_type,omitempty"` // Ideally we should just have the following oneof for different // Reg types and get rid of EventType. But this is an API change // Additional Reg types may add messages specific to their type // to the oneof. // // Types that are valid to be assigned to RegInfo: // *Interest_ChaincodeRegInfo RegInfo isInterest_RegInfo `protobuf_oneof:"RegInfo"` ChainID string `protobuf:"bytes,3,opt,name=chainID" json:"chainID,omitempty"` }
func (*Interest) Descriptor ¶
func (*Interest) GetChainID ¶
func (*Interest) GetChaincodeRegInfo ¶
func (m *Interest) GetChaincodeRegInfo() *ChaincodeReg
func (*Interest) GetEventType ¶
func (*Interest) GetRegInfo ¶
func (m *Interest) GetRegInfo() isInterest_RegInfo
func (*Interest) ProtoMessage ¶
func (*Interest) ProtoMessage()
type Interest_ChaincodeRegInfo ¶
type Interest_ChaincodeRegInfo struct {
ChaincodeRegInfo *ChaincodeReg `protobuf:"bytes,2,opt,name=chaincode_reg_info,json=chaincodeRegInfo,oneof"`
}
type LifecycleEvent ¶
type LifecycleEvent struct {
ChaincodeName string `protobuf:"bytes,1,opt,name=chaincode_name,json=chaincodeName" json:"chaincode_name,omitempty"`
}
LifecycleEvent is used as the payload of the chaincode event emitted by LSCC
func (*LifecycleEvent) Descriptor ¶
func (*LifecycleEvent) Descriptor() ([]byte, []int)
func (*LifecycleEvent) GetChaincodeName ¶
func (m *LifecycleEvent) GetChaincodeName() string
func (*LifecycleEvent) ProtoMessage ¶
func (*LifecycleEvent) ProtoMessage()
func (*LifecycleEvent) Reset ¶
func (m *LifecycleEvent) Reset()
func (*LifecycleEvent) String ¶
func (m *LifecycleEvent) String() string
type PeerEndpoint ¶
type PeerEndpoint struct { Id *PeerID `protobuf:"bytes,1,opt,name=id" json:"id,omitempty"` Address string `protobuf:"bytes,2,opt,name=address" json:"address,omitempty"` }
func (*PeerEndpoint) Descriptor ¶
func (*PeerEndpoint) Descriptor() ([]byte, []int)
func (*PeerEndpoint) GetAddress ¶
func (m *PeerEndpoint) GetAddress() string
func (*PeerEndpoint) GetId ¶
func (m *PeerEndpoint) GetId() *PeerID
func (*PeerEndpoint) ProtoMessage ¶
func (*PeerEndpoint) ProtoMessage()
func (*PeerEndpoint) Reset ¶
func (m *PeerEndpoint) Reset()
func (*PeerEndpoint) String ¶
func (m *PeerEndpoint) String() string
type PeerID ¶
type PeerID struct {
Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"`
}
func (*PeerID) Descriptor ¶
func (*PeerID) ProtoMessage ¶
func (*PeerID) ProtoMessage()
type ProcessedTransaction ¶
type ProcessedTransaction struct { // An Envelope which includes a processed transaction TransactionEnvelope *common.Envelope `protobuf:"bytes,1,opt,name=transactionEnvelope" json:"transactionEnvelope,omitempty"` // An indication of whether the transaction was validated or invalidated by committing peer ValidationCode int32 `protobuf:"varint,2,opt,name=validationCode" json:"validationCode,omitempty"` }
ProcessedTransaction wraps an Envelope that includes a transaction along with an indication of whether the transaction was validated or invalidated by committing peer. The use case is that GetTransactionByID API needs to retrieve the transaction Envelope from block storage, and return it to a client, and indicate whether the transaction was validated or invalidated by committing peer. So that the originally submitted transaction Envelope is not modified, the ProcessedTransaction wrapper is returned.
func (*ProcessedTransaction) Descriptor ¶
func (*ProcessedTransaction) Descriptor() ([]byte, []int)
func (*ProcessedTransaction) GetTransactionEnvelope ¶
func (m *ProcessedTransaction) GetTransactionEnvelope() *common.Envelope
func (*ProcessedTransaction) GetValidationCode ¶
func (m *ProcessedTransaction) GetValidationCode() int32
func (*ProcessedTransaction) ProtoMessage ¶
func (*ProcessedTransaction) ProtoMessage()
func (*ProcessedTransaction) Reset ¶
func (m *ProcessedTransaction) Reset()
func (*ProcessedTransaction) String ¶
func (m *ProcessedTransaction) String() string
type Proposal ¶
type Proposal struct { // The header of the proposal. It is the bytes of the Header Header []byte `protobuf:"bytes,1,opt,name=header,proto3" json:"header,omitempty"` // The payload of the proposal as defined by the type in the proposal // header. Payload []byte `protobuf:"bytes,2,opt,name=payload,proto3" json:"payload,omitempty"` // Optional extensions to the proposal. Its content depends on the Header's // type field. For the type CHAINCODE, it might be the bytes of a // ChaincodeAction message. Extension []byte `protobuf:"bytes,3,opt,name=extension,proto3" json:"extension,omitempty"` }
A Proposal is sent to an endorser for endorsement. The proposal contains:
- A header which should be unmarshaled to a Header message. Note that Header is both the header of a Proposal and of a Transaction, in that i) both headers should be unmarshaled to this message; and ii) it is used to compute cryptographic hashes and signatures. The header has fields common to all proposals/transactions. In addition it has a type field for additional customization. An example of this is the ChaincodeHeaderExtension message used to extend the Header for type CHAINCODE.
- A payload whose type depends on the header's type field.
- An extension whose type depends on the header's type field.
Let us see an example. For type CHAINCODE (see the Header message), we have the following:
- The header is a Header message whose extensions field is a ChaincodeHeaderExtension message.
- The payload is a ChaincodeProposalPayload message.
- The extension is a ChaincodeAction that might be used to ask the endorsers to endorse a specific ChaincodeAction, thus emulating the submitting peer model.
func (*Proposal) Descriptor ¶
func (*Proposal) GetExtension ¶
func (*Proposal) GetPayload ¶
func (*Proposal) ProtoMessage ¶
func (*Proposal) ProtoMessage()
type ProposalResponse ¶
type ProposalResponse struct { // Version indicates message protocol version Version int32 `protobuf:"varint,1,opt,name=version" json:"version,omitempty"` // Timestamp is the time that the message // was created as defined by the sender Timestamp *google_protobuf1.Timestamp `protobuf:"bytes,2,opt,name=timestamp" json:"timestamp,omitempty"` // A response message indicating whether the // endorsement of the action was successful Response *Response `protobuf:"bytes,4,opt,name=response" json:"response,omitempty"` // The payload of response. It is the bytes of ProposalResponsePayload Payload []byte `protobuf:"bytes,5,opt,name=payload,proto3" json:"payload,omitempty"` // The endorsement of the proposal, basically // the endorser's signature over the payload Endorsement *Endorsement `protobuf:"bytes,6,opt,name=endorsement" json:"endorsement,omitempty"` }
A ProposalResponse is returned from an endorser to the proposal submitter. The idea is that this message contains the endorser's response to the request of a client to perform an action over a chaincode (or more generically on the ledger); the response might be success/error (conveyed in the Response field) together with a description of the action and a signature over it by that endorser. If a sufficient number of distinct endorsers agree on the same action and produce signature to that effect, a transaction can be generated and sent for ordering.
func (*ProposalResponse) Descriptor ¶
func (*ProposalResponse) Descriptor() ([]byte, []int)
func (*ProposalResponse) GetEndorsement ¶
func (m *ProposalResponse) GetEndorsement() *Endorsement
func (*ProposalResponse) GetPayload ¶
func (m *ProposalResponse) GetPayload() []byte
func (*ProposalResponse) GetResponse ¶
func (m *ProposalResponse) GetResponse() *Response
func (*ProposalResponse) GetTimestamp ¶
func (m *ProposalResponse) GetTimestamp() *google_protobuf1.Timestamp
func (*ProposalResponse) GetVersion ¶
func (m *ProposalResponse) GetVersion() int32
func (*ProposalResponse) ProtoMessage ¶
func (*ProposalResponse) ProtoMessage()
func (*ProposalResponse) Reset ¶
func (m *ProposalResponse) Reset()
func (*ProposalResponse) String ¶
func (m *ProposalResponse) String() string
type ProposalResponsePayload ¶
type ProposalResponsePayload struct { // Hash of the proposal that triggered this response. The hash is used to // link a response with its proposal, both for bookeeping purposes on an // asynchronous system and for security reasons (accountability, // non-repudiation). The hash usually covers the entire Proposal message // (byte-by-byte). However this implies that the hash can only be verified // if the entire proposal message is available when ProposalResponsePayload is // included in a transaction or stored in the ledger. For confidentiality // reasons, with chaincodes it might be undesirable to store the proposal // payload in the ledger. If the type is CHAINCODE, this is handled by // separating the proposal's header and // the payload: the header is always hashed in its entirety whereas the // payload can either be hashed fully, or only its hash may be hashed, or // nothing from the payload can be hashed. The PayloadVisibility field in the // Header's extension controls to which extent the proposal payload is // "visible" in the sense that was just explained. ProposalHash []byte `protobuf:"bytes,1,opt,name=proposal_hash,json=proposalHash,proto3" json:"proposal_hash,omitempty"` // Extension should be unmarshaled to a type-specific message. The type of // the extension in any proposal response depends on the type of the proposal // that the client selected when the proposal was initially sent out. In // particular, this information is stored in the type field of a Header. For // chaincode, it's a ChaincodeAction message Extension []byte `protobuf:"bytes,2,opt,name=extension,proto3" json:"extension,omitempty"` }
ProposalResponsePayload is the payload of a proposal response. This message is the "bridge" between the client's request and the endorser's action in response to that request. Concretely, for chaincodes, it contains a hashed representation of the proposal (proposalHash) and a representation of the chaincode state changes and events inside the extension field.
func (*ProposalResponsePayload) Descriptor ¶
func (*ProposalResponsePayload) Descriptor() ([]byte, []int)
func (*ProposalResponsePayload) GetExtension ¶
func (m *ProposalResponsePayload) GetExtension() []byte
func (*ProposalResponsePayload) GetProposalHash ¶
func (m *ProposalResponsePayload) GetProposalHash() []byte
func (*ProposalResponsePayload) ProtoMessage ¶
func (*ProposalResponsePayload) ProtoMessage()
func (*ProposalResponsePayload) Reset ¶
func (m *ProposalResponsePayload) Reset()
func (*ProposalResponsePayload) String ¶
func (m *ProposalResponsePayload) String() string
type Register ¶
type Register struct {
Events []*Interest `protobuf:"bytes,1,rep,name=events" json:"events,omitempty"`
}
---------- consumer events --------- Register is sent by consumers for registering events string type - "register"
func (*Register) Descriptor ¶
func (*Register) ProtoMessage ¶
func (*Register) ProtoMessage()
type Rejection ¶
type Rejection struct { Tx *Transaction `protobuf:"bytes,1,opt,name=tx" json:"tx,omitempty"` ErrorMsg string `protobuf:"bytes,2,opt,name=error_msg,json=errorMsg" json:"error_msg,omitempty"` }
Rejection is sent by consumers for erroneous transaction rejection events string type - "rejection"
func (*Rejection) Descriptor ¶
func (*Rejection) GetErrorMsg ¶
func (*Rejection) GetTx ¶
func (m *Rejection) GetTx() *Transaction
func (*Rejection) ProtoMessage ¶
func (*Rejection) ProtoMessage()
type Response ¶
type Response struct { // A status code that should follow the HTTP status codes. Status int32 `protobuf:"varint,1,opt,name=status" json:"status,omitempty"` // A message associated with the response code. Message string `protobuf:"bytes,2,opt,name=message" json:"message,omitempty"` // A payload that can be used to include metadata with this response. Payload []byte `protobuf:"bytes,3,opt,name=payload,proto3" json:"payload,omitempty"` }
A response with a representation similar to an HTTP response that can be used within another message.
func (*Response) Descriptor ¶
func (*Response) GetMessage ¶
func (*Response) GetPayload ¶
func (*Response) ProtoMessage ¶
func (*Response) ProtoMessage()
type SignedChaincodeDeploymentSpec ¶
type SignedChaincodeDeploymentSpec struct { // This is the bytes of the ChaincodeDeploymentSpec ChaincodeDeploymentSpec []byte `` /* 132-byte string literal not displayed */ // This is the instantiation policy which is identical in structure // to endorsement policy. This policy is checked by the VSCC at commit // time on the instantiation (all peers will get the same policy as it // will be part of the LSCC instantation record and will be part of the // hash as well) InstantiationPolicy []byte `protobuf:"bytes,2,opt,name=instantiation_policy,json=instantiationPolicy,proto3" json:"instantiation_policy,omitempty"` // The endorsements of the above deployment spec, the owner's signature over // chaincode_deployment_spec and Endorsement.endorser. OwnerEndorsements []*Endorsement `protobuf:"bytes,3,rep,name=owner_endorsements,json=ownerEndorsements" json:"owner_endorsements,omitempty"` }
SignedChaincodeDeploymentSpec carries the CDS along with endorsements
func (*SignedChaincodeDeploymentSpec) Descriptor ¶
func (*SignedChaincodeDeploymentSpec) Descriptor() ([]byte, []int)
func (*SignedChaincodeDeploymentSpec) GetChaincodeDeploymentSpec ¶
func (m *SignedChaincodeDeploymentSpec) GetChaincodeDeploymentSpec() []byte
func (*SignedChaincodeDeploymentSpec) GetInstantiationPolicy ¶
func (m *SignedChaincodeDeploymentSpec) GetInstantiationPolicy() []byte
func (*SignedChaincodeDeploymentSpec) GetOwnerEndorsements ¶
func (m *SignedChaincodeDeploymentSpec) GetOwnerEndorsements() []*Endorsement
func (*SignedChaincodeDeploymentSpec) ProtoMessage ¶
func (*SignedChaincodeDeploymentSpec) ProtoMessage()
func (*SignedChaincodeDeploymentSpec) Reset ¶
func (m *SignedChaincodeDeploymentSpec) Reset()
func (*SignedChaincodeDeploymentSpec) String ¶
func (m *SignedChaincodeDeploymentSpec) String() string
type SignedEvent ¶
type SignedEvent struct { // Signature over the event bytes Signature []byte `protobuf:"bytes,1,opt,name=signature,proto3" json:"signature,omitempty"` // Marshal of Event object EventBytes []byte `protobuf:"bytes,2,opt,name=eventBytes,proto3" json:"eventBytes,omitempty"` }
SignedEvent is used for any communication between consumer and producer
func (*SignedEvent) Descriptor ¶
func (*SignedEvent) Descriptor() ([]byte, []int)
func (*SignedEvent) GetEventBytes ¶
func (m *SignedEvent) GetEventBytes() []byte
func (*SignedEvent) GetSignature ¶
func (m *SignedEvent) GetSignature() []byte
func (*SignedEvent) ProtoMessage ¶
func (*SignedEvent) ProtoMessage()
func (*SignedEvent) Reset ¶
func (m *SignedEvent) Reset()
func (*SignedEvent) String ¶
func (m *SignedEvent) String() string
type SignedProposal ¶
type SignedProposal struct { // The bytes of Proposal ProposalBytes []byte `protobuf:"bytes,1,opt,name=proposal_bytes,json=proposalBytes,proto3" json:"proposal_bytes,omitempty"` // Signaure over proposalBytes; this signature is to be verified against // the creator identity contained in the header of the Proposal message // marshaled as proposalBytes Signature []byte `protobuf:"bytes,2,opt,name=signature,proto3" json:"signature,omitempty"` }
This structure is necessary to sign the proposal which contains the header and the payload. Without this structure, we would have to concatenate the header and the payload to verify the signature, which could be expensive with large payload
When an endorser receives a SignedProposal message, it should verify the signature over the proposal bytes. This verification requires the following steps:
- Verification of the validity of the certificate that was used to produce the signature. The certificate will be available once proposalBytes has been unmarshalled to a Proposal message, and Proposal.header has been unmarshalled to a Header message. While this unmarshalling-before-verifying might not be ideal, it is unavoidable because i) the signature needs to also protect the signing certificate; ii) it is desirable that Header is created once by the client and never changed (for the sake of accountability and non-repudiation). Note also that it is actually impossible to conclusively verify the validity of the certificate included in a Proposal, because the proposal needs to first be endorsed and ordered with respect to certificate expiration transactions. Still, it is useful to pre-filter expired certificates at this stage.
- Verification that the certificate is trusted (signed by a trusted CA) and that it is allowed to transact with us (with respect to some ACLs);
- Verification that the signature on proposalBytes is valid;
- Detect replay attacks;
func (*SignedProposal) Descriptor ¶
func (*SignedProposal) Descriptor() ([]byte, []int)
func (*SignedProposal) GetProposalBytes ¶
func (m *SignedProposal) GetProposalBytes() []byte
func (*SignedProposal) GetSignature ¶
func (m *SignedProposal) GetSignature() []byte
func (*SignedProposal) ProtoMessage ¶
func (*SignedProposal) ProtoMessage()
func (*SignedProposal) Reset ¶
func (m *SignedProposal) Reset()
func (*SignedProposal) String ¶
func (m *SignedProposal) String() string
type SignedTransaction ¶
type SignedTransaction struct { // The bytes of the Transaction. NDD TransactionBytes []byte `protobuf:"bytes,1,opt,name=transaction_bytes,json=transactionBytes,proto3" json:"transaction_bytes,omitempty"` // Signature of the transactionBytes The public key of the signature is in // the header field of TransactionAction There might be multiple // TransactionAction, so multiple headers, but there should be same // transactor identity (cert) in all headers Signature []byte `protobuf:"bytes,2,opt,name=signature,proto3" json:"signature,omitempty"` }
This message is necessary to facilitate the verification of the signature (in the signature field) over the bytes of the transaction (in the transactionBytes field).
func (*SignedTransaction) Descriptor ¶
func (*SignedTransaction) Descriptor() ([]byte, []int)
func (*SignedTransaction) GetSignature ¶
func (m *SignedTransaction) GetSignature() []byte
func (*SignedTransaction) GetTransactionBytes ¶
func (m *SignedTransaction) GetTransactionBytes() []byte
func (*SignedTransaction) ProtoMessage ¶
func (*SignedTransaction) ProtoMessage()
func (*SignedTransaction) Reset ¶
func (m *SignedTransaction) Reset()
func (*SignedTransaction) String ¶
func (m *SignedTransaction) String() string
type Transaction ¶
type Transaction struct { // The payload is an array of TransactionAction. An array is necessary to // accommodate multiple actions per transaction Actions []*TransactionAction `protobuf:"bytes,1,rep,name=actions" json:"actions,omitempty"` }
The transaction to be sent to the ordering service. A transaction contains one or more TransactionAction. Each TransactionAction binds a proposal to potentially multiple actions. The transaction is atomic meaning that either all actions in the transaction will be committed or none will. Note that while a Transaction might include more than one Header, the Header.creator field must be the same in each. A single client is free to issue a number of independent Proposal, each with their header (Header) and request payload (ChaincodeProposalPayload). Each proposal is independently endorsed generating an action (ProposalResponsePayload) with one signature per Endorser. Any number of independent proposals (and their action) might be included in a transaction to ensure that they are treated atomically.
func (*Transaction) Descriptor ¶
func (*Transaction) Descriptor() ([]byte, []int)
func (*Transaction) GetActions ¶
func (m *Transaction) GetActions() []*TransactionAction
func (*Transaction) ProtoMessage ¶
func (*Transaction) ProtoMessage()
func (*Transaction) Reset ¶
func (m *Transaction) Reset()
func (*Transaction) String ¶
func (m *Transaction) String() string
type TransactionAction ¶
type TransactionAction struct { // The header of the proposal action, which is the proposal header Header []byte `protobuf:"bytes,1,opt,name=header,proto3" json:"header,omitempty"` // The payload of the action as defined by the type in the header For // chaincode, it's the bytes of ChaincodeActionPayload Payload []byte `protobuf:"bytes,2,opt,name=payload,proto3" json:"payload,omitempty"` }
TransactionAction binds a proposal to its action. The type field in the header dictates the type of action to be applied to the ledger.
func (*TransactionAction) Descriptor ¶
func (*TransactionAction) Descriptor() ([]byte, []int)
func (*TransactionAction) GetHeader ¶
func (m *TransactionAction) GetHeader() []byte
func (*TransactionAction) GetPayload ¶
func (m *TransactionAction) GetPayload() []byte
func (*TransactionAction) ProtoMessage ¶
func (*TransactionAction) ProtoMessage()
func (*TransactionAction) Reset ¶
func (m *TransactionAction) Reset()
func (*TransactionAction) String ¶
func (m *TransactionAction) String() string
type TxValidationCode ¶
type TxValidationCode int32
const ( TxValidationCode_VALID TxValidationCode = 0 TxValidationCode_NIL_ENVELOPE TxValidationCode = 1 TxValidationCode_BAD_PAYLOAD TxValidationCode = 2 TxValidationCode_BAD_COMMON_HEADER TxValidationCode = 3 TxValidationCode_BAD_CREATOR_SIGNATURE TxValidationCode = 4 TxValidationCode_INVALID_ENDORSER_TRANSACTION TxValidationCode = 5 TxValidationCode_INVALID_CONFIG_TRANSACTION TxValidationCode = 6 TxValidationCode_UNSUPPORTED_TX_PAYLOAD TxValidationCode = 7 TxValidationCode_BAD_PROPOSAL_TXID TxValidationCode = 8 TxValidationCode_DUPLICATE_TXID TxValidationCode = 9 TxValidationCode_ENDORSEMENT_POLICY_FAILURE TxValidationCode = 10 TxValidationCode_MVCC_READ_CONFLICT TxValidationCode = 11 TxValidationCode_PHANTOM_READ_CONFLICT TxValidationCode = 12 TxValidationCode_UNKNOWN_TX_TYPE TxValidationCode = 13 TxValidationCode_TARGET_CHAIN_NOT_FOUND TxValidationCode = 14 TxValidationCode_MARSHAL_TX_ERROR TxValidationCode = 15 TxValidationCode_NIL_TXACTION TxValidationCode = 16 TxValidationCode_EXPIRED_CHAINCODE TxValidationCode = 17 TxValidationCode_CHAINCODE_VERSION_CONFLICT TxValidationCode = 18 TxValidationCode_BAD_HEADER_EXTENSION TxValidationCode = 19 TxValidationCode_BAD_CHANNEL_HEADER TxValidationCode = 20 TxValidationCode_BAD_RESPONSE_PAYLOAD TxValidationCode = 21 TxValidationCode_BAD_RWSET TxValidationCode = 22 TxValidationCode_ILLEGAL_WRITESET TxValidationCode = 23 TxValidationCode_NOT_VALIDATED TxValidationCode = 254 TxValidationCode_INVALID_OTHER_REASON TxValidationCode = 255 )
func (TxValidationCode) EnumDescriptor ¶
func (TxValidationCode) EnumDescriptor() ([]byte, []int)
func (TxValidationCode) String ¶
func (x TxValidationCode) String() string
type Unregister ¶
type Unregister struct {
Events []*Interest `protobuf:"bytes,1,rep,name=events" json:"events,omitempty"`
}
---------- producer events ---------
func (*Unregister) Descriptor ¶
func (*Unregister) Descriptor() ([]byte, []int)
func (*Unregister) GetEvents ¶
func (m *Unregister) GetEvents() []*Interest
func (*Unregister) ProtoMessage ¶
func (*Unregister) ProtoMessage()
func (*Unregister) Reset ¶
func (m *Unregister) Reset()
func (*Unregister) String ¶
func (m *Unregister) String() string