Pledge is the stake that you delegate to your own pool. Using a transaction, you must register on the blockchain the stake address associated with a payment address containing funds that you want to pledge.
To register a stake address on the blockchain:
Create a certificate, stake.cert
, using the stake.vkey
air-gapped offline machine
Copy cardano-cli stake-address registration-certificate \
--stake-verification-key-file stake.vkey \
--out-file stake.cert
Copy stake.cert to your hot environment.
You need to find the tip of the blockchain to set the invalid-hereafter parameter properly.
block producer node
Copy currentSlot = $( cardano-cli query tip --mainnet | jq -r '.slot' )
echo Current Slot: $currentSlot
Find your balance and UTXOs .
block producer node
Copy cardano-cli query utxo \
--address $( cat payment.addr ) \
--mainnet > fullUtxo.out
tail -n +3 fullUtxo.out | sort -k3 -nr > balance.out
cat balance.out
tx_in = ""
total_balance = 0
while read -r utxo ; do
type = $( awk '{ print $6 }' <<< "${utxo}" )
if [[ ${type} == 'TxOutDatumNone' ]]
then
in_addr = $( awk '{ print $1 }' <<< "${utxo}" )
idx = $( awk '{ print $2 }' <<< "${utxo}" )
utxo_balance = $( awk '{ print $3 }' <<< "${utxo}" )
total_balance = $((${total_balance}+${utxo_balance}))
echo TxHash: ${in_addr} # ${idx}
echo ADA: ${utxo_balance}
tx_in = "${tx_in} --tx-in ${in_addr}#${idx}"
fi
done < balance.out
txcnt = $( cat balance.out | wc -l )
echo Total available ADA balance: ${total_balance}
echo Number of UTXOs: ${txcnt}
Find the amount of the deposit required to register a stake address.
block producer node
Copy stakeAddressDeposit = $( cat $NODE_HOME /params.json | jq -r '.stakeAddressDeposit' )
echo stakeAddressDeposit : $stakeAddressDeposit
Registering a stake address requires a deposit of 2000000 lovelace.
Run the build-raw transaction command
The invalid-hereafter value must be greater than the current tip. In this example, we use current slot + 10000.
block producer node
Copy cardano-cli transaction build-raw \
${tx_in} \
--tx-out $( cat payment.addr ) +0 \
--invalid-hereafter $(( ${currentSlot} + 10000 )) \
--fee 0 \
--out-file tx.tmp \
--certificate stake.cert
Calculate the current minimum fee:
block producer node
Copy fee = $( cardano-cli transaction calculate-min-fee \
--tx-body-file tx.tmp \
--tx-in-count ${txcnt} \
--tx-out-count 1 \
--mainnet \
--witness-count 2 \
--byron-witness-count 0 \
--protocol-params-file params.json | awk '{ print $1 }' )
echo fee: $fee
When calculating the fee for a transaction, the --witness-count
option indicates the number of keys signing the transaction. You must sign a transaction submitting a stake address registration certificate to the blockchain using the secret—private—key for the payment address spending the input, as well as the secret key for the stake address to register.
When creating the transaction, ensure that the funds the input contains are greater than the total of the transaction fee and stake address deposit. If funds are insufficient, then the transaction fails.
Calculate your change output.
block producer node
Copy txOut = $((${total_balance}-${stakeAddressDeposit}-${fee}))
echo Change Output: ${txOut}
Build your transaction which will register your stake address.
block producer node
Copy cardano-cli transaction build-raw \
${tx_in} \
--tx-out $( cat payment.addr ) + ${txOut} \
--invalid-hereafter $(( ${currentSlot} + 10000 )) \
--fee ${fee} \
--certificate-file stake.cert \
--out-file tx.raw
Copy tx.raw to your cold environment .
Sign the transaction with both the payment and stake secret keys.
air-gapped offline machine
Copy cardano-cli transaction sign \
--tx-body-file tx.raw \
--signing-key-file payment.skey \
--signing-key-file stake.skey \
--mainnet \
--out-file tx.signed
Copy tx.signed to your hot environment.
Send the signed transaction.
block producer node
Copy cardano-cli transaction submit \
--tx-file tx.signed \
--mainnet