Struct dharitri_wasm::contract_base::BlockchainWrapper
source · pub struct BlockchainWrapper<A>{ /* private fields */ }Expand description
Interface to be used by the actual smart contract code.
Note: contracts and the api are not mutable. They simply pass on/retrieve data to/from the protocol. When mocking the blockchain state, we use the Rc/RefCell pattern to isolate mock state mutability from the contract interface.
Implementations§
source§impl<A> BlockchainWrapper<A>
impl<A> BlockchainWrapper<A>
pub fn get_caller_legacy(&self) -> Address
pub fn get_caller(&self) -> ManagedAddress<A>
pub fn get_sc_address_legacy(&self) -> Address
pub fn get_sc_address(&self) -> ManagedAddress<A>
pub fn get_owner_address_legacy(&self) -> Address
pub fn get_owner_address(&self) -> ManagedAddress<A>
pub fn check_caller_is_owner(&self)
pub fn get_shard_of_address_legacy(&self, address: &Address) -> u32
pub fn get_shard_of_address(&self, address: &ManagedAddress<A>) -> u32
pub fn is_smart_contract_legacy(&self, address: &Address) -> bool
pub fn is_smart_contract(&self, address: &ManagedAddress<A>) -> bool
pub fn get_balance_legacy(&self, address: &Address) -> BigUint<A>
pub fn get_balance(&self, address: &ManagedAddress<A>) -> BigUint<A>
pub fn get_sc_balance( &self, token: &TokenIdentifier<A>, nonce: u64 ) -> BigUint<A>
pub fn get_state_root_hash_legacy(&self) -> H256
pub fn get_state_root_hash(&self) -> ManagedByteArray<A, 32>
pub fn get_tx_hash_legacy(&self) -> H256
pub fn get_tx_hash(&self) -> ManagedByteArray<A, 32>
pub fn get_gas_left(&self) -> u64
pub fn get_block_timestamp(&self) -> u64
pub fn get_block_nonce(&self) -> u64
pub fn get_block_round(&self) -> u64
pub fn get_block_epoch(&self) -> u64
pub fn get_block_random_seed_legacy(&self) -> Box<[u8; 48]>
pub fn get_block_random_seed(&self) -> ManagedByteArray<A, 48>
pub fn get_prev_block_timestamp(&self) -> u64
pub fn get_prev_block_nonce(&self) -> u64
pub fn get_prev_block_round(&self) -> u64
pub fn get_prev_block_epoch(&self) -> u64
pub fn get_prev_block_random_seed_legacy(&self) -> Box<[u8; 48]>
pub fn get_prev_block_random_seed(&self) -> ManagedByteArray<A, 48>
pub fn get_current_dct_nft_nonce( &self, address: &Address, token_id: &TokenIdentifier<A> ) -> u64
pub fn get_dct_balance( &self, address: &ManagedAddress<A>, token_id: &TokenIdentifier<A>, nonce: u64 ) -> BigUint<A>
pub fn get_dct_token_data( &self, address: &ManagedAddress<A>, token_id: &TokenIdentifier<A>, nonce: u64 ) -> DctTokenData<A>
sourcepub fn get_cumulated_validator_rewards(&self) -> BigUint<A>
pub fn get_cumulated_validator_rewards(&self) -> BigUint<A>
Retrieves validator rewards, as set by the protocol.
sourcepub fn get_dct_local_roles(
&self,
token_id: &TokenIdentifier<A>
) -> Vec<DctLocalRole>
pub fn get_dct_local_roles( &self, token_id: &TokenIdentifier<A> ) -> Vec<DctLocalRole>
Retrieves local roles for the token, by reading protected storage. TODO: rewrite using managed types
Auto Trait Implementations§
impl<A> RefUnwindSafe for BlockchainWrapper<A>where
A: RefUnwindSafe,
impl<A> Send for BlockchainWrapper<A>where
A: Send,
impl<A> Sync for BlockchainWrapper<A>where
A: Sync,
impl<A> Unpin for BlockchainWrapper<A>where
A: Unpin,
impl<A> UnwindSafe for BlockchainWrapper<A>where
A: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more