From 446ee9e4efda190521a35fafbca3006d71f35530 Mon Sep 17 00:00:00 2001 From: johba Date: Sun, 5 Apr 2026 17:17:04 +0000 Subject: [PATCH] fix: pass LM_ADDRESS and POOL_ADDRESS to ponder env (#4) bootstrap now discovers the Uniswap pool address from the factory contract and writes both LM_ADDRESS and POOL_ADDRESS to ponder .env.local. Without these, ponder watches hardcoded default addresses that dont exist on the local Anvil fork, causing all protocol stats except holder count to stay zero. --- containers/bootstrap.sh | 2 ++ scripts/bootstrap-common.sh | 12 ++++++++++++ 2 files changed, 14 insertions(+) diff --git a/containers/bootstrap.sh b/containers/bootstrap.sh index 1952593..c2277f8 100755 --- a/containers/bootstrap.sh +++ b/containers/bootstrap.sh @@ -104,6 +104,8 @@ write_ponder_env() { PONDER_NETWORK=$NETWORK_NAME KRAIKEN_ADDRESS=$KRAIKEN STAKE_ADDRESS=$STAKE +LM_ADDRESS=$LIQUIDITY_MANAGER +POOL_ADDRESS=$POOL_ADDRESS START_BLOCK=$DEPLOY_BLOCK PONDER_RPC_URL_${NETWORK_NAME}=$ANVIL_RPC DATABASE_URL=postgresql://ponder:ponder_local@postgres:5432/ponder_local diff --git a/scripts/bootstrap-common.sh b/scripts/bootstrap-common.sh index 2c6182b..dc8ab54 100755 --- a/scripts/bootstrap-common.sh +++ b/scripts/bootstrap-common.sh @@ -102,6 +102,18 @@ extract_addresses() { bootstrap_log "LiquidityManager address missing" exit 1 fi + + # Discover Uniswap pool address from factory + detect_swap_router + local factory + factory=$(cast call --rpc-url "$ANVIL_RPC" "$SWAP_ROUTER" "factory()(address)" 2>/dev/null) || factory="" + if [[ -n "$factory" && "$factory" != "0x" ]]; then + POOL_ADDRESS=$(cast call --rpc-url "$ANVIL_RPC" "$factory" "getPool(address,address,uint24)(address)" "$WETH" "$KRAIKEN" 10000 2>/dev/null) || POOL_ADDRESS="" + fi + if [[ -z "$POOL_ADDRESS" || "$POOL_ADDRESS" == "0x0000000000000000000000000000000000000000" ]]; then + bootstrap_log "Warning: could not discover pool address" + POOL_ADDRESS="" + fi } write_contracts_env() { -- 2.49.1