From 0e91b933e99f09ecee445e275e286d946a53c85d Mon Sep 17 00:00:00 2001 From: Max Conway Date: Fri, 10 Jan 2025 12:26:02 +0000 Subject: [PATCH] Fix for issue where statuscode 255 was being returned even for successful transactions - `receipt.accepted==Some(false)` is no ignored, and if `receipt.success==true` the transaction is reported dispatched --- zilliqa/src/api/types/zil.rs | 37 ++++++++++++++++++------------------ 1 file changed, 19 insertions(+), 18 deletions(-) diff --git a/zilliqa/src/api/types/zil.rs b/zilliqa/src/api/types/zil.rs index 81e19e00b..31bb23ac3 100644 --- a/zilliqa/src/api/types/zil.rs +++ b/zilliqa/src/api/types/zil.rs @@ -800,25 +800,26 @@ impl TransactionStatusResponse { tx.to_addr.is_some().then(|| hex::encode(&tx.payload)), ), }; - let status_code = if receipt.accepted.is_some() && receipt.accepted.unwrap() { - TxnStatusCode::Confirmed - } else if receipt.accepted.is_none() { - TxnStatusCode::Dispatched - } else { - let errors: Vec = - receipt.errors.into_iter().flat_map(|(_k, v)| v).collect(); - if errors.len() == 1 { - match errors[0] { - ScillaError::CallContractFailed => TxnStatusCode::FailScillaLib, - ScillaError::CreateContractFailed => TxnStatusCode::Error, - ScillaError::GasNotSufficient => TxnStatusCode::InsufficientGas, - ScillaError::BalanceTransferFailed => TxnStatusCode::InsufficientBalance, - _ => TxnStatusCode::Error, - } + let status_code = + if receipt.accepted.is_some() && receipt.accepted.unwrap() && receipt.success { + TxnStatusCode::Confirmed + } else if receipt.success { + TxnStatusCode::Dispatched } else { - TxnStatusCode::Error - } - }; + let errors: Vec = + receipt.errors.into_iter().flat_map(|(_k, v)| v).collect(); + if errors.len() == 1 { + match errors[0] { + ScillaError::CallContractFailed => TxnStatusCode::FailScillaLib, + ScillaError::CreateContractFailed => TxnStatusCode::Error, + ScillaError::GasNotSufficient => TxnStatusCode::InsufficientGas, + ScillaError::BalanceTransferFailed => TxnStatusCode::InsufficientBalance, + _ => TxnStatusCode::Error, + } + } else { + TxnStatusCode::Error + } + }; let modification_state = if receipt.accepted.is_none() { 0 } else { 2 }; Ok(Self { id: tx.hash.to_string(),