generate dshackle configs

This commit is contained in:
Sebastian
2024-03-19 18:15:08 +01:00
parent f44f172625
commit 3f22d9f7b9
3 changed files with 86 additions and 9 deletions

67
upstreams.sh Executable file
View File

@@ -0,0 +1,67 @@
#!/bin/bash
BASEPATH="$(dirname "$0")"
source $BASEPATH/.env
IFS=':' read -ra parts <<< $COMPOSE_FILE
blacklist=("drpc.yml" "base.yml" "rpc.yml" "monitoring.yml")
upstreams=()
path_blacklist=()
while IFS= read -r line; do
# Add each line to the array
path_blacklist+=("$line")
done < "$BASEPATH/path-blacklist.txt"
for part in "${parts[@]}"; do
include=true
for word in "${blacklist[@]}"; do
if echo "$part" | grep -qE "$word"; then
#echo "The path $path contains a blacklisted word: $word"
include=false
fi
done
if $include; then
pathlist=$(cat $BASEPATH/$part | grep -oP "(?<=stripprefix\.prefixes).*\"" | cut -d'=' -f2- | sed 's/.$//')
for path in $pathlist; do
path_include=true
for word in "${path_blacklist[@]}"; do
if echo "$path" | grep -qE "$word"; then
path_include=false
fi
done
if $path_include; then
url="$DOMAIN$path"
#echo "$url"
export ID=$(echo "$url" | sed -E 's/^rpc-(.*)\.stakesquid\.eu\/(.*)$/\1-\2/')
export PROVIDER=${ORGANIZATION}-${ID}
export RPC_URL="https://$url"
export WS_URL="wss://$url"
chain_id=$(curl --ipv4 -m 1 -s -X POST -H "Content-Type: application/json" --data '{"jsonrpc":"2.0","method":"eth_chainId","params":[],"id":1}' $RPC_URL | jq -r '.result')
chain_id_decimal=$((16#${chain_id#0x}))
export CHAIN=$($BASEPATH/get-shortname.sh $chain_id_decimal)
# Define the path to the input YAML file
input_file="$BASEPATH/${part%.yml}.cfg"
[ -f "$input_file" ] || input_file="$BASEPATH/default.cfg"
# Run envsubst to replace environment variables in the input file and save the result to the output file
upstreams+=("$(envsubst < "$input_file")")
break
fi
done
fi
done
printf "%s\n" "${upstreams[@]}"