Generate stage1 genesis file from CSV with subscribed participants (#13)

Part of [laconicd testnet validator enrollment](https://www.notion.so/laconicd-testnet-validator-enrollment-6fc1d3cafcc64fef8c5ed3affa27c675)

Reviewed-on: #13
Co-authored-by: Prathamesh Musale <prathamesh.musale0@gmail.com>
Co-committed-by: Prathamesh Musale <prathamesh.musale0@gmail.com>
This commit is contained in:
Prathamesh Musale 2024-08-16 14:52:08 +00:00 committed by nabarun
parent 81a3141db4
commit 77decda197
3 changed files with 105 additions and 10 deletions

View File

@ -0,0 +1,94 @@
#!/bin/bash
# Exit on error
set -e
set -u
# Check args
if [ "$#" -ne 3 ]; then
echo "Usage: $0 <subscribed-participants-csv> <participant-allocation> <validator-allocation>"
echo "Example: $0 /home/user/subscribed-participants.csv 1000000 1000000000000"
exit 1
fi
SUBSCRIBED_PARTICIPANTS_CSV="$1"
PARTICIPANT_ALLOCATION="$2"
VALIDATOR_ALLOCATION="$3"
STAGE1_GENESIS_DIR=stage1-genesis
# Create a temporary target directory
mkdir -p $STAGE1_GENESIS_DIR
# --------
# Parse the input CSV file to create stage1 onboarding module state
# Input CSV columns:
# 5: laconic_address, 6: nitro_address, 7: role, 8: hashed_subscriber_id, 11: funding_amount
stage1_participants_file="$STAGE1_GENESIS_DIR/stage1-participants.json"
jq -R -s --arg participant_allocation "$PARTICIPANT_ALLOCATION" --arg validator_allocation "$VALIDATOR_ALLOCATION" -f <(cat <<'EOF'
# Split the input into lines
split("\n") |
# Skip the first line (header) and filter out empty lines
.[1:] | map(select(length > 0)) |
# For each line, split it into fields by comma
map(split(",") | map(gsub("^\"|\"$"; ""))) |
# Create objects from the relevant fields
map({
cosmos_address: .[5],
nitro_address: .[6],
role: .[7],
kyc_id: .[8]
})
EOF
) < "$SUBSCRIBED_PARTICIPANTS_CSV" > "$stage1_participants_file"
echo "Exported participants for stage1 onboarding module state"
# --------
# Parse the input CSV file to calculate allocations on stage1
# Use provided input amounts if funding amount not present in the CSV
stage1_allocations_file="$STAGE1_GENESIS_DIR/stage1-allocations.json"
jq -R -s --arg participant_allocation "$PARTICIPANT_ALLOCATION" --arg validator_allocation "$VALIDATOR_ALLOCATION" -f <(cat <<'EOF'
# Split the input into lines
split("\n") |
# Skip the first line (header) and filter out empty lines
.[1:] | map(select(length > 0)) |
# For each line, split it into fields by comma
map(split(",") | map(gsub("^\"|\"$"; ""))) |
# Create objects from the relevant fields
map({
cosmos_address: .[5],
balance: (
if .[11] == "" or .[11] == null then
if .[7] == "validator" then $validator_allocation else $participant_allocation end
else .[11] end
)
})
EOF
) < "$SUBSCRIBED_PARTICIPANTS_CSV" > "$stage1_allocations_file"
echo "Calculated allocations for stage 1 chain"
# --------
# Run a script with cerc/laconicd:local to generate the genesis file
# with onboarding module state and given allocations
docker run -it \
-v ./$STAGE1_GENESIS_DIR:/root/.laconicd \
-v ./scripts:/scripts \
cerc/laconicd:local bash -c "/scripts/genesis.sh"
# Copy over the genesis file to output folder
OUTPUT_DIR=output
mkdir -p $OUTPUT_DIR
cp ./$STAGE1_GENESIS_DIR/config/genesis.json $OUTPUT_DIR/genesis.json
echo "Genesis file for stage1 written to $OUTPUT_DIR/genesis.json"
# --------
# Clean up
echo "Please remove the temporary data directory: sudo rm -rf $STAGE1_GENESIS_DIR"

View File

@ -21,23 +21,24 @@ mkdir -p $STAGE1_GENESIS_DIR
# --------
# Export onboarding module state from stage0 laconicd chain
# Export participants from onboarding module state on stage0 laconicd chain
# Use cerc/laconicd-stage0:local image for stage0 laconicd build
onboarding_state_file="$STAGE1_GENESIS_DIR/stage0-onboarding-state.json"
stage1_participants_file="$STAGE1_GENESIS_DIR/stage1-participants.json"
docker run -it \
-v ${STAGE0_DEPLOYMENT_DIR}/data/laconicd-data:/root/stage0-deployment/.laconicd \
cerc/laconicd:local bash -c "laconicd export --home /root/stage0-deployment/.laconicd" \
| jq .app_state.onboarding > "$onboarding_state_file"
cerc/laconicd-stage0:local bash -c "laconicd export --home /root/stage0-deployment/.laconicd" \
| jq .app_state.onboarding.participants > "$stage1_participants_file"
stage0_participants=$(cat "$onboarding_state_file" | jq .participants)
stage1_participants=$(cat "$stage1_participants_file")
echo "Exported onboarding module state from stage 0 chain"
echo "Exported participants for stage1 onboarding module state"
# --------
# For each participant, using ETH account holdings, figure out balance allocation for stage1
stage1_allocations_file="$STAGE1_GENESIS_DIR/stage1-allocations.json"
jq -n --argjson participants "$stage0_participants" --arg participant_allocation "$PARTICIPANT_ALLOCATION" --arg validator_allocation "$VALIDATOR_ALLOCATION" '
jq -n --argjson participants "$stage1_participants" --arg participant_allocation "$PARTICIPANT_ALLOCATION" --arg validator_allocation "$VALIDATOR_ALLOCATION" '
[
$participants[] |
{

View File

@ -10,14 +10,14 @@ CHAINID="laconic_9000-1"
STAGE1_MONIKER=localtestnet-stage-1
NODE_HOME="/root/.laconicd"
onboarding_state_file="$NODE_HOME/stage0-onboarding-state.json"
stage1_participants_file="$NODE_HOME/stage1-participants.json"
stage1_allocations_file="$NODE_HOME/stage1-allocations.json"
stage1_genesis_file="$NODE_HOME/config/genesis.json"
laconicd init $STAGE1_MONIKER --chain-id $CHAINID --default-denom alnt
# Update onboarding module state with participants from stage0
participants=$(jq -c '.participants' $onboarding_state_file)
# Update onboarding module state with participants
participants=$(jq -c '.' $stage1_participants_file)
jq --argjson p "$participants" '.app_state.onboarding.participants = $p' "$stage1_genesis_file" > tmp.$$.json && mv tmp.$$.json "$stage1_genesis_file"
# Disable bank module transfers