use super::{ErrorApi, ManagedTypeApi};
use crate::types::{
Address, BigUint, DctTokenData, ManagedAddress, ManagedByteArray, TokenIdentifier, H256,
};
use alloc::boxed::Box;
pub trait BlockchainApi: ErrorApi + ManagedTypeApi + Clone + Sized + 'static {
fn get_caller_legacy(&self) -> Address;
fn get_caller(&self) -> ManagedAddress<Self> {
ManagedAddress::from_address(self.clone(), &self.get_caller_legacy())
}
fn get_sc_address_legacy(&self) -> Address;
fn get_sc_address(&self) -> ManagedAddress<Self> {
ManagedAddress::from_address(self.clone(), &self.get_sc_address_legacy())
}
fn get_owner_address_legacy(&self) -> Address;
fn get_owner_address(&self) -> ManagedAddress<Self> {
ManagedAddress::from_address(self.clone(), &self.get_owner_address_legacy())
}
fn get_shard_of_address_legacy(&self, address: &Address) -> u32;
fn get_shard_of_address(&self, address: &ManagedAddress<Self>) -> u32 {
self.get_shard_of_address_legacy(&address.to_address())
}
fn is_smart_contract_legacy(&self, address: &Address) -> bool;
fn is_smart_contract(&self, address: &ManagedAddress<Self>) -> bool {
self.is_smart_contract_legacy(&address.to_address())
}
fn get_balance_legacy(&self, address: &Address) -> BigUint<Self>;
fn get_balance(&self, address: &ManagedAddress<Self>) -> BigUint<Self> {
self.get_balance_legacy(&address.to_address())
}
fn get_state_root_hash_legacy(&self) -> H256;
#[inline]
fn get_state_root_hash(&self) -> ManagedByteArray<Self, 32> {
ManagedByteArray::new_from_bytes(self.clone(), self.get_state_root_hash_legacy().as_array())
}
fn get_tx_hash_legacy(&self) -> H256;
fn get_tx_hash(&self) -> ManagedByteArray<Self, 32> {
ManagedByteArray::new_from_bytes(self.clone(), self.get_tx_hash_legacy().as_array())
}
fn get_gas_left(&self) -> u64;
fn get_block_timestamp(&self) -> u64;
fn get_block_nonce(&self) -> u64;
fn get_block_round(&self) -> u64;
fn get_block_epoch(&self) -> u64;
fn get_block_random_seed_legacy(&self) -> Box<[u8; 48]>;
fn get_block_random_seed(&self) -> ManagedByteArray<Self, 48> {
ManagedByteArray::new_from_bytes(self.clone(), &*self.get_block_random_seed_legacy())
}
fn get_prev_block_timestamp(&self) -> u64;
fn get_prev_block_nonce(&self) -> u64;
fn get_prev_block_round(&self) -> u64;
fn get_prev_block_epoch(&self) -> u64;
fn get_prev_block_random_seed_legacy(&self) -> Box<[u8; 48]>;
fn get_prev_block_random_seed(&self) -> ManagedByteArray<Self, 48> {
ManagedByteArray::new_from_bytes(self.clone(), &*self.get_prev_block_random_seed_legacy())
}
fn get_current_dct_nft_nonce(
&self,
address: &Address,
token_id: &TokenIdentifier<Self>,
) -> u64;
fn get_dct_balance(
&self,
address: &ManagedAddress<Self>,
token_id: &TokenIdentifier<Self>,
nonce: u64,
) -> BigUint<Self>;
fn get_dct_token_data(
&self,
address: &ManagedAddress<Self>,
token_id: &TokenIdentifier<Self>,
nonce: u64,
) -> DctTokenData<Self>;
}