Bridge2
General Information
Deposit
Withdraw
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
#[serde(deny_unknown_fields)]
pub(crate) struct WithdrawAction3 {
pub(crate) signature_chain_id: U256,
pub(crate) hyperliquid_chain: Chain,
pub(crate) destination: String,
pub(crate) amount: String,
pub(crate) time: u64,
}
impl Eip712 for WithdrawAction3 {
type Error = Eip712Error;
fn domain(&self) -> StdResult<EIP712Domain, Self::Error> {
Ok(eip_712_domain(self.signature_chain_id))
}
fn type_hash() -> StdResult<[u8; 32], Self::Error> {
Ok(eip712::make_type_hash(
format!("{HYPERLIQUID_EIP_PREFIX}Withdraw"),
&[
("hyperliquidChain".to_string(), ParamType::String),
("destination".to_string(), ParamType::String),
("amount".to_string(), ParamType::String),
("time".to_string(), ParamType::Uint(64)),
],
))
}
fn struct_hash(&self) -> StdResult<[u8; 32], Self::Error> {
let Self { signature_chain_id: _, hyperliquid_chain, destination, amount, time } = self;
let items = vec![
ethers::abi::Token::Uint(Self::type_hash()?.into()),
encode_eip712_type(hyperliquid_chain.to_string().into_token()),
encode_eip712_type(destination.clone().into_token()),
encode_eip712_type(amount.clone().into_token()),
encode_eip712_type(time.into_token()),
];
Ok(keccak256(encode(&items)))
}
}Deposit with permit
Last updated