Skip to content

Commit

Permalink
Don't build pqclean on wasm target (#81)
Browse files Browse the repository at this point in the history
  • Loading branch information
franziskuskiefer authored Sep 18, 2023
1 parent 2b7aa4c commit 388d6d2
Show file tree
Hide file tree
Showing 6 changed files with 62 additions and 30 deletions.
3 changes: 1 addition & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -38,8 +38,6 @@ quickcheck_macros = "1"
serde_json = { version = "1.0" }
serde = { version = "1.0", features = ["derive"] }
hex = { version = "0.4.3", features = ["serde"] }
pqcrypto-kyber = { version = "0.7.6", default-features = false }
libcrux-pqclean = { version = "*", path = "sys/pqclean" }

# Benchmarking "RustCrypto"
chacha20poly1305 = "0.10"
Expand All @@ -55,6 +53,7 @@ wasm-bindgen-test = "0.3"
[target.'cfg(not(target_arch = "wasm32"))'.dev-dependencies]
criterion = "0.5"
libcrux-pqclean = { version = "*", path = "sys/pqclean" }
pqcrypto-kyber = { version = "0.7.6", default-features = false }

# Benchmarking "OpenSSL"
# XXX: We don't do this for Windows or wasm right now.
Expand Down
17 changes: 12 additions & 5 deletions examples/kyber768_encapsulate.rs
Original file line number Diff line number Diff line change
@@ -1,13 +1,20 @@
use libcrux::digest;
use libcrux::drbg::Drbg;
use libcrux::kem;

#[cfg(not(target_arch = "wasm32"))]
use libcrux::drbg;
#[cfg(target_arch = "wasm32")]
use rand_core::OsRng;

fn main() {
let mut drbg = Drbg::new(digest::Algorithm::Sha256).unwrap();
let (_secret_key, public_key) = kem::key_gen(kem::Algorithm::Kyber768, &mut drbg).unwrap();
#[cfg(not(target_arch = "wasm32"))]
let mut rng = drbg::Drbg::new(libcrux::digest::Algorithm::Sha256).unwrap();
#[cfg(target_arch = "wasm32")]
let mut rng = OsRng;

let (_secret_key, public_key) = kem::key_gen(kem::Algorithm::Kyber768, &mut rng).unwrap();

for _i in 0..100000 {
let (_shared_secret, _ciphertext) =
kem::encapsulate(kem::Algorithm::Kyber768, &public_key, &mut drbg).unwrap();
kem::encapsulate(kem::Algorithm::Kyber768, &public_key, &mut rng).unwrap();
}
}
14 changes: 10 additions & 4 deletions examples/kyber768_generate_keypair.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,17 @@
use libcrux::digest;
use libcrux::drbg::Drbg;
use libcrux::kem;

#[cfg(not(target_arch = "wasm32"))]
use libcrux::drbg;
#[cfg(target_arch = "wasm32")]
use rand_core::OsRng;

fn main() {
let mut drbg = Drbg::new(digest::Algorithm::Sha256).unwrap();
#[cfg(not(target_arch = "wasm32"))]
let mut rng = drbg::Drbg::new(libcrux::digest::Algorithm::Sha256).unwrap();
#[cfg(target_arch = "wasm32")]
let mut rng = OsRng;

for _i in 0..100000 {
let (_secret_key, _public_key) = kem::key_gen(kem::Algorithm::Kyber768, &mut drbg).unwrap();
let (_secret_key, _public_key) = kem::key_gen(kem::Algorithm::Kyber768, &mut rng).unwrap();
}
}
2 changes: 1 addition & 1 deletion src/hacl.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ pub(crate) mod aesgcm;
pub(crate) mod blake2;
pub(crate) mod chacha20_poly1305;
pub(crate) mod curve25519;
#[cfg(not(target_arch ="wasm32"))]
#[cfg(not(target_arch = "wasm32"))]
pub(crate) mod drbg;
pub(crate) mod ed25519;
pub(crate) mod hkdf;
Expand Down
54 changes: 37 additions & 17 deletions tests/kyber768.rs
Original file line number Diff line number Diff line change
@@ -1,22 +1,30 @@
use libcrux::{
digest::{self, sha3_256, shake256},
drbg::{Drbg, RngCore},
kem::{self, Algorithm},
};

#[cfg(not(target_arch = "wasm32"))]
use libcrux::drbg::{self, RngCore};
#[cfg(target_arch = "wasm32")]
use rand_core::{OsRng, RngCore};

const SHARED_SECRET_SIZE: usize = 32;
const SECRET_KEY_SIZE: usize = 2400;
const CIPHERTEXT_SIZE: u32 = 1088;

const SECRET_KEY_REJECTION_VALUE_POSITION: usize = SECRET_KEY_SIZE - SHARED_SECRET_SIZE;

#[cfg_attr(target_arch = "wasm32", wasm_bindgen_test::wasm_bindgen_test)]
#[test]
fn consistency() {
let mut drbg = Drbg::new(digest::Algorithm::Sha256).unwrap();
#[cfg(not(target_arch = "wasm32"))]
let mut rng = drbg::Drbg::new(libcrux::digest::Algorithm::Sha256).unwrap();
#[cfg(target_arch = "wasm32")]
let mut rng = OsRng;

if let Ok((secret_key, public_key)) = kem::key_gen(Algorithm::Kyber768, &mut drbg) {
if let Ok((secret_key, public_key)) = kem::key_gen(Algorithm::Kyber768, &mut rng) {
if let Ok((shared_secret, ciphertext)) =
kem::encapsulate(Algorithm::Kyber768, &public_key, &mut drbg)
kem::encapsulate(Algorithm::Kyber768, &public_key, &mut rng)
{
let shared_secret_decapsulated =
kem::decapsulate(Algorithm::Kyber768, &ciphertext, &secret_key).unwrap();
Expand All @@ -29,21 +37,25 @@ fn consistency() {
// failing.
}

#[cfg_attr(target_arch = "wasm32", wasm_bindgen_test::wasm_bindgen_test)]
#[test]
fn modified_ciphertext() {
let mut drbg = Drbg::new(digest::Algorithm::Sha256).unwrap();
#[cfg(not(target_arch = "wasm32"))]
let mut rng = drbg::Drbg::new(libcrux::digest::Algorithm::Sha256).unwrap();
#[cfg(target_arch = "wasm32")]
let mut rng = OsRng;

let random_u32 = drbg.next_u32();
let random_u32 = rng.next_u32();
let mut random_byte: u8 = (random_u32 & 0xFF).try_into().unwrap();
if random_byte == 0 {
random_byte += 1;
}

let ciphertext_position: usize = (random_u32 % CIPHERTEXT_SIZE).try_into().unwrap();

if let Ok((secret_key, public_key)) = kem::key_gen(Algorithm::Kyber768, &mut drbg) {
if let Ok((secret_key, public_key)) = kem::key_gen(Algorithm::Kyber768, &mut rng) {
if let Ok((shared_secret, mut ciphertext)) =
kem::encapsulate(Algorithm::Kyber768, &public_key, &mut drbg)
kem::encapsulate(Algorithm::Kyber768, &public_key, &mut rng)
{
ciphertext[ciphertext_position] ^= random_byte;
let shared_secret_decapsulated =
Expand All @@ -69,11 +81,15 @@ fn compute_implicit_rejection_shared_secret(
shake256(&to_hash)
}

#[cfg_attr(target_arch = "wasm32", wasm_bindgen_test::wasm_bindgen_test)]
#[test]
fn modified_secret_key() {
let mut drbg = Drbg::new(digest::Algorithm::Sha256).unwrap();
#[cfg(not(target_arch = "wasm32"))]
let mut rng = drbg::Drbg::new(libcrux::digest::Algorithm::Sha256).unwrap();
#[cfg(target_arch = "wasm32")]
let mut rng = OsRng;

let random_u32 = drbg.next_u32();
let random_u32 = rng.next_u32();

let mut random_byte: u8 = (random_u32 & 0xFF).try_into().unwrap();
if random_byte == 0 {
Expand All @@ -82,9 +98,9 @@ fn modified_secret_key() {

let secret_key_position: usize = ((random_u32 >> 8) % (SECRET_KEY_SIZE as u32 - 32)) as usize;

if let Ok((mut secret_key, public_key)) = kem::key_gen(Algorithm::Kyber768, &mut drbg) {
if let Ok((mut secret_key, public_key)) = kem::key_gen(Algorithm::Kyber768, &mut rng) {
if let Ok((shared_secret, ciphertext)) =
kem::encapsulate(Algorithm::Kyber768, &public_key, &mut drbg)
kem::encapsulate(Algorithm::Kyber768, &public_key, &mut rng)
{
secret_key[secret_key_position] ^= random_byte;
let shared_secret_decapsulated =
Expand All @@ -107,11 +123,15 @@ fn modified_secret_key() {
// failing.
}

#[cfg_attr(target_arch = "wasm32", wasm_bindgen_test::wasm_bindgen_test)]
#[test]
fn modified_ciphertext_and_implicit_rejection_value() {
let mut drbg = Drbg::new(digest::Algorithm::Sha256).unwrap();
#[cfg(not(target_arch = "wasm32"))]
let mut rng = drbg::Drbg::new(libcrux::digest::Algorithm::Sha256).unwrap();
#[cfg(target_arch = "wasm32")]
let mut rng = OsRng;

let random_u32 = drbg.next_u32();
let random_u32 = rng.next_u32();

let mut random_byte_for_ciphertext: u8 = (random_u32 & 0xFF).try_into().unwrap();
if random_byte_for_ciphertext == 0 {
Expand All @@ -120,7 +140,7 @@ fn modified_ciphertext_and_implicit_rejection_value() {

let ciphertext_position: usize = ((random_u32 >> 8) % CIPHERTEXT_SIZE).try_into().unwrap();

let random_u32 = drbg.next_u32();
let random_u32 = rng.next_u32();

let mut random_byte_for_secret_key: u8 = (random_u32 & 0xFF).try_into().unwrap();
if random_byte_for_secret_key == 0 {
Expand All @@ -131,9 +151,9 @@ fn modified_ciphertext_and_implicit_rejection_value() {
.try_into()
.unwrap();

if let Ok((mut secret_key, public_key)) = kem::key_gen(Algorithm::Kyber768, &mut drbg) {
if let Ok((mut secret_key, public_key)) = kem::key_gen(Algorithm::Kyber768, &mut rng) {
if let Ok((_, mut ciphertext)) =
kem::encapsulate(Algorithm::Kyber768, &public_key, &mut drbg)
kem::encapsulate(Algorithm::Kyber768, &public_key, &mut rng)
{
ciphertext[ciphertext_position] ^= random_byte_for_ciphertext;
let shared_secret_decapsulated =
Expand Down
2 changes: 1 addition & 1 deletion tests/p256.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
#[cfg(not(target_arch = "wasm32"))]
use libcrux::drbg;
use libcrux::ecdh::{self, key_gen};
#[cfg(target_arch = "wasm32")]
use rand_core::OsRng;
use libcrux::ecdh::{self, key_gen};

#[cfg_attr(target_arch = "wasm32", wasm_bindgen_test::wasm_bindgen_test)]
#[test]
Expand Down

0 comments on commit 388d6d2

Please sign in to comment.