Skip to content

Commit

Permalink
Merge branch 'celo8' into jcortejoso/update-maxframelen
Browse files Browse the repository at this point in the history
  • Loading branch information
jcortejoso authored Sep 18, 2024
2 parents ecfa0ee + 9e5409e commit c4165c0
Show file tree
Hide file tree
Showing 2 changed files with 53 additions and 19 deletions.
2 changes: 1 addition & 1 deletion .envrc.example
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ export PRIVATE_KEY=
# CELO additional configuration
export ENABLE_GOVERNANCE=false
export FUNDS_DEV_ACCOUNTS=false
export USE_PLASMA=false
export USE_ALTDA=false
# Set to false if migrating state from a Celo L1. True for new testnets
export DEPLOY_CELO_CONTRACTS=false

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,28 @@
# need to have the getting-started.json committed to the repo since it's an
# invalid JSON file when not filled in, which is annoying.

SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
CONTRACTS_BASE=$(dirname "$(dirname "$SCRIPT_DIR")")
reqenv() {
if [ -z "${!1}" ]; then
echo "Error: environment variable '$1' is undefined"
exit 1
fi
}

append_with_default() {
json_key="$1"
env_var_name="$2"
default_value="$3"
var_value="${!env_var_name}"

if [ -z "$var_value" ] || [ "$var_value" == "None" ]; then
var_value="$default_value"
fi

echo " \"$json_key\": \"$var_value\"," >> tmp_config.json
}

# Check required environment variables
reqenv "DEPLOYMENT_CONTEXT"
reqenv "GS_ADMIN_ADDRESS"
Expand All @@ -24,7 +39,7 @@ reqenv "L2_CHAIN_ID"
reqenv "L1_BLOCK_TIME"
reqenv "L2_BLOCK_TIME"
reqenv "FUNDS_DEV_ACCOUNTS"
reqenv "USE_PLASMA"
reqenv "USE_ALTDA"
reqenv "DEPLOY_CELO_CONTRACTS"
reqenv "USE_CUSTOM_GAS_TOKEN"
reqenv "CUSTOM_GAS_TOKEN_ADDRESS"
Expand All @@ -36,9 +51,10 @@ blockhash=$(echo "$block" | awk '/hash/ { print $2 }')
batchInboxAddressSuffix=$(printf "%0$((38 - ${#L2_CHAIN_ID}))d" 0)$L2_CHAIN_ID
batchInboxAddress=0xff$batchInboxAddressSuffix

# Generate the config file
config=$(cat << EOL
{
# Start generating the config file in a temporary file

cat << EOL > tmp_config.json
{
"l1StartingBlockTag": "$blockhash",
"l1ChainID": $L1_CHAIN_ID,
Expand Down Expand Up @@ -89,17 +105,36 @@ config=$(cat << EOL
"l2GenesisBlockGasLimit": "0x1c9c380",
"l2GenesisBlockBaseFeePerGas": "0x3b9aca00",
"l2GenesisRegolithTimeOffset": "0x0",
"eip1559Denominator": 50,
"eip1559DenominatorCanyon": 250,
"eip1559Elasticity": 6,
EOL

"l2GenesisFjordTimeOffset": "0x0",
"l2GenesisEcotoneTimeOffset": "0x0",
"l2GenesisDeltaTimeOffset": "0x0",
"l2GenesisCanyonTimeOffset": "0x0",
# Append conditional environment variables with their corresponding default values
# Activate granite fork
if [ -n "${GRANITE_TIME_OFFSET}" ]; then
append_with_default "l2GenesisGraniteTimeOffset" "GRANITE_TIME_OFFSET" "0x0"
fi
# Activate holocene fork
if [ -n "${HOLOCENE_TIME_OFFSET}" ]; then
append_with_default "l2GenesisHoloceneTimeOffset" "HOLOCENE_TIME_OFFSET" "0x0"
fi

# Activate the interop fork
if [ -n "${INTEROP_TIME_OFFSET}" ]; then
append_with_default "l2GenesisInteropTimeOffset" "INTEROP_TIME_OFFSET" "0x0"
fi

# Already forked updates
append_with_default "l2GenesisFjordTimeOffset" "FJORD_TIME_OFFSET" "0x0"
append_with_default "l2GenesisRegolithTimeOffset" "REGOLITH_TIME_OFFSET" "0x0"
append_with_default "l2GenesisEcotoneTimeOffset" "ECOTONE_TIME_OFFSET" "0x0"
append_with_default "l2GenesisDeltaTimeOffset" "DELTA_TIME_OFFSET" "0x0"
append_with_default "l2GenesisCanyonTimeOffset" "CANYON_TIME_OFFSET" "0x0"

# Continue generating the config file
cat << EOL >> tmp_config.json
"systemConfigStartBlock": 0,
"requiredProtocolVersion": "0x0000000000000000000000000000000000000000000000000000000000000000",
Expand All @@ -108,22 +143,22 @@ config=$(cat << EOL
"faultGameAbsolutePrestate": "0x03c7ae758795765c6664a5d39bf63841c71ff191e9189522bad8ebff5d4eca98",
"faultGameMaxDepth": 44,
"faultGameClockExtension": 0,
"faultGameMaxClockDuration": 600,
"faultGameMaxClockDuration": 1200,
"faultGameGenesisBlock": 0,
"faultGameGenesisOutputRoot": "0x0000000000000000000000000000000000000000000000000000000000000000",
"faultGameSplitDepth": 14,
"faultGameWithdrawalDelay": 604800,
"faultGameWithdrawalDelay": 600,
"preimageOracleMinProposalSize": 1800000,
"preimageOracleChallengePeriod": 86400,
"preimageOracleChallengePeriod": 300,
"fundDevAccounts": $FUNDS_DEV_ACCOUNTS,
"useFaultProofs": false,
"proofMaturityDelaySeconds": 604800,
"disputeGameFinalityDelaySeconds": 302400,
"respectedGameType": 0,
"usePlasma": $USE_PLASMA,
"useAltDA": $USE_ALTDA,
"daCommitmentType": "GenericCommitment",
"daChallengeWindow": 1,
"daResolveWindow": 1,
Expand All @@ -132,9 +167,8 @@ config=$(cat << EOL
"customGasTokenAddress": "$CUSTOM_GAS_TOKEN_ADDRESS"
}
EOL
)

# Write the config file
echo "$config" > "deploy-config/$DEPLOYMENT_CONTEXT.json"
# Write the final config file
mv tmp_config.json "$CONTRACTS_BASE/deploy-config/$DEPLOYMENT_CONTEXT.json"

echo "Wrote config file to deploy-config/$DEPLOYMENT_CONTEXT.json"
echo "Wrote config file to $CONTRACTS_BASE/deploy-config/$DEPLOYMENT_CONTEXT.json"

0 comments on commit c4165c0

Please sign in to comment.