Skip to content

Commit

Permalink
Fix withdrawal bugs
Browse files Browse the repository at this point in the history
  • Loading branch information
Ash-L2L committed Nov 18, 2024
1 parent 1ee1b11 commit d8adb3c
Show file tree
Hide file tree
Showing 6 changed files with 496 additions and 58 deletions.
10 changes: 10 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions lib/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ hashlink = { version = "0.9.1", features = ["serde_impl"] }
heed = "0.20.1"
hex = { version = "0.4.3", features = ["serde"] }
jsonrpsee = { version = "0.23.2" }
nonempty = { version = "0.10.0", features = ["serialize"] }
parking_lot = "0.12.1"
prost = "0.13.3"
prost-types = "0.13.3"
Expand Down
2 changes: 2 additions & 0 deletions lib/node/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -575,12 +575,14 @@ where
let rotxn = self.env.read_txn()?;
let bundle = self.state.get_pending_withdrawal_bundle(&rotxn)?;
if let Some((bundle, _)) = bundle {
let m6id = bundle.compute_m6id();
let mut cusf_mainchain_wallet_lock =
cusf_mainchain_wallet.lock().await;
let () = cusf_mainchain_wallet_lock
.broadcast_withdrawal_bundle(bundle.tx())
.await?;
drop(cusf_mainchain_wallet_lock);
tracing::trace!(%m6id, "Broadcast withdrawal bundle");
}
Ok(true)
}
Expand Down
88 changes: 85 additions & 3 deletions lib/node/net_task.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
//! Task to manage peers and their responses
use std::{
cmp::Ordering,
collections::{HashMap, HashSet},
net::SocketAddr,
sync::Arc,
Expand Down Expand Up @@ -79,8 +80,39 @@ where
Transport: proto::Transport,
{
let last_deposit_block_hash = state.get_last_deposit_block_hash(rwtxn)?;
let last_withdrawal_bundle_event_block_hash =
state.get_last_withdrawal_bundle_event_block_hash(rwtxn)?;
let last_2wpd_block = match (
last_deposit_block_hash,
last_withdrawal_bundle_event_block_hash,
) {
(None, None) => None,
(Some(last_deposit_block_hash), None) => Some(last_deposit_block_hash),
(None, Some(last_withdrawal_bundle_event_block_hash)) => {
Some(last_withdrawal_bundle_event_block_hash)
}
(
Some(last_deposit_block_hash),
Some(last_withdrawal_bundle_event_block_hash),
) => {
if archive.is_main_descendant(
rwtxn,
last_deposit_block_hash,
last_withdrawal_bundle_event_block_hash,
)? {
Some(last_withdrawal_bundle_event_block_hash)
} else {
assert!(archive.is_main_descendant(
rwtxn,
last_withdrawal_bundle_event_block_hash,
last_deposit_block_hash
)?);
Some(last_deposit_block_hash)
}
}
};
let two_way_peg_data = cusf_mainchain
.get_two_way_peg_data(last_deposit_block_hash, header.prev_main_hash)
.get_two_way_peg_data(last_2wpd_block, header.prev_main_hash)
.await?;
let block_hash = header.hash();
let _fees: bitcoin::Amount = state.validate_block(rwtxn, header, body)?;
Expand Down Expand Up @@ -120,17 +152,67 @@ where
let tip_body = archive.get_body(rwtxn, tip_block_hash)?;
let height = state.get_height(rwtxn)?;
let two_way_peg_data = {
let start_block_hash = state
let last_applied_deposit_block = state
.deposit_blocks
.rev_iter(rwtxn)?
.transpose_into_fallible()
.find_map(|(_, (block_hash, applied_height))| {
if applied_height < height - 1 {
Ok(Some(block_hash))
Ok(Some((block_hash, applied_height)))
} else {
Ok(None)
}
})?;
let last_applied_withdrawal_bundle_event_block = state
.withdrawal_bundle_event_blocks
.rev_iter(rwtxn)?
.transpose_into_fallible()
.find_map(|(_, (block_hash, applied_height))| {
if applied_height < height - 1 {
Ok(Some((block_hash, applied_height)))
} else {
Ok(None)
}
})?;
let start_block_hash = match (
last_applied_deposit_block,
last_applied_withdrawal_bundle_event_block,
) {
(None, None) => None,
(Some((block_hash, _)), None) | (None, Some((block_hash, _))) => {
Some(block_hash)
}
(
Some((deposit_block, deposit_block_applied_height)),
Some((
withdrawal_event_block,
withdrawal_event_block_applied_height,
)),
) => {
match deposit_block_applied_height
.cmp(&withdrawal_event_block_applied_height)
{
Ordering::Less => Some(withdrawal_event_block),
Ordering::Greater => Some(deposit_block),
Ordering::Equal => {
if archive.is_main_descendant(
rwtxn,
withdrawal_event_block,
deposit_block,
)? {
Some(withdrawal_event_block)
} else {
assert!(archive.is_main_descendant(
rwtxn,
deposit_block,
withdrawal_event_block
)?);
Some(deposit_block)
}
}
}
}
};
cusf_mainchain
.get_two_way_peg_data(start_block_hash, tip_header.prev_main_hash)
.await?
Expand Down
Loading

0 comments on commit d8adb3c

Please sign in to comment.