2018-10-02 06:41:10 +00:00
|
|
|
extern crate blake2_rfc;
|
|
|
|
|
|
|
|
use self::blake2_rfc::blake2b::blake2b;
|
2018-09-19 04:45:03 +00:00
|
|
|
|
|
|
|
pub fn canonical_hash(input: &[u8]) -> Vec<u8> {
|
|
|
|
let result = blake2b(64, &[], input);
|
|
|
|
result.as_bytes()[0..32].to_vec()
|
|
|
|
}
|
2018-10-19 16:09:42 +00:00
|
|
|
|
|
|
|
pub fn proof_of_possession_hash(input: &[u8]) -> Vec<u8> {
|
|
|
|
let result = blake2b(64, &[], input);
|
|
|
|
let mut hash = result.as_bytes()[32..64].to_vec();
|
|
|
|
// TODO: this padding is not part of the spec, it is required otherwise Milagro will panic.
|
|
|
|
// We should either drop the padding or ensure the padding is in the spec.
|
|
|
|
hash.append(&mut vec![0; 18]);
|
|
|
|
hash
|
|
|
|
}
|