Direcciones de payment y stake
Generamos las direcciones para solventar los fees de nuestras transacciones, delegar nuestro pledge y recibir las recompensas. Necesitaremos 3 ADA para pagar el depósito y fees.
Este procedimiento solo se realiza para el nodo productor de bloques.
Es muy recomendado que toda operación que implique acceso a las cold keys, payment.addr o stake.addr se realicen en una maquina sin acceso a internet a fin de minimizar posibilidades de exponer info sensitiva de nuestro pool y/o fondos a terceros mal intencionados. Luego se copian los archivos firmados al BP o un relay online y desde ahí se les agrega a la blockchain.
Generar payment y stake key pairs
La payment.addr
es la dirección desde la cual recibiremos y enviaremos nuestros ADA, vendría a ser el equivalente a una billetera. Para crear una el primer paso es generar una Verification (.vkey) y una Signing key (.skey). La primera te sirve para generar la dirección y la segunda te permite firmar transacciones.
cd ~/cardano-node
cardano-cli address key-gen \
--verification-key-file payment.vkey \
--signing-key-file payment.skey
La stake.addr
es la dirección donde recibiremos nuestras recompensas. Como con lapayment.addr
vamos a necesitar primero generar sus Verification y Signing keys.
cardano-cli stake-address key-gen \
--verification-key-file stake.vkey \
--signing-key-file stake.skey
Generar payment.add y stake.addr
Ahora generamos las direcciones utilizando los keys que acabamos de crear. Para la testnet es necesario reemplazar --mainnet
por --testnet-magic xxxxxxxxxx
.
Para generar la stake.addr
podemos utilizar el siguiente comando:
cardano-cli stake-address build \
--stake-verification-key-file stake.vkey \
--out-file stake.addr \
--mainnet
Y ahora generamos nuestro payment.addr
así:
cardano-cli address build \
--payment-verification-key-file payment.vkey \
--stake-verification-key-file stake.vkey \
--out-file payment.addr \
--mainnet
A partir de este momento puedes utilizar esta dirección para enviar y recibir ADA en la blockchain de Cardano. Se recomienda que transfieras a la misma un mínimo de 504 ADA para cubrir los depósitos y fees de las transacciones por registrar tu stake.addr
y el pool.
Registrar stake.addr
El ultimo paso en esta sección es registrar nuestro stake.addr
en la blockchain, el procedimiento es el siguiente:
Certificado de registro
Lo primero que haremos será generar un certificado de registro.
cardano-cli stake-address registration-certificate \
--stake-verification-key-file stake.vkey \
--out-file stake.cert
protocol.json
Luego necesitamos consultar los parámetros del protocolo y los escribiremos al archivo out/protocol.json
con el siguiente comando, los valores de este archivo los vamos a necesitar para varias partes de nuestro proceso.
cardano-cli query protocol-parameters \
--mainnet \
--out-file out/protocol.json
Consultar balance
Para los siguientes pasos ya necesitamos tener al menos 3 ADA para cubrir el fee de las transacciones y el depósito por nuestra stake.addr
. Ahora necesitamos consultar nuestros saldos y UTXO.
cardano-cli query utxo \
--address $(cat payment.addr) \
--mainnet
Con lo cual obtenemos un resultado similar al siguiente:

Generar borrador
Con estos datos podemos armar nuestra transacción, el primer paso para esto es generar un borrador de transacción, que nos servirá para calcular los fees de la misma. En el ejemplo presente tenemos 2 TXHash, por este motivo vamos a sumar los montos de ambos en Lovelace para los cálculos.
El formato correcto para ingresar los --tx-in
es TxHash#TxIx
.
En el caso de los --tx-out
se puede utilizar una dirección común addr1
, pero lo mas probable es que usemos la que tenemos almacenada en nuestro payment.addr
. Se puede dejar ttl
y fee
en 0.
cardano-cli transaction build-raw \
--tx-in 441c5b0650b5d33f2f05a192453a86398c6e8efeac78438d17fcc18222ee0065#0 \
--tx-in de4e0cd1e4858460b1563de5e279c59b09b073c63656790c3b6f07b6d42be9e2#0 \
--tx-out $(cat payment.addr)+0 \
--ttl 0 \
--fee 0 \
--out-file tmp/tx.draft\
--certificate-file stake.cert
Calcular fees, saldos y ttl
Ahora calculamos los fees, atención con --tx-in-count
y --tx-out-count
, debemos poner la cantidad de direcciones/UTXO que utilizamos:
cardano-cli transaction calculate-min-fee \
--tx-body-file tmp/tx.draft \
--tx-in-count 2 \
--tx-out-count 1 \
--witness-count 1 \
--byron-witness-count 0 \
--mainnet \
--protocol-params-file out/protocol.json
El siguiente valor que nos interesa es keyDeposit
, podemos extraerlo con de nuestro archivo con:
cat out/protocol.json | jq .keyDeposit
Este valor esta expresado en Lovelaces, recordamos que 1 ADA = 1,000,000 Lovelace. Por defecto en la mainnet de Cardano es de 2000000 (2 ADA). Nuestra formula es: Saldos_UTXO - fee - keyDeposit
. En nuestro ejemplo estamos sumando primero los dos UTXO.
expr 49992783811 + 7216189 - 179552 - 2000000
Luego consultamos el tip:
cardano-cli query tip --mainnet | jq .slotNo
Armamos nuestra transacción con todos los datos obtenidos. Para el --ttl
(Time To Live o el slot hasta el cual puede ser procesada nuestra transacción), un valor puede ser tip + 2000
, de esta manera contamos con un buen margen de tiempo para preparar nuestras transacciones. Para el --tx-out
el formato correcto es dirección+saldo
, donde "saldo" es el restante después de pagar el deposito y los fees.
Generar transacción
Utilizamos los valores obtenidos anteriormente para generar nuestra transacción
cardano-cli transaction build-raw \
--tx-in 441c5b0650b5d33f2f05a192453a86398c6e8efeac78438d17fcc18222ee0065#0 \
--tx-in de4e0cd1e4858460b1563de5e279c59b09b073c63656790c3b6f07b6d42be9e2#0 \
--tx-out $(cat payment.addr)+49997820448 \
--ttl 8520151 \
--fee 179552 \
--out-file tmp/tx.raw \
--certificate-file stake.cert
Firmar transacción
Firmamos nuestra transacción:
cardano-cli transaction sign \
--tx-body-file tmp/tx.raw \
--signing-key-file payment.skey \
--signing-key-file stake.skey \
--mainnet \
--out-file tmp/tx.signed
Someter transacción
Y sometemos nuestro archivo firmado a la blockchain desde un nodo online.
cardano-cli transaction submit \
--tx-file tmp/tx.signed \
--mainnet
Última actualización
¿Te fue útil?