pub trait BlockchainApi:
ErrorApi
+ ManagedTypeApi
+ Clone
+ Sized
+ 'static {
Show 32 methods
// Required methods
fn get_caller_legacy(&self) -> Address;
fn get_sc_address_legacy(&self) -> Address;
fn get_owner_address_legacy(&self) -> Address;
fn get_shard_of_address_legacy(&self, address: &Address) -> u32;
fn is_smart_contract_legacy(&self, address: &Address) -> bool;
fn get_balance_legacy(&self, address: &Address) -> BigUint<Self>;
fn get_state_root_hash_legacy(&self) -> H256;
fn get_tx_hash_legacy(&self) -> H256;
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_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_current_dcdt_nft_nonce(
&self,
address: &Address,
token_id: &TokenIdentifier<Self>,
) -> u64;
fn get_dcdt_balance(
&self,
address: &ManagedAddress<Self>,
token_id: &TokenIdentifier<Self>,
nonce: u64,
) -> BigUint<Self>;
fn get_dcdt_token_data(
&self,
address: &ManagedAddress<Self>,
token_id: &TokenIdentifier<Self>,
nonce: u64,
) -> DcdtTokenData<Self>;
// Provided methods
fn get_caller(&self) -> ManagedAddress<Self> { ... }
fn get_sc_address(&self) -> ManagedAddress<Self> { ... }
fn get_owner_address(&self) -> ManagedAddress<Self> { ... }
fn get_shard_of_address(&self, address: &ManagedAddress<Self>) -> u32 { ... }
fn is_smart_contract(&self, address: &ManagedAddress<Self>) -> bool { ... }
fn get_balance(&self, address: &ManagedAddress<Self>) -> BigUint<Self> { ... }
fn get_state_root_hash(&self) -> ManagedByteArray<Self, 32> { ... }
fn get_tx_hash(&self) -> ManagedByteArray<Self, 32> { ... }
fn get_block_random_seed(&self) -> ManagedByteArray<Self, 48> { ... }
fn get_prev_block_random_seed(&self) -> ManagedByteArray<Self, 48> { ... }
}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.
Required Methods§
fn get_caller_legacy(&self) -> Address
fn get_sc_address_legacy(&self) -> Address
fn get_owner_address_legacy(&self) -> Address
fn get_shard_of_address_legacy(&self, address: &Address) -> u32
fn is_smart_contract_legacy(&self, address: &Address) -> bool
fn get_balance_legacy(&self, address: &Address) -> BigUint<Self>
fn get_state_root_hash_legacy(&self) -> H256
fn get_tx_hash_legacy(&self) -> H256
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_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_current_dcdt_nft_nonce( &self, address: &Address, token_id: &TokenIdentifier<Self>, ) -> u64
fn get_dcdt_balance( &self, address: &ManagedAddress<Self>, token_id: &TokenIdentifier<Self>, nonce: u64, ) -> BigUint<Self>
fn get_dcdt_token_data( &self, address: &ManagedAddress<Self>, token_id: &TokenIdentifier<Self>, nonce: u64, ) -> DcdtTokenData<Self>
Provided Methods§
fn get_caller(&self) -> ManagedAddress<Self>
fn get_sc_address(&self) -> ManagedAddress<Self>
fn get_owner_address(&self) -> ManagedAddress<Self>
fn get_shard_of_address(&self, address: &ManagedAddress<Self>) -> u32
fn is_smart_contract(&self, address: &ManagedAddress<Self>) -> bool
fn get_balance(&self, address: &ManagedAddress<Self>) -> BigUint<Self>
fn get_state_root_hash(&self) -> ManagedByteArray<Self, 32>
fn get_tx_hash(&self) -> ManagedByteArray<Self, 32>
fn get_block_random_seed(&self) -> ManagedByteArray<Self, 48>
fn get_prev_block_random_seed(&self) -> ManagedByteArray<Self, 48>
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.