pub async fn fetch_positions_for_owner(
rpc: &RpcClient,
owner: Pubkey,
) -> Result<Vec<PositionOrBundle>, Box<dyn Error>>
Expand description
Fetches all positions owned by a given wallet in the Orca Whirlpools.
This function retrieves token accounts owned by the wallet, using both the SPL Token Program and Token 2022 Program. It identifies accounts holding exactly one token, which represent either a position or a position bundle. For each of these accounts, it fetches the corresponding position or bundle data, including any bundled positions, and returns them.
§Arguments
rpc
- A reference to the Solana RPC client.owner
- The public key of the wallet whose positions should be fetched.
§Returns
A Result
containing a vector of PositionOrBundle
objects, representing the decoded
positions or position bundles owned by the given wallet.
§Errors
This function will return an error if:
- Token accounts cannot be fetched.
- Position or position bundle addresses cannot be derived.
- RPC calls fail when fetching account data.
§Example
use orca_whirlpools::{
fetch_positions_for_owner, set_whirlpools_config_address, WhirlpoolsConfigInput
};
use solana_client::nonblocking::rpc_client::RpcClient;
use solana_sdk::pubkey::Pubkey;
use std::str::FromStr;
#[tokio::main]
async fn main() {
set_whirlpools_config_address(WhirlpoolsConfigInput::SolanaDevnet).unwrap();
let rpc = RpcClient::new("https://api.devnet.solana.com".to_string());
let whirlpool_address =
Pubkey::from_str("3KBZiL2g8C7tiJ32hTv5v3KM7aK9htpqTw4cTXz1HvPt").unwrap();
let positions = fetch_positions_for_owner(&rpc, whirlpool_address)
.await
.unwrap();
println!("Positions: {:?}", positions);
}