From 55b766708baf5116b3240b2de0a8fc7c8848ce03 Mon Sep 17 00:00:00 2001 From: 0xsatoshi <157293609+zeroxsatoshi@users.noreply.github.com> Date: Thu, 18 Apr 2024 15:21:00 +0800 Subject: [PATCH] add script to start localtestnet (#1) --- localtestnet.sh | 116 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 116 insertions(+) create mode 100755 localtestnet.sh diff --git a/localtestnet.sh b/localtestnet.sh new file mode 100755 index 00000000..a9bcee9e --- /dev/null +++ b/localtestnet.sh @@ -0,0 +1,116 @@ +#! /bin/bash +set -e + +validatorMnemonic="equip town gesture square tomorrow volume nephew minute witness beef rich gadget actress egg sing secret pole winter alarm law today check violin uncover" +# kava1ffv7nhd3z6sych2qpqkk03ec6hzkmufy0r2s4c +# kavavaloper1ffv7nhd3z6sych2qpqkk03ec6hzkmufyz4scd0 + +faucetMnemonic="crash sort dwarf disease change advice attract clump avoid mobile clump right junior axis book fresh mask tube front require until face effort vault" +# kava1adkm6svtzjsxxvg7g6rshg6kj9qwej8gwqadqd + +evmFaucetMnemonic="hundred flash cattle inquiry gorilla quick enact lazy galaxy apple bitter liberty print sun hurdle oak town cash because round chalk marriage response success" +# 0x3C854F92F726A7897C8B23F55B2D6E2C482EF3E0 +# kava18jz5lyhhy6ncjlyty064kttw93yzaulq7rlptu + +userMnemonic="news tornado sponsor drastic dolphin awful plastic select true lizard width idle ability pigeon runway lift oppose isolate maple aspect safe jungle author hole" +# 0x7Bbf300890857b8c241b219C6a489431669b3aFA +# kava10wlnqzyss4accfqmyxwx5jy5x9nfkwh6qm7n4t + +relayerMnemonic="never reject sniff east arctic funny twin feed upper series stay shoot vivid adapt defense economy pledge fetch invite approve ceiling admit gloom exit" +# 0xa2F728F997f62F47D4262a70947F6c36885dF9fa +# kava15tmj37vh7ch504px9fcfglmvx6y9m70646ev8t + +DATA=~/.kava +# remove any old state and config +rm -rf $DATA + +BINARY=kava + +# Create new data directory, overwriting any that alread existed +chainID="zgchain_8888-1" +$BINARY init validator --chain-id $chainID + +# hacky enable of rest api +sed -in-place='' 's/enable = false/enable = true/g' $DATA/config/app.toml + +# Set evm tracer to json +sed -in-place='' 's/tracer = ""/tracer = "json"/g' $DATA/config/app.toml + +# Enable full error trace to be returned on tx failure +sed -in-place='' '/iavl-cache-size/a\ +trace = true' $DATA/config/app.toml + +# Set client chain id +sed -in-place='' 's/chain-id = ""/chain-id = "zgchain_8888-1"/g' $DATA/config/client.toml + +# avoid having to use password for keys +$BINARY config keyring-backend test + +# Create validator keys and add account to genesis +validatorKeyName="validator" +printf "$validatorMnemonic\n" | $BINARY keys add $validatorKeyName --recover +$BINARY add-genesis-account $validatorKeyName 2000000000ukava + +# Create faucet keys and add account to genesis +faucetKeyName="faucet" +printf "$faucetMnemonic\n" | $BINARY keys add $faucetKeyName --recover +$BINARY add-genesis-account $faucetKeyName 1000000000ukava + +evmFaucetKeyName="evm-faucet" +printf "$evmFaucetMnemonic\n" | $BINARY keys add $evmFaucetKeyName --eth --recover +$BINARY add-genesis-account $evmFaucetKeyName 1000000000ukava + +userKeyName="user" +printf "$userMnemonic\n" | $BINARY keys add $userKeyName --eth --recover +$BINARY add-genesis-account $userKeyName 1000000000ukava,1000000000usdx + +relayerKeyName="relayer" +printf "$relayerMnemonic\n" | $BINARY keys add $relayerKeyName --eth --recover +$BINARY add-genesis-account $relayerKeyName 1000000000ukava + +storageContractAcc="kava1l0j9dqdvd3fatfqywhm4y6avrln4jracrfy9hk" +$BINARY add-genesis-account $storageContractAcc 1000000000ukava + +# Create a delegation tx for the validator and add to genesis +$BINARY gentx $validatorKeyName 1000000000ukava --keyring-backend test --chain-id $chainID +$BINARY collect-gentxs + +# Replace stake with ukava +sed -in-place='' 's/stake/ukava/g' $DATA/config/genesis.json + +# Replace the default evm denom of aphoton with ukava +sed -in-place='' 's/aphoton/akava/g' $DATA/config/genesis.json + +jq '.consensus_params.block.max_gas = "25000000"' $DATA/config/genesis.json|sponge $DATA/config/genesis.json + +# Zero out the total supply so it gets recalculated during InitGenesis +jq '.app_state.bank.supply = []' $DATA/config/genesis.json|sponge $DATA/config/genesis.json + +# Disable fee market +jq '.app_state.feemarket.params.no_base_fee = true' $DATA/config/genesis.json|sponge $DATA/config/genesis.json + +# Disable london fork +jq '.app_state.evm.params.chain_config.london_block = null' $DATA/config/genesis.json|sponge $DATA/config/genesis.json +jq '.app_state.evm.params.chain_config.arrow_glacier_block = null' $DATA/config/genesis.json|sponge $DATA/config/genesis.json +jq '.app_state.evm.params.chain_config.gray_glacier_block = null' $DATA/config/genesis.json|sponge $DATA/config/genesis.json +jq '.app_state.evm.params.chain_config.merge_netsplit_block = null' $DATA/config/genesis.json|sponge $DATA/config/genesis.json +jq '.app_state.evm.params.chain_config.shanghai_block = null' $DATA/config/genesis.json|sponge $DATA/config/genesis.json +jq '.app_state.evm.params.chain_config.cancun_block = null' $DATA/config/genesis.json|sponge $DATA/config/genesis.json + +# Add earn vault +jq '.app_state.earn.params.allowed_vaults = [ + { + denom: "usdx", + strategies: ["STRATEGY_TYPE_HARD"], + }, + { + denom: "bkava", + strategies: ["STRATEGY_TYPE_SAVINGS"], + }]' $DATA/config/genesis.json | sponge $DATA/config/genesis.json + +jq '.app_state.savings.params.supported_denoms = ["bkava-kavavaloper1ffv7nhd3z6sych2qpqkk03ec6hzkmufyz4scd0"]' $DATA/config/genesis.json | sponge $DATA/config/genesis.json + + +$BINARY config broadcast-mode sync + +$BINARY start --home $DATA