hopr_chain_types/payload/
mod.rs1#[cfg(feature = "use-bindings")]
15mod bindings_based;
16
17#[cfg(feature = "use-bindings")]
18pub(crate) use bindings_based::KeyBindAndAnnouncePayload;
19#[cfg(feature = "use-bindings")]
20pub use bindings_based::{BasicPayloadGenerator, SafePayloadGenerator, TransactionRequest};
21use hopr_crypto_types::prelude::*;
22use hopr_internal_types::prelude::*;
23use hopr_primitive_types::prelude::*;
24
25type Result<T> = std::result::Result<T, crate::errors::ChainTypesError>;
26
27#[derive(Clone, Copy, Debug, PartialEq, Eq)]
29pub struct GasEstimation {
30 pub gas_limit: u64,
34 pub max_fee_per_gas: u128,
38 pub max_priority_fee_per_gas: u128,
42}
43
44impl Default for GasEstimation {
45 fn default() -> Self {
46 Self {
47 gas_limit: 17_000_000,
48 max_fee_per_gas: 10_000_000, max_priority_fee_per_gas: 2_000_000, }
51 }
52}
53
54#[async_trait::async_trait]
56pub trait SignableTransaction {
57 async fn sign_and_encode_to_eip2718(
59 self,
60 nonce: u64,
61 max_gas: Option<GasEstimation>,
62 chain_keypair: &ChainKeypair,
63 ) -> Result<Box<[u8]>>;
64}
65
66pub trait PayloadGenerator {
68 type TxRequest: SignableTransaction + Send;
69
70 fn approve(&self, spender: Address, amount: HoprBalance) -> Result<Self::TxRequest>;
73
74 fn transfer<C: Currency>(&self, destination: Address, amount: Balance<C>) -> Result<Self::TxRequest>;
76
77 fn announce(&self, announcement: AnnouncementData, key_binding_fee: HoprBalance) -> Result<Self::TxRequest>;
79
80 fn fund_channel(&self, dest: Address, amount: HoprBalance) -> Result<Self::TxRequest>;
82
83 fn close_incoming_channel(&self, source: Address) -> Result<Self::TxRequest>;
85
86 fn initiate_outgoing_channel_closure(&self, destination: Address) -> Result<Self::TxRequest>;
90
91 fn finalize_outgoing_channel_closure(&self, destination: Address) -> Result<Self::TxRequest>;
95
96 fn redeem_ticket(&self, acked_ticket: RedeemableTicket) -> Result<Self::TxRequest>;
98
99 fn register_safe_by_node(&self, safe_addr: Address) -> Result<Self::TxRequest>;
102
103 fn deregister_node_by_safe(&self) -> Result<Self::TxRequest>;
106}
107
108#[cfg(test)]
109pub(crate) mod tests {
110 use crate::ContractAddresses;
111
112 lazy_static::lazy_static! {
113 pub static ref CONTRACT_ADDRS: ContractAddresses = serde_json::from_str(r#"{
114 "announcements": "0xf1c143B1bA20C7606d56aA2FA94502D25744b982",
115 "channels": "0x77C9414043d27fdC98A6A2d73fc77b9b383092a7",
116 "module_implementation": "0x32863c4974fBb6253E338a0cb70C382DCeD2eFCb",
117 "network_registry": "0x15a315E1320cFF0de84671c0139042EE320CE38d",
118 "network_registry_proxy": "0x20559cbD3C2eDcD0b396431226C00D2Cd102eB3F",
119 "node_safe_registry": "0x4F7C7dE3BA2B29ED8B2448dF2213cA43f94E45c0",
120 "node_safe_migration": "0x222222222222890352Ed9Ca694EdeAC49528D8F3",
121 "node_stake_factory": "0x791d190b2c95397F4BcE7bD8032FD67dCEA7a5F2",
122 "token": "0xD4fdec44DB9D44B8f2b6d529620f9C0C7066A2c1",
123 "ticket_price_oracle": "0x442df1d946303fB088C9377eefdaeA84146DA0A6",
124 "winning_probability_oracle": "0xC15675d4CCa538D91a91a8D3EcFBB8499C3B0471"
125 }"#).unwrap();
126 }
127}