Compute message to be signed differently

This commit is contained in:
Thomas Eizinger 2021-05-12 20:29:06 +10:00
parent 370718ab66
commit 2c6e917554
No known key found for this signature in database
GPG Key ID: 651AC83A6C6C8B96

View File

@ -19,6 +19,7 @@ use rand::{Rng, SeedableRng};
use std::convert::TryInto; use std::convert::TryInto;
use std::iter; use std::iter;
use testcontainers::clients::Cli; use testcontainers::clients::Cli;
use tiny_keccak::{Hasher, Keccak};
#[tokio::test] #[tokio::test]
async fn monerod_integration_test() { async fn monerod_integration_test() {
@ -62,27 +63,27 @@ async fn monerod_integration_test() {
.await .await
.expect("can generate blocks"); .expect("can generate blocks");
let lock_tx = transfer.tx_hash.parse().unwrap(); let lock_tx_hash = transfer.tx_hash.parse().unwrap();
let o_indexes_response = client.get_o_indexes(lock_tx).await.unwrap(); let o_indexes_response = client.get_o_indexes(lock_tx_hash).await.unwrap();
let transaction = client let lock_tx = client
.get_transactions(&[lock_tx]) .get_transactions(&[lock_tx_hash])
.await .await
.unwrap() .unwrap()
.pop() .pop()
.unwrap(); .unwrap();
dbg!(&transaction.prefix.inputs); dbg!(&lock_tx.prefix.inputs);
let viewpair = ViewPair::from(&lock_kp); let viewpair = ViewPair::from(&lock_kp);
let our_output = transaction let our_output = lock_tx
.check_outputs(&viewpair, 0..1, 0..1) .check_outputs(&viewpair, 0..1, 0..1)
.expect("to have outputs in this transaction") .expect("to have outputs in this transaction")
.pop() .pop()
.expect("to own at least one output"); .expect("to own at least one output");
let actual_lock_amount = transaction.get_amount(&viewpair, &our_output).unwrap(); let actual_lock_amount = lock_tx.get_amount(&viewpair, &our_output).unwrap();
assert_eq!(actual_lock_amount, lock_amount); assert_eq!(actual_lock_amount, lock_amount);
@ -215,7 +216,7 @@ async fn monerod_integration_test() {
let pseudo_out = fee_key + out_pk[0].decompress().unwrap() + out_pk[1].decompress().unwrap(); let pseudo_out = fee_key + out_pk[0].decompress().unwrap() + out_pk[1].decompress().unwrap();
let (_, real_commitment_blinder) = transaction.clone().rct_signatures.sig.unwrap().ecdh_info let (_, real_commitment_blinder) = lock_tx.clone().rct_signatures.sig.unwrap().ecdh_info
[our_output.index] [our_output.index]
.open_commitment(&viewpair, &our_output.tx_pubkey, our_output.index); .open_commitment(&viewpair, &our_output.tx_pubkey, our_output.index);
@ -224,8 +225,69 @@ async fn monerod_integration_test() {
let mut responses = random_array(|| Scalar::random(&mut rng)); let mut responses = random_array(|| Scalar::random(&mut rng));
responses[0] = signing_key; responses[0] = signing_key;
let out_pk = out_pk
.iter()
.map(|c| monero::util::ringct::CtKey {
mask: monero::util::ringct::Key { key: c.to_bytes() },
})
.collect::<Vec<_>>();
let rct_sig_base = RctSigBase {
rct_type: RctType::Clsag,
txn_fee: VarInt(fee),
pseudo_outs: Vec::new(),
ecdh_info: vec![ecdh_info_0, ecdh_info_1],
out_pk,
};
let message = {
let tx_prefix_hash = prefix.hash().to_bytes();
let mut rct_sig_base_hash = [0u8; 32];
let mut keccak = Keccak::v256();
keccak.update(&monero::consensus::serialize(&rct_sig_base));
keccak.finalize(&mut rct_sig_base_hash);
let bp_hash = {
let mut keccak = Keccak::v256();
keccak.update(&bulletproof.A.key);
keccak.update(&bulletproof.S.key);
keccak.update(&bulletproof.T1.key);
keccak.update(&bulletproof.T2.key);
keccak.update(&bulletproof.taux.key);
keccak.update(&bulletproof.mu.key);
for i in &bulletproof.L {
keccak.update(&i.key);
}
for i in &bulletproof.R {
keccak.update(&i.key);
}
keccak.update(&bulletproof.a.key);
keccak.update(&bulletproof.b.key);
keccak.update(&bulletproof.t.key);
let mut hash = [0u8; 32];
keccak.finalize(&mut hash);
hash
};
let mut keccak = Keccak::v256();
keccak.update(&tx_prefix_hash);
keccak.update(&rct_sig_base_hash);
keccak.update(&bp_hash);
let mut hash = [0u8; 32];
keccak.finalize(&mut hash);
hash
};
let sig = monero_adaptor::clsag::sign( let sig = monero_adaptor::clsag::sign(
&prefix.hash().to_bytes(), &message,
H_p_pk, H_p_pk,
alpha, alpha,
&ring, &ring,
@ -240,7 +302,7 @@ async fn monerod_integration_test() {
); );
assert!(monero_adaptor::clsag::verify( assert!(monero_adaptor::clsag::verify(
&sig, &sig,
&prefix.hash().to_bytes(), &message,
&ring, &ring,
&commitment_ring, &commitment_ring,
pseudo_out pseudo_out
@ -267,7 +329,7 @@ async fn monerod_integration_test() {
); );
println!( println!(
r#"epee::string_tools::hex_to_pod("{}", msg);"#, r#"epee::string_tools::hex_to_pod("{}", msg);"#,
hex::encode(&prefix.hash().to_bytes()) hex::encode(&message)
); );
ring.iter() ring.iter()
@ -291,24 +353,11 @@ async fn monerod_integration_test() {
hex::encode(pseudo_out.compress().to_bytes()) hex::encode(pseudo_out.compress().to_bytes())
); );
let out_pk = out_pk
.iter()
.map(|c| monero::util::ringct::CtKey {
mask: monero::util::ringct::Key { key: c.to_bytes() },
})
.collect::<Vec<_>>();
let transaction = Transaction { let transaction = Transaction {
prefix, prefix,
signatures: Vec::new(), signatures: Vec::new(),
rct_signatures: RctSig { rct_signatures: RctSig {
sig: Some(RctSigBase { sig: Some(rct_sig_base),
rct_type: RctType::Clsag,
txn_fee: VarInt(fee),
pseudo_outs: Vec::new(),
ecdh_info: vec![ecdh_info_0, ecdh_info_1],
out_pk,
}),
p: Some(RctSigPrunable { p: Some(RctSigPrunable {
range_sigs: Vec::new(), range_sigs: Vec::new(),
bulletproofs: vec![bulletproof], bulletproofs: vec![bulletproof],