fabric-samples/off_chain_data/application-go/parser/endorserTransaction.go
Stanislav Jakuschevskij fd1a1fc38b
Add first batch of pull request rework
- 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>
2025-02-24 13:14:48 +01:00

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
}