Once you set up a provider, you can interact with the Fuel blockchain. Here are a few examples of what you can do with a provider; for a more in-depth overview of the API, check the official provider API documentation Icon Link.
You might need to set up a test blockchain first. You can skip this step if you're connecting to an external blockchain.
use fuels::prelude::*;// Set up our test blockchain.// Create a random wallet (more on wallets later).let wallet =WalletUnlocked::new_random(None);// How many coins in our wallet.let number_of_coins =1;// The amount/value in each coin in our wallet.let amount_per_coin =3;let coins =setup_single_asset_coins( wallet.address(),BASE_ASSET_ID, number_of_coins, amount_per_coin,);let retry_config =RetryConfig::new(3, Backoff::Fixed(Duration::from_secs(2)))?;let provider =setup_test_provider(coins.clone(), vec![], None, None).await?.with_retry_config(retry_config);
The following example shows how to fetch resources owned by an address. First, you create a ResourceFilter which specifies the target address, asset ID, and amount. You can also define UTXO IDs and message IDs that should be excluded when retrieving the resources:
The example uses default values for the asset ID and the exclusion lists. This resolves to the base asset ID and empty vectors for the ID lists respectively:
Get all the spendable balances of all assets for an address. This is different from getting the coins because we only return the numbers (the sum of UTXOs coins amount for each asset ID) and not the UTXOs coins themselves.
let _balances = provider.get_balances(wallet.address()).await?;