我正在尝试使用以太坊区块链和 Solidity 合约。我目前正在部署合约并对其执行一些操作,但我想知道如何获取特定交易的一些“反馈/回调/返回”。
例如,有没有办法将事务的状态设置为 0(错误)并仍然获取事件?
if (id.length <= 0) {
emit Result("KO", "1");
revert();
}
这不起作用(无事件),因为我恢复了所有内容,但状态将设置为 0
if (id.length <= 0) {
emit Result("KO", "1");
return;
}
我会收到一些事件,但状态将保持 1
if (id.length <= 0) {
revert("KO_1");
}
状态将为0,但我不会有任何事件
这是我执行该操作的代码:
func testFunction(id []byte) {
//...
//...
tx, err := instance.Action(opt, id)
if (errors.HasError(err)) {
return
}
callbackValue := subscribeToContract(tx.Hash().Hex())
logs.Pretty(tx, callbackValue)
//...
//...
}
func subscribeToContract(hashToRead string) myStruct {
query := ethereum.FilterQuery{
Addresses: []common.Address{address},
}
soc := make(chan types.Log)
sub, err := WssClient.SubscribeFilterLogs(context.Background(), query, soc)
if err != nil {
logs.Error(err)
}
for {
select {
case err := <-sub.Err():
logs.Info(`SOMETHING ERROR`)
logs.Error(err)
case vLog := <-soc:
logs.Info(`SOMETHING`)
contractAbi, _ := abi.JSON(strings.NewReader(string(SignABI)))
event := myStruct{}
contractAbi.Unpack(&event, "Result", vLog.Data)
logs.Info(`New Event from [` + vLog.TxHash.Hex() + `] : ` + event.Message)
}
}
}
如果id.length > 0,一切都好。但如果id.length <= 0,我没有来自该subscribeToContract函数的回调。
有没有办法直接获得结果状态,或者应该循环tx, err := client.TransactionReceipt(context.Background(), txHash)直到获得状态?
海绵宝宝撒
呼啦一阵风
相关分类