コンテンツにスキップ

プール情報(pool.cert)の更新

概要

  • 誓約、固定手数料、変動手数料、リレー情報、メタデータを変更する場合に実施します。
  • メタデータURLのみ変更になる場合でも「メタデータ更新を含む場合」を実施しメタデータファイルを再作成してください。

注意

誓約・固定手数料・変動手数料の反映は提出エポック+3エポック後からになります。
例)
320エポックに変更申請
321エポックで有効化
322エポックで待機
323エポックで反映

変数にプールメタデータ値を設定し実行してください

文字列は''で囲ってください
extendedを設定していない場合は ''のままで大丈夫です

name=''
description=''
ticker=''
homepage=''
extended=''

メタデータファイルを作成する

このボックスはすべてコピーして実行してください
cat > $NODE_HOME/poolMetaData.json << EOF
{
    "name": "$name",
    "description": "$description",
    "ticker": "$ticker",
    "homepage": "$homepage",
    "extended": "$extended",
    "nonce":"$(date +%s)"
}
EOF

poolMetaData.jsonを各ホストサーバーへアップロードする

poolMetaData.jsonをローカルマシンにダウンロードし、Githubまたはご自身のサーバーの所定の位置にアップロードしてください

ハッシュ値確認

cd $NODE_HOME
cardano-cli stake-pool metadata-hash --pool-metadata-file poolMetaData.json > poolMetaDataHash.txt

オンラインファイルハッシュ値確認

https:****.**.**をメタデータファイルのURLに置き換えてから実行してください

cd $NODE_HOME
wget -O onlineMetaData.json https:****.**.**

オンラインメタデータハッシュ値

cardano-cli stake-pool metadata-hash --pool-metadata-file onlineMetaData.json > onlineMetaDataHash.txt

ハッシュ値

printf "\n サーバー:$(cat poolMetaDataHash.txt)\nオンライン:$(cat onlineMetaDataHash.txt)\n\n"

ハッシュ値が一致する必要があります。異なる場合はホストサーバーへ正しくアップロードされているかご確認ください。

ハッシュ値が一致したら、確認用ファイルを削除する。

rm onlineMetaDataHash.txt
rm onlineMetaData.json

ファイル転送

BPのpoolMetaDataHash.txt をエアギャップマシンのcnodeディレクトリにコピーします。

graph LR
    A[BP] -->|poolMetaDataHash.txt| B[エアギャップ];

BPとエアギャップハッシュ値確認

cd $NODE_HOME
echo $(cat poolMetaDataHash.txt)
cd $NODE_HOME
echo $(cat poolMetaDataHash.txt)

ハッシュ値が異なっている場合は、BPのpoolMetaDataHash.txtがエアギャップに正しくコピーされていません。

登録証明書トランザクションを作成する

複数のリレーノードを設定する場合は 複数のリレーノードを構成する記述方法 を参考にパラメーターを指定して下さい。

注意

以下は参考コードです。ご自身のプール設定値に変更してください
例)

  • 固定費・・・170ADA
  • Margin・・・5%
  • 誓約・・・1000ADA
cd $NODE_HOME
chmod u+rwx $HOME/cold-keys
cardano-cli stake-pool registration-certificate \
    --cold-verification-key-file $HOME/cold-keys/node.vkey \
    --vrf-verification-key-file vrf.vkey \
    --pool-pledge 1000000000 \
    --pool-cost 170000000 \
    --pool-margin 0.05 \
    --pool-reward-account-verification-key-file stake.vkey \
    --pool-owner-stake-verification-key-file stake.vkey \
    $NODE_NETWORK \
    --pool-relay-ipv4 ***.***.***.*** \
    --pool-relay-port 6000 \
    --metadata-url https://xxx.xxx.xxx/poolMetaData.json \
    --metadata-hash $(cat poolMetaDataHash.txt) \
    --out-file pool.cert

ヒント

上記のコードを自プール用の設定に修正したら、次回も使用できるようテキストファイルとして保存しておいてください。

ステークプールに誓約します。

cardano-cli stake-address delegation-certificate \
    --stake-verification-key-file stake.vkey \
    --cold-verification-key-file $HOME/cold-keys/node.vkey \
    --out-file deleg.cert

ファイル転送

エアギャップのpool.certdeleg.certをブロックプロデューサーのcnodeディレクトリにコピーします。

graph LR
    A[エアギャップ] -->|pool.cert / deleg.cert| B[BP];

最新のスロット番号を取得します

cd $NODE_HOME
currentSlot=$(cardano-cli query tip $NODE_NETWORK | jq -r '.slot')
echo Current Slot: $currentSlot

payment.addrの残高を出力します。

cardano-cli query utxo \
    --address $(cat payment.addr) \
    $NODE_NETWORK > fullUtxo.out

tail -n +3 fullUtxo.out | sort -k3 -nr | sed -e '/lovelace + [0-9]/d' > balance.out

cat balance.out

UTXOを算出します

tx_in=""
total_balance=0
while read -r utxo; do
    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}"
done < balance.out
txcnt=$(cat balance.out | wc -l)
echo Total ADA balance: ${total_balance}
echo Number of UTXOs: ${txcnt}

build-rawトランザクションコマンドを実行します。

cardano-cli transaction build-raw \
    ${tx_in} \
    --tx-out $(cat payment.addr)+${total_balance} \
    --invalid-hereafter $(( ${currentSlot} + 10000)) \
    --fee 0 \
    --certificate-file pool.cert \
    --certificate-file deleg.cert \
    --out-file tx.tmp

最低手数料を計算します。

fee=$(cardano-cli transaction calculate-min-fee \
    --tx-body-file tx.tmp \
    --tx-in-count ${txcnt} \
    --tx-out-count 1 \
    $NODE_NETWORK \
    --witness-count 3 \
    --byron-witness-count 0 \
    --protocol-params-file params.json | awk '{ print $1 }')
echo fee: $fee

計算結果を出力します。

txOut=$((${total_balance}-${fee}))
echo txOut: ${txOut}

トランザクションファイルを構築します。

cardano-cli transaction build-raw \
    ${tx_in} \
    --tx-out $(cat payment.addr)+${txOut} \
    --invalid-hereafter $(( ${currentSlot} + 10000)) \
    --fee ${fee} \
    --certificate-file pool.cert \
    --certificate-file deleg.cert \
    --out-file tx.raw

ファイル転送

BPのtx.raw をエアギャップマシンのcnodeディレクトリにコピーします。

graph LR
    A[BP] -->|tx.raw| B[エアギャップ];

トランザクションに署名します。

cd $NODE_HOME
cardano-cli transaction sign \
    --tx-body-file tx.raw \
    --signing-key-file payment.skey \
    --signing-key-file $HOME/cold-keys/node.skey \
    --signing-key-file stake.skey \
    $NODE_NETWORK \
    --out-file tx.signed
chmod a-rwx $HOME/cold-keys

ファイル転送

エアギャップのtx.signed をBPのcnodeディレクトリにコピーします。

graph LR
    A[エアギャップ] -->|tx.signed| B[BP];

トランザクションを送信します。

cardano-cli transaction submit \
    --tx-file tx.signed \
    $NODE_NETWORK

Transacsion Successfully submittedと表示されれば成功