1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
use super::super::place_order::blockchain::eth::FillOrder as FillOrderEth;
use super::types::{ClientSignedState, ContractBalanceState, RecycledOrder, StateData};
use crate::errors::{ProtocolError, Result};
use crate::types::Blockchain;
use crate::utils::{decode_hexstr, hash_eth_message, hash_neo_message};
use nash_mpc::rust_bigint::BigInt;
use super::super::signer::Signer;
#[cfg(feature = "num_bigint")]
use num_traits::Num;
pub mod eth;
pub mod neo;
use eth::StateUpdatePayloadEth;
pub enum StateUpdatePayload {
Eth(StateUpdatePayloadEth),
}
impl ContractBalanceState {
pub fn verify(&self) -> bool {
let state_data = &self.0;
match state_data.blockchain {
Blockchain::Ethereum => {
if let Ok(_state) = StateUpdatePayloadEth::from_hex(&state_data.payload) {
true
} else {
false
}
}
Blockchain::NEO => true,
Blockchain::Bitcoin => true,
}
}
}
impl RecycledOrder {
pub fn verify(&self) -> bool {
let order_data = &self.0;
match order_data.blockchain {
Blockchain::Ethereum => {
if let Ok(_order) = FillOrderEth::from_hex(&order_data.payload) {
true
} else {
false
}
}
Blockchain::NEO => true,
Blockchain::Bitcoin => true,
}
}
}
pub fn sign_state_data(state_data: &StateData, signer: &mut Signer) -> Result<ClientSignedState> {
let data = match state_data.blockchain {
Blockchain::Ethereum => hash_eth_message(&decode_hexstr(&state_data.payload)?),
Blockchain::NEO => hash_neo_message(&decode_hexstr(&state_data.payload)?),
Blockchain::Bitcoin => BigInt::from_str_radix(&state_data.payload, 16)
.map_err(|_| ProtocolError("Could not parse BTC hash as BigInt"))?,
};
let (sig, r, _pub) = signer.sign_child_key(data, state_data.blockchain)?;
Ok(ClientSignedState::from_state_data(state_data, r, sig))
}
impl From<std::array::TryFromSliceError> for ProtocolError {
fn from(_error: std::array::TryFromSliceError) -> Self {
ProtocolError("Could not convert slice into correct number of bytes")
}
}