Hub
The Hub contract acts as the central hub for all minted nINJ. Native INJ tokens received from users are delegated from here. And undelegations from nINJ unbond requests are also handled from this contract. Rewards generated from delegations are withdrawn to the Reward contract.
Config
creator
CanonicalAddr
Address of contract creator
reward_dispatcher_contract*
CanonicalAddr
Contract address of Rewards Dispatcher
validators_registry_contract*
CanonicalAddr
Contract address of Validators Registry
binj_token_contract*
CanonicalAddr
Contract address of nINJ's Cw20 token contract
stinj_token_contract*
CanonicalAddr
Contract address of stINJ's Cw20 token contract
rewards_contract*
CanonicalAddr
Contract address of Reward
* = optional
Parameters
epoch_period
u64
Minimum time delay between undelegation batches [seconds]
underlying_coin_denom
String
Underlying asset denomination of stAsset (INJ)
unbonding_period
u64
Time required for the Hub contract to consider an undelegation batch to be fully undelegated (past the unbonding period) [seconds]
peg_recovery_fee
Decimal
Fee applied to stINJ generation and redemption
er_threshold
Decimal
Minimum stINJ exchange rate before peg recovery fee is applied
reward_denom
String
Native token denomination for distributed nINJ rewards (nUSD)
InitMsg
Instantiates the stINJ Hub contract. Adds a specified validator to whitelist and bonds the creator's initial INJ deposit. The creator's initial INJ deposit ensures the stINJ supply always be a high enough value to prevent rounding errors in the stINJ exchange rate calculation.
epoch_period
u64
Minimum time delay between undelegation batches [seconds]
underlying_coin_denom
String
Underlying asset denomination of stAsset (INJ)
unbonding_period
u64
Time required for the Hub contract to consider an undelegation batch to be fully undelegated (past the unbonding period) [seconds]
peg_recovery_fee
Decimal
Fee applied to stINJ generation and redemption
er_threshold
Decimal
Minimum stINJ exchange rate before peg recovery fee is applied
reward_denom
String
Native token denomination for distributed bINJ rewards (nUSD)
update_reward_index_addr
String
The address allowed to call UpdateGlobalIndex
ExecuteMsg
Receive
Can be called during a CW20 token transfer when the Hub contract is the recipient. Allows the token transfer to execute a Receive Hook as a subsequent action within the same transaction.
sender
String
Sender of token transfer
amount
Uint128
Amount of tokens received
Bond
Bonds inj by delegating the inj amount equally between validators from the registry and mints nInj tokens to the message sender. Requires native Inj tokens to be sent to Hub.
Gryphon tries to distribute the stake evenly across all validators. Given a single delegation, the exact number of validators that will receive delegations and the amount that they will receive depends on the current distribution of stake. We take a sorted (ASC) list of validators, calculate the desired amount that each validator should have target_stake = (total delegated + delegation_amount) / num_validators and begin adding stake up to the desired amount, starting from the validator with the least stake. The exact amount of a single delegation is calculated as target_stake - validator_stake, and you'll have as many delegations as it takes to "drain" the delegation_amount.
BondForStINJ
Bonds INJ by delegating the INJ amount equally between validators from the registry and mints stINJ tokens to the message sender. Requires native INJ tokens to be sent to Hub
.
The platform tries to distribute the stake evenly across all validators. Given a single delegation, the exact number of validators that will receive delegations and the amount that they will receive depends on the current distribution of stake. We take a sorted (ASC) list of validators, calculate the desired amount that each validator should have target_stake = (total delegated + delegation_amount) / num_validators
and begin adding stake up to the desired amount, starting from the validator with the least stake. The exact amount of a single delegation is calculated as target_stake - validator_stake
, and you'll have as many delegations as it takes to "drain" the delegation_amount.
UpdateGlobalIndex
Distributes INJ delegation rewards to stINJ holders. Withdraws all accrued delegation rewards to the Reward Dispatcher
contract and requests the Reward
contract to update the global reward index value. Can be issued by the specific address .
airdrop_hooks
Vec<Binary>
Not currently enabled
WithdrawUnbonded
Withdraws unbonded INJ. Requires an unbonding entry to have been made before the unbonding period.
CheckSlashing
Checks whether a slashing event occurred and updates state accordingly.
UpdateParams
Updates parameter values of the Hub contract. Can only be issued by the creator.
epoch_period
u64
Minimum time delay between undelegation batches [seconds]
unbonding_period
u64
Time required for the Hub contract to consider an undelegation batch to be fully undelegated (past the unbonding period) [seconds]
peg_recovery_fee
Decimal
Fee applied to stINJ generation and redemption
et_threshold
Decimal
Minimum stINJ exchange rate before peg recovery fee is applied
paused
bool
The pause system operation switch to facilitate smooth contract upgrades and data migration
reward_denom
String
Native token denomination for distributed bINJ rewards (nUSD)
UpdateConfig
Updates the Hub
contract configuration. Can only be issued by the creator.
rewards_dispatcher_contract
String
Contract address of Rewards Dispatcher
validators_registry_contract
String
Contract address of Validators Registry
binj_token_contract
String
Contract address of bINJ's Cw20 token contract
stinj_token_contract
String
Contract address of stINJ's Cw20 token contract
airdrop_registry_contract
String
Not currently enabled
rewards_contract
String
Contract address of Reward
[Internal] RedelegateProxy
A proxy handler to execute redelegations from Hub address.
Can only be executed by Validators Registry or by the owner of the Hub.
src_validator
String
Address of source vaildator in redelegation pair
redelegations
Vec<(String, Coin)>
List of(destination validator, redelegation amount)
[Internal] BondRewards
Bonds INJ by delegating the INJ amount equally between validators from the registry.
No stINJ tokens have been minted.
Can only be executed by Rewards Dispatcher.
Requires native INJ tokens to be sent to Hub
.
Receive Hooks
Unbond
Burns received stINJ and equally unbonds a corresponding amount of INJ from a validator from the registry.
QueryMsg
Config
Gets the Hub
contract's configuration.
ConfigResponse
owner
String
Address of the owner
reward_dispatcher_contract
String
Contract address of Rewards Dispatcher
validators_registry_contract
String
Contract address of Validators Registry
binj_token_contract
String
Contract address of bINJ's Cw20 token contract
stinj_token_contract
String
Contract address of stINJ's Cw20 token contract
airdrop_registry_contract
String
Not currently enabled
token_contract
String
Not currently enabled
State
StateResponse
binj_exchange_rate
Decimal
Current bINJ <> INJ exchange rate
stset_exchange_rate
Decimal
Current stINJ <> INJ exchange rate
total_bond_binj_amount
Uint128
Total amount of INJ currently bonded by Hub via bINJ logic
total_bond_stinj_amount
Uint128
Total amount of INJ currently bonded by Hub via stINJ logic
last_index_modification
u64
Unix block timestamp when the global reward index was last updated
prev_hub_balance
Uint128
Hub's INJ balance when WithdrawUnbonded was lasted executed. Used to calcutate the actual amount of unbonded INJ
last_unbonded_time
u64
Unix block timestamp when a batch was last undelegated
last_processed_batch
u64
Batch ID of the most recently released batch
CurrentBatch
Gets information about the current undelegation batch.
CurrentBatchResponse
id
u64
Batch ID of the current undelegation batch
requested_binj_with_fee
Uint128
Amount of (fee-applied)bINJ requested for undelegation in this batch
requested_stinj
Uint128
Amount of stINJ requested for undelegation in this batch
WithdrawableUnbonded
Gets the amount of undelegated INJ that will be available for withdrawal (unbonding requests past the unbonding period) for the specified user.
address
String
Address of user that previously unbonded INJ via redeeming bINJ
withdrawable
Uint128
Amount of undelegated INJ availabe for withdrawal
Parameters
Gets parameter information.
ParametersResponse
epoch_period
u64
Minimum time delay between undelegation batches [seconds]
underlying_coin_denom
String
Underlying asset denomination of stAsset (INJ)
unbonding_period
u64
Time required for the Hub contract to consider an undelegation batch to be fully undelegated (past the unbonding period) [seconds]
peg_recovery_fee
Decimal
Fee applied to stINJ generation and redemption
er_threshold
Decimal
Minimum stINJ exchange rate before peg recovery fee is applied
reward_denom
String
Native token denomination for distributed bINJ rewards (nUSD)
paused
Option<bool>
The pause system operation switch to facilitate smooth contract upgrades and data migration
UnbondRequests
Gets the list of INJ unbonding amounts being unbonded for the specified user.
address
String
Address of user that previously unbonded INJ by redeeming stINJ
UnbondRequestsResponse
address
String
Address of user that requested to unbond stINJ
requests
UnbondRequest
List of unbonding requests made by user
UnbondRequest
Vec<(u64, Uint128, Uint128)>
List of (batch ID, bINJ unbond amount, stINJ unbond amount)
AllHistory
Gets the historical list of undelegation batch entries.
start_from*
u64
Batch Id to start query
limit*
u32
Maximum number of query entries
* = optional
AllHistoryResponse
history
Vec<UnbondHistoryResponse>
List of batch information
batch_id
u64
Batch ID
time
u64
Unix block timestamp when this batch was undelegated
binj_amount
Uint128
(Fee-applied)amount of bINJ unbonded in this batch
binj_applied_exchange_rate
Decimal
bINJ exchange rate at the time of batch undelegation
binj_withdraw_rate
Decimal
Conversion rate applied when users later withdraw from this batch
stinj_amount
Uint128
(Fee-applied)amount of stINJ unbonded in this batch
stinj_applied_exchange_rate
Decimal
stINJ exchange rate at the time of batch undelegation
stinj_withdraw_rate
Decimal
Convertion rate applied when users later withdraw from this batch
released
bool
Indication on whether is batch is released(processed as fully undelegated by the contract)
Last updated