Balances
The StakeKit API offers multiple endpoints to retrieve an address balance, including yield-related balances and available token balances.
Yield Balances
Endpoints
Endpoints related to yield balances require an address, a network, and in some cases, validator address(es) or Yield IDs. (See API Referencefor more details)
To fetch for yield balances given an address and an integrationId:
curl --request POST \
--url https://api.stakek.it/v1/yields/balances \
--header 'accept: application/json' \
--header 'X-API-KEY: INSERT_YOUR_TOKEN' \
--header 'content-type: application/json' \
--data '
[
{
"addresses": {
"address": "0xB6c5273e79E2aDD234EBC07d87F3824e0f94B2F7"
},
"integrationId": "ethereum-eth-lido-staking"
}
]
'
This will return the following response:
[
{
"integrationId": "ethereum-eth-lido-staking",
"balances": [
{
"type": "staked",
"amount": "0.109871139090150026",
"pricePerShare": "0.999253559516919067",
"pendingActions": [],
"token": {
"network": "ethereum",
"name": "Lido Staked Ether",
"decimals": 18,
"address": "0xae7ab96520de3a18e5e111b5eaab095312d7fe84",
"symbol": "stETH",
"logoURI": "https://assets.stakek.it/tokens/steth.svg"
}
},
{
"type": "unstaking",
"amount": "0.000000000000000000",
"pricePerShare": "0.999253559516919067",
"pendingActions": [],
"token": {
"network": "ethereum",
"name": "Lido Staked Ether",
"decimals": 18,
"address": "0xae7ab96520de3a18e5e111b5eaab095312d7fe84",
"symbol": "stETH",
"logoURI": "https://assets.stakek.it/tokens/steth.svg"
}
},
{
"type": "unstaked",
"amount": "0.010000000000000000",
"pricePerShare": "0.999253559516919067",
"pendingActions": [
{
"type": "CLAIM_UNSTAKED",
"passthrough": "eyJhZGRyZXNzZXMiOnsiYWRkcmVzcyI6IjB4QjZjNTI3M2U3OUUyYUREMjM0RUJDMDdkODdGMzgyNGUwZjk0QjJGNyJ9fQ=="
}
],
"token": {
"network": "ethereum",
"name": "Lido Staked Ether",
"decimals": 18,
"address": "0xae7ab96520de3a18e5e111b5eaab095312d7fe84",
"symbol": "stETH",
"logoURI": "https://assets.stakek.it/tokens/steth.svg"
}
}
]
},
]
Types
For consistency, all yield balances use the following interface:
export interface YieldBalanceDto {
/** What state the balance is in. "staked" is the only balance earning yields */
type: BalanceTypes;
/** The balance amount */
amount: string;
/** Date */
date?: string;
/** The price of the reward token as a multiple of the underlying token. Used when dealing with index based yields where the reward asset appreciates in value over time. */
pricePerShare: string;
/** A list of pending actions that is related to the balance. Can for example be "CLAIM_REWARDS" for balances of type "rewards" */
pendingActions: PendingActionDto[];
/** The token associated with the balance */
token: TokenDto;
/** The validator associated with the balance */
validatorAddress?: string;
}
The Type is an important enum that describes what state the balance is currently in:
export enum BalanceTypes {
Available = 'available',
Staked = 'staked',
Unstaking = 'unstaking',
Unstaked = 'unstaked',
Preparing = 'preparing',
Rewards = 'rewards',
Locked = 'locked',
Unlocking = 'unlocking',
}
Balances can also contain Pending Actions (such as "Claim Rewards", "Withdraw", "Unlock", and "Restake"):
export interface PendingActionDto {
/** The pending action type */
type: ActionTypes;
/** A server generated passthrough that must passed back when pulling the transactions for a given pending action */
passthrough: string;
/** Any user chosen options for the pending action. Possible options can be for example validator address, duration, etc */
args?: ActionArgumentOptionsDto;
}
export enum ActionTypes {
STAKE = 'STAKE',
UNSTAKE = 'UNSTAKE',
CLAIM_REWARDS = 'CLAIM_REWARDS',
RESTAKE_REWARDS = 'RESTAKE_REWARDS',
WITHDRAW = 'WITHDRAW',
RESTAKE = 'RESTAKE',
CLAIM_UNSTAKED = 'CLAIM_UNSTAKED',
UNLOCK_LOCKED = 'UNLOCK_LOCKED',
UNLOCK_LOCKED_LEGACY = 'UNLOCK_LOCKED_LEGACY',
STAKE_LOCKED = 'STAKE_LOCKED',
}
The Pending Action related to the balance on line 512 in the example response above can be initiated using the following request:
curl --request POST \
--url https://api.stakek.it/v1/actions/pending \
--header 'accept: application/json' \
--header 'content-type: application/json' \
--data '
{
"type": "CLAIM_REWARDS",
"integrationId": "ethereum-ape-native-staking",
"passthrough": "eyJhZGRyZXNzZXMiOnsiYWRkcmVzcyI6IjB4QjZjNTI3M2U3OUUyYUREMjM0RUJDMDdkODdGMzgyNGUwZjk0QjJGNyJ9fQ=="
}
'
This will return the action and unsigned transactions needed to sign and submit to perform the action. More details about pending actions can be found here.
Yield Balances Breakdown
Staked Balance
The staked balance is the amount that is currently earning user rewards. It returns the staked amount, the asset metadata, and the validator address. For a single yield, a user can have multiple staked balances depending on how many different validators the user has staked with. Staked balances do not usually have Pending Actions.
{
"type": "staked",
"amount": "5.100000000000000000",
"pricePerShare": "1",
"pendingActions": [],
"token": {
"name": "Cosmos",
"network": "cosmos",
"decimals": 6,
"symbol": "ATOM",
"logoURI": "https://assets.stakek.it/tokens/atom.svg",
"coinGeckoId": "cosmos"
},
"validatorAddress": "cosmosvaloper1gpx52r9h3zeul45amvcy2pysgvcwddxrgx6cnv"
},
Unstaking Balance
Unstaking periods vary depending on the asset or yield opportunity. During an unstaking period, users do not have access to the tokens being staked – the tokens either become available automatically after the lockup period or have to be claimed through a Pending Action once unstaking period concludes. This balance includes the time at which the assets become available. The below example demonstrates ATOM unstaking data, including the amount being unstaked, the date when the unstaking period ends, the asset metadata, and the validator address.
{
"type": "unstaking",
"amount": "0.100000000000000000",
"date": "2023-12-01T13:56:09.000Z",
"pricePerShare": "1",
"pendingActions": [],
"token": {
"name": "Cosmos",
"network": "cosmos",
"decimals": 6,
"symbol": "ATOM",
"logoURI": "https://assets.stakek.it/tokens/atom.svg">,
"coinGeckoId": "cosmos"
},
"validatorAddress": "cosmosvaloper1tflk30mq5vgqjdly92kkhhq3raev2hnz6eete3"
},
Unstaked Balance
Some yields require users to manually withdraw unstaked assets once the unstaking period is over. The example below shows an unstaked balance amount and the associated "Withdraw" Pending Actions.
....{
"type": "unstaked",
"amount": "0.200000000000000000",
"pendingActions":\[
{
"type": "WITHDRAW",
"passthrough": "..."
}....
Locked Balance
When it comes to staking flows such as that of CELO native staking, users make three transactions that need to be signed and submitted: account creation, locking CELO, and delegating CELO. If the final transaction fails, the user will have a locked CELO balance. Users are able to adjust their locked position by utilizing the “Stake Locked” or “Unstake Locked” Pending Actions. If the locked balance is 0, the Pending Actions aren’t available. Here is an example of a locked balance after calling the balances endpoint:
{
"type": "locked",
"amount": "1.000000000000000000",
"pendingActions": [],
"token": {
"name": "Celo",
"symbol": "CELO",
"decimals": 18,
"address": "0x471EcE3750Da237f93B8E339c536989b8978a438",
"network": "celo",
"coinGeckoId": "celo",
"logoURI": "https://assets.stakek.it/tokens/celo.svg"
},
"pricePerShare": "1"
}
Unlocking Balance
On Celo, there are three transactions that need to be signed and submitted when staking: account creation, locking CELO, and delegating CELO. If the final transaction fails, the user will have a locked CELO balance. If a user decides to adjust their locked position by utilizing the “Unlock Locked” Pending Action, they will have an “unlocking balance” until the process is finished.
Rewards Balance
You can retrieve the rewards balance for each available yield. For yields where there are multiple validators, the rewards balance is shown for each validator, not combined per yield. If the reward balances are above the minimum claimable amount, they will include Pending Actions as well. The example below shows the amount of accrued rewards and two possible Pending Actions ("Claim Rewards" and "Restake Rewards"):
....{
"type": "rewards",
"amount": "0.000023920678712104",
"pricePerShare": "1",
"pendingActions": \[
{
"type": "CLAIM_REWARDS",
"passthrough": "..."
},
{
"type": "RESTAKE_REWARDS",
"passthrough": "..."
}....
Preparing Balance
In staking flows of the likes of Celo native staking, there is a period where the votes are pending. The process of activating a stake on Solana is another example of this. For that, it takes three days before the user can begin to earn rewards. During such periods, the balance type will be “preparing”.
{
"type": "preparing",
"amount": "1.000000000000000000",
"validatorAddress": "0x01b2b83fdf26afc3ca7062c35bc68c8dde56db04",
"pendingActions": [],
"pricePerShare": "1",
"token": {
"name": "Celo",
"symbol": "CELO",
"decimals": 18,
"address": "0x471EcE3750Da237f93B8E339c536989b8978a438",
"network": "celo",
"coinGeckoId": "celo",
"logoURI": "https://assets.stakek.it/tokens/celo.svg"
},
"date": "2023-11-15T19:03:29.579Z"
},
Token Balances
Endpoints
There are two primary endpoints to retrieve token balances. See API Referencefor more details).
The first is: /token/balances
This endpoint fetches token balances and returns it to the user. See request below. Please note that it only able to retrieve balances across networks and yields that our platform supports.
curl --request POST \
--url https://api.stakek.it/v1/tokens/balances \
--header 'accept: application/json' \
--header 'X-API-KEY: INSERT_YOUR_TOKEN' \
--header 'content-type: application/json' \
--data '
{
"addresses": [
{
"network": "ethereum",
"address": "0xB6c5273e79E2aDD234EBC07d87F3824e0f94B2F7"
},
{
"network": "ethereum",
"address": "0xB6c5273e79E2aDD234EBC07d87F3824e0f94B2F7",
"tokenAddress": "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"
}
]
}
'
The response will include both the available balances and the yield integrations that the end user can enter into, which is beneficial when combined with the Yield Metadata.
[
{
"token": {
"address": "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",
"network": "ethereum",
"name": "USD Coin",
"symbol": "USDC",
"decimals": 6,
"logoURI": "https://assets.stakek.it/tokens/usdc.svg"
},
"amount": "345.676630000000000000",
"availableYields": [
"ethereum-USDC-morpho-aave-lending",
"ethereum-USDC-morpho-compound-lending",
"ethereum-usdc-yvusdc-0.2.2-fbce41-yearn-vault",
"ethereum-usdc-yvusdc-0.3.0-20f1cb-yearn-vault",
"ethereum-usdc-yvusdc-0.4.3-ec5cdf-yearn-vault",
"ethereum-usdc-compound-v3-lending"
]
},
{
"token": {
"network": "ethereum",
"name": "Ethereum",
"symbol": "ETH",
"decimals": 18,
"coinGeckoId": "ethereum",
"logoURI": "https://assets.stakek.it/tokens/eth.svg"
},
"amount": "0.158470564159791889",
"availableYields": [
"ethereum-eth-lido-staking",
"ethereum-eth-stakewise-staking",
"ethereum-eth-reth-staking"
]
},
]
Types
Token balances use the following type:
interface BalanceDto {
amount: string;
token: Token;
availableYields: string[];
}
Updated 12 days ago