use dharitri_sc_scenario::{dharitri_sc::types::Address, scenario_model::AddressValue};
use dharitri_sdk::{
blockchain::CommunicationProxy,
data::{address::Address as ErdrsAddress, network_config::NetworkConfig},
wallet::Wallet,
};
use std::{collections::HashMap, time::Duration};
use crate::Sender;
pub struct Interactor {
pub proxy: CommunicationProxy,
pub network_config: NetworkConfig,
pub sender_map: HashMap<Address, Sender>,
pub(crate) waiting_time_ms: u64,
}
impl Interactor {
pub async fn new(gateway_url: &str) -> Self {
let proxy = CommunicationProxy::new(gateway_url.to_string());
let network_config = proxy.get_network_config().await.unwrap();
Self {
proxy,
network_config,
sender_map: HashMap::new(),
waiting_time_ms: 0,
}
}
pub fn register_wallet(&mut self, wallet: Wallet) -> Address {
let address = erdrs_address_to_h256(wallet.address());
self.sender_map.insert(
address.clone(),
Sender {
address: address.clone(),
wallet,
current_nonce: None,
},
);
address
}
pub async fn sleep(&mut self, duration: Duration) {
self.waiting_time_ms += duration.as_millis() as u64;
tokio::time::sleep(duration).await;
}
}
pub(crate) fn mandos_to_erdrs_address(mandos_address: &AddressValue) -> ErdrsAddress {
let bytes = mandos_address.value.as_array();
ErdrsAddress::from_bytes(*bytes)
}
pub(crate) fn address_h256_to_erdrs(address: &Address) -> ErdrsAddress {
let bytes = address.as_array();
ErdrsAddress::from_bytes(*bytes)
}
pub(crate) fn erdrs_address_to_h256(erdrs_address: ErdrsAddress) -> Address {
erdrs_address.to_bytes().into()
}