mirror of
https://github.com/hyperledger/fabric-samples.git
synced 2026-06-17 23:45:10 +00:00
- update Application section in README
- remove param name in app.go
- add error checks in processor/block.go
- move vars from model to transact logic
- move newAsset to transact
- use ID for well-known initialisms
- move randomelement, randomnint and differentelement to transact
- remove AssertDefined
- blockTxIdsJoinedByComma: use standard library to join elements
- return nil, instead of []byte{}
- remove go routine in listen.go
- move cache to parser
- inline processor in listen.go
- move store to main package
- move util to main package
- fixed failing cache issue
- fixed staticcheck issues
- removed cache function, implemented caching in the structs and methods
Signed-off-by: Stanislav Jakuschevskij <stas@two-giants.com>
121 lines
4.2 KiB
Go
121 lines
4.2 KiB
Go
package parser
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/hyperledger/fabric-protos-go-apiv2/ledger/rwset"
|
|
"github.com/hyperledger/fabric-protos-go-apiv2/peer"
|
|
"google.golang.org/protobuf/proto"
|
|
)
|
|
|
|
type endorserTransaction struct {
|
|
transaction *peer.Transaction
|
|
cachedReadWriteSets []*readWriteSet
|
|
}
|
|
|
|
func parseEndorserTransaction(transaction *peer.Transaction) *endorserTransaction {
|
|
return &endorserTransaction{transaction, nil}
|
|
}
|
|
|
|
func (p *endorserTransaction) readWriteSets() ([]*readWriteSet, error) {
|
|
funcName := "readWriteSets"
|
|
|
|
if p.cachedReadWriteSets != nil {
|
|
return p.cachedReadWriteSets, nil
|
|
}
|
|
|
|
chaincodeActionPayloads, err := p.unmarshalChaincodeActionPayloads()
|
|
if err != nil {
|
|
return nil, fmt.Errorf("in %s: %w", funcName, err)
|
|
}
|
|
|
|
chaincodeEndorsedActions, err := p.extractChaincodeEndorsedActionsFrom(chaincodeActionPayloads)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("in %s: %w", funcName, err)
|
|
}
|
|
|
|
proposalResponsePayloads, err := p.unmarshalProposalResponsePayloadsFrom(chaincodeEndorsedActions)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("in %s: %w", funcName, err)
|
|
}
|
|
|
|
chaincodeActions, err := p.unmarshalChaincodeActionsFrom(proposalResponsePayloads)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("in %s: %w", funcName, err)
|
|
}
|
|
|
|
txReadWriteSets, err := p.unmarshalTxReadWriteSetsFrom(chaincodeActions)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("in %s: %w", funcName, err)
|
|
}
|
|
|
|
p.cachedReadWriteSets = p.parseReadWriteSets(txReadWriteSets)
|
|
|
|
return p.cachedReadWriteSets, nil
|
|
}
|
|
|
|
func (p *endorserTransaction) unmarshalChaincodeActionPayloads() ([]*peer.ChaincodeActionPayload, error) {
|
|
result := []*peer.ChaincodeActionPayload{}
|
|
for _, transactionAction := range p.transaction.GetActions() {
|
|
chaincodeActionPayload := &peer.ChaincodeActionPayload{}
|
|
if err := proto.Unmarshal(transactionAction.GetPayload(), chaincodeActionPayload); err != nil {
|
|
return nil, fmt.Errorf("in unmarshalChaincodeActionPayloads: %w", err)
|
|
}
|
|
|
|
result = append(result, chaincodeActionPayload)
|
|
}
|
|
return result, nil
|
|
}
|
|
|
|
func (*endorserTransaction) extractChaincodeEndorsedActionsFrom(chaincodeActionPayloads []*peer.ChaincodeActionPayload) ([]*peer.ChaincodeEndorsedAction, error) {
|
|
result := []*peer.ChaincodeEndorsedAction{}
|
|
for _, payload := range chaincodeActionPayloads {
|
|
result = append(result, payload.GetAction())
|
|
}
|
|
return result, nil
|
|
}
|
|
|
|
func (*endorserTransaction) unmarshalProposalResponsePayloadsFrom(chaincodeEndorsedActions []*peer.ChaincodeEndorsedAction) ([]*peer.ProposalResponsePayload, error) {
|
|
result := []*peer.ProposalResponsePayload{}
|
|
for _, endorsedAction := range chaincodeEndorsedActions {
|
|
proposalResponsePayload := &peer.ProposalResponsePayload{}
|
|
if err := proto.Unmarshal(endorsedAction.GetProposalResponsePayload(), proposalResponsePayload); err != nil {
|
|
return nil, fmt.Errorf("in unmarshalProposalResponsePayloadsFrom: %w", err)
|
|
}
|
|
result = append(result, proposalResponsePayload)
|
|
}
|
|
return result, nil
|
|
}
|
|
|
|
func (*endorserTransaction) unmarshalChaincodeActionsFrom(proposalResponsePayloads []*peer.ProposalResponsePayload) ([]*peer.ChaincodeAction, error) {
|
|
result := []*peer.ChaincodeAction{}
|
|
for _, proposalResponsePayload := range proposalResponsePayloads {
|
|
chaincodeAction := &peer.ChaincodeAction{}
|
|
if err := proto.Unmarshal(proposalResponsePayload.GetExtension(), chaincodeAction); err != nil {
|
|
return nil, fmt.Errorf("in unmarshalChaincodeActionsFrom: %w", err)
|
|
}
|
|
result = append(result, chaincodeAction)
|
|
}
|
|
return result, nil
|
|
}
|
|
|
|
func (*endorserTransaction) unmarshalTxReadWriteSetsFrom(chaincodeActions []*peer.ChaincodeAction) ([]*rwset.TxReadWriteSet, error) {
|
|
result := []*rwset.TxReadWriteSet{}
|
|
for _, chaincodeAction := range chaincodeActions {
|
|
txReadWriteSet := &rwset.TxReadWriteSet{}
|
|
if err := proto.Unmarshal(chaincodeAction.GetResults(), txReadWriteSet); err != nil {
|
|
return nil, fmt.Errorf("in unmarshalTxReadWriteSetsFrom: %w", err)
|
|
}
|
|
result = append(result, txReadWriteSet)
|
|
}
|
|
return result, nil
|
|
}
|
|
|
|
func (*endorserTransaction) parseReadWriteSets(txReadWriteSets []*rwset.TxReadWriteSet) []*readWriteSet {
|
|
result := []*readWriteSet{}
|
|
for _, txReadWriteSet := range txReadWriteSets {
|
|
parsedReadWriteSet := parseReadWriteSet(txReadWriteSet)
|
|
result = append(result, parsedReadWriteSet)
|
|
}
|
|
return result
|
|
}
|