Skip to content

Commit

Permalink
Fix Sortition hash
Browse files Browse the repository at this point in the history
This changes the hash from H(round||counter||step||seed)
to H(seed||round||step||counter), to be compliant with
Deterministic Sortition specification.

Tests 'test_sortition_hash()' and 'test_generate_sortition_score()'
are also updated.
  • Loading branch information
fed-franz committed Jun 1, 2023
1 parent 36d5360 commit 7bda642
Showing 1 changed file with 8 additions and 7 deletions.
15 changes: 8 additions & 7 deletions consensus/src/user/sortition.rs
Original file line number Diff line number Diff line change
Expand Up @@ -43,10 +43,10 @@ pub fn create_sortition_hash(cfg: &Config, counter: u32) -> [u8; 32] {
let mut hasher = Sha3_256::new();

// write input message
hasher.update(&cfg.seed.inner()[..]);
hasher.update(cfg.round.to_le_bytes());
hasher.update(counter.to_le_bytes());
hasher.update(cfg.step.to_le_bytes());
hasher.update(&cfg.seed.inner()[..]);
hasher.update(counter.to_le_bytes());

// read hash digest
let reader = hasher.finalize();
Expand Down Expand Up @@ -76,12 +76,13 @@ mod tests {
};

#[test]
pub fn test_sortition_hash() {
pub fn test_sortition_hash() {
let hash = [
56, 81, 125, 39, 109, 105, 243, 20, 138, 196, 236, 197, 7, 155, 41,
26, 217, 150, 9, 226, 76, 174, 67, 1, 230, 187, 81, 107, 192, 5,
13, 73,
134, 22, 162, 136, 186, 35, 16, 207, 237, 50, 11, 236, 74, 189, 37,
137, 101, 205, 53, 161, 248, 199, 195, 228, 68, 68, 95, 223, 239, 199,
1, 7,
];

assert_eq!(
create_sortition_hash(
&Config::new(Seed::from([3; 48]), 10, 3, 0),
Expand All @@ -94,7 +95,7 @@ mod tests {
#[test]
pub fn test_generate_sortition_score() {
let dataset =
vec![([3; 48], 123342342, 78899961), ([4; 48], 44443333, 5505832)];
vec![([3; 48], 123342342, 66422677), ([4; 48], 44443333, 22757716)];

for (seed, total_weight, expected_score) in dataset {
let hash = create_sortition_hash(
Expand Down

0 comments on commit 7bda642

Please sign in to comment.