69 lines
1.6 KiB
Bash
Executable File
69 lines
1.6 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
BASEPATH="$(dirname "$0")"
|
|
source $BASEPATH/.env
|
|
|
|
blacklist=()
|
|
while IFS= read -r line; do
|
|
# Add each line to the array
|
|
blacklist+=("$line")
|
|
done < "$BASEPATH/path-blacklist.txt"
|
|
|
|
if [ -n "$NO_SSL" ]; then
|
|
PROTO="http"
|
|
DOMAIN="${DOMAIN:-0.0.0.0}"
|
|
else
|
|
PROTO="https"
|
|
fi
|
|
|
|
pathlist=$(cat $BASEPATH/$1.yml | grep -oP "stripprefix\.prefixes.*?/\K[^\"]+")
|
|
|
|
for path in $pathlist; do
|
|
include=true
|
|
for word in "${blacklist[@]}"; do
|
|
if echo "$path" | grep -qE "$word"; then
|
|
if echo "$path" | grep -qE "viction"; then
|
|
# excemption
|
|
include=$include
|
|
else
|
|
include=false
|
|
fi
|
|
fi
|
|
done
|
|
|
|
if $include; then
|
|
RPC_URL="$PROTO://$DOMAIN/$path"
|
|
|
|
ref=''
|
|
if [ -n "$2" ]; then
|
|
ref="$2"
|
|
else
|
|
chain_id_response=$(curl -L --ipv4 -m 1 -s -X POST -H "Content-Type: application/json" --data '{"jsonrpc":"2.0","method":"eth_chainId","params":[],"id":1}' $RPC_URL)
|
|
|
|
if [ $? -eq 0 ]; then
|
|
chain_id=$(echo "$chain_id_response" | jq -r '.result' 2>/dev/null)
|
|
|
|
# echo "$RPC_URL: $chain_id"
|
|
|
|
if [[ "$chain_id" =~ ^0x[0-9a-fA-F]+$ ]]; then
|
|
chain_id_decimal=$((16#${chain_id#0x}))
|
|
ref=$($BASEPATH/reference-rpc-endpoint.sh $chain_id_decimal)
|
|
else
|
|
echo "error"
|
|
exit 1
|
|
fi
|
|
else
|
|
echo "error"
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
# Call the health check script with RPC_URL and ref
|
|
$BASEPATH/check-health.sh "$RPC_URL" $ref
|
|
exit $?
|
|
fi
|
|
done
|
|
|
|
echo "unverified"
|
|
exit 1
|