Skip to content

Commit

Permalink
fix(horizon_sync): check max number of kernels/utxos from peer (tari-…
Browse files Browse the repository at this point in the history
…project#5703)

Description
---
Add a upper limit check on the stream processing loop for both kernels
and UTXOs.

Motivation and Context
---
The peer responses of the `sync_kenels` and `sync_utxos` RPC calls
return streams. We don't have a check to avoid a malicious peer for
repeatedly send data in the stream to keep the client node blocked.

How Has This Been Tested?
---
Tests pass

What process can a PR reviewer use to test or verify this change?
---
Code review

Breaking Changes
---

- [x] None
- [ ] Requires data directory on base node to be deleted
- [ ] Requires hard fork
- [ ] Other - Please specify

Co-authored-by: SW van Heerden <swvheerden@gmail.com>
  • Loading branch information
mrnaveira and SWvheerden authored Aug 31, 2023
1 parent dc5cfce commit 5e4f3c2
Showing 1 changed file with 12 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -360,6 +360,12 @@ impl<'a, B: BlockchainBackend + 'static> HorizonStateSynchronization<'a, B> {

kernel_hashes.push(kernel.hash());

if mmr_position > end {
return Err(HorizonSyncError::IncorrectResponse(format!(
"Peer sent too many kernels",
)));
}

let mmr_position_u32 = u32::try_from(mmr_position).map_err(|_| HorizonSyncError::InvalidMmrPosition {
at_height: current_header.height(),
mmr_position,
Expand Down Expand Up @@ -549,6 +555,12 @@ impl<'a, B: BlockchainBackend + 'static> HorizonStateSynchronization<'a, B> {
avg_latency.add_sample(latency);
let res: SyncUtxosResponse = response?;

if mmr_position > end {
return Err(HorizonSyncError::IncorrectResponse(format!(
"Peer sent too many outputs",
)));
}

if res.mmr_index != 0 && res.mmr_index != mmr_position {
return Err(HorizonSyncError::IncorrectResponse(format!(
"Expected MMR position of {} but got {}",
Expand Down

0 comments on commit 5e4f3c2

Please sign in to comment.