monitoring scripts: protocol dispatch via registry slug + mantle/metis chainid fixes
- sync-status.sh: resolve protocol family from the compose x-upstreams chain label via the registry (reference-rpc-endpoint.sh --protocol) instead of path-substring guessing; legacy path detection kept as fallback for composes without a resolved label. Unknown families report 'unsupported protocol: X' honestly instead of a bogus eth_chainId error. Aztec reference lookup falls back to slug urls when rollup_version is not in the registry. - reference-rpc-endpoint.sh: new --chain <slug> (urls by registry key, works for idless non-EVM entries) and --protocol <slug> modes; existing chainid and --rollup-version lookups unchanged. - mantle-sepolia: chainid 5001 -> 5003 (verified live: 0x138b), label and --networkid now correct - metis-sepolia: label resolves via registry override (drpc chains.yaml carries wrong id 59901; live chain is 59902, verified via official RPC) Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
This commit is contained in:
@@ -190,7 +190,7 @@ x-upstreams:
|
|||||||
frameSize: 20Mb
|
frameSize: 20Mb
|
||||||
msgSize: 50Mb
|
msgSize: 50Mb
|
||||||
url: $${WS_URL}
|
url: $${WS_URL}
|
||||||
chain:
|
chain: metis-sepolia
|
||||||
method-groups:
|
method-groups:
|
||||||
enabled:
|
enabled:
|
||||||
- debug
|
- debug
|
||||||
|
|||||||
@@ -64,7 +64,7 @@ services:
|
|||||||
- --metrics
|
- --metrics
|
||||||
- --metrics.addr=0.0.0.0
|
- --metrics.addr=0.0.0.0
|
||||||
- --metrics.port=6060
|
- --metrics.port=6060
|
||||||
- --networkid=5001
|
- --networkid=5003
|
||||||
- --nodiscover
|
- --nodiscover
|
||||||
- --rpc.gascap=600000000
|
- --rpc.gascap=600000000
|
||||||
- --rpc.txfeecap=0
|
- --rpc.txfeecap=0
|
||||||
@@ -173,7 +173,7 @@ x-upstreams:
|
|||||||
frameSize: 20Mb
|
frameSize: 20Mb
|
||||||
msgSize: 50Mb
|
msgSize: 50Mb
|
||||||
url: $${WS_URL}
|
url: $${WS_URL}
|
||||||
chain:
|
chain: mantle-sepolia
|
||||||
method-groups:
|
method-groups:
|
||||||
enabled:
|
enabled:
|
||||||
- debug
|
- debug
|
||||||
|
|||||||
@@ -64,7 +64,7 @@ services:
|
|||||||
- --metrics
|
- --metrics
|
||||||
- --metrics.addr=0.0.0.0
|
- --metrics.addr=0.0.0.0
|
||||||
- --metrics.port=6060
|
- --metrics.port=6060
|
||||||
- --networkid=5001
|
- --networkid=5003
|
||||||
- --nodiscover
|
- --nodiscover
|
||||||
- --rpc.gascap=600000000
|
- --rpc.gascap=600000000
|
||||||
- --rpc.txfeecap=0
|
- --rpc.txfeecap=0
|
||||||
@@ -173,7 +173,7 @@ x-upstreams:
|
|||||||
frameSize: 20Mb
|
frameSize: 20Mb
|
||||||
msgSize: 50Mb
|
msgSize: 50Mb
|
||||||
url: $${WS_URL}
|
url: $${WS_URL}
|
||||||
chain:
|
chain: mantle-sepolia
|
||||||
method-groups:
|
method-groups:
|
||||||
enabled:
|
enabled:
|
||||||
- debug
|
- debug
|
||||||
|
|||||||
@@ -472,7 +472,7 @@
|
|||||||
},
|
},
|
||||||
"metis-sepolia": {
|
"metis-sepolia": {
|
||||||
"protocol": "eth",
|
"protocol": "eth",
|
||||||
"id": 59901,
|
"id": 59902,
|
||||||
"urls": [
|
"urls": [
|
||||||
"https://metis-sepolia.drpc.org"
|
"https://metis-sepolia.drpc.org"
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -13,6 +13,37 @@ if [ ! -f "$json_file" ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Look up urls by registry key (drpc slug from the compose x-upstreams chain label).
|
||||||
|
# Works for non-EVM chains that have no chainid in the registry.
|
||||||
|
if [ "$1" = "--chain" ]; then
|
||||||
|
if [ $# -lt 2 ]; then
|
||||||
|
echo "Usage: $0 --chain <slug>"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
urls=$(jq -r --arg k "$2" '.[$k].urls // [] | .[]' "$json_file" 2>/dev/null | tr '\n' ' ')
|
||||||
|
if [ -z "${urls// /}" ]; then
|
||||||
|
echo "Chain not found: $2"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "$urls"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Look up the protocol family for a registry key (eth, starknet, aztec, bitcoin, solana, ...)
|
||||||
|
if [ "$1" = "--protocol" ]; then
|
||||||
|
if [ $# -lt 2 ]; then
|
||||||
|
echo "Usage: $0 --protocol <slug>"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
protocol=$(jq -r --arg k "$2" 'if has($k) then (.[$k].protocol // "eth") else empty end' "$json_file" 2>/dev/null)
|
||||||
|
if [ -z "$protocol" ]; then
|
||||||
|
echo "Chain not found: $2"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "$protocol"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
# Look up by rollup_version (for Aztec: version from result.header.globalVariables.version)
|
# Look up by rollup_version (for Aztec: version from result.header.globalVariables.version)
|
||||||
if [ "$1" = "--rollup-version" ]; then
|
if [ "$1" = "--rollup-version" ]; then
|
||||||
if [ $# -lt 2 ]; then
|
if [ $# -lt 2 ]; then
|
||||||
|
|||||||
@@ -34,17 +34,41 @@ for path in $pathlist; do
|
|||||||
if $include; then
|
if $include; then
|
||||||
RPC_URL="$PROTO://$DOMAIN/$path"
|
RPC_URL="$PROTO://$DOMAIN/$path"
|
||||||
|
|
||||||
# Detect Starknet vs Ethereum vs Aztec based on path
|
# Resolve the protocol family from the compose x-upstreams chain label
|
||||||
if echo "$path" | grep -qi "starknet"; then
|
# (drpc slug) via the registry. Falls back to legacy path-substring
|
||||||
is_starknet=true
|
# detection for composes without a resolved chain label.
|
||||||
is_aztec=false
|
chain_slug=$(grep -oP '^\s*chain:\s*\K\S+' "$BASEPATH/$1.yml" 2>/dev/null | head -1)
|
||||||
elif echo "$path" | grep -qi "aztec"; then
|
protocol=""
|
||||||
is_starknet=false
|
if [ -n "$chain_slug" ]; then
|
||||||
is_aztec=true
|
protocol=$($BASEPATH/reference-rpc-endpoint.sh --protocol "$chain_slug" 2>/dev/null) || protocol=""
|
||||||
else
|
|
||||||
is_starknet=false
|
|
||||||
is_aztec=false
|
|
||||||
fi
|
fi
|
||||||
|
if [ -z "$protocol" ]; then
|
||||||
|
# Legacy detection by path substring
|
||||||
|
if echo "$path" | grep -qi "starknet"; then
|
||||||
|
protocol="starknet"
|
||||||
|
elif echo "$path" | grep -qi "aztec"; then
|
||||||
|
protocol="aztec"
|
||||||
|
else
|
||||||
|
protocol="eth"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$protocol" in
|
||||||
|
eth|starknet|aztec)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
# Protocol family known from the registry but no probe support
|
||||||
|
# in check-health.sh yet - honest output instead of a bogus
|
||||||
|
# eth_chainId error. Add a handler when we deploy such a node.
|
||||||
|
echo "unsupported protocol: $protocol ($chain_slug)"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
is_starknet=false
|
||||||
|
is_aztec=false
|
||||||
|
[ "$protocol" = "starknet" ] && is_starknet=true
|
||||||
|
[ "$protocol" = "aztec" ] && is_aztec=true
|
||||||
|
|
||||||
ref=''
|
ref=''
|
||||||
if [ -n "$2" ]; then
|
if [ -n "$2" ]; then
|
||||||
@@ -67,8 +91,14 @@ for path in $pathlist; do
|
|||||||
version_hex="${version_hex#0x}"
|
version_hex="${version_hex#0x}"
|
||||||
version_hex="${version_hex: -8}"
|
version_hex="${version_hex: -8}"
|
||||||
version_decimal=$((16#$version_hex))
|
version_decimal=$((16#$version_hex))
|
||||||
ref=$($BASEPATH/reference-rpc-endpoint.sh --rollup-version "$version_decimal")
|
ref=$($BASEPATH/reference-rpc-endpoint.sh --rollup-version "$version_decimal" 2>/dev/null)
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ] || [ -z "$ref" ]; then
|
||||||
|
# Fallback: reference urls by chain slug from the compose label
|
||||||
|
if [ -n "$chain_slug" ]; then
|
||||||
|
ref=$($BASEPATH/reference-rpc-endpoint.sh --chain "$chain_slug" 2>/dev/null) || ref=""
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [ -z "$ref" ]; then
|
||||||
echo "error: no reference endpoint for Aztec rollup_version $version_decimal"
|
echo "error: no reference endpoint for Aztec rollup_version $version_decimal"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|||||||
Reference in New Issue
Block a user