Procházet zdrojové kódy

Add automatic rollback on drop for wallet transactions in FFI

Implements Drop trait for FfiWalletTransaction to ensure uncommitted database
transactions are automatically rolled back when dropped. This prevents
transaction leaks and ensures database consistency even when transactions are
not explicitly committed.
Cesar Rodas před 7 měsíci
rodič
revize
548aa46304
1 změnil soubory, kde provedl 13 přidání a 2 odebrání
  1. 13 2
      crates/cdk-ffi/src/database.rs

+ 13 - 2
crates/cdk-ffi/src/database.rs

@@ -826,13 +826,24 @@ where
 
 /// Transaction wrapper for FFI
 pub(crate) struct FfiWalletTransaction {
-    tx: Mutex<Option<DynWalletDatabaseTransaction>>,
+    tx: Arc<Mutex<Option<DynWalletDatabaseTransaction>>>,
+}
+
+impl Drop for FfiWalletTransaction {
+    fn drop(&mut self) {
+        let tx = self.tx.clone();
+        tokio::spawn(async move {
+            if let Some(s) = tx.lock().await.take() {
+                let _ = s.rollback().await;
+            }
+        });
+    }
 }
 
 impl FfiWalletTransaction {
     pub fn new(tx: DynWalletDatabaseTransaction) -> Arc<Self> {
         Arc::new(Self {
-            tx: Mutex::new(Some(tx)),
+            tx: Arc::new(Mutex::new(Some(tx))),
         })
     }
 }