Files
ethereum-rpc-docker/check-health.sh
2025-03-31 12:58:11 +02:00

161 lines
5.4 KiB
Bash
Executable File

#!/bin/bash
BASEPATH="$(dirname "$0")"
if [ $# -lt 2 ]; then
echo "Error: At least two parameters are required."
exit 1
fi
RPC_URL=$1
REF=""
for url in "${@:2}"; do
REF+="--url $url "
done
# Optional: You can remove the trailing space if needed
ref=${REF% }
# echo "ref: $ref"
timeout=3 # seconds
response_file=$(mktemp)
http_status_code=$(curl -L --ipv4 -m $timeout -s -X POST -w "%{http_code}" -o "$response_file" -H "Content-Type: application/json" --data '{"jsonrpc":"2.0","method":"eth_getBlockByNumber","params":["latest", false],"id":1}' $RPC_URL)
if [ $? -eq 0 ]; then
if [[ $http_status_code -eq 200 ]]; then
response=$(cat "$response_file")
latest_block_timestamp=$(echo "$response" | jq -r '.result.timestamp')
latest_block_timestamp_decimal=$((16#${latest_block_timestamp#0x}))
current_time=$(date +%s)
time_difference=$((current_time - latest_block_timestamp_decimal))
rm "$response_file"
if [ -n "$ref" ]; then
latest_block_number=$(echo "$response" | jq -r '.result.number')
latest_block_hash=$(echo "$response" | jq -r '.result.hash')
response_file2=$(mktemp)
sleep 3 # to give the reference node more time to import the block if it is very current
http_status_code2=$($BASEPATH/multicurl.sh -L --ipv4 -m $timeout -s -X POST -w "%{http_code}" -o "$response_file2" -H "Content-Type: application/json" --data "{\"jsonrpc\":\"2.0\",\"method\":\"eth_getBlockByNumber\",\"params\":[\"$latest_block_number\", false],\"id\":1}" $ref)
curl_code2=$?
if [ $curl_code2 -eq 0 ]; then
if [[ $http_status_code2 -eq 200 ]]; then
response2=$(cat "$response_file2")
latest_block_hash2=$(echo "$response2" | jq -r '.result.hash')
rm "$response_file2"
if [ "$latest_block_hash" == "$latest_block_hash2" ]; then
response_file3=$(mktemp)
status_file3=$(mktemp)
{
$BASEPATH/multicurl.sh -L --ipv4 -m $timeout -s -X POST -w "%{http_code} %{time_total}" -o "$response_file3" -H "Content-Type: application/json" --data "{\"jsonrpc\":\"2.0\",\"method\":\"eth_getBlockByNumber\",\"params\":[\"latest\", false],\"id\":1}" $ref > "$status_file3"
} &
pid3=$!
response_file4=$(mktemp)
status_file4=$(mktemp)
{
curl -L --ipv4 -m $timeout -s -X POST -w "%{http_code} %{time_total}" -o "$response_file4" -H "Content-Type: application/json" --data '{"jsonrpc":"2.0","method":"eth_getBlockByNumber","params":["latest", false],"id":1}' $RPC_URL > "$status_file4"
} &
pid4=$!
wait $pid3
curl_code3=$?
http_status_code3=$(cat "$status_file3" | cut -d ' ' -f 1)
request_time3=$(cat "$status_file3" | cut -d ' ' -f 2)
rm "$status_file3"
wait $pid4
curl_code4=$?
http_status_code4=$(cat "$status_file4" | cut -d ' ' -f 1)
request_time4=$(cat "$status_file4" | cut -d ' ' -f 2)
rm "$status_file4"
# echo "lets check"
if [ $curl_code3 -eq 0 ]; then
if [[ $http_status_code3 -eq 200 ]]; then
response3=$(cat "$response_file3")
latest_block_timestamp3=$(echo "$response3" | jq -r '.result.timestamp')
latest_block_timestamp_decimal3=$((16#${latest_block_timestamp3#0x}))
# echo "refer: $latest_block_timestamp_decimal3"
rm "$response_file3"
if [ $curl_code4 -eq 0 ]; then
if [[ $http_status_code4 -eq 200 ]]; then
response4=$(cat "$response_file4")
latest_block_timestamp4=$(echo "$response4" | jq -r '.result.timestamp')
latest_block_timestamp_decimal4=$((16#${latest_block_timestamp4#0x}))
#echo "local: $latest_block_timestamp_decimal4"
rm "$response_file4"
time_difference3=$(echo "scale=6; (${latest_block_timestamp_decimal3} - ${request_time3}) - (${latest_block_timestamp_decimal4} - ${request_time4})" | bc)
#echo "diff after network latency: $time_difference3 s"
if (( $(echo "$time_difference3 < 2" | bc -l) )); then
echo "online"
exit 0
elif (( $(echo "$time_difference3 < 5" | bc -l) )); then
echo "lagging"
exit 0
else
echo "syncing"
exit 1
fi
else
echo "error"
exit 1
fi
fi
fi
fi
else
echo "forked"
exit 1
fi
else
echo "unverified ($http_status_code2)"
exit 1
fi
fi
echo "unverified ($curl_code)"
exit 0
elif [ $time_difference -lt 60 ]; then
echo "online"
exit 0
else
echo "behind"
exit 1
fi
elif [[ $http_status_code -eq 404 ]]; then
echo "offline"
exit 1
elif [[ $http_status_code -eq 401 ]]; then
echo "unauthorized"
exit 1
elif [[ $http_status_code -eq 500 ]]; then
echo "error"
exit 1
else
echo "Unexpected HTTP status code: $http_status_code"
exit 1
fi
else
echo "timeout"
exit 1
fi