Bonding and proof-of-stake
Bonded tokens
Any account on Namada can bond or stake NAM tokens to any validator in the proof-of-stake system. When NAM tokens are bonded to a validator, that validator, if it is a member of the consensus set, may use those tokens as voting power to vote or sign newly proposed blocks.
These validators earn some block rewards for doing so, and the original stakers of those tokens earn a proportional share of the validators' block rewards.
The non-validator accounts that bond NAM to a validator are known as delegators. Validators may also bond NAM tokens to themselves.
Becoming a delegator
In order to become a delegator, you must first have an account with positive NAM balance. If you do not have an account, you can follow the instructions here to create one.
Once you have an account, you can bond your NAM to a validator. Bonding (or delegating) to a validator is the same as staking with a validator.
First, you may want to list some available validators you can stake to:
namadac bonded-stake
If you have a specific tenderimnt key of a validator but do not know the address, you can use the following command to find the address:
namadac find-validator --tendermint-key $VALIDATOR_TENDERMINT_KEY # Similarly you can find the tendermint key from the address by providing the argument --validator <validator-address> instead
Before bonding to a validator, it is important to know their commision rate. This is the percentage of the block rewards that the validator will take as a fee for their services. You can find this information by running the following command:
namadac commission-rate --validator $VALIDATOR_ADDRESS
Typically, the commission rate is between 0% and 5%.
Once you've found the address of your favorite validator, you can bond to them with the following command:
namadac bond --source $DELEGATOR_ADDRESS --validator $VALIDATOR_ADDRESS --amount $AMOUNT
Because the validator alias sometimes clashes with the alias for the implicit account and or established account in the wallet, it is recommended to use the validator address instead of the alias. In order to find the validator address, you can use the following command:
namadaw list --addr | grep $VALIDATOR_ALIAS
then make sure it is the corresponding tnam
address.
The $DELEGATOR_ADDRESS
is your account address from which you would like to stake NAM tokens. Validators who would like to self-bond do not need to provide the --source
argument.
If you have the alias for an address saved in your wallet, you can also pass it as an argument.
Once the transaction is submitted, the bond will become active at the pipeline length relative to the current epoch, which is some number of epochs in the future relative to the current one. Currently, this value is 2 epochs.
The pipeline length of the chain and other important proof-of-stake parameters can be queried from the chain with the following command:
namadac query-protocol-parameters
Querying delegations
It is possible to query processed delegations through the client
namadac delegations --owner $DELEGATOR_ADDRESS
Unbonding
Unbonding is the process of removing your bonded NAM from a validator, and this must be done before attempting to withdraw your previously bonded tokens.
This process is identical to unbonding tokens from a validator.
The command to unbond is similar to the bonding command:
namadac unbond --source $DELEGATOR_ADDRESS --validator $VALIDATOR_ADDRESS --amount $AMOUNT
After a successful unbond transaction, the unbonded NAM tokens will be available for withdrawal after pipeline_length + unbonding_length + cubic_slashing_window_length
epochs. Once again, the values of these three parameters can be queried from the chain.
Withdrawing
When the full unbonding period has passed, you can withdraw the unbonded NAM using the following command:
namadac withdraw --source $DELEGATOR_ADDRESS --validator $VALIDATOR_ADDRESS
This transaction will immediately transfer all fully unbonded NAM tokens back to the delegator-address
account, increasing your transferable balance.
You may also query some information regarding how many NAM tokens are available for withdrawal with the following command:
namadac bonds --owner $DELEGATOR_ADDRESS
Redelegating
In certain circumstances, you may want to switch the validator that holds your bonded tokens. This could be because your original validator has dropped out of the consensus set or has been deactivated or jailed and slashed for misbehaving.
You can accomplish this with a redelegating the bonded tokens rather than unbonding, withdrawing, and then bonding again. Use the following command:
namadac redelegate --owner $DELEGATOR_ADDRESS --source-validator $SOURCE_VALIDATOR_ADDRESS --destination-validator $DEST_VALIDATOR_ADDRESS --amount $AMOUNT
The delegator-address
is your address, the source-validator
is the validator that currently holds your bond, and the destination-validator
is your desired new validator to hold your bond.
Your new bond will be active and begin contributing to the destination-validator
's voting power after the pipeline length has passed. It will no longer be held by the source-validator
at this epoch as well.
Claiming rewards
Inflationary rewards for proof-of-stake are computed and minted once per epoch, at the very beginning of a new epoch.
In order to claim rewards that are owed to you for bonded NAM tokens, run the following command:
namadac claim-rewards --source $DELEGATOR_ADDRESS --validator $VALIDATOR_ADDRESS
Successful execution of this transaction will immediately transfer the the reward tokens you are owed to your delegator-address
, incrementing your transparent balance.
Additionally, you can query the pending reward tokens without claiming by running:
namadac rewards --source $DELEGATOR_ADDRESS --validator $VALIDATOR_ADDRESS
Interacting with jailed validators
When the validator that holds a bond is jailed, there are restrictions on what can be done with the bond.
Bonding tokens is always permitted to any validator, even if it is jailed.
Unbonding and redelegating from a jailed validator is not permitted if that validator is enqueued to be slashed (it is frozen), as described in this section on jailing validators for protocol misbehaviors. Otherwise, unbonding and redelegating is permitted.