fabric-samples/off_chain_data/application-go/transact.go
Stanislav Jakuschevskij dfd860d8e9
Execute transactions in go routines concurrently
Signed-off-by: Stanislav Jakuschevskij <stas@two-giants.com>
2025-02-24 13:14:48 +01:00

70 lines
1.5 KiB
Go

package main
import (
"fmt"
"sync"
atb "offChainData/contract"
"offChainData/utils"
"github.com/hyperledger/fabric-gateway/pkg/client"
"google.golang.org/grpc"
)
func transact(clientConnection *grpc.ClientConn) {
id, options := newConnectOptions(clientConnection)
gateway, err := client.Connect(id, options...)
if err != nil {
panic((err))
}
defer gateway.Close()
contract := gateway.GetNetwork(channelName).GetContract(chaincodeName)
smartContract := atb.NewAssetTransferBasic(contract)
app := newTransactApp(smartContract)
app.run()
}
type transactApp struct {
smartContract *atb.AssetTransferBasic
batchSize int
}
func newTransactApp(smartContract *atb.AssetTransferBasic) *transactApp {
return &transactApp{smartContract, 10}
}
func (t *transactApp) run() {
var wg sync.WaitGroup
for i := 0; i < t.batchSize; i++ {
wg.Add(1)
go func() {
defer wg.Done()
t.transact()
}()
}
wg.Wait()
}
func (t *transactApp) transact() {
anAsset := atb.NewAsset()
t.smartContract.CreateAsset(anAsset)
fmt.Println("Created asset", anAsset.ID)
// Transfer randomly 1 in 2 assets to a new owner.
if utils.RandomInt(2) == 0 {
newOwner := utils.DifferentElement(atb.Owners, anAsset.Owner)
oldOwner := t.smartContract.TransferAsset(anAsset.ID, newOwner)
fmt.Printf("Transferred asset %s from %s to %s\n", anAsset.ID, oldOwner, newOwner)
}
// Delete randomly 1 in 4 created assets.
if utils.RandomInt(4) == 0 {
t.smartContract.DeleteAsset(anAsset.ID)
fmt.Println("Deleted asset", anAsset.ID)
}
}