Withdraw
This section covers the withdraw functions on a Vault. You can do this in 3 ways: through Smart Contract, Through API or through SDK.
Method 1: Smart Contract call
Withdraw
To withdraw assets from the vault, use the withdraw method. Here are the steps to create the transaction:
Prepare parameters:
withdraw_shares: The amount of vault shares you wish to withdraw.min_amounts_out: A vector specifying the minimum amounts required to receive before the transaction fails (tolerance). This amount is represented in underlying assets.from: The address of the user performing the withdrawal, who will receive the funds. Represents a Soroban address.
Example arguments transaction:
{ "method": "withdraw", "params": { "withdraw_shares": 500, "min_amounts_out": [450], "from": "GCINP..." } }
In code it should look like something like this
let withdraw_args = vec![
e,
&withdraw_shares,
&min_amounts_out,
&from
]
let result = e.try_invoke_contract::(
&vault_address,
&Symbol::new(&e, "withdraw"),
withdraw_args.into_val(e),
).unwrap_or_else(|_| {
panic_with_error!(e, SomeError::SomeError);
}).unwrap();If you want to withdraw specifying the underlying asset, you need to do a "simple rule of three".
So first you call total_supply to get the total amount of shares of the vault, then you need to call fetch_total_managed_funds to get the total_amount of the asset
(Note that DeFindex support multiple assets, so if you are using a vault with only one asset, you should take the first element and get the total_amount)
Then, the needed shares to withdraw will be shares_to_withdraw=total_supply*amount_to_withdraw/total_amount
Method 2: Withdraw using API
Withdraws funds from the DeFindex vault.
const vault = 'CAQ6PAG4X6L7LJVGOKSQ6RU2LADWK4EQXRJGMUWL7SECS7LXUEQLM5U7';
async function withdraw(amount: number, user: string, apiClient: ApiClient, signerFunction: (tx: string) => string) {
const { xdr: unsignedTx } = await apiClient.postData("withdraw", vault, {
amounts: [amount],
from: user
});
// This should be done by implementer
const signedTx = signerFunction(unsignedTx);
const response = await apiClient.postData("send", vault, {
xdr: signedTx
});
return response;
}Method 3: Using SDK
Withdraw from Vault
Remove funds by specifying amounts:
const withdrawData: WithdrawFromVaultParams = {
amounts: [500000], // Specific amounts to withdraw
caller: userAddress,
slippageBps: 100 // 1% slippage tolerance
};
const response = await sdk.withdrawFromVault(vaultAddress, withdrawData, SupportedNetworks.TESTNET);
// Sign response.xdr with the caller account and submit transaction
Withdraw by Shares
Remove funds by burning vault shares:
const shareData: WithdrawSharesParams = {
shares: 1000000, // Number of vault shares to burn
caller: userAddress,
slippageBps: 100
};
const response = await sdk.withdrawShares(vaultAddress, shareData, SupportedNetworks.TESTNET);
// Sign response.xdr with the caller account and submit transactionLast updated