From f71db1a7fe5df88581d46e05da94e5e087b85511 Mon Sep 17 00:00:00 2001 From: Daniel Sanchez Date: Sat, 9 Nov 2024 01:06:32 +0100 Subject: [PATCH] Mix: Fix bug in cover traffic ticket generation (#915) * Fix bug in cover traffic ticket generation * fix hash bug * Clippy happy --- nomos-mix/core/src/cover_traffic.rs | 29 +++++++++++++++++++++++------ 1 file changed, 23 insertions(+), 6 deletions(-) diff --git a/nomos-mix/core/src/cover_traffic.rs b/nomos-mix/core/src/cover_traffic.rs index 1451704c..ababf121 100644 --- a/nomos-mix/core/src/cover_traffic.rs +++ b/nomos-mix/core/src/cover_traffic.rs @@ -1,3 +1,4 @@ +use blake2::digest::consts::U4; use blake2::Digest; use futures::{Stream, StreamExt}; use nomos_mix_message::MixMessage; @@ -84,12 +85,12 @@ where } fn generate_ticket>(node_id: Id, r: usize, slot: usize) -> u32 { - let mut hasher = blake2::Blake2b512::new(); + let mut hasher = blake2::Blake2s::::new(); hasher.update(node_id); hasher.update(r.to_be_bytes()); hasher.update(slot.to_be_bytes()); - let hash = &hasher.finalize()[..]; - u32::from_be_bytes(hash.try_into().unwrap()) + let hash: [u8; std::mem::size_of::()] = hasher.finalize()[..].to_vec().try_into().unwrap(); + u32::from_be_bytes(hash) } fn select_slot + Copy>( @@ -100,10 +101,12 @@ fn select_slot + Copy>( winning_probability: f64, ) -> HashSet { let i = (slots_per_epoch as f64).div(network_size as f64) * winning_probability; - let i = i.ceil() as usize; + let size = i.ceil() as usize; let mut w = HashSet::new(); - while w.len() != i { - w.insert(generate_ticket(node_id, r, slots_per_epoch)); + let mut i = 0; + while w.len() != size { + w.insert(generate_ticket(node_id, r, i) % slots_per_epoch as u32); + i += 1; } w } @@ -111,3 +114,17 @@ fn select_slot + Copy>( fn winning_probability(number_of_hops: usize) -> f64 { 1.0 / number_of_hops as f64 } + +#[cfg(test)] +mod tests { + use crate::cover_traffic::{generate_ticket, select_slot, winning_probability}; + + #[test] + fn test_ticket() { + generate_ticket(10u32.to_be_bytes(), 1123, 0); + for i in (0..1u32) { + let slots = select_slot(i.to_be_bytes(), 1234, 100, 21600, winning_probability(1)); + println!("slots = {slots:?}"); + } + } +}