From 0ee5e7d28be600881b79c9ba9676003d8d874a48 Mon Sep 17 00:00:00 2001 From: oleksandrSydorenkoJ Date: Fri, 6 Jun 2025 19:13:08 +0200 Subject: [PATCH 1/5] Create.env example file and updte deploy_mirage.sh --- .env.example | 6 ++++++ deploy_mirage.sh | 12 +++++++++++- helper.sh | 11 +++++++++-- 3 files changed, 26 insertions(+), 3 deletions(-) create mode 100644 .env.example diff --git a/.env.example b/.env.example new file mode 100644 index 0000000..cfd7faf --- /dev/null +++ b/.env.example @@ -0,0 +1,6 @@ +ETH_PRIVATE_KEY= +MAINNET_ENDPOINT=https://example.com +ENDPOINT=http://eth-proxy.skalenodes.com:8888/holesky +CHAIN_NAME= +MIRAGE_TAG=.0.1-develop.6 +TARGET= \ No newline at end of file diff --git a/deploy_mirage.sh b/deploy_mirage.sh index 3de73f9..7dd52ea 100755 --- a/deploy_mirage.sh +++ b/deploy_mirage.sh @@ -6,6 +6,14 @@ set -e +if [ -f .env ]; then + source .env + export $(grep -v '^#' .env | xargs) + echo "Loaded environment variables from .env" +else + echo ".env not found, using variables from command line" +fi + : "${MIRAGE_TAG:?Need to set MIRAGE_TAG}" DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )" @@ -14,6 +22,8 @@ GAS_PRICE=${GAS_PRICE:-10000000000} ETHERSCAN=${ETHERSCAN:-1234} NETWORK=${NETWORK:-custom} DOCKER_NETWORK=${DOCKER_NETWORK:-host} +CHAIN_NAME=${CHAIN_NAME:-"mirage-qa"} +TARGET=${TARGET:-"legacy"} source "$DIR/helper.sh" @@ -22,4 +32,4 @@ source "$DIR/helper.sh" PRIVATE_KEY=${ANVIL_PRIVATE_KEY:-$ETH_PRIVATE_KEY} : "${PRIVATE_KEY:?Need to set ETH_PRIVATE_KEY}" -deploy_mirage "$MIRAGE_TAG" "$DEPLOYMENT_ENDPOINT" "$PRIVATE_KEY" "$GAS_PRICE" "$NETWORK" "$ETHERSCAN" +deploy_mirage "$MIRAGE_TAG" "$DEPLOYMENT_ENDPOINT" "$PRIVATE_KEY" "$GAS_PRICE" "$NETWORK" "$ETHERSCAN" "$CHAIN_NAME" "$TARGET" "$ENDPOINT" diff --git a/helper.sh b/helper.sh index 16e1eca..ae5e7c0 100644 --- a/helper.sh +++ b/helper.sh @@ -92,6 +92,9 @@ deploy_mirage () { : "${4?Pass GAS_PRICE to ${FUNCNAME[0]}}" : "${5?Pass NETWORK to ${FUNCNAME[0]}}" : "${6?Pass ETHERSCAN to ${FUNCNAME[0]}}" + : "${7?Pass CHAIN_NAME to ${FUNCNAME[0]}}" + : "${8?Pass TARGET to ${FUNCNAME[0]}}" + : "${9?Pass ENDPOINT to ${FUNCNAME[0]}}" echo Going to run $MIRAGE_IMAGE_NAME:$1 docker container... mkdir -p $DIR/contracts_data/openzeppelin @@ -99,16 +102,20 @@ deploy_mirage () { docker rm -f $MIRAGE_IMAGE_NAME || true docker pull skalenetwork/$MIRAGE_IMAGE_NAME:$1 + docker run \ --name $MIRAGE_IMAGE_NAME \ -v $DIR/contracts_data:/usr/src/manager/data \ --network $DOCKER_NETWORK \ - -e ENDPOINT=$2 \ + -e MAINNET_ENDPOINT=$2 \ -e PRIVATE_KEY=$3 \ -e GASPRICE=$4 \ -e ETHERSCAN=$6 \ + -e CHAIN_NAME=$7 \ + -e TARGET=$8 \ + -e ENDPOINT=$9 \ skalenetwork/$MIRAGE_IMAGE_NAME:$1 \ - /bin/bash -c "$cmd" + /bin/bash -c "$cmd" echo Copying $DIR/contracts_data/mirage-manager-${MIRAGE_TAG}-* to $DIR/contracts_data/mirage.json cp $DIR/contracts_data/mirage-manager-${MIRAGE_TAG}-* $DIR/contracts_data/mirage.json From f556cc569493d555aaa0db9e79191cc181247252 Mon Sep 17 00:00:00 2001 From: oleksandrSydorenkoJ Date: Fri, 6 Jun 2025 19:15:28 +0200 Subject: [PATCH 2/5] Update Read,e.md --- README.md | 3 ++- helper.sh | 1 - 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 1c38d3d..22b901f 100644 --- a/README.md +++ b/README.md @@ -106,9 +106,10 @@ Required environment variables: Example: ```bash -ETH_PRIVATE_KEY= ENDPOINT=https://example.com MIRAGE_TAG=0.0.1-develop.6 bash deploy_mirage.sh +ETH_PRIVATE_KEY= ENDPOINT=https://example.com MIRAGE_TAG=0.0.1-develop.6 CHAIN_NAME= TARGET= bash deploy_mirage.sh ``` + ABI and address of the deployed contracts will be saved in `contracts_data/mirage.json` file. ### Deploy SKALE Allocator diff --git a/helper.sh b/helper.sh index ae5e7c0..b70bd9f 100644 --- a/helper.sh +++ b/helper.sh @@ -94,7 +94,6 @@ deploy_mirage () { : "${6?Pass ETHERSCAN to ${FUNCNAME[0]}}" : "${7?Pass CHAIN_NAME to ${FUNCNAME[0]}}" : "${8?Pass TARGET to ${FUNCNAME[0]}}" - : "${9?Pass ENDPOINT to ${FUNCNAME[0]}}" echo Going to run $MIRAGE_IMAGE_NAME:$1 docker container... mkdir -p $DIR/contracts_data/openzeppelin From 5771aec4611e84667a6c95b87029aae2bb7b8f8c Mon Sep 17 00:00:00 2001 From: oleksandrSydorenkoJ Date: Fri, 6 Jun 2025 19:46:30 +0200 Subject: [PATCH 3/5] Fix type --- deploy_mirage.sh | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/deploy_mirage.sh b/deploy_mirage.sh index 7dd52ea..c23c741 100755 --- a/deploy_mirage.sh +++ b/deploy_mirage.sh @@ -17,13 +17,14 @@ fi : "${MIRAGE_TAG:?Need to set MIRAGE_TAG}" DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )" -DEPLOYMENT_ENDPOINT=${ENDPOINT:-'http://127.0.0.1:8545'} +DEPLOYMENT_ENDPOINT=${MAINNET_ENDPOINT:-'http://127.0.0.1:8545'} GAS_PRICE=${GAS_PRICE:-10000000000} ETHERSCAN=${ETHERSCAN:-1234} NETWORK=${NETWORK:-custom} DOCKER_NETWORK=${DOCKER_NETWORK:-host} CHAIN_NAME=${CHAIN_NAME:-"mirage-qa"} TARGET=${TARGET:-"legacy"} +ENDPOINT=${ENDPOINT:-"http://127.0.0.1:8545"} source "$DIR/helper.sh" From a919d9997e436d60eb4c85e72612daad0d4af59a Mon Sep 17 00:00:00 2001 From: Oleksandr Sydorenko <84327300+oleksandrSydorenkoJ@users.noreply.github.com> Date: Wed, 11 Jun 2025 14:27:03 +0200 Subject: [PATCH 4/5] Rename .env.example to .env.mirage.example --- .env.example => .env.mirage.example | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename .env.example => .env.mirage.example (85%) diff --git a/.env.example b/.env.mirage.example similarity index 85% rename from .env.example rename to .env.mirage.example index cfd7faf..ae5ccb1 100644 --- a/.env.example +++ b/.env.mirage.example @@ -3,4 +3,4 @@ MAINNET_ENDPOINT=https://example.com ENDPOINT=http://eth-proxy.skalenodes.com:8888/holesky CHAIN_NAME= MIRAGE_TAG=.0.1-develop.6 -TARGET= \ No newline at end of file +TARGET= From 16dfa60dc9d56136a0ca96cc77044997d43c63ff Mon Sep 17 00:00:00 2001 From: Oleksandr Sydorenko <84327300+oleksandrSydorenkoJ@users.noreply.github.com> Date: Wed, 11 Jun 2025 14:30:40 +0200 Subject: [PATCH 5/5] Update README.md --- README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/README.md b/README.md index 22b901f..0df7a92 100644 --- a/README.md +++ b/README.md @@ -102,6 +102,8 @@ Required environment variables: * `ETH_PRIVATE_KEY` (Ethereum private key without the `0x` prefix) * `ENDPOINT` (Ethereum RPC endpoint) * `MIRAGE_TAG` (tag for the Mirage-Manager version) +* `CHAIN_NAME` chain name what should be migrated +* `TARGET` Skale Manager address for the Ethereum Example: