#prf #tink

tink-prf

PRF functionality for Rust port of Google's Tink cryptography library

9 releases

0.3.0 Nov 28, 2024
0.2.5 Mar 14, 2023
0.2.4 Mar 25, 2022
0.2.1 Oct 8, 2021
0.1.0 Jan 21, 2021

#1392 in Cryptography

Download history 9181/week @ 2024-10-25 4577/week @ 2024-11-01 15544/week @ 2024-11-08 36074/week @ 2024-11-15 7379/week @ 2024-11-22 16015/week @ 2024-11-29 18294/week @ 2024-12-06 20117/week @ 2024-12-13 288/week @ 2024-12-20 1730/week @ 2024-12-27 13366/week @ 2025-01-03 20583/week @ 2025-01-10 9077/week @ 2025-01-17 9894/week @ 2025-01-24 9636/week @ 2025-01-31 12457/week @ 2025-02-07

47,706 downloads per month
Used in 6 crates (2 directly)

Apache-2.0

255KB
4K SLoC

Tink-Rust: Pseudo-Random Functions

Docs MSRV

This crate provides pseudo-random function (PRF) functionality, as described in the upstream Tink documentation.

Usage

fn main() -> Result<(), Box<dyn Error>> {
    tink_prf::init();
    let kh = tink_core::keyset::Handle::new(&tink_prf::hmac_sha256_prf_key_template())?;
    let m = tink_prf::Set::new(&kh)?;

    let pt = b"need pseudo-random data deterministically produced from this input";
    let out = m.compute_primary_prf(pt, 16)?;
    println!("'{}' => {}", String::from_utf8_lossy(pt), hex::encode(&out));
    assert_eq!(out.len(), 16);
    Ok(())
}

License

Apache License, Version 2.0

Disclaimer

This is not an officially supported Google product.

Dependencies

~1.5–3.5MB
~53K SLoC