mirror of
https://github.com/logos-storage/logos-storage-DAppNodePackage.git
synced 2026-01-02 13:23:10 +00:00
chore: update testnet bootstrap records (#6)
* chore: spelling * chore: update testnet geth enodes records * chore: set testnet codex spr records from url * chore: publish updated packges
This commit is contained in:
parent
84b3e462e3
commit
cb6f170ffd
@ -35,8 +35,8 @@
|
|||||||
|
|
||||||
| Package | Link |
|
| Package | Link |
|
||||||
| --------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
| --------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
||||||
| Codex | [`/ipfs/QmRobj7vPQ7qJBG42iD8c75SAoMkG1pr1YetYD5QHJNrdz`](http://my.dappnode/installer/public/%2Fipfs%2FQmRobj7vPQ7qJBG42iD8c75SAoMkG1pr1YetYD5QHJNrdz) |
|
| Codex | [`/ipfs/QmZFLxyaJgiWojBP9Gvm491SHD9pjZsmW6iwt2nSsxZiBy`](http://my.dappnode/installer/public/%2Fipfs%2FQmZFLxyaJgiWojBP9Gvm491SHD9pjZsmW6iwt2nSsxZiBy) |
|
||||||
| Codex with local Geth | [`/ipfs/QmVwJtetY98Y1mVwQ3ULwha1tiE49jVn3DQEFigdtbRjj6`](http://my.dappnode/installer/public/%2Fipfs%2FQmVwJtetY98Y1mVwQ3ULwha1tiE49jVn3DQEFigdtbRjj6) |
|
| Codex with local Geth | [`/ipfs/QmeuvYaHVDQsgAz6BP7AdvCu6ZMxHE5vftQ1ivcwkzd9BH`](http://my.dappnode/installer/public/%2Fipfs%2FQmeuvYaHVDQsgAz6BP7AdvCu6ZMxHE5vftQ1ivcwkzd9BH) |
|
||||||
|
|
||||||
|
|
||||||
## Todo
|
## Todo
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Environment variables from files
|
# Environment variables from files in form of foo=bar
|
||||||
# If set to file path, read the file and export the variables
|
# If set to file path, read the file and export the variables
|
||||||
# If set to directory path, read all files in the directory and export the variables
|
# If set to directory path, read all files in the directory and export the variables
|
||||||
if [[ -n "${ENV_PATH}" ]]; then
|
if [[ -n "${ENV_PATH}" ]]; then
|
||||||
@ -9,11 +9,11 @@ if [[ -n "${ENV_PATH}" ]]; then
|
|||||||
set +a
|
set +a
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
# Parameters
|
# Parameters
|
||||||
if [[ -z "${CODEX_NAT}" ]]; then
|
if [[ -z "${CODEX_NAT}" ]]; then
|
||||||
if [[ "${NAT_IP_AUTO}" == "true" && -z "${NAT_PUBLIC_IP_AUTO}" ]]; then
|
if [[ "${NAT_IP_AUTO}" == "true" && -z "${NAT_PUBLIC_IP_AUTO}" ]]; then
|
||||||
export CODEX_NAT="extip:$(hostname --ip-address)"
|
export CODEX_NAT="extip:$(hostname --ip-address)"
|
||||||
echo "Private: CODEX_NAT=${CODEX_NAT}"
|
|
||||||
elif [[ -n "${NAT_PUBLIC_IP_AUTO}" ]]; then
|
elif [[ -n "${NAT_PUBLIC_IP_AUTO}" ]]; then
|
||||||
# Run for 60 seconds if fail
|
# Run for 60 seconds if fail
|
||||||
WAIT=120
|
WAIT=120
|
||||||
@ -24,7 +24,6 @@ if [[ -z "${CODEX_NAT}" ]]; then
|
|||||||
# Check if exit code is 0 and returned value is not empty
|
# Check if exit code is 0 and returned value is not empty
|
||||||
if [[ $? -eq 0 && -n "${IP}" ]]; then
|
if [[ $? -eq 0 && -n "${IP}" ]]; then
|
||||||
export CODEX_NAT="extip:${IP}"
|
export CODEX_NAT="extip:${IP}"
|
||||||
echo "Public: CODEX_NAT=${CODEX_NAT}"
|
|
||||||
break
|
break
|
||||||
else
|
else
|
||||||
# Sleep and check again
|
# Sleep and check again
|
||||||
@ -46,16 +45,13 @@ fi
|
|||||||
|
|
||||||
# If marketplace is enabled from the testing environment,
|
# If marketplace is enabled from the testing environment,
|
||||||
# The file has to be written before Codex starts.
|
# The file has to be written before Codex starts.
|
||||||
for key in PRIV_KEY ETH_PRIVATE_KEY; do
|
keyfile="private.key"
|
||||||
keyfile="private.key"
|
if [[ -n "${ETH_PRIVATE_KEY}" ]]; then
|
||||||
if [[ -n "${!key}" ]]; then
|
echo "${ETH_PRIVATE_KEY}" > "${keyfile}"
|
||||||
[[ "${key}" == "PRIV_KEY" ]] && echo "PRIV_KEY variable is deprecated and will be removed in the next releases, please use ETH_PRIVATE_KEY instead!"
|
chmod 600 "${keyfile}"
|
||||||
echo "${!key}" > "${keyfile}"
|
export CODEX_ETH_PRIVATE_KEY="${keyfile}"
|
||||||
chmod 600 "${keyfile}"
|
echo "Private key set"
|
||||||
export CODEX_ETH_PRIVATE_KEY="${keyfile}"
|
fi
|
||||||
echo "Private key set"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# Set arguments
|
# Set arguments
|
||||||
if [[ "${MODE}" == "codex-node-with-marketplace" ]]; then
|
if [[ "${MODE}" == "codex-node-with-marketplace" ]]; then
|
||||||
@ -67,21 +63,33 @@ else
|
|||||||
unset CODEX_ETH_PROVIDER
|
unset CODEX_ETH_PROVIDER
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Set network parameters
|
# Bootstrap node from URL
|
||||||
if [[ "${NETWORK}" == "testnet" ]]; then
|
BOOTSTRAP_NODE_FROM_URL="${BOOTSTRAP_NODE_FROM_URL:-https://spr.codex.storage/${NETWORK}}"
|
||||||
bootstrap_nodes=(
|
|
||||||
--bootstrap-node=spr:CiUIAhIhAiJvIcA_ZwPZ9ugVKDbmqwhJZaig5zKyLiuaicRcCGqLEgIDARo8CicAJQgCEiECIm8hwD9nA9n26BUoNuarCEllqKDnMrIuK5qJxFwIaosQ3d6esAYaCwoJBJ_f8zKRAnU6KkYwRAIgM0MvWNJL296kJ9gWvfatfmVvT-A7O2s8Mxp8l9c8EW0CIC-h-H-jBVSgFjg3Eny2u33qF7BDnWFzo7fGfZ7_qc9P
|
if [[ -n "${BOOTSTRAP_NODE_FROM_URL}" ]]; then
|
||||||
--bootstrap-node=spr:CiUIAhIhAyUvcPkKoGE7-gh84RmKIPHJPdsX5Ugm_IHVJgF-Mmu_EgIDARo8CicAJQgCEiEDJS9w-QqgYTv6CHzhGYog8ck92xflSCb8gdUmAX4ya78QoemesAYaCwoJBES39Q2RAnVOKkYwRAIgLi3rouyaZFS_Uilx8k99ySdQCP1tsmLR21tDb9p8LcgCIG30o5YnEooQ1n6tgm9fCT7s53k6XlxyeSkD_uIO9mb3
|
WAIT=${BOOTSTRAP_NODE_FROM_URL_WAIT:-300}
|
||||||
--bootstrap-node=spr:CiUIAhIhA6_j28xa--PvvOUxH10wKEm9feXEKJIK3Z9JQ5xXgSD9EgIDARo8CicAJQgCEiEDr-PbzFr74--85TEfXTAoSb195cQokgrdn0lDnFeBIP0QzOGesAYaCwoJBK6Kf1-RAnVEKkcwRQIhAPUH5nQrqG4OW86JQWphdSdnPA98ErQ0hL9OZH9a4e5kAiBBZmUl9KnhSOiDgU3_hvjXrXZXoMxhGuZ92_rk30sNDA
|
SECONDS=0
|
||||||
--bootstrap-node=spr:CiUIAhIhA7E4DEMer8nUOIUSaNPA4z6x0n9Xaknd28Cfw9S2-cCeEgIDARo8CicAJQgCEiEDsTgMQx6vydQ4hRJo08DjPrHSf1dqSd3bwJ_D1Lb5wJ4Qt_CesAYaCwoJBEDhWZORAnVYKkYwRAIgFNzhnftocLlVHJl1onuhbSUM7MysXPV6dawHAA0DZNsCIDRVu9gnPTH5UkcRXLtt7MLHCo4-DL-RCMyTcMxYBXL0
|
SLEEP=1
|
||||||
--bootstrap-node=spr:CiUIAhIhAzZn3JmJab46BNjadVnLNQKbhnN3eYxwqpteKYY32SbOEgIDARo8CicAJQgCEiEDNmfcmYlpvjoE2Np1Wcs1ApuGc3d5jHCqm14phjfZJs4QrvWesAYaCwoJBKpA-TaRAnViKkcwRQIhANuMmZDD2c25xzTbKSirEpkZYoxbq-FU_lpI0K0e4mIVAiBfQX4yR47h1LCnHznXgDs6xx5DLO5q3lUcicqUeaqGeg
|
# Run and retry if fail
|
||||||
--bootstrap-node=spr:CiUIAhIhAgybmRwboqDdUJjeZrzh43sn5mp8jt6ENIb08tLn4x01EgIDARo8CicAJQgCEiECDJuZHBuioN1QmN5mvOHjeyfmanyO3oQ0hvTy0ufjHTUQh4ifsAYaCwoJBI_0zSiRAnVsKkcwRQIhAJCb_z0E3RsnQrEePdJzMSQrmn_ooHv6mbw1DOh5IbVNAiBbBJrWR8eBV6ftzMd6ofa5khNA2h88OBhMqHCIzSjCeA
|
while (( SECONDS < WAIT )); do
|
||||||
--bootstrap-node=spr:CiUIAhIhAntGLadpfuBCD9XXfiN_43-V3L5VWgFCXxg4a8uhDdnYEgIDARo8CicAJQgCEiECe0Ytp2l-4EIP1dd-I3_jf5XcvlVaAUJfGDhry6EN2dgQsIufsAYaCwoJBNEmoCiRAnV2KkYwRAIgXO3bzd5VF8jLZG8r7dcLJ_FnQBYp1BcxrOvovEa40acCIDhQ14eJRoPwJ6GKgqOkXdaFAsoszl-HIRzYcXKeb7D9
|
SPR=($(curl -s -f -m 5 "${BOOTSTRAP_NODE_FROM_URL}"))
|
||||||
)
|
# Check if exit code is 0 and returned value is not empty
|
||||||
|
if [[ $? -eq 0 && -n "${SPR}" ]]; then
|
||||||
|
for node in "${SPR[@]}"; do
|
||||||
|
bootstrap+="--bootstrap-node=$node "
|
||||||
|
done
|
||||||
|
set -- "$@" ${bootstrap}
|
||||||
|
break
|
||||||
|
else
|
||||||
|
# Sleep and check again
|
||||||
|
echo "Can't get SPR from ${BOOTSTRAP_NODE_FROM_URL} - Retry in $SLEEP seconds / $((WAIT - SECONDS))"
|
||||||
|
sleep $SLEEP
|
||||||
|
fi
|
||||||
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Update arguments
|
# Update arguments
|
||||||
set -- "$@" ${bootstrap_nodes[@]} ${EXTRA_OPTS}
|
set -- "$@" ${EXTRA_OPTS}
|
||||||
|
|
||||||
# Check if the endpoint is synced
|
# Check if the endpoint is synced
|
||||||
if [[ -n "${CODEX_ETH_PROVIDER}" ]]; then
|
if [[ -n "${CODEX_ETH_PROVIDER}" ]]; then
|
||||||
@ -143,11 +151,11 @@ if [[ "$@" == *"prover"* ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Show
|
# Show
|
||||||
echo "Codex parameters:"
|
echo -e "\nCodex run parameters:"
|
||||||
vars=$(env | grep CODEX_)
|
vars=$(env | grep CODEX_)
|
||||||
echo -e "${vars//CODEX_/ - CODEX_}"
|
echo -e "${vars//CODEX_/ - CODEX_}"
|
||||||
echo -e " $@"
|
echo -e " - $@\n"
|
||||||
|
|
||||||
# Run
|
# Run
|
||||||
echo "Run Codex node..."
|
echo "Run Codex node"
|
||||||
exec "$@"
|
exec "$@"
|
||||||
|
|||||||
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
# Network
|
# Network
|
||||||
if [ "${NETWORK}" = "testnet" ]; then
|
if [ "${NETWORK}" = "testnet" ]; then
|
||||||
export GETH_BOOTNODES=enode://cff0c44c62ecd6e00d72131f336bb4e4968f2c1c1abeca7d4be2d35f818608b6d8688b6b65a18f1d57796eaca32fd9d08f15908a88afe18c1748997235ea6fe7@159.223.243.50:40010,enode://ea331eaa8c5150a45b793b3d7c17db138b09f7c9dd7d881a1e2e17a053e0d2600e0a8419899188a87e6b91928d14267949a7e6ec18bfe972f3a14c5c2fe9aecb@68.183.245.13:40030,enode://4a7303b8a72db91c7c80c8fb69df0ffb06370d7f5fe951bcdc19107a686ba61432dc5397d073571433e8fc1f8295127cabbcbfd9d8464b242b7ad0dcd35e67fc@174.138.127.95:40020,enode://36f25e91385206300d04b95a2f8df7d7a792db0a76bd68f897ec7749241b5fdb549a4eecfab4a03c36955d1242b0316b47548b87ad8291794ab6d3fecda3e85b@64.225.89.147:40040,enode://2e14e4a8092b67db76c90b0a02d97d88fc2bb9df0e85df1e0a96472cdfa06b83d970ea503a9bc569c4112c4c447dbd1e1f03cf68471668ba31920ac1d05f85e3@170.64.249.54:40050,enode://6eeb3b3af8bef5634b47b573a17477ea2c4129ab3964210afe3b93774ce57da832eb110f90fbfcfa5f7adf18e55faaf2393d2e94710882d09d0204a9d7bc6dd2@143.244.205.40:40060,enode://6ba0e8b5d968ca8eb2650dd984cdcf50acc01e4ea182350e990191aadd79897801b79455a1186060aa3818a6bc4496af07f0912f7af53995a5ddb1e53d6f31b5@209.38.160.40:40070
|
export GETH_BOOTNODES=enode://cff0c44c62ecd6e00d72131f336bb4e4968f2c1c1abeca7d4be2d35f818608b6d8688b6b65a18f1d57796eaca32fd9d08f15908a88afe18c1748997235ea6fe7@159.223.243.50:40010,enode://4a7303b8a72db91c7c80c8fb69df0ffb06370d7f5fe951bcdc19107a686ba61432dc5397d073571433e8fc1f8295127cabbcbfd9d8464b242b7ad0dcd35e67fc@174.138.127.95:40020,enode://ea331eaa8c5150a45b793b3d7c17db138b09f7c9dd7d881a1e2e17a053e0d2600e0a8419899188a87e6b91928d14267949a7e6ec18bfe972f3a14c5c2fe9aecb@68.183.245.13:40030
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Show
|
# Show
|
||||||
|
|||||||
@ -37,7 +37,7 @@ fields:
|
|||||||
service: codex-node
|
service: codex-node
|
||||||
title: ETH_PRIVATE_KEY
|
title: ETH_PRIVATE_KEY
|
||||||
description: >-
|
description: >-
|
||||||
Ethereum private key which will be saved to a file and passed as a value for `CODEX_ETH_PRIVATE_KEY` variable.
|
Ethereum private key which will be saved to a file which will be passed as a value for `CODEX_ETH_PRIVATE_KEY` variable.
|
||||||
secret: true
|
secret: true
|
||||||
pattern: "^0x[a-fA-F0-9]{64}$"
|
pattern: "^0x[a-fA-F0-9]{64}$"
|
||||||
patternErrorMessage: Must be a valid private key (0x1fd16a...)
|
patternErrorMessage: Must be a valid private key (0x1fd16a...)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user