-
Notifications
You must be signed in to change notification settings - Fork 156
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore(zk): add a proof compat test between x86_64 and wasm
- Loading branch information
1 parent
c1374a0
commit 6ee3eb1
Showing
8 changed files
with
160 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,5 +7,5 @@ | |
"test": "node --test --test-reporter=tap" | ||
}, | ||
"author": "", | ||
"license": "ISC" | ||
"license": "BSD-3-Clause" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,86 @@ | ||
//! Test compatibility between x86_64 and wasm proofs | ||
//! | ||
//! - Generate a crs and public key from rust | ||
//! - Load them in js, encrypt and prove some ciphertexts | ||
//! - Load the proven ciphertexts in rust and verify the proof | ||
#![cfg(feature = "zk-pok")] | ||
#![cfg(feature = "integer")] | ||
|
||
use std::fs::File; | ||
use std::path::{Path, PathBuf}; | ||
use std::process::Command; | ||
use tfhe::safe_serialization::{safe_deserialize, safe_serialize}; | ||
use tfhe::zk::{CompactPkeCrs, CompactPkePublicParams}; | ||
use tfhe::{ClientKey, CompactPublicKey, ConfigBuilder, ProvenCompactCiphertextList}; | ||
|
||
const SIZE_LIMIT: u64 = 1024 * 1024 * 1024; | ||
|
||
fn gen_key_and_crs() -> (CompactPublicKey, CompactPkeCrs) { | ||
println!("Generating keys"); | ||
let config = ConfigBuilder::default().build(); | ||
let client_key = ClientKey::generate(config); | ||
let pub_key = CompactPublicKey::new(&client_key); | ||
|
||
println!("Generating crs"); | ||
let crs = CompactPkeCrs::from_config(config, 16).unwrap(); | ||
|
||
(pub_key, crs) | ||
} | ||
|
||
fn gen_proven_ct_in_wasm(path: &Path) { | ||
println!("Generating proven ciphertext in wasm"); | ||
let mut child = Command::new("node") | ||
.arg("index.js") | ||
.current_dir(path) | ||
.spawn() | ||
.expect("Failed to run node script"); | ||
|
||
let exit_status = child.wait().unwrap(); | ||
if let Some(exit_code) = exit_status.code() { | ||
if exit_code == 0 { | ||
return; | ||
} | ||
} | ||
|
||
panic!("node script returned a non-0 code."); | ||
} | ||
|
||
fn verify_proof( | ||
public_key: &CompactPublicKey, | ||
crs: &CompactPkePublicParams, | ||
proven_ct: &ProvenCompactCiphertextList, | ||
) { | ||
println!("Verifying proof"); | ||
match proven_ct.verify(crs, public_key, &[]) { | ||
tfhe::zk::ZkVerificationOutCome::Valid => { | ||
println!("proof verification succeeded"); | ||
} | ||
tfhe::zk::ZkVerificationOutCome::Invalid => { | ||
panic!("proof verification failed!!!") | ||
} | ||
} | ||
} | ||
|
||
#[test] | ||
fn test_proof_compat_with_wasm() { | ||
let manifest_dir = env!("CARGO_MANIFEST_DIR"); | ||
let mut test_path = PathBuf::from(manifest_dir); | ||
test_path.push("tests"); | ||
test_path.push("zk_wasm_x86_test"); | ||
|
||
let (pub_key, crs) = gen_key_and_crs(); | ||
|
||
let mut f_pubkey = File::create(test_path.join("public_key.bin")).unwrap(); | ||
safe_serialize(&pub_key, &mut f_pubkey, SIZE_LIMIT).unwrap(); | ||
|
||
let mut f_crs = File::create(test_path.join("crs.bin")).unwrap(); | ||
safe_serialize(crs.public_params(), &mut f_crs, SIZE_LIMIT).unwrap(); | ||
|
||
gen_proven_ct_in_wasm(&test_path); | ||
|
||
let mut f_ct = File::open(test_path.join("proof.bin")).unwrap(); | ||
let proven_ct: ProvenCompactCiphertextList = safe_deserialize(&mut f_ct, SIZE_LIMIT).unwrap(); | ||
|
||
verify_proof(&pub_key, crs.public_params(), &proven_ct); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
const { | ||
TfheCompactPublicKey, | ||
CompactCiphertextList, | ||
CompactPkePublicParams, | ||
ZkComputeLoad, | ||
} = require('node-tfhe'); | ||
|
||
const fs = require('fs'); | ||
|
||
const SIZE_LIMIT = BigInt(1024) * BigInt(1024) * BigInt(1024); | ||
|
||
const tfhe_proof = async () => { | ||
const publicKeyBuf = fs.readFileSync(`${__dirname}/public_key.bin`); | ||
const publicParamsBuf = fs.readFileSync(`${__dirname}/crs.bin`); | ||
const publicKey = TfheCompactPublicKey.safe_deserialize(publicKeyBuf, SIZE_LIMIT); | ||
const publicParams = CompactPkePublicParams.safe_deserialize(publicParamsBuf, SIZE_LIMIT); | ||
|
||
const builder = CompactCiphertextList.builder(publicKey); | ||
builder.push_u4(1); | ||
|
||
builder.push_u8(0xff); | ||
|
||
const encrypted = builder.build_with_proof_packed( | ||
publicParams, | ||
new Uint8Array(), | ||
ZkComputeLoad.Proof, | ||
); | ||
|
||
const ciphertext = encrypted.safe_serialize(SIZE_LIMIT); | ||
let ciphertext_hex = Buffer.from(ciphertext); | ||
|
||
|
||
fs.writeFile('proof.bin', ciphertext_hex, (err) => { | ||
|
||
if (err) throw err; | ||
}); | ||
} | ||
tfhe_proof(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
{ | ||
"name": "zk_wasm_x86_test", | ||
"version": "1.0.0", | ||
"description": "", | ||
"main": "index.js", | ||
"scripts": { | ||
"test": "echo \"Error: no test specified\" && exit 1" | ||
}, | ||
"type": "commonjs", | ||
"author": "", | ||
"license": "BSD-3-Clause", | ||
"dependencies": { | ||
"node-tfhe": "file:../../pkg" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters