Skip to content
Snippets Groups Projects
Select Git revision
  • 9f1450f89dea00d9dac7c7cc43b17cd625faed70
  • master default protected
  • network/gtest-1000 protected
  • upgradable-multisig
  • runtime/gtest-1000
  • network/gdev-800 protected
  • cgeek/issue-297-cpu
  • gdev-800-tests
  • update-docker-compose-rpc-squid-names
  • fix-252
  • 1000i100-test
  • hugo/tmp-0.9.1
  • network/gdev-803 protected
  • hugo/endpoint-gossip
  • network/gdev-802 protected
  • hugo/distance-precompute
  • network/gdev-900 protected
  • tuxmain/anonymous-tx
  • debug/podman
  • hugo/195-doc
  • hugo/195-graphql-schema
  • gdev-900-0.10.1 protected
  • gdev-900-0.10.0 protected
  • gdev-900-0.9.2 protected
  • gdev-800-0.8.0 protected
  • gdev-900-0.9.1 protected
  • gdev-900-0.9.0 protected
  • gdev-803 protected
  • gdev-802 protected
  • runtime-801 protected
  • gdev-800 protected
  • runtime-800-bis protected
  • runtime-800 protected
  • runtime-800-backup protected
  • runtime-701 protected
  • runtime-700 protected
  • runtime-600 protected
  • runtime-500 protected
  • v0.4.1 protected
  • runtime-401 protected
  • v0.4.0 protected
41 results

chain_spec.rs

Blame
  • create-live-network.sh 3.18 KiB
    #!/usr/bin/env bash
    #
    # USAGE
    #
    # 1. Generate genesis authorities session keys.
    # 2. Create the json file that contains the genesis configuration and verify carefully that the
    #    declared session keys correspond to the one you have generated in the first step.
    # 3. Generate raw chain specs with script `gen-live-network-raw-spec.sh`.
    # 4. Share the generated raw spec with other genesis authorities.
    # 5. Each genesis authority should run this script with its session keys seed.
    #
    
    # This script is meant to be run on Unix/Linux based systems
    set -e
    
    # params
    VALIDATOR_SESSION_KEYS_SURI=$1
    CURRENCY="${2:-gdev}"
    WORK_DIR="${3:-tmp/$CURRENCY}"
    SPEC_DIR="${4:-resources}"
    
    echo "CURRENCY=$CURRENCY"
    
    # constants
    DUNITER_IMAGE_TAG="sha-99fb985b"
    
    # Clean and (re-)create working forders
    rm -rf $WORK_DIR
    mkdir -p $WORK_DIR/duniter-rpc
    mkdir -p $WORK_DIR/duniter-validator/chains/$CURRENCY
    
    # Helper to execute a duniter subcommand in docker
    function duniter_tmp () {
      docker rm duniter-tmp > /dev/null
      OUTPUT=$(docker run --name duniter-tmp -it --entrypoint duniter duniter/duniter-v2s:$DUNITER_IMAGE_TAG "$@")
      echo "${OUTPUT::-1}"
    }
    
    if [ -e "$SPEC_DIR/$CURRENCY-raw.json" ]
    then
      # copy raw chain spec
      cp $SPEC_DIR/$CURRENCY-raw.json $WORK_DIR/duniter-rpc/$CURRENCY-raw.json
      cp $SPEC_DIR/$CURRENCY-raw.json $WORK_DIR/duniter-validator/$CURRENCY-raw.json
    else
      # generate raw chain spec
      echo "generate raw_chain spec…"
      export DUNITER_GENESIS_CONFIG="$SPEC_DIR/$CURRENCY.json"
      duniter_tmp build-spec --chain $CURRENCY-gl --raw > /var/lib/duniter/$CURRENCY-raw.json
      docker cp duniter-tmp:/var/lib/duniter/$CURRENCY-raw.json $WORK_DIR/duniter-rpc/$CURRENCY-raw.json
      cp $WORK_DIR/duniter-rpc/$CURRENCY-raw.json $WORK_DIR/duniter-validator/$CURRENCY-raw.json
    fi
    
    # generate rpc node key
    echo "generate rpc node key…"
    RPC_NODE_KEY=$(duniter_tmp key generate-node-key --file /var/lib/duniter/node-key.txt)
    docker cp duniter-tmp:/var/lib/duniter/node-key.txt $WORK_DIR/duniter-rpc/node-key
    echo "RPC_NODE_KEY=$RPC_NODE_KEY"
    
    # generate validator node key
    echo "generate validator node key…"
    VALIDATOR_NODE_KEY=$(duniter_tmp key generate-node-key --file /var/lib/duniter/node-key.txt)
    docker cp duniter-tmp:/var/lib/duniter/node-key.txt $WORK_DIR/duniter-validator/node-key
    echo "VALIDATOR_NODE_KEY=$VALIDATOR_NODE_KEY"
    
    # generate docker-compose file
    echo "generate docker-compose file…"
    cp docker/compose/live-template.docker-compose.yml $WORK_DIR/docker-compose.yml
    sed -i -e "s/DUNITER_IMAGE_TAG/$DUNITER_IMAGE_TAG/g" $WORK_DIR/docker-compose.yml
    sed -i -e "s/CURRENCY/$CURRENCY/g" $WORK_DIR/docker-compose.yml
    sed -i -e "s/RPC_NODE_KEY/$RPC_NODE_KEY/g" $WORK_DIR/docker-compose.yml
    sed -i -e "s/VALIDATOR_NODE_KEY/$VALIDATOR_NODE_KEY/g" $WORK_DIR/docker-compose.yml
    
    # Inject validator session keys in validator node keystore
    echo "Inject validator session keys in validator node keystore…"
    duniter_tmp key generate-session-keys --chain "${CURRENCY}_local" --suri "$VALIDATOR_SESSION_KEYS_SURI" -d /var/lib/duniter
    docker cp duniter-tmp:/var/lib/duniter/chains/${CURRENCY}_local/keystore $WORK_DIR/duniter-validator/chains/$CURRENCY
    
    # Launch the network
    echo "compose ready in '$WORK_DIR'"
    cd $WORK_DIR
    #docker-compose up -d