Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Blake2: add missing types of common digest sizes #564

Merged
merged 1 commit into from May 2, 2024

Conversation

HeCorr
Copy link
Contributor

@HeCorr HeCorr commented Feb 10, 2024

See comment #67.

This PR adds the following common fixed digest sizes:

  • BLAKE2s-128
  • BLAKE2b-128
  • BLAKE2b-256

Unsure if I should also add the Mac variants, please let me know!

BLAKE2s-128
BLAKE2b-128
BLAKE2b-256
@HeCorr
Copy link
Contributor Author

HeCorr commented Feb 10, 2024

Also, I've noticed that only the BLAKE2b-512 fixed variant is tested, but I've just recently started learning Rust so I'm not sure how to write tests for the other variants (specifically how to generate the .blb files).

Any guidance on this would be very welcome!

@newpavlov
Copy link
Member

Could you please link cases where those variations are used in practice?

only the BLAKE2b-512 fixed variant is tested

We could add tests for other variants, but we would have to generate tests ourselves. Ideally, we would use "official" test vectors, but we probably couldn't find them at the time.

@HeCorr
Copy link
Contributor Author

HeCorr commented Apr 27, 2024

Could you please link cases where those variations are used in practice?

I can't, but I personally always use either 256 or 128 if I need the hash to be shorter. What I can link you though are other projects which do include them and even other less common sizes (160, 384..):

CyberChef
Go standard lib

@StackOverflowExcept1on
Copy link

I have similar problem that I need hash of 256 bit size, but this crate does not provide BLAKE2b-256.

@HeCorr
Copy link
Contributor Author

HeCorr commented Apr 30, 2024

this crate does not provide BLAKE2b-256.

@StackOverflowExcept1on this is how you can currently generate a Blake2b-256 hash:

use blake2::{Blake2b, Digest, digest::consts::U32};

type Blake2b256 = Blake2b<U32>;

let mut hasher = Blake2b256::new();
hasher.update(b"my_input");
let res = hasher.finalize();

@newpavlov newpavlov merged commit 470c789 into RustCrypto:master May 2, 2024
14 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

3 participants