From 3daeae10f4648e455d7395fa65b1e6bb0321cba0 Mon Sep 17 00:00:00 2001 From: Jac0xb Date: Sat, 18 Nov 2023 23:02:17 -0500 Subject: [PATCH] Add transaction error and logs to TransactionFailure rpc bundle execution error --- rpc-client-api/src/bundles.rs | 41 +++++++++++++++++++++++++---------- 1 file changed, 30 insertions(+), 11 deletions(-) diff --git a/rpc-client-api/src/bundles.rs b/rpc-client-api/src/bundles.rs index 72afc51d91..c2eee2bc34 100644 --- a/rpc-client-api/src/bundles.rs +++ b/rpc-client-api/src/bundles.rs @@ -8,7 +8,6 @@ use { solana_sdk::{ clock::Slot, commitment_config::{CommitmentConfig, CommitmentLevel}, - signature::Signature, transaction::TransactionError, }, solana_transaction_status::{UiTransactionEncoding, UiTransactionReturnData}, @@ -49,8 +48,15 @@ pub enum RpcBundleExecutionError { #[error("Tip payment error: {0}")] TipError(String), - #[error("A transaction in the bundle failed to execute: [signature={0}, error={1}]")] - TransactionFailure(Signature, String), + #[error( + "A transaction in the bundle failed to execute: [signature={0}, errormsg={1}, error={2:?}, log_messages={3:?}]" + )] + TransactionFailure( + String, + String, + Option, + Option>, + ), } impl From for RpcBundleExecutionError { @@ -68,22 +74,35 @@ impl From for RpcBundleExecutionError { LoadAndExecuteBundleError::LockError { signature, transaction_error, - } => Self::TransactionFailure(signature, transaction_error.to_string()), + } => Self::TransactionFailure( + signature.to_string(), + transaction_error.to_string(), + Some(transaction_error), + None, + ), LoadAndExecuteBundleError::TransactionError { signature, execution_result, } => match *execution_result { TransactionExecutionResult::Executed { details, .. } => { - let err_msg = if let Err(e) = details.status { - e.to_string() + let (err_msg, e) = if let Err(e) = details.status { + (e.to_string(), Some(e)) } else { - "Unknown error".to_string() + ("Unknown error".to_string(), None) }; - Self::TransactionFailure(signature, err_msg) - } - TransactionExecutionResult::NotExecuted(e) => { - Self::TransactionFailure(signature, e.to_string()) + Self::TransactionFailure( + signature.to_string(), + err_msg, + e, + details.log_messages, + ) } + TransactionExecutionResult::NotExecuted(e) => Self::TransactionFailure( + signature.to_string(), + e.to_string(), + Some(e), + None, + ), }, LoadAndExecuteBundleError::InvalidPreOrPostAccounts => { Self::InvalidPreOrPostAccounts