@subsquid/ponder 0.15.17-sqd.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +3386 -0
- package/README.md +186 -0
- package/dist/esm/bin/commands/codegen.js +46 -0
- package/dist/esm/bin/commands/codegen.js.map +1 -0
- package/dist/esm/bin/commands/createViews.js +196 -0
- package/dist/esm/bin/commands/createViews.js.map +1 -0
- package/dist/esm/bin/commands/dev.js +430 -0
- package/dist/esm/bin/commands/dev.js.map +1 -0
- package/dist/esm/bin/commands/list.js +148 -0
- package/dist/esm/bin/commands/list.js.map +1 -0
- package/dist/esm/bin/commands/prune.js +224 -0
- package/dist/esm/bin/commands/prune.js.map +1 -0
- package/dist/esm/bin/commands/serve.js +198 -0
- package/dist/esm/bin/commands/serve.js.map +1 -0
- package/dist/esm/bin/commands/start.js +253 -0
- package/dist/esm/bin/commands/start.js.map +1 -0
- package/dist/esm/bin/isolatedController.js +200 -0
- package/dist/esm/bin/isolatedController.js.map +1 -0
- package/dist/esm/bin/isolatedWorker.js +146 -0
- package/dist/esm/bin/isolatedWorker.js.map +1 -0
- package/dist/esm/bin/ponder.js +137 -0
- package/dist/esm/bin/ponder.js.map +1 -0
- package/dist/esm/bin/utils/codegen.js +25 -0
- package/dist/esm/bin/utils/codegen.js.map +1 -0
- package/dist/esm/bin/utils/exit.js +100 -0
- package/dist/esm/bin/utils/exit.js.map +1 -0
- package/dist/esm/build/config.js +743 -0
- package/dist/esm/build/config.js.map +1 -0
- package/dist/esm/build/factory.js +76 -0
- package/dist/esm/build/factory.js.map +1 -0
- package/dist/esm/build/index.js +538 -0
- package/dist/esm/build/index.js.map +1 -0
- package/dist/esm/build/plugin.js +53 -0
- package/dist/esm/build/plugin.js.map +1 -0
- package/dist/esm/build/pre.js +76 -0
- package/dist/esm/build/pre.js.map +1 -0
- package/dist/esm/build/schema.js +164 -0
- package/dist/esm/build/schema.js.map +1 -0
- package/dist/esm/build/stacktrace.js +137 -0
- package/dist/esm/build/stacktrace.js.map +1 -0
- package/dist/esm/client/index.js +441 -0
- package/dist/esm/client/index.js.map +1 -0
- package/dist/esm/config/address.js +2 -0
- package/dist/esm/config/address.js.map +1 -0
- package/dist/esm/config/eventFilter.js +2 -0
- package/dist/esm/config/eventFilter.js.map +1 -0
- package/dist/esm/config/index.js +2 -0
- package/dist/esm/config/index.js.map +1 -0
- package/dist/esm/config/utilityTypes.js +2 -0
- package/dist/esm/config/utilityTypes.js.map +1 -0
- package/dist/esm/database/actions.js +445 -0
- package/dist/esm/database/actions.js.map +1 -0
- package/dist/esm/database/index.js +597 -0
- package/dist/esm/database/index.js.map +1 -0
- package/dist/esm/database/queryBuilder.js +310 -0
- package/dist/esm/database/queryBuilder.js.map +1 -0
- package/dist/esm/drizzle/bigint.js +38 -0
- package/dist/esm/drizzle/bigint.js.map +1 -0
- package/dist/esm/drizzle/bytes.js +47 -0
- package/dist/esm/drizzle/bytes.js.map +1 -0
- package/dist/esm/drizzle/hex.js +40 -0
- package/dist/esm/drizzle/hex.js.map +1 -0
- package/dist/esm/drizzle/index.js +40 -0
- package/dist/esm/drizzle/index.js.map +1 -0
- package/dist/esm/drizzle/json.js +119 -0
- package/dist/esm/drizzle/json.js.map +1 -0
- package/dist/esm/drizzle/kit/index.js +928 -0
- package/dist/esm/drizzle/kit/index.js.map +1 -0
- package/dist/esm/drizzle/onchain.js +158 -0
- package/dist/esm/drizzle/onchain.js.map +1 -0
- package/dist/esm/drizzle/text.js +61 -0
- package/dist/esm/drizzle/text.js.map +1 -0
- package/dist/esm/graphql/graphiql.html.js +59 -0
- package/dist/esm/graphql/graphiql.html.js.map +1 -0
- package/dist/esm/graphql/index.js +916 -0
- package/dist/esm/graphql/index.js.map +1 -0
- package/dist/esm/graphql/json.js +42 -0
- package/dist/esm/graphql/json.js.map +1 -0
- package/dist/esm/graphql/middleware.js +78 -0
- package/dist/esm/graphql/middleware.js.map +1 -0
- package/dist/esm/index.js +9 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/indexing/addStackTrace.js +54 -0
- package/dist/esm/indexing/addStackTrace.js.map +1 -0
- package/dist/esm/indexing/client.js +675 -0
- package/dist/esm/indexing/client.js.map +1 -0
- package/dist/esm/indexing/index.js +652 -0
- package/dist/esm/indexing/index.js.map +1 -0
- package/dist/esm/indexing/profile.js +584 -0
- package/dist/esm/indexing/profile.js.map +1 -0
- package/dist/esm/indexing-store/cache.js +665 -0
- package/dist/esm/indexing-store/cache.js.map +1 -0
- package/dist/esm/indexing-store/historical.js +427 -0
- package/dist/esm/indexing-store/historical.js.map +1 -0
- package/dist/esm/indexing-store/index.js +35 -0
- package/dist/esm/indexing-store/index.js.map +1 -0
- package/dist/esm/indexing-store/profile.js +428 -0
- package/dist/esm/indexing-store/profile.js.map +1 -0
- package/dist/esm/indexing-store/realtime.js +305 -0
- package/dist/esm/indexing-store/realtime.js.map +1 -0
- package/dist/esm/indexing-store/utils.js +111 -0
- package/dist/esm/indexing-store/utils.js.map +1 -0
- package/dist/esm/internal/common.js +2 -0
- package/dist/esm/internal/common.js.map +1 -0
- package/dist/esm/internal/errors.js +300 -0
- package/dist/esm/internal/errors.js.map +1 -0
- package/dist/esm/internal/logger.js +178 -0
- package/dist/esm/internal/logger.js.map +1 -0
- package/dist/esm/internal/metrics.js +1046 -0
- package/dist/esm/internal/metrics.js.map +1 -0
- package/dist/esm/internal/options.js +73 -0
- package/dist/esm/internal/options.js.map +1 -0
- package/dist/esm/internal/shutdown.js +24 -0
- package/dist/esm/internal/shutdown.js.map +1 -0
- package/dist/esm/internal/telemetry.js +200 -0
- package/dist/esm/internal/telemetry.js.map +1 -0
- package/dist/esm/internal/types.js +2 -0
- package/dist/esm/internal/types.js.map +1 -0
- package/dist/esm/rpc/actions.js +988 -0
- package/dist/esm/rpc/actions.js.map +1 -0
- package/dist/esm/rpc/http.js +130 -0
- package/dist/esm/rpc/http.js.map +1 -0
- package/dist/esm/rpc/index.js +749 -0
- package/dist/esm/rpc/index.js.map +1 -0
- package/dist/esm/runtime/events.js +664 -0
- package/dist/esm/runtime/events.js.map +1 -0
- package/dist/esm/runtime/filter.js +443 -0
- package/dist/esm/runtime/filter.js.map +1 -0
- package/dist/esm/runtime/fragments.js +478 -0
- package/dist/esm/runtime/fragments.js.map +1 -0
- package/dist/esm/runtime/historical.js +985 -0
- package/dist/esm/runtime/historical.js.map +1 -0
- package/dist/esm/runtime/index.js +325 -0
- package/dist/esm/runtime/index.js.map +1 -0
- package/dist/esm/runtime/init.js +12 -0
- package/dist/esm/runtime/init.js.map +1 -0
- package/dist/esm/runtime/isolated.js +463 -0
- package/dist/esm/runtime/isolated.js.map +1 -0
- package/dist/esm/runtime/multichain.js +509 -0
- package/dist/esm/runtime/multichain.js.map +1 -0
- package/dist/esm/runtime/omnichain.js +544 -0
- package/dist/esm/runtime/omnichain.js.map +1 -0
- package/dist/esm/runtime/realtime.js +733 -0
- package/dist/esm/runtime/realtime.js.map +1 -0
- package/dist/esm/server/error.js +56 -0
- package/dist/esm/server/error.js.map +1 -0
- package/dist/esm/server/index.js +121 -0
- package/dist/esm/server/index.js.map +1 -0
- package/dist/esm/sync-historical/index.js +701 -0
- package/dist/esm/sync-historical/index.js.map +1 -0
- package/dist/esm/sync-historical/portal-realtime-wire.js +302 -0
- package/dist/esm/sync-historical/portal-realtime-wire.js.map +1 -0
- package/dist/esm/sync-historical/portal-realtime.js +154 -0
- package/dist/esm/sync-historical/portal-realtime.js.map +1 -0
- package/dist/esm/sync-historical/portal-transform.js +113 -0
- package/dist/esm/sync-historical/portal-transform.js.map +1 -0
- package/dist/esm/sync-historical/portal.js +949 -0
- package/dist/esm/sync-historical/portal.js.map +1 -0
- package/dist/esm/sync-historical/realtime.js +127 -0
- package/dist/esm/sync-historical/realtime.js.map +1 -0
- package/dist/esm/sync-realtime/bloom.js +76 -0
- package/dist/esm/sync-realtime/bloom.js.map +1 -0
- package/dist/esm/sync-realtime/index.js +917 -0
- package/dist/esm/sync-realtime/index.js.map +1 -0
- package/dist/esm/sync-store/encode.js +105 -0
- package/dist/esm/sync-store/encode.js.map +1 -0
- package/dist/esm/sync-store/index.js +885 -0
- package/dist/esm/sync-store/index.js.map +1 -0
- package/dist/esm/sync-store/migrations.js +1595 -0
- package/dist/esm/sync-store/migrations.js.map +1 -0
- package/dist/esm/sync-store/schema.js +181 -0
- package/dist/esm/sync-store/schema.js.map +1 -0
- package/dist/esm/types/db.js +2 -0
- package/dist/esm/types/db.js.map +1 -0
- package/dist/esm/types/eth.js +2 -0
- package/dist/esm/types/eth.js.map +1 -0
- package/dist/esm/types/utils.js +2 -0
- package/dist/esm/types/utils.js.map +1 -0
- package/dist/esm/types/virtual.js +2 -0
- package/dist/esm/types/virtual.js.map +1 -0
- package/dist/esm/ui/app.js +157 -0
- package/dist/esm/ui/app.js.map +1 -0
- package/dist/esm/ui/index.js +29 -0
- package/dist/esm/ui/index.js.map +1 -0
- package/dist/esm/ui/patch.js +103 -0
- package/dist/esm/ui/patch.js.map +1 -0
- package/dist/esm/utils/abi.js +55 -0
- package/dist/esm/utils/abi.js.map +1 -0
- package/dist/esm/utils/bigint.js +37 -0
- package/dist/esm/utils/bigint.js.map +1 -0
- package/dist/esm/utils/chains.js +21 -0
- package/dist/esm/utils/chains.js.map +1 -0
- package/dist/esm/utils/checkpoint.js +139 -0
- package/dist/esm/utils/checkpoint.js.map +1 -0
- package/dist/esm/utils/chunk.js +8 -0
- package/dist/esm/utils/chunk.js.map +1 -0
- package/dist/esm/utils/copy.js +129 -0
- package/dist/esm/utils/copy.js.map +1 -0
- package/dist/esm/utils/date.js +27 -0
- package/dist/esm/utils/date.js.map +1 -0
- package/dist/esm/utils/debug.js +2 -0
- package/dist/esm/utils/debug.js.map +1 -0
- package/dist/esm/utils/decodeAbiParameters.js +290 -0
- package/dist/esm/utils/decodeAbiParameters.js.map +1 -0
- package/dist/esm/utils/decodeEventLog.js +75 -0
- package/dist/esm/utils/decodeEventLog.js.map +1 -0
- package/dist/esm/utils/dedupe.js +29 -0
- package/dist/esm/utils/dedupe.js.map +1 -0
- package/dist/esm/utils/duplicates.js +19 -0
- package/dist/esm/utils/duplicates.js.map +1 -0
- package/dist/esm/utils/estimate.js +6 -0
- package/dist/esm/utils/estimate.js.map +1 -0
- package/dist/esm/utils/finality.js +38 -0
- package/dist/esm/utils/finality.js.map +1 -0
- package/dist/esm/utils/format.js +20 -0
- package/dist/esm/utils/format.js.map +1 -0
- package/dist/esm/utils/generators.js +121 -0
- package/dist/esm/utils/generators.js.map +1 -0
- package/dist/esm/utils/hash.js +11 -0
- package/dist/esm/utils/hash.js.map +1 -0
- package/dist/esm/utils/interval.js +171 -0
- package/dist/esm/utils/interval.js.map +1 -0
- package/dist/esm/utils/lowercase.js +7 -0
- package/dist/esm/utils/lowercase.js.map +1 -0
- package/dist/esm/utils/mutex.js +26 -0
- package/dist/esm/utils/mutex.js.map +1 -0
- package/dist/esm/utils/never.js +4 -0
- package/dist/esm/utils/never.js.map +1 -0
- package/dist/esm/utils/offset.js +101 -0
- package/dist/esm/utils/offset.js.map +1 -0
- package/dist/esm/utils/order.js +18 -0
- package/dist/esm/utils/order.js.map +1 -0
- package/dist/esm/utils/partition.js +46 -0
- package/dist/esm/utils/partition.js.map +1 -0
- package/dist/esm/utils/pg.js +149 -0
- package/dist/esm/utils/pg.js.map +1 -0
- package/dist/esm/utils/pglite.js +80 -0
- package/dist/esm/utils/pglite.js.map +1 -0
- package/dist/esm/utils/port.js +30 -0
- package/dist/esm/utils/port.js.map +1 -0
- package/dist/esm/utils/print.js +23 -0
- package/dist/esm/utils/print.js.map +1 -0
- package/dist/esm/utils/promiseAllSettledWithThrow.js +19 -0
- package/dist/esm/utils/promiseAllSettledWithThrow.js.map +1 -0
- package/dist/esm/utils/promiseWithResolvers.js +13 -0
- package/dist/esm/utils/promiseWithResolvers.js.map +1 -0
- package/dist/esm/utils/queue.js +150 -0
- package/dist/esm/utils/queue.js.map +1 -0
- package/dist/esm/utils/range.js +8 -0
- package/dist/esm/utils/range.js.map +1 -0
- package/dist/esm/utils/result.js +10 -0
- package/dist/esm/utils/result.js.map +1 -0
- package/dist/esm/utils/sql-parse.js +1326 -0
- package/dist/esm/utils/sql-parse.js.map +1 -0
- package/dist/esm/utils/timer.js +9 -0
- package/dist/esm/utils/timer.js.map +1 -0
- package/dist/esm/utils/truncate.js +15 -0
- package/dist/esm/utils/truncate.js.map +1 -0
- package/dist/esm/utils/wait.js +10 -0
- package/dist/esm/utils/wait.js.map +1 -0
- package/dist/esm/utils/zipper.js +67 -0
- package/dist/esm/utils/zipper.js.map +1 -0
- package/dist/types/bin/commands/codegen.d.ts +5 -0
- package/dist/types/bin/commands/codegen.d.ts.map +1 -0
- package/dist/types/bin/commands/createViews.d.ts +8 -0
- package/dist/types/bin/commands/createViews.d.ts.map +1 -0
- package/dist/types/bin/commands/dev.d.ts +5 -0
- package/dist/types/bin/commands/dev.d.ts.map +1 -0
- package/dist/types/bin/commands/list.d.ts +5 -0
- package/dist/types/bin/commands/list.d.ts.map +1 -0
- package/dist/types/bin/commands/prune.d.ts +5 -0
- package/dist/types/bin/commands/prune.d.ts.map +1 -0
- package/dist/types/bin/commands/serve.d.ts +5 -0
- package/dist/types/bin/commands/serve.d.ts.map +1 -0
- package/dist/types/bin/commands/start.d.ts +19 -0
- package/dist/types/bin/commands/start.d.ts.map +1 -0
- package/dist/types/bin/isolatedController.d.ts +13 -0
- package/dist/types/bin/isolatedController.d.ts.map +1 -0
- package/dist/types/bin/isolatedWorker.d.ts +9 -0
- package/dist/types/bin/isolatedWorker.d.ts.map +1 -0
- package/dist/types/bin/ponder.d.ts +37 -0
- package/dist/types/bin/ponder.d.ts.map +1 -0
- package/dist/types/bin/utils/codegen.d.ts +6 -0
- package/dist/types/bin/utils/codegen.d.ts.map +1 -0
- package/dist/types/bin/utils/exit.d.ts +10 -0
- package/dist/types/bin/utils/exit.d.ts.map +1 -0
- package/dist/types/build/config.d.ts +97 -0
- package/dist/types/build/config.d.ts.map +1 -0
- package/dist/types/build/factory.d.ts +13 -0
- package/dist/types/build/factory.d.ts.map +1 -0
- package/dist/types/build/index.d.ts +84 -0
- package/dist/types/build/index.d.ts.map +1 -0
- package/dist/types/build/plugin.d.ts +4 -0
- package/dist/types/build/plugin.d.ts.map +1 -0
- package/dist/types/build/pre.d.ts +26 -0
- package/dist/types/build/pre.d.ts.map +1 -0
- package/dist/types/build/schema.d.ts +20 -0
- package/dist/types/build/schema.d.ts.map +1 -0
- package/dist/types/build/stacktrace.d.ts +13 -0
- package/dist/types/build/stacktrace.d.ts.map +1 -0
- package/dist/types/client/index.d.ts +27 -0
- package/dist/types/client/index.d.ts.map +1 -0
- package/dist/types/config/address.d.ts +24 -0
- package/dist/types/config/address.d.ts.map +1 -0
- package/dist/types/config/eventFilter.d.ts +18 -0
- package/dist/types/config/eventFilter.d.ts.map +1 -0
- package/dist/types/config/index.d.ts +149 -0
- package/dist/types/config/index.d.ts.map +1 -0
- package/dist/types/config/utilityTypes.d.ts +43 -0
- package/dist/types/config/utilityTypes.d.ts.map +1 -0
- package/dist/types/database/actions.d.ts +99 -0
- package/dist/types/database/actions.d.ts.map +1 -0
- package/dist/types/database/index.d.ts +481 -0
- package/dist/types/database/index.d.ts.map +1 -0
- package/dist/types/database/queryBuilder.d.ts +65 -0
- package/dist/types/database/queryBuilder.d.ts.map +1 -0
- package/dist/types/drizzle/bigint.d.ts +25 -0
- package/dist/types/drizzle/bigint.d.ts.map +1 -0
- package/dist/types/drizzle/bytes.d.ts +31 -0
- package/dist/types/drizzle/bytes.d.ts.map +1 -0
- package/dist/types/drizzle/hex.d.ts +25 -0
- package/dist/types/drizzle/hex.d.ts.map +1 -0
- package/dist/types/drizzle/index.d.ts +10 -0
- package/dist/types/drizzle/index.d.ts.map +1 -0
- package/dist/types/drizzle/json.d.ts +51 -0
- package/dist/types/drizzle/json.d.ts.map +1 -0
- package/dist/types/drizzle/kit/index.d.ts +189 -0
- package/dist/types/drizzle/kit/index.d.ts.map +1 -0
- package/dist/types/drizzle/onchain.d.ts +287 -0
- package/dist/types/drizzle/onchain.d.ts.map +1 -0
- package/dist/types/drizzle/text.d.ts +29 -0
- package/dist/types/drizzle/text.d.ts.map +1 -0
- package/dist/types/graphql/graphiql.html.d.ts +2 -0
- package/dist/types/graphql/graphiql.html.d.ts.map +1 -0
- package/dist/types/graphql/index.d.ts +12 -0
- package/dist/types/graphql/index.d.ts.map +1 -0
- package/dist/types/graphql/json.d.ts +3 -0
- package/dist/types/graphql/json.d.ts.map +1 -0
- package/dist/types/graphql/middleware.d.ts +29 -0
- package/dist/types/graphql/middleware.d.ts.map +1 -0
- package/dist/types/index.d.ts +23 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/indexing/addStackTrace.d.ts +3 -0
- package/dist/types/indexing/addStackTrace.d.ts.map +1 -0
- package/dist/types/indexing/client.d.ts +154 -0
- package/dist/types/indexing/client.d.ts.map +1 -0
- package/dist/types/indexing/index.d.ts +75 -0
- package/dist/types/indexing/index.d.ts.map +1 -0
- package/dist/types/indexing/profile.d.ts +16 -0
- package/dist/types/indexing/profile.d.ts.map +1 -0
- package/dist/types/indexing-store/cache.d.ts +115 -0
- package/dist/types/indexing-store/cache.d.ts.map +1 -0
- package/dist/types/indexing-store/historical.d.ts +12 -0
- package/dist/types/indexing-store/historical.d.ts.map +1 -0
- package/dist/types/indexing-store/index.d.ts +14 -0
- package/dist/types/indexing-store/index.d.ts.map +1 -0
- package/dist/types/indexing-store/profile.d.ts +7 -0
- package/dist/types/indexing-store/profile.d.ts.map +1 -0
- package/dist/types/indexing-store/realtime.d.ts +10 -0
- package/dist/types/indexing-store/realtime.d.ts.map +1 -0
- package/dist/types/indexing-store/utils.d.ts +19 -0
- package/dist/types/indexing-store/utils.d.ts.map +1 -0
- package/dist/types/internal/common.d.ts +15 -0
- package/dist/types/internal/common.d.ts.map +1 -0
- package/dist/types/internal/errors.d.ts +101 -0
- package/dist/types/internal/errors.d.ts.map +1 -0
- package/dist/types/internal/logger.d.ts +37 -0
- package/dist/types/internal/logger.d.ts.map +1 -0
- package/dist/types/internal/metrics.d.ts +120 -0
- package/dist/types/internal/metrics.d.ts.map +1 -0
- package/dist/types/internal/options.d.ts +62 -0
- package/dist/types/internal/options.d.ts.map +1 -0
- package/dist/types/internal/shutdown.d.ts +8 -0
- package/dist/types/internal/shutdown.d.ts.map +1 -0
- package/dist/types/internal/telemetry.d.ts +43 -0
- package/dist/types/internal/telemetry.d.ts.map +1 -0
- package/dist/types/internal/types.d.ts +435 -0
- package/dist/types/internal/types.d.ts.map +1 -0
- package/dist/types/rpc/actions.d.ts +360 -0
- package/dist/types/rpc/actions.d.ts.map +1 -0
- package/dist/types/rpc/http.d.ts +17 -0
- package/dist/types/rpc/http.d.ts.map +1 -0
- package/dist/types/rpc/index.d.ts +43 -0
- package/dist/types/rpc/index.d.ts.map +1 -0
- package/dist/types/runtime/events.d.ts +40 -0
- package/dist/types/runtime/events.d.ts.map +1 -0
- package/dist/types/runtime/filter.d.ts +87 -0
- package/dist/types/runtime/filter.d.ts.map +1 -0
- package/dist/types/runtime/fragments.d.ts +30 -0
- package/dist/types/runtime/fragments.d.ts.map +1 -0
- package/dist/types/runtime/historical.d.ts +123 -0
- package/dist/types/runtime/historical.d.ts.map +1 -0
- package/dist/types/runtime/index.d.ts +89 -0
- package/dist/types/runtime/index.d.ts.map +1 -0
- package/dist/types/runtime/init.d.ts +28 -0
- package/dist/types/runtime/init.d.ts.map +1 -0
- package/dist/types/runtime/isolated.d.ts +14 -0
- package/dist/types/runtime/isolated.d.ts.map +1 -0
- package/dist/types/runtime/multichain.d.ts +13 -0
- package/dist/types/runtime/multichain.d.ts.map +1 -0
- package/dist/types/runtime/omnichain.d.ts +23 -0
- package/dist/types/runtime/omnichain.d.ts.map +1 -0
- package/dist/types/runtime/realtime.d.ts +93 -0
- package/dist/types/runtime/realtime.d.ts.map +1 -0
- package/dist/types/server/error.d.ts +5 -0
- package/dist/types/server/error.d.ts.map +1 -0
- package/dist/types/server/index.d.ts +13 -0
- package/dist/types/server/index.d.ts.map +1 -0
- package/dist/types/sync-historical/index.d.ts +36 -0
- package/dist/types/sync-historical/index.d.ts.map +1 -0
- package/dist/types/sync-historical/portal-realtime-wire.d.ts +102 -0
- package/dist/types/sync-historical/portal-realtime-wire.d.ts.map +1 -0
- package/dist/types/sync-historical/portal-realtime.d.ts +95 -0
- package/dist/types/sync-historical/portal-realtime.d.ts.map +1 -0
- package/dist/types/sync-historical/portal-transform.d.ts +51 -0
- package/dist/types/sync-historical/portal-transform.d.ts.map +1 -0
- package/dist/types/sync-historical/portal.d.ts +34 -0
- package/dist/types/sync-historical/portal.d.ts.map +1 -0
- package/dist/types/sync-historical/realtime.d.ts +71 -0
- package/dist/types/sync-historical/realtime.d.ts.map +1 -0
- package/dist/types/sync-realtime/bloom.d.ts +18 -0
- package/dist/types/sync-realtime/bloom.d.ts.map +1 -0
- package/dist/types/sync-realtime/index.d.ts +47 -0
- package/dist/types/sync-realtime/index.d.ts.map +1 -0
- package/dist/types/sync-store/encode.d.ts +25 -0
- package/dist/types/sync-store/encode.d.ts.map +1 -0
- package/dist/types/sync-store/index.d.ts +135 -0
- package/dist/types/sync-store/index.d.ts.map +1 -0
- package/dist/types/sync-store/migrations.d.ts +8 -0
- package/dist/types/sync-store/migrations.d.ts.map +1 -0
- package/dist/types/sync-store/schema.d.ts +1828 -0
- package/dist/types/sync-store/schema.d.ts.map +1 -0
- package/dist/types/types/db.d.ts +213 -0
- package/dist/types/types/db.d.ts.map +1 -0
- package/dist/types/types/eth.d.ts +196 -0
- package/dist/types/types/eth.d.ts.map +1 -0
- package/dist/types/types/utils.d.ts +38 -0
- package/dist/types/types/utils.d.ts.map +1 -0
- package/dist/types/types/virtual.d.ts +99 -0
- package/dist/types/types/virtual.d.ts.map +1 -0
- package/dist/types/ui/app.d.ts +22 -0
- package/dist/types/ui/app.d.ts.map +1 -0
- package/dist/types/ui/index.d.ts +5 -0
- package/dist/types/ui/index.d.ts.map +1 -0
- package/dist/types/ui/patch.d.ts +7 -0
- package/dist/types/ui/patch.d.ts.map +1 -0
- package/dist/types/utils/abi.d.ts +23 -0
- package/dist/types/utils/abi.d.ts.map +1 -0
- package/dist/types/utils/bigint.d.ts +15 -0
- package/dist/types/utils/bigint.d.ts.map +1 -0
- package/dist/types/utils/chains.d.ts +42 -0
- package/dist/types/utils/chains.d.ts.map +1 -0
- package/dist/types/utils/checkpoint.d.ts +52 -0
- package/dist/types/utils/checkpoint.d.ts.map +1 -0
- package/dist/types/utils/chunk.d.ts +2 -0
- package/dist/types/utils/chunk.d.ts.map +1 -0
- package/dist/types/utils/copy.d.ts +16 -0
- package/dist/types/utils/copy.d.ts.map +1 -0
- package/dist/types/utils/date.d.ts +7 -0
- package/dist/types/utils/date.d.ts.map +1 -0
- package/dist/types/utils/debug.d.ts +105 -0
- package/dist/types/utils/debug.d.ts.map +1 -0
- package/dist/types/utils/decodeAbiParameters.d.ts +28 -0
- package/dist/types/utils/decodeAbiParameters.d.ts.map +1 -0
- package/dist/types/utils/decodeEventLog.d.ts +12 -0
- package/dist/types/utils/decodeEventLog.d.ts.map +1 -0
- package/dist/types/utils/dedupe.d.ts +20 -0
- package/dist/types/utils/dedupe.d.ts.map +1 -0
- package/dist/types/utils/duplicates.d.ts +7 -0
- package/dist/types/utils/duplicates.d.ts.map +1 -0
- package/dist/types/utils/estimate.d.ts +11 -0
- package/dist/types/utils/estimate.d.ts.map +1 -0
- package/dist/types/utils/finality.d.ts +12 -0
- package/dist/types/utils/finality.d.ts.map +1 -0
- package/dist/types/utils/format.d.ts +3 -0
- package/dist/types/utils/format.d.ts.map +1 -0
- package/dist/types/utils/generators.d.ts +42 -0
- package/dist/types/utils/generators.d.ts.map +1 -0
- package/dist/types/utils/hash.d.ts +11 -0
- package/dist/types/utils/hash.d.ts.map +1 -0
- package/dist/types/utils/interval.d.ts +53 -0
- package/dist/types/utils/interval.d.ts.map +1 -0
- package/dist/types/utils/lowercase.d.ts +5 -0
- package/dist/types/utils/lowercase.d.ts.map +1 -0
- package/dist/types/utils/mutex.d.ts +5 -0
- package/dist/types/utils/mutex.d.ts.map +1 -0
- package/dist/types/utils/never.d.ts +2 -0
- package/dist/types/utils/never.d.ts.map +1 -0
- package/dist/types/utils/offset.d.ts +8 -0
- package/dist/types/utils/offset.d.ts.map +1 -0
- package/dist/types/utils/order.d.ts +2 -0
- package/dist/types/utils/order.d.ts.map +1 -0
- package/dist/types/utils/partition.d.ts +22 -0
- package/dist/types/utils/partition.d.ts.map +1 -0
- package/dist/types/utils/pg.d.ts +8 -0
- package/dist/types/utils/pg.d.ts.map +1 -0
- package/dist/types/utils/pglite.d.ts +25 -0
- package/dist/types/utils/pglite.d.ts.map +1 -0
- package/dist/types/utils/port.d.ts +5 -0
- package/dist/types/utils/port.d.ts.map +1 -0
- package/dist/types/utils/print.d.ts +2 -0
- package/dist/types/utils/print.d.ts.map +1 -0
- package/dist/types/utils/promiseAllSettledWithThrow.d.ts +8 -0
- package/dist/types/utils/promiseAllSettledWithThrow.d.ts.map +1 -0
- package/dist/types/utils/promiseWithResolvers.d.ts +10 -0
- package/dist/types/utils/promiseWithResolvers.d.ts.map +1 -0
- package/dist/types/utils/queue.d.ts +33 -0
- package/dist/types/utils/queue.d.ts.map +1 -0
- package/dist/types/utils/range.d.ts +8 -0
- package/dist/types/utils/range.d.ts.map +1 -0
- package/dist/types/utils/result.d.ts +17 -0
- package/dist/types/utils/result.d.ts.map +1 -0
- package/dist/types/utils/sql-parse.d.ts +21 -0
- package/dist/types/utils/sql-parse.d.ts.map +1 -0
- package/dist/types/utils/timer.d.ts +6 -0
- package/dist/types/utils/timer.d.ts.map +1 -0
- package/dist/types/utils/truncate.d.ts +9 -0
- package/dist/types/utils/truncate.d.ts.map +1 -0
- package/dist/types/utils/wait.d.ts +6 -0
- package/dist/types/utils/wait.d.ts.map +1 -0
- package/dist/types/utils/zipper.d.ts +36 -0
- package/dist/types/utils/zipper.d.ts.map +1 -0
- package/package.json +116 -0
- package/src/bin/commands/codegen.ts +56 -0
- package/src/bin/commands/createViews.ts +311 -0
- package/src/bin/commands/dev.ts +490 -0
- package/src/bin/commands/list.ts +207 -0
- package/src/bin/commands/prune.ts +316 -0
- package/src/bin/commands/serve.ts +236 -0
- package/src/bin/commands/start.ts +319 -0
- package/src/bin/isolatedController.ts +300 -0
- package/src/bin/isolatedWorker.ts +192 -0
- package/src/bin/ponder.ts +200 -0
- package/src/bin/utils/codegen.ts +32 -0
- package/src/bin/utils/exit.ts +112 -0
- package/src/build/config.ts +1136 -0
- package/src/build/factory.ts +122 -0
- package/src/build/index.ts +747 -0
- package/src/build/plugin.ts +58 -0
- package/src/build/pre.ts +100 -0
- package/src/build/schema.ts +291 -0
- package/src/build/stacktrace.ts +137 -0
- package/src/client/index.ts +551 -0
- package/src/config/address.ts +32 -0
- package/src/config/eventFilter.ts +33 -0
- package/src/config/index.ts +245 -0
- package/src/config/utilityTypes.ts +152 -0
- package/src/database/actions.ts +870 -0
- package/src/database/index.ts +1018 -0
- package/src/database/queryBuilder.ts +534 -0
- package/src/drizzle/bigint.ts +57 -0
- package/src/drizzle/bytes.ts +68 -0
- package/src/drizzle/hex.ts +58 -0
- package/src/drizzle/index.ts +58 -0
- package/src/drizzle/json.ts +154 -0
- package/src/drizzle/kit/index.ts +1352 -0
- package/src/drizzle/onchain.ts +447 -0
- package/src/drizzle/text.ts +77 -0
- package/src/graphql/graphiql.html.ts +59 -0
- package/src/graphql/index.ts +1329 -0
- package/src/graphql/json.ts +62 -0
- package/src/graphql/middleware.ts +111 -0
- package/src/index.ts +139 -0
- package/src/indexing/addStackTrace.ts +69 -0
- package/src/indexing/client.ts +1184 -0
- package/src/indexing/index.ts +961 -0
- package/src/indexing/profile.ts +771 -0
- package/src/indexing-store/cache.ts +1056 -0
- package/src/indexing-store/historical.ts +555 -0
- package/src/indexing-store/index.ts +73 -0
- package/src/indexing-store/profile.ts +557 -0
- package/src/indexing-store/realtime.ts +412 -0
- package/src/indexing-store/utils.ts +162 -0
- package/src/internal/common.ts +15 -0
- package/src/internal/errors.ts +228 -0
- package/src/internal/logger.ts +252 -0
- package/src/internal/metrics.ts +1027 -0
- package/src/internal/options.ts +130 -0
- package/src/internal/shutdown.ts +32 -0
- package/src/internal/telemetry.ts +303 -0
- package/src/internal/types.ts +598 -0
- package/src/rpc/actions.ts +1344 -0
- package/src/rpc/http.ts +164 -0
- package/src/rpc/index.ts +959 -0
- package/src/runtime/events.ts +875 -0
- package/src/runtime/filter.ts +664 -0
- package/src/runtime/fragments.ts +674 -0
- package/src/runtime/historical.ts +1556 -0
- package/src/runtime/index.ts +578 -0
- package/src/runtime/init.ts +49 -0
- package/src/runtime/isolated.ts +769 -0
- package/src/runtime/multichain.ts +853 -0
- package/src/runtime/omnichain.ts +913 -0
- package/src/runtime/realtime.ts +1179 -0
- package/src/server/error.ts +68 -0
- package/src/server/index.ts +173 -0
- package/src/sync-historical/index.ts +1062 -0
- package/src/sync-historical/portal-realtime-wire.ts +389 -0
- package/src/sync-historical/portal-realtime.ts +209 -0
- package/src/sync-historical/portal-transform.ts +123 -0
- package/src/sync-historical/portal.ts +811 -0
- package/src/sync-historical/realtime.ts +132 -0
- package/src/sync-realtime/bloom.ts +102 -0
- package/src/sync-realtime/index.ts +1298 -0
- package/src/sync-store/encode.ts +153 -0
- package/src/sync-store/index.ts +1633 -0
- package/src/sync-store/migrations.ts +1801 -0
- package/src/sync-store/schema.ts +248 -0
- package/src/types/db.ts +292 -0
- package/src/types/eth.ts +216 -0
- package/src/types/utils.ts +47 -0
- package/src/types/virtual.ts +244 -0
- package/src/types.d.ts +38 -0
- package/src/ui/app.ts +207 -0
- package/src/ui/index.ts +37 -0
- package/src/ui/patch.ts +145 -0
- package/src/utils/abi.ts +103 -0
- package/src/utils/bigint.ts +41 -0
- package/src/utils/chains.ts +22 -0
- package/src/utils/checkpoint.ts +203 -0
- package/src/utils/chunk.ts +7 -0
- package/src/utils/copy.ts +151 -0
- package/src/utils/date.ts +26 -0
- package/src/utils/debug.ts +110 -0
- package/src/utils/decodeAbiParameters.ts +428 -0
- package/src/utils/decodeEventLog.ts +100 -0
- package/src/utils/dedupe.ts +32 -0
- package/src/utils/duplicates.ts +19 -0
- package/src/utils/estimate.ts +27 -0
- package/src/utils/finality.ts +40 -0
- package/src/utils/format.ts +22 -0
- package/src/utils/generators.ts +157 -0
- package/src/utils/hash.ts +22 -0
- package/src/utils/interval.ts +212 -0
- package/src/utils/lowercase.ts +6 -0
- package/src/utils/mutex.ts +33 -0
- package/src/utils/never.ts +3 -0
- package/src/utils/offset.ts +133 -0
- package/src/utils/order.ts +16 -0
- package/src/utils/partition.ts +53 -0
- package/src/utils/pg.ts +197 -0
- package/src/utils/pglite.ts +97 -0
- package/src/utils/port.ts +34 -0
- package/src/utils/print.ts +31 -0
- package/src/utils/promiseAllSettledWithThrow.ts +27 -0
- package/src/utils/promiseWithResolvers.ts +20 -0
- package/src/utils/queue.ts +258 -0
- package/src/utils/range.ts +8 -0
- package/src/utils/result.ts +26 -0
- package/src/utils/sql-parse.ts +1477 -0
- package/src/utils/timer.ts +8 -0
- package/src/utils/truncate.ts +15 -0
- package/src/utils/wait.ts +8 -0
- package/src/utils/zipper.ts +80 -0
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Realtime source helpers + endpoint instrumentation.
|
|
3
|
+
*
|
|
4
|
+
* Ponder owns realtime and reorg handling natively (RealtimeSync: parent-hash tracking + rollback to the
|
|
5
|
+
* common ancestor, bounded by the finalized block). The fork only swaps the HISTORICAL sync to the Portal.
|
|
6
|
+
* So the realtime source is purely a `rpc` config choice — ponder polls whatever transport(s) you give it
|
|
7
|
+
* and reorg-handles the result identically. The lib is RPC-agnostic: an authenticated RPC (an x-api-key
|
|
8
|
+
* header, a keyed proxy, …) is just `http(url, { fetchOptions: { headers } })` — nothing special.
|
|
9
|
+
*
|
|
10
|
+
* import { http, fallback } from "viem";
|
|
11
|
+
* // a plain list (Ponder-style), or latency-ranked for fastest-tip:
|
|
12
|
+
* rpc: [process.env.RPC_1!, process.env.RPC_1B!],
|
|
13
|
+
* rpc: fallback([http(process.env.RPC_1!), http(process.env.RPC_1B!)], { rank: true }),
|
|
14
|
+
* // an authenticated RPC + fallback:
|
|
15
|
+
* rpc: fallback([ http(process.env.RPC_URL!, { fetchOptions: { headers: { "x-api-key": process.env.RPC_KEY! } } }), http(process.env.RPC_1!) ]),
|
|
16
|
+
*
|
|
17
|
+
* `fallback` gives smooth failover; `{ rank: true }` probes latency and routes to the fastest tip. Either
|
|
18
|
+
* way ponder's reorg safety comes for free.
|
|
19
|
+
*/
|
|
20
|
+
import { http, fallback, type Transport } from "viem";
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Compose realtime RPC(s) into a latency-ranked fallback so the fastest tip lands. Accepts URL strings or
|
|
24
|
+
* viem Transports — pass a Transport for an authenticated RPC: `http(url, { fetchOptions: { headers } })`.
|
|
25
|
+
*/
|
|
26
|
+
export function rpcRealtime(rpcs: Array<string | Transport>, opts?: { rank?: boolean }): Transport {
|
|
27
|
+
return fallback(rpcs.map((r) => (typeof r === "string" ? http(r) : r)), { rank: opts?.rank ?? true });
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
// ─────────────────────────────── endpoint instrumentation ───────────────────────────────
|
|
31
|
+
// Periodically probe each configured endpoint (eth_blockNumber) to evaluate, per endpoint:
|
|
32
|
+
// • latency — request round-trip (ms), p50/p95/mean
|
|
33
|
+
// • freshness — how many blocks behind the FRESHEST endpoint for that chain (tip lag)
|
|
34
|
+
// • responsiveness — error rate + last error
|
|
35
|
+
// This is a side-probe (consistent, independent of ponder's request pattern), written to the metrics suite.
|
|
36
|
+
|
|
37
|
+
export type Endpoint = { name: string; url: string; headers?: Record<string, string> };
|
|
38
|
+
export type ChainEndpoints = { chainId: number; endpoints: Endpoint[] };
|
|
39
|
+
export type ProbeSample = { chainId: number; name: string; ok: boolean; latencyMs: number; tip: number | null; error?: string; lag?: number | null };
|
|
40
|
+
|
|
41
|
+
/** Probe every endpoint once. Pure w.r.t. state — takes a `fetchImpl` for testability. */
|
|
42
|
+
export async function probeOnce(chains: ChainEndpoints[], fetchImpl: typeof fetch = fetch, timeoutMs = 8_000): Promise<ProbeSample[]> {
|
|
43
|
+
const out: ProbeSample[] = [];
|
|
44
|
+
await Promise.all(
|
|
45
|
+
chains.flatMap((c) =>
|
|
46
|
+
c.endpoints.map(async (e) => {
|
|
47
|
+
const t0 = Date.now();
|
|
48
|
+
try {
|
|
49
|
+
const res = await fetchImpl(e.url, {
|
|
50
|
+
method: "POST",
|
|
51
|
+
headers: { "content-type": "application/json", ...(e.headers ?? {}) },
|
|
52
|
+
body: JSON.stringify({ jsonrpc: "2.0", id: 1, method: "eth_blockNumber", params: [] }),
|
|
53
|
+
signal: AbortSignal.timeout(timeoutMs),
|
|
54
|
+
});
|
|
55
|
+
const latencyMs = Date.now() - t0;
|
|
56
|
+
if (!res.ok) { out.push({ chainId: c.chainId, name: e.name, ok: false, latencyMs, tip: null, error: `HTTP ${res.status}` }); return; }
|
|
57
|
+
const j = await res.json();
|
|
58
|
+
const tip = typeof j?.result === "string" ? Number(j.result) : null;
|
|
59
|
+
out.push({ chainId: c.chainId, name: e.name, ok: tip !== null && Number.isFinite(tip), latencyMs, tip, error: j?.error ? JSON.stringify(j.error).slice(0, 80) : undefined });
|
|
60
|
+
} catch (err: any) {
|
|
61
|
+
out.push({ chainId: c.chainId, name: e.name, ok: false, latencyMs: Date.now() - t0, tip: null, error: String(err?.message ?? err).slice(0, 80) });
|
|
62
|
+
}
|
|
63
|
+
}),
|
|
64
|
+
),
|
|
65
|
+
);
|
|
66
|
+
return out;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
/** Freshness lag (blocks behind the freshest endpoint for the same chain). Pure. */
|
|
70
|
+
export function freshnessLag(samples: ProbeSample[]): Map<string, number | null> {
|
|
71
|
+
const maxTip = new Map<number, number>();
|
|
72
|
+
for (const s of samples) if (s.ok && s.tip !== null) maxTip.set(s.chainId, Math.max(maxTip.get(s.chainId) ?? 0, s.tip));
|
|
73
|
+
const lag = new Map<string, number | null>();
|
|
74
|
+
for (const s of samples) {
|
|
75
|
+
const key = `${s.chainId}:${s.name}`;
|
|
76
|
+
lag.set(key, s.ok && s.tip !== null && maxTip.has(s.chainId) ? maxTip.get(s.chainId)! - s.tip : null);
|
|
77
|
+
}
|
|
78
|
+
return lag;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
const pct = (arr: number[], p: number): number => {
|
|
82
|
+
if (!arr.length) return 0;
|
|
83
|
+
const s = [...arr].sort((a, b) => a - b);
|
|
84
|
+
return s[Math.min(s.length - 1, Math.floor((p / 100) * s.length))] ?? 0;
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
/** Roll a window of samples into per-endpoint stats. Pure. */
|
|
88
|
+
export function summarize(window: ProbeSample[]): Record<string, { chainId: number; name: string; n: number; okRate: number; latP50: number; latP95: number; latMean: number; avgLag: number | null; lastError?: string }> {
|
|
89
|
+
const byKey: Record<string, ProbeSample[]> = {};
|
|
90
|
+
for (const s of window) (byKey[`${s.chainId}:${s.name}`] ??= []).push(s);
|
|
91
|
+
const res: Record<string, any> = {};
|
|
92
|
+
for (const [key, ss] of Object.entries(byKey)) {
|
|
93
|
+
const ok = ss.filter((s) => s.ok);
|
|
94
|
+
const lats = ok.map((s) => s.latencyMs);
|
|
95
|
+
const lags = ok.map((s) => s.lag).filter((x): x is number => typeof x === "number");
|
|
96
|
+
res[key] = {
|
|
97
|
+
chainId: ss[0]!.chainId, name: ss[0]!.name, n: ss.length,
|
|
98
|
+
okRate: ss.length ? ok.length / ss.length : 0,
|
|
99
|
+
latP50: pct(lats, 50), latP95: pct(lats, 95), latMean: lats.length ? Math.round(lats.reduce((a, b) => a + b, 0) / lats.length) : 0,
|
|
100
|
+
avgLag: lags.length ? Math.round(lags.reduce((a: number, b: number) => a + b, 0) / lags.length) : null,
|
|
101
|
+
lastError: [...ss].reverse().find((s) => s.error)?.error,
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
return res;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
/** Start the periodic endpoint probe. Returns a stop() fn. Writes `<metricsFile>` (JSON) each tick. */
|
|
108
|
+
export function startEndpointProbe(
|
|
109
|
+
chains: ChainEndpoints[],
|
|
110
|
+
opts: { intervalMs?: number; windowTicks?: number; metricsFile?: string; fetchImpl?: typeof fetch; onSummary?: (s: ReturnType<typeof summarize>) => void; log?: (m: string) => void } = {},
|
|
111
|
+
): () => void {
|
|
112
|
+
const intervalMs = opts.intervalMs ?? 10_000;
|
|
113
|
+
const windowTicks = opts.windowTicks ?? 30; // rolling window
|
|
114
|
+
const fetchImpl = opts.fetchImpl ?? fetch;
|
|
115
|
+
const ring: ProbeSample[] = [];
|
|
116
|
+
let stopped = false;
|
|
117
|
+
const tick = async () => {
|
|
118
|
+
if (stopped) return;
|
|
119
|
+
const samples = await probeOnce(chains, fetchImpl);
|
|
120
|
+
const lag = freshnessLag(samples);
|
|
121
|
+
for (const s of samples) s.lag = lag.get(`${s.chainId}:${s.name}`) ?? null;
|
|
122
|
+
ring.push(...samples);
|
|
123
|
+
while (ring.length > windowTicks * chains.reduce((n, c) => n + c.endpoints.length, 0)) ring.shift();
|
|
124
|
+
const summary = summarize(ring);
|
|
125
|
+
opts.onSummary?.(summary);
|
|
126
|
+
if (opts.metricsFile) { try { (await import("node:fs")).writeFileSync(opts.metricsFile, JSON.stringify({ ts: Date.now(), intervalMs, endpoints: summary }, null, 2)); } catch { /* best-effort */ } }
|
|
127
|
+
if (opts.log) for (const v of Object.values(summary)) opts.log(`[probe] ${v.chainId}:${v.name} lat p50=${v.latP50}ms p95=${v.latP95}ms ok=${(v.okRate * 100).toFixed(0)}% lag=${v.avgLag ?? "?"}blk`);
|
|
128
|
+
};
|
|
129
|
+
const timer = setInterval(tick, intervalMs);
|
|
130
|
+
void tick();
|
|
131
|
+
return () => { stopped = true; clearInterval(timer); };
|
|
132
|
+
}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import type { LogFilter, SyncBlock } from "@/internal/types.js";
|
|
2
|
+
import {
|
|
3
|
+
getFilterFromBlock,
|
|
4
|
+
getFilterToBlock,
|
|
5
|
+
isAddressFactory,
|
|
6
|
+
} from "@/runtime/filter.js";
|
|
7
|
+
import { type Hex, hexToBytes, hexToNumber, keccak256 } from "viem";
|
|
8
|
+
|
|
9
|
+
export const zeroLogsBloom =
|
|
10
|
+
"0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000";
|
|
11
|
+
|
|
12
|
+
const BLOOM_SIZE_BYTES = 256;
|
|
13
|
+
|
|
14
|
+
export const isInBloom = (_bloom: Hex, input: Hex): boolean => {
|
|
15
|
+
const bloom = hexToBytes(_bloom);
|
|
16
|
+
const hash = hexToBytes(keccak256(input));
|
|
17
|
+
|
|
18
|
+
for (const i of [0, 2, 4]) {
|
|
19
|
+
const bit = (hash[i + 1]! + (hash[i]! << 8)) & 0x7ff;
|
|
20
|
+
if (
|
|
21
|
+
(bloom[BLOOM_SIZE_BYTES - 1 - Math.floor(bit / 8)]! &
|
|
22
|
+
(1 << (bit % 8))) ===
|
|
23
|
+
0
|
|
24
|
+
)
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
return true;
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Return true if `filter` is in `bloom`.
|
|
33
|
+
*
|
|
34
|
+
* A filter with an address of type `LogFactory` is matched
|
|
35
|
+
* if the address filter is matched (new child contract) or the log
|
|
36
|
+
* filter is matched (log on child contract).
|
|
37
|
+
*
|
|
38
|
+
* Note: False positives are possible.
|
|
39
|
+
*/
|
|
40
|
+
export function isFilterInBloom({
|
|
41
|
+
block,
|
|
42
|
+
filter,
|
|
43
|
+
}: {
|
|
44
|
+
block: Pick<SyncBlock, "number" | "logsBloom">;
|
|
45
|
+
filter: LogFilter;
|
|
46
|
+
}): boolean {
|
|
47
|
+
// Return `false` for out of range blocks
|
|
48
|
+
if (
|
|
49
|
+
hexToNumber(block.number) < getFilterFromBlock(filter) ||
|
|
50
|
+
hexToNumber(block.number) > getFilterToBlock(filter)
|
|
51
|
+
) {
|
|
52
|
+
return false;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
const isTopicsInBloom = [
|
|
56
|
+
filter.topic0,
|
|
57
|
+
filter.topic1,
|
|
58
|
+
filter.topic2,
|
|
59
|
+
filter.topic3,
|
|
60
|
+
].every((topic) => {
|
|
61
|
+
if (topic === null || topic === undefined) {
|
|
62
|
+
return true;
|
|
63
|
+
} else if (Array.isArray(topic)) {
|
|
64
|
+
return topic.some((t) => isInBloom(block.logsBloom, t));
|
|
65
|
+
} else {
|
|
66
|
+
return isInBloom(block.logsBloom, topic);
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
let isAddressInBloom: boolean;
|
|
71
|
+
|
|
72
|
+
if (filter.address === undefined) isAddressInBloom = true;
|
|
73
|
+
else if (isAddressFactory(filter.address)) {
|
|
74
|
+
// Return true if the `Factory` is matched.
|
|
75
|
+
if (
|
|
76
|
+
(filter.address.address === undefined ||
|
|
77
|
+
(Array.isArray(filter.address.address)
|
|
78
|
+
? filter.address.address.some((address) =>
|
|
79
|
+
isInBloom(block.logsBloom, address),
|
|
80
|
+
)
|
|
81
|
+
: isInBloom(block.logsBloom, filter.address.address))) &&
|
|
82
|
+
isInBloom(block.logsBloom, filter.address.eventSelector)
|
|
83
|
+
) {
|
|
84
|
+
return true;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
isAddressInBloom = true;
|
|
88
|
+
} else if (Array.isArray(filter.address)) {
|
|
89
|
+
if (filter.address.length === 0) {
|
|
90
|
+
isAddressInBloom = true;
|
|
91
|
+
} else {
|
|
92
|
+
isAddressInBloom = filter.address.some((address) =>
|
|
93
|
+
isInBloom(block.logsBloom, address),
|
|
94
|
+
);
|
|
95
|
+
}
|
|
96
|
+
} else {
|
|
97
|
+
// single address case
|
|
98
|
+
isAddressInBloom = isInBloom(block.logsBloom, filter.address);
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
return isAddressInBloom && isTopicsInBloom;
|
|
102
|
+
}
|