diff --git a/TNLS-Gateways/secret/src/contract.rs b/TNLS-Gateways/secret/src/contract.rs index e009e2c..b76a176 100644 --- a/TNLS-Gateways/secret/src/contract.rs +++ b/TNLS-Gateways/secret/src/contract.rs @@ -254,8 +254,8 @@ fn pre_execution(deps: DepsMut, _env: Env, msg: PreExecutionMsg) -> StdResult StdResult StdResult StdResult StdResult StdResult { fn query_execution_result(deps: Deps, task: Task) -> StdResult { let task_info = RESULT_MAP - .get(deps.storage, &task) - .ok_or_else(|| StdError::generic_err("task not found"))?; + .get(deps.storage, &task) + .ok_or_else(|| StdError::generic_err("task not found"))?; to_binary(&ResultInfo { source_network: task_info.source_network, @@ -523,7 +494,7 @@ mod tests { use super::*; use crate::types::*; use cosmwasm_std::testing::{mock_dependencies, mock_env, mock_info}; - use cosmwasm_std::{from_binary, Addr, Binary, Empty}; + use cosmwasm_std::{from_binary, Addr, Api, Binary, Empty}; use chacha20poly1305::aead::{Aead, NewAead}; use chacha20poly1305::{ChaCha20Poly1305, Key, Nonce}; @@ -533,13 +504,11 @@ mod tests { const SOMEBODY: &str = "somebody"; #[track_caller] - fn setup_test_case(deps: DepsMut) -> Result, StdError> { + fn setup_test_case(deps: DepsMut) -> Result { // Instantiate a contract with entropy let admin = Some(Addr::unchecked(OWNER.to_owned())); - let init_msg = InstantiateMsg { - admin, - }; + let init_msg = InstantiateMsg { admin }; instantiate(deps, mock_env(), mock_info(OWNER, &[]), init_msg) } @@ -562,16 +531,14 @@ mod tests { } #[test] - #[ignore = "need new callback fields"] fn test_init() { let mut deps = mock_dependencies(); - let response = setup_test_case(deps.as_mut()).unwrap(); - assert_eq!(1, response.messages.len()); + let response = setup_test_case(deps.as_mut()); + assert!(response.is_ok()); } #[test] - #[ignore = "need new callback fields"] fn test_query() { let mut deps = mock_dependencies(); let env = mock_env(); @@ -589,7 +556,6 @@ mod tests { } #[test] - #[ignore = "need new callback fields"] fn test_pre_execution() { let mut deps = mock_dependencies(); let env = mock_env(); @@ -632,8 +598,8 @@ mod tests { routing_code_hash: routing_code_hash.clone(), user_address: user_address.clone(), user_key: user_key.clone(), - callback_address: todo!(), - callback_selector: todo!(), + callback_address: b"public gateway address".into(), + callback_selector: b"0xfaef40fe".into(), callback_gas_limit: 300_000u32, }; let serialized_payload = to_binary(&payload).unwrap(); @@ -648,9 +614,19 @@ mod tests { .unwrap(); // sign the payload - let payload_hash = sha_256(serialized_payload.as_slice()); - let message = Message::from_slice(&payload_hash).unwrap(); - let payload_signature = secp.sign_ecdsa(&message, &secret_key); + let prefix = "\x19Ethereum Signed Message:\n32".as_bytes(); + let mut hasher = Keccak256::new(); + + // NOTE: hmmm shouldn't this be a hash of the non-encrypted payload? + hasher.update(encrypted_payload.as_slice()); + let payload_hash_tmp = hasher.finalize_reset(); + hasher.update([prefix, &payload_hash_tmp].concat()); + let payload_hash = hasher.finalize(); + + // let message = Message::from_slice(&payload_hash).unwrap(); + // let payload_signature = secp.sign_ecdsa(&message, &secret_key); + + let payload_signature = deps.api.secp256k1_sign(&payload_hash, secret_key.as_ref()).unwrap(); // mock wrong payload (encrypted with a key that does not match the one inside the payload) let wrong_user_address = Addr::unchecked("wrong eth address".to_string()); @@ -662,8 +638,8 @@ mod tests { routing_code_hash: routing_code_hash.clone(), user_address: wrong_user_address.clone(), user_key: wrong_user_key.clone(), - callback_address: todo!(), - callback_selector: todo!(), + callback_address: b"public gateway address".into(), + callback_selector: b"0xfaef40fe".into(), callback_gas_limit: 300_000u32, }; let wrong_serialized_payload = to_binary(&wrong_payload).unwrap(); @@ -681,7 +657,7 @@ mod tests { routing_code_hash: routing_code_hash.clone(), payload: Binary(wrong_encrypted_payload.clone()), payload_hash: Binary(payload_hash.to_vec()), - payload_signature: Binary(payload_signature.serialize_compact().to_vec()), + payload_signature: Binary(payload_signature.to_vec()), user_address: user_address.clone(), user_key: user_key.clone(), user_pubkey: user_pubkey.clone(), @@ -709,7 +685,7 @@ mod tests { routing_code_hash: routing_code_hash.clone(), payload: Binary(encrypted_payload.clone()), payload_hash: Binary(payload_hash.to_vec()), - payload_signature: Binary(payload_signature.serialize_compact().to_vec()), + payload_signature: Binary(payload_signature.to_vec()), user_address: user_address.clone(), user_key: user_key.clone(), user_pubkey: user_pubkey.clone(), @@ -731,7 +707,7 @@ mod tests { routing_code_hash, payload: Binary(encrypted_payload), payload_hash: Binary(payload_hash.to_vec()), - payload_signature: Binary(payload_signature.serialize_compact().to_vec()), + payload_signature: Binary(payload_signature.to_vec()), user_address, user_key, user_pubkey, @@ -754,7 +730,6 @@ mod tests { } #[test] - #[ignore = "need new callback fields"] fn test_post_execution() { let mut deps = mock_dependencies(); let env = mock_env(); @@ -792,8 +767,8 @@ mod tests { routing_code_hash: routing_code_hash.clone(), user_address: user_address.clone(), user_key: user_key.clone(), - callback_address: todo!(), - callback_selector: todo!(), + callback_address: b"public gateway address".into(), + callback_selector: b"0xfaef40fe".into(), callback_gas_limit: 300_000u32, }; let serialized_payload = to_binary(&payload).unwrap(); @@ -805,12 +780,19 @@ mod tests { let nonce = Nonce::from_slice(b"unique nonce"); // 12-bytes; unique per message let encrypted_payload = cipher .encrypt(nonce, serialized_payload.as_slice()) - .expect("encryption failure!"); // NOTE: handle this error to avoid panics! + .expect("encryption failure!"); // sign the payload - let payload_hash = sha_256(serialized_payload.as_slice()); - let message = Message::from_slice(&payload_hash).unwrap(); - let payload_signature = secp.sign_ecdsa(&message, &secret_key); + let prefix = "\x19Ethereum Signed Message:\n32".as_bytes(); + let mut hasher = Keccak256::new(); + + // NOTE: shouldn't this be a hash of the non-encrypted payload? + hasher.update(encrypted_payload.as_slice()); + let payload_hash_tmp = hasher.finalize_reset(); + hasher.update([prefix, &payload_hash_tmp].concat()); + let payload_hash = hasher.finalize(); + + let payload_signature = deps.api.secp256k1_sign(&payload_hash, secret_key.as_ref()).unwrap(); // execute input handle let pre_execution_msg = PreExecutionMsg { @@ -820,7 +802,7 @@ mod tests { routing_code_hash, payload: Binary(encrypted_payload), payload_hash: Binary(payload_hash.to_vec()), - payload_signature: Binary(payload_signature.serialize_compact().to_vec()), + payload_signature: Binary(payload_signature.to_vec()), user_address, user_key, user_pubkey: user_pubkey.clone(), @@ -835,7 +817,7 @@ mod tests { // test incorrect input_hash let wrong_post_execution_msg = PostExecutionMsg { - result: "{\"answer\": 42}".to_string(), + result: base64::encode("{\"answer\": 42}".to_string()), task: Task { network: "ethereum".to_string(), task_id: "1".to_string() }, input_hash: Binary(sha_256("wrong data".as_bytes()).to_vec()), }; @@ -843,17 +825,14 @@ mod tests { outputs: wrong_post_execution_msg, }; let err = execute(deps.as_mut(), env.clone(), info.clone(), handle_msg).unwrap_err(); - assert_eq!( - err, - StdError::generic_err("input hash does not match task id") - ); + assert_eq!(err, StdError::generic_err("input hash does not match task")); // test output handle let post_execution_msg = PostExecutionMsg { - result: "{\"answer\": 42}".to_string(), + result: base64::encode("{\"answer\": 42}".to_string()), task: Task { network: "ethereum".to_string(), task_id: "1".to_string() }, input_hash: Binary( - sha_256(&[data.as_bytes(), 1u64.to_le_bytes().as_ref()].concat()).to_vec(), + sha_256(&[data.as_bytes(), "1".to_string().as_bytes(), &[0u8]].concat()).to_vec(), ), };