@mikeatlast/ponder 0.16.1-fork.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.
Files changed (619) hide show
  1. package/CHANGELOG.md +3415 -0
  2. package/README.md +186 -0
  3. package/dist/esm/bin/commands/codegen.js +46 -0
  4. package/dist/esm/bin/commands/codegen.js.map +1 -0
  5. package/dist/esm/bin/commands/createViews.js +196 -0
  6. package/dist/esm/bin/commands/createViews.js.map +1 -0
  7. package/dist/esm/bin/commands/dev.js +430 -0
  8. package/dist/esm/bin/commands/dev.js.map +1 -0
  9. package/dist/esm/bin/commands/list.js +148 -0
  10. package/dist/esm/bin/commands/list.js.map +1 -0
  11. package/dist/esm/bin/commands/prune.js +223 -0
  12. package/dist/esm/bin/commands/prune.js.map +1 -0
  13. package/dist/esm/bin/commands/serve.js +198 -0
  14. package/dist/esm/bin/commands/serve.js.map +1 -0
  15. package/dist/esm/bin/commands/start.js +253 -0
  16. package/dist/esm/bin/commands/start.js.map +1 -0
  17. package/dist/esm/bin/isolatedController.js +200 -0
  18. package/dist/esm/bin/isolatedController.js.map +1 -0
  19. package/dist/esm/bin/isolatedWorker.js +146 -0
  20. package/dist/esm/bin/isolatedWorker.js.map +1 -0
  21. package/dist/esm/bin/ponder.js +137 -0
  22. package/dist/esm/bin/ponder.js.map +1 -0
  23. package/dist/esm/bin/utils/codegen.js +25 -0
  24. package/dist/esm/bin/utils/codegen.js.map +1 -0
  25. package/dist/esm/bin/utils/exit.js +100 -0
  26. package/dist/esm/bin/utils/exit.js.map +1 -0
  27. package/dist/esm/build/config.js +745 -0
  28. package/dist/esm/build/config.js.map +1 -0
  29. package/dist/esm/build/factory.js +82 -0
  30. package/dist/esm/build/factory.js.map +1 -0
  31. package/dist/esm/build/index.js +567 -0
  32. package/dist/esm/build/index.js.map +1 -0
  33. package/dist/esm/build/plugin.js +53 -0
  34. package/dist/esm/build/plugin.js.map +1 -0
  35. package/dist/esm/build/pre.js +83 -0
  36. package/dist/esm/build/pre.js.map +1 -0
  37. package/dist/esm/build/schema.js +202 -0
  38. package/dist/esm/build/schema.js.map +1 -0
  39. package/dist/esm/build/stacktrace.js +137 -0
  40. package/dist/esm/build/stacktrace.js.map +1 -0
  41. package/dist/esm/client/index.js +441 -0
  42. package/dist/esm/client/index.js.map +1 -0
  43. package/dist/esm/config/address.js +2 -0
  44. package/dist/esm/config/address.js.map +1 -0
  45. package/dist/esm/config/eventFilter.js +2 -0
  46. package/dist/esm/config/eventFilter.js.map +1 -0
  47. package/dist/esm/config/index.js +2 -0
  48. package/dist/esm/config/index.js.map +1 -0
  49. package/dist/esm/config/utilityTypes.js +2 -0
  50. package/dist/esm/config/utilityTypes.js.map +1 -0
  51. package/dist/esm/database/actions.js +445 -0
  52. package/dist/esm/database/actions.js.map +1 -0
  53. package/dist/esm/database/index.js +604 -0
  54. package/dist/esm/database/index.js.map +1 -0
  55. package/dist/esm/database/queryBuilder.js +314 -0
  56. package/dist/esm/database/queryBuilder.js.map +1 -0
  57. package/dist/esm/drizzle/bigint.js +38 -0
  58. package/dist/esm/drizzle/bigint.js.map +1 -0
  59. package/dist/esm/drizzle/bytes.js +47 -0
  60. package/dist/esm/drizzle/bytes.js.map +1 -0
  61. package/dist/esm/drizzle/hex.js +40 -0
  62. package/dist/esm/drizzle/hex.js.map +1 -0
  63. package/dist/esm/drizzle/index.js +28 -0
  64. package/dist/esm/drizzle/index.js.map +1 -0
  65. package/dist/esm/drizzle/json.js +123 -0
  66. package/dist/esm/drizzle/json.js.map +1 -0
  67. package/dist/esm/drizzle/kit/index.js +927 -0
  68. package/dist/esm/drizzle/kit/index.js.map +1 -0
  69. package/dist/esm/drizzle/onchain.js +184 -0
  70. package/dist/esm/drizzle/onchain.js.map +1 -0
  71. package/dist/esm/drizzle/text.js +61 -0
  72. package/dist/esm/drizzle/text.js.map +1 -0
  73. package/dist/esm/graphql/graphiql.html.js +59 -0
  74. package/dist/esm/graphql/graphiql.html.js.map +1 -0
  75. package/dist/esm/graphql/index.js +934 -0
  76. package/dist/esm/graphql/index.js.map +1 -0
  77. package/dist/esm/graphql/json.js +42 -0
  78. package/dist/esm/graphql/json.js.map +1 -0
  79. package/dist/esm/graphql/middleware.js +83 -0
  80. package/dist/esm/graphql/middleware.js.map +1 -0
  81. package/dist/esm/index.js +9 -0
  82. package/dist/esm/index.js.map +1 -0
  83. package/dist/esm/indexing/addStackTrace.js +54 -0
  84. package/dist/esm/indexing/addStackTrace.js.map +1 -0
  85. package/dist/esm/indexing/client.js +675 -0
  86. package/dist/esm/indexing/client.js.map +1 -0
  87. package/dist/esm/indexing/index.js +663 -0
  88. package/dist/esm/indexing/index.js.map +1 -0
  89. package/dist/esm/indexing/profile.js +584 -0
  90. package/dist/esm/indexing/profile.js.map +1 -0
  91. package/dist/esm/indexing-store/cache.js +666 -0
  92. package/dist/esm/indexing-store/cache.js.map +1 -0
  93. package/dist/esm/indexing-store/index.js +461 -0
  94. package/dist/esm/indexing-store/index.js.map +1 -0
  95. package/dist/esm/indexing-store/profile.js +428 -0
  96. package/dist/esm/indexing-store/profile.js.map +1 -0
  97. package/dist/esm/indexing-store/utils.js +111 -0
  98. package/dist/esm/indexing-store/utils.js.map +1 -0
  99. package/dist/esm/internal/common.js +2 -0
  100. package/dist/esm/internal/common.js.map +1 -0
  101. package/dist/esm/internal/errors.js +300 -0
  102. package/dist/esm/internal/errors.js.map +1 -0
  103. package/dist/esm/internal/logger.js +178 -0
  104. package/dist/esm/internal/logger.js.map +1 -0
  105. package/dist/esm/internal/metrics.js +1049 -0
  106. package/dist/esm/internal/metrics.js.map +1 -0
  107. package/dist/esm/internal/options.js +73 -0
  108. package/dist/esm/internal/options.js.map +1 -0
  109. package/dist/esm/internal/shutdown.js +24 -0
  110. package/dist/esm/internal/shutdown.js.map +1 -0
  111. package/dist/esm/internal/telemetry.js +200 -0
  112. package/dist/esm/internal/telemetry.js.map +1 -0
  113. package/dist/esm/internal/types.js +2 -0
  114. package/dist/esm/internal/types.js.map +1 -0
  115. package/dist/esm/rpc/actions.js +988 -0
  116. package/dist/esm/rpc/actions.js.map +1 -0
  117. package/dist/esm/rpc/http.js +130 -0
  118. package/dist/esm/rpc/http.js.map +1 -0
  119. package/dist/esm/rpc/index.js +749 -0
  120. package/dist/esm/rpc/index.js.map +1 -0
  121. package/dist/esm/runtime/events.js +664 -0
  122. package/dist/esm/runtime/events.js.map +1 -0
  123. package/dist/esm/runtime/filter.js +476 -0
  124. package/dist/esm/runtime/filter.js.map +1 -0
  125. package/dist/esm/runtime/fragments.js +478 -0
  126. package/dist/esm/runtime/fragments.js.map +1 -0
  127. package/dist/esm/runtime/historical.js +954 -0
  128. package/dist/esm/runtime/historical.js.map +1 -0
  129. package/dist/esm/runtime/index.js +316 -0
  130. package/dist/esm/runtime/index.js.map +1 -0
  131. package/dist/esm/runtime/init.js +12 -0
  132. package/dist/esm/runtime/init.js.map +1 -0
  133. package/dist/esm/runtime/isolated.js +464 -0
  134. package/dist/esm/runtime/isolated.js.map +1 -0
  135. package/dist/esm/runtime/multichain.js +511 -0
  136. package/dist/esm/runtime/multichain.js.map +1 -0
  137. package/dist/esm/runtime/omnichain.js +546 -0
  138. package/dist/esm/runtime/omnichain.js.map +1 -0
  139. package/dist/esm/runtime/realtime.js +722 -0
  140. package/dist/esm/runtime/realtime.js.map +1 -0
  141. package/dist/esm/server/error.js +56 -0
  142. package/dist/esm/server/error.js.map +1 -0
  143. package/dist/esm/server/index.js +121 -0
  144. package/dist/esm/server/index.js.map +1 -0
  145. package/dist/esm/sync-historical/index.js +703 -0
  146. package/dist/esm/sync-historical/index.js.map +1 -0
  147. package/dist/esm/sync-realtime/bloom.js +76 -0
  148. package/dist/esm/sync-realtime/bloom.js.map +1 -0
  149. package/dist/esm/sync-realtime/index.js +918 -0
  150. package/dist/esm/sync-realtime/index.js.map +1 -0
  151. package/dist/esm/sync-store/encode.js +105 -0
  152. package/dist/esm/sync-store/encode.js.map +1 -0
  153. package/dist/esm/sync-store/index.js +885 -0
  154. package/dist/esm/sync-store/index.js.map +1 -0
  155. package/dist/esm/sync-store/migrations.js +1595 -0
  156. package/dist/esm/sync-store/migrations.js.map +1 -0
  157. package/dist/esm/sync-store/schema.js +181 -0
  158. package/dist/esm/sync-store/schema.js.map +1 -0
  159. package/dist/esm/types/db.js +2 -0
  160. package/dist/esm/types/db.js.map +1 -0
  161. package/dist/esm/types/eth.js +2 -0
  162. package/dist/esm/types/eth.js.map +1 -0
  163. package/dist/esm/types/utils.js +2 -0
  164. package/dist/esm/types/utils.js.map +1 -0
  165. package/dist/esm/types/virtual.js +2 -0
  166. package/dist/esm/types/virtual.js.map +1 -0
  167. package/dist/esm/ui/app.js +157 -0
  168. package/dist/esm/ui/app.js.map +1 -0
  169. package/dist/esm/ui/index.js +29 -0
  170. package/dist/esm/ui/index.js.map +1 -0
  171. package/dist/esm/ui/patch.js +140 -0
  172. package/dist/esm/ui/patch.js.map +1 -0
  173. package/dist/esm/utils/abi.js +55 -0
  174. package/dist/esm/utils/abi.js.map +1 -0
  175. package/dist/esm/utils/bigint.js +37 -0
  176. package/dist/esm/utils/bigint.js.map +1 -0
  177. package/dist/esm/utils/chains.js +21 -0
  178. package/dist/esm/utils/chains.js.map +1 -0
  179. package/dist/esm/utils/checkpoint.js +139 -0
  180. package/dist/esm/utils/checkpoint.js.map +1 -0
  181. package/dist/esm/utils/chunk.js +8 -0
  182. package/dist/esm/utils/chunk.js.map +1 -0
  183. package/dist/esm/utils/copy.js +129 -0
  184. package/dist/esm/utils/copy.js.map +1 -0
  185. package/dist/esm/utils/date.js +27 -0
  186. package/dist/esm/utils/date.js.map +1 -0
  187. package/dist/esm/utils/debug.js +2 -0
  188. package/dist/esm/utils/debug.js.map +1 -0
  189. package/dist/esm/utils/decodeAbiParameters.js +290 -0
  190. package/dist/esm/utils/decodeAbiParameters.js.map +1 -0
  191. package/dist/esm/utils/decodeEventLog.js +75 -0
  192. package/dist/esm/utils/decodeEventLog.js.map +1 -0
  193. package/dist/esm/utils/dedupe.js +29 -0
  194. package/dist/esm/utils/dedupe.js.map +1 -0
  195. package/dist/esm/utils/duplicates.js +19 -0
  196. package/dist/esm/utils/duplicates.js.map +1 -0
  197. package/dist/esm/utils/estimate.js +6 -0
  198. package/dist/esm/utils/estimate.js.map +1 -0
  199. package/dist/esm/utils/finality.js +38 -0
  200. package/dist/esm/utils/finality.js.map +1 -0
  201. package/dist/esm/utils/format.js +20 -0
  202. package/dist/esm/utils/format.js.map +1 -0
  203. package/dist/esm/utils/generators.js +121 -0
  204. package/dist/esm/utils/generators.js.map +1 -0
  205. package/dist/esm/utils/hash.js +11 -0
  206. package/dist/esm/utils/hash.js.map +1 -0
  207. package/dist/esm/utils/interval.js +171 -0
  208. package/dist/esm/utils/interval.js.map +1 -0
  209. package/dist/esm/utils/lowercase.js +7 -0
  210. package/dist/esm/utils/lowercase.js.map +1 -0
  211. package/dist/esm/utils/mutex.js +26 -0
  212. package/dist/esm/utils/mutex.js.map +1 -0
  213. package/dist/esm/utils/never.js +4 -0
  214. package/dist/esm/utils/never.js.map +1 -0
  215. package/dist/esm/utils/offset.js +101 -0
  216. package/dist/esm/utils/offset.js.map +1 -0
  217. package/dist/esm/utils/order.js +18 -0
  218. package/dist/esm/utils/order.js.map +1 -0
  219. package/dist/esm/utils/partition.js +46 -0
  220. package/dist/esm/utils/partition.js.map +1 -0
  221. package/dist/esm/utils/pg.js +175 -0
  222. package/dist/esm/utils/pg.js.map +1 -0
  223. package/dist/esm/utils/pglite.js +80 -0
  224. package/dist/esm/utils/pglite.js.map +1 -0
  225. package/dist/esm/utils/port.js +30 -0
  226. package/dist/esm/utils/port.js.map +1 -0
  227. package/dist/esm/utils/print.js +23 -0
  228. package/dist/esm/utils/print.js.map +1 -0
  229. package/dist/esm/utils/promiseAllSettledWithThrow.js +19 -0
  230. package/dist/esm/utils/promiseAllSettledWithThrow.js.map +1 -0
  231. package/dist/esm/utils/promiseWithResolvers.js +13 -0
  232. package/dist/esm/utils/promiseWithResolvers.js.map +1 -0
  233. package/dist/esm/utils/queue.js +150 -0
  234. package/dist/esm/utils/queue.js.map +1 -0
  235. package/dist/esm/utils/range.js +8 -0
  236. package/dist/esm/utils/range.js.map +1 -0
  237. package/dist/esm/utils/result.js +10 -0
  238. package/dist/esm/utils/result.js.map +1 -0
  239. package/dist/esm/utils/sql-parse.js +1326 -0
  240. package/dist/esm/utils/sql-parse.js.map +1 -0
  241. package/dist/esm/utils/timer.js +9 -0
  242. package/dist/esm/utils/timer.js.map +1 -0
  243. package/dist/esm/utils/truncate.js +15 -0
  244. package/dist/esm/utils/truncate.js.map +1 -0
  245. package/dist/esm/utils/wait.js +10 -0
  246. package/dist/esm/utils/wait.js.map +1 -0
  247. package/dist/esm/utils/zipper.js +67 -0
  248. package/dist/esm/utils/zipper.js.map +1 -0
  249. package/dist/types/bin/commands/codegen.d.ts +5 -0
  250. package/dist/types/bin/commands/codegen.d.ts.map +1 -0
  251. package/dist/types/bin/commands/createViews.d.ts +8 -0
  252. package/dist/types/bin/commands/createViews.d.ts.map +1 -0
  253. package/dist/types/bin/commands/dev.d.ts +5 -0
  254. package/dist/types/bin/commands/dev.d.ts.map +1 -0
  255. package/dist/types/bin/commands/list.d.ts +5 -0
  256. package/dist/types/bin/commands/list.d.ts.map +1 -0
  257. package/dist/types/bin/commands/prune.d.ts +5 -0
  258. package/dist/types/bin/commands/prune.d.ts.map +1 -0
  259. package/dist/types/bin/commands/serve.d.ts +5 -0
  260. package/dist/types/bin/commands/serve.d.ts.map +1 -0
  261. package/dist/types/bin/commands/start.d.ts +19 -0
  262. package/dist/types/bin/commands/start.d.ts.map +1 -0
  263. package/dist/types/bin/isolatedController.d.ts +13 -0
  264. package/dist/types/bin/isolatedController.d.ts.map +1 -0
  265. package/dist/types/bin/isolatedWorker.d.ts +9 -0
  266. package/dist/types/bin/isolatedWorker.d.ts.map +1 -0
  267. package/dist/types/bin/ponder.d.ts +37 -0
  268. package/dist/types/bin/ponder.d.ts.map +1 -0
  269. package/dist/types/bin/utils/codegen.d.ts +6 -0
  270. package/dist/types/bin/utils/codegen.d.ts.map +1 -0
  271. package/dist/types/bin/utils/exit.d.ts +10 -0
  272. package/dist/types/bin/utils/exit.d.ts.map +1 -0
  273. package/dist/types/build/config.d.ts +97 -0
  274. package/dist/types/build/config.d.ts.map +1 -0
  275. package/dist/types/build/factory.d.ts +15 -0
  276. package/dist/types/build/factory.d.ts.map +1 -0
  277. package/dist/types/build/index.d.ts +84 -0
  278. package/dist/types/build/index.d.ts.map +1 -0
  279. package/dist/types/build/plugin.d.ts +4 -0
  280. package/dist/types/build/plugin.d.ts.map +1 -0
  281. package/dist/types/build/pre.d.ts +29 -0
  282. package/dist/types/build/pre.d.ts.map +1 -0
  283. package/dist/types/build/schema.d.ts +20 -0
  284. package/dist/types/build/schema.d.ts.map +1 -0
  285. package/dist/types/build/stacktrace.d.ts +13 -0
  286. package/dist/types/build/stacktrace.d.ts.map +1 -0
  287. package/dist/types/client/index.d.ts +27 -0
  288. package/dist/types/client/index.d.ts.map +1 -0
  289. package/dist/types/config/address.d.ts +34 -0
  290. package/dist/types/config/address.d.ts.map +1 -0
  291. package/dist/types/config/eventFilter.d.ts +18 -0
  292. package/dist/types/config/eventFilter.d.ts.map +1 -0
  293. package/dist/types/config/index.d.ts +144 -0
  294. package/dist/types/config/index.d.ts.map +1 -0
  295. package/dist/types/config/utilityTypes.d.ts +43 -0
  296. package/dist/types/config/utilityTypes.d.ts.map +1 -0
  297. package/dist/types/database/actions.d.ts +99 -0
  298. package/dist/types/database/actions.d.ts.map +1 -0
  299. package/dist/types/database/index.d.ts +493 -0
  300. package/dist/types/database/index.d.ts.map +1 -0
  301. package/dist/types/database/queryBuilder.d.ts +65 -0
  302. package/dist/types/database/queryBuilder.d.ts.map +1 -0
  303. package/dist/types/drizzle/bigint.d.ts +25 -0
  304. package/dist/types/drizzle/bigint.d.ts.map +1 -0
  305. package/dist/types/drizzle/bytes.d.ts +31 -0
  306. package/dist/types/drizzle/bytes.d.ts.map +1 -0
  307. package/dist/types/drizzle/hex.d.ts +25 -0
  308. package/dist/types/drizzle/hex.d.ts.map +1 -0
  309. package/dist/types/drizzle/index.d.ts +6 -0
  310. package/dist/types/drizzle/index.d.ts.map +1 -0
  311. package/dist/types/drizzle/json.d.ts +51 -0
  312. package/dist/types/drizzle/json.d.ts.map +1 -0
  313. package/dist/types/drizzle/kit/index.d.ts +187 -0
  314. package/dist/types/drizzle/kit/index.d.ts.map +1 -0
  315. package/dist/types/drizzle/onchain.d.ts +298 -0
  316. package/dist/types/drizzle/onchain.d.ts.map +1 -0
  317. package/dist/types/drizzle/text.d.ts +29 -0
  318. package/dist/types/drizzle/text.d.ts.map +1 -0
  319. package/dist/types/graphql/graphiql.html.d.ts +2 -0
  320. package/dist/types/graphql/graphiql.html.d.ts.map +1 -0
  321. package/dist/types/graphql/index.d.ts +12 -0
  322. package/dist/types/graphql/index.d.ts.map +1 -0
  323. package/dist/types/graphql/json.d.ts +3 -0
  324. package/dist/types/graphql/json.d.ts.map +1 -0
  325. package/dist/types/graphql/middleware.d.ts +29 -0
  326. package/dist/types/graphql/middleware.d.ts.map +1 -0
  327. package/dist/types/index.d.ts +23 -0
  328. package/dist/types/index.d.ts.map +1 -0
  329. package/dist/types/indexing/addStackTrace.d.ts +3 -0
  330. package/dist/types/indexing/addStackTrace.d.ts.map +1 -0
  331. package/dist/types/indexing/client.d.ts +154 -0
  332. package/dist/types/indexing/client.d.ts.map +1 -0
  333. package/dist/types/indexing/index.d.ts +72 -0
  334. package/dist/types/indexing/index.d.ts.map +1 -0
  335. package/dist/types/indexing/profile.d.ts +16 -0
  336. package/dist/types/indexing/profile.d.ts.map +1 -0
  337. package/dist/types/indexing-store/cache.d.ts +115 -0
  338. package/dist/types/indexing-store/cache.d.ts.map +1 -0
  339. package/dist/types/indexing-store/index.d.ts +24 -0
  340. package/dist/types/indexing-store/index.d.ts.map +1 -0
  341. package/dist/types/indexing-store/profile.d.ts +7 -0
  342. package/dist/types/indexing-store/profile.d.ts.map +1 -0
  343. package/dist/types/indexing-store/utils.d.ts +19 -0
  344. package/dist/types/indexing-store/utils.d.ts.map +1 -0
  345. package/dist/types/internal/common.d.ts +15 -0
  346. package/dist/types/internal/common.d.ts.map +1 -0
  347. package/dist/types/internal/errors.d.ts +101 -0
  348. package/dist/types/internal/errors.d.ts.map +1 -0
  349. package/dist/types/internal/logger.d.ts +37 -0
  350. package/dist/types/internal/logger.d.ts.map +1 -0
  351. package/dist/types/internal/metrics.d.ts +120 -0
  352. package/dist/types/internal/metrics.d.ts.map +1 -0
  353. package/dist/types/internal/options.d.ts +62 -0
  354. package/dist/types/internal/options.d.ts.map +1 -0
  355. package/dist/types/internal/shutdown.d.ts +8 -0
  356. package/dist/types/internal/shutdown.d.ts.map +1 -0
  357. package/dist/types/internal/telemetry.d.ts +43 -0
  358. package/dist/types/internal/telemetry.d.ts.map +1 -0
  359. package/dist/types/internal/types.d.ts +443 -0
  360. package/dist/types/internal/types.d.ts.map +1 -0
  361. package/dist/types/rpc/actions.d.ts +360 -0
  362. package/dist/types/rpc/actions.d.ts.map +1 -0
  363. package/dist/types/rpc/http.d.ts +17 -0
  364. package/dist/types/rpc/http.d.ts.map +1 -0
  365. package/dist/types/rpc/index.d.ts +43 -0
  366. package/dist/types/rpc/index.d.ts.map +1 -0
  367. package/dist/types/runtime/events.d.ts +40 -0
  368. package/dist/types/runtime/events.d.ts.map +1 -0
  369. package/dist/types/runtime/filter.d.ts +96 -0
  370. package/dist/types/runtime/filter.d.ts.map +1 -0
  371. package/dist/types/runtime/fragments.d.ts +30 -0
  372. package/dist/types/runtime/fragments.d.ts.map +1 -0
  373. package/dist/types/runtime/historical.d.ts +123 -0
  374. package/dist/types/runtime/historical.d.ts.map +1 -0
  375. package/dist/types/runtime/index.d.ts +89 -0
  376. package/dist/types/runtime/index.d.ts.map +1 -0
  377. package/dist/types/runtime/init.d.ts +28 -0
  378. package/dist/types/runtime/init.d.ts.map +1 -0
  379. package/dist/types/runtime/isolated.d.ts +14 -0
  380. package/dist/types/runtime/isolated.d.ts.map +1 -0
  381. package/dist/types/runtime/multichain.d.ts +13 -0
  382. package/dist/types/runtime/multichain.d.ts.map +1 -0
  383. package/dist/types/runtime/omnichain.d.ts +23 -0
  384. package/dist/types/runtime/omnichain.d.ts.map +1 -0
  385. package/dist/types/runtime/realtime.d.ts +93 -0
  386. package/dist/types/runtime/realtime.d.ts.map +1 -0
  387. package/dist/types/server/error.d.ts +5 -0
  388. package/dist/types/server/error.d.ts.map +1 -0
  389. package/dist/types/server/index.d.ts +13 -0
  390. package/dist/types/server/index.d.ts.map +1 -0
  391. package/dist/types/sync-historical/index.d.ts +36 -0
  392. package/dist/types/sync-historical/index.d.ts.map +1 -0
  393. package/dist/types/sync-realtime/bloom.d.ts +18 -0
  394. package/dist/types/sync-realtime/bloom.d.ts.map +1 -0
  395. package/dist/types/sync-realtime/index.d.ts +48 -0
  396. package/dist/types/sync-realtime/index.d.ts.map +1 -0
  397. package/dist/types/sync-store/encode.d.ts +25 -0
  398. package/dist/types/sync-store/encode.d.ts.map +1 -0
  399. package/dist/types/sync-store/index.d.ts +135 -0
  400. package/dist/types/sync-store/index.d.ts.map +1 -0
  401. package/dist/types/sync-store/migrations.d.ts +8 -0
  402. package/dist/types/sync-store/migrations.d.ts.map +1 -0
  403. package/dist/types/sync-store/schema.d.ts +1828 -0
  404. package/dist/types/sync-store/schema.d.ts.map +1 -0
  405. package/dist/types/types/db.d.ts +213 -0
  406. package/dist/types/types/db.d.ts.map +1 -0
  407. package/dist/types/types/eth.d.ts +196 -0
  408. package/dist/types/types/eth.d.ts.map +1 -0
  409. package/dist/types/types/utils.d.ts +38 -0
  410. package/dist/types/types/utils.d.ts.map +1 -0
  411. package/dist/types/types/virtual.d.ts +99 -0
  412. package/dist/types/types/virtual.d.ts.map +1 -0
  413. package/dist/types/ui/app.d.ts +22 -0
  414. package/dist/types/ui/app.d.ts.map +1 -0
  415. package/dist/types/ui/index.d.ts +5 -0
  416. package/dist/types/ui/index.d.ts.map +1 -0
  417. package/dist/types/ui/patch.d.ts +7 -0
  418. package/dist/types/ui/patch.d.ts.map +1 -0
  419. package/dist/types/utils/abi.d.ts +23 -0
  420. package/dist/types/utils/abi.d.ts.map +1 -0
  421. package/dist/types/utils/bigint.d.ts +15 -0
  422. package/dist/types/utils/bigint.d.ts.map +1 -0
  423. package/dist/types/utils/chains.d.ts +42 -0
  424. package/dist/types/utils/chains.d.ts.map +1 -0
  425. package/dist/types/utils/checkpoint.d.ts +52 -0
  426. package/dist/types/utils/checkpoint.d.ts.map +1 -0
  427. package/dist/types/utils/chunk.d.ts +2 -0
  428. package/dist/types/utils/chunk.d.ts.map +1 -0
  429. package/dist/types/utils/copy.d.ts +16 -0
  430. package/dist/types/utils/copy.d.ts.map +1 -0
  431. package/dist/types/utils/date.d.ts +7 -0
  432. package/dist/types/utils/date.d.ts.map +1 -0
  433. package/dist/types/utils/debug.d.ts +105 -0
  434. package/dist/types/utils/debug.d.ts.map +1 -0
  435. package/dist/types/utils/decodeAbiParameters.d.ts +28 -0
  436. package/dist/types/utils/decodeAbiParameters.d.ts.map +1 -0
  437. package/dist/types/utils/decodeEventLog.d.ts +12 -0
  438. package/dist/types/utils/decodeEventLog.d.ts.map +1 -0
  439. package/dist/types/utils/dedupe.d.ts +20 -0
  440. package/dist/types/utils/dedupe.d.ts.map +1 -0
  441. package/dist/types/utils/duplicates.d.ts +7 -0
  442. package/dist/types/utils/duplicates.d.ts.map +1 -0
  443. package/dist/types/utils/estimate.d.ts +11 -0
  444. package/dist/types/utils/estimate.d.ts.map +1 -0
  445. package/dist/types/utils/finality.d.ts +12 -0
  446. package/dist/types/utils/finality.d.ts.map +1 -0
  447. package/dist/types/utils/format.d.ts +3 -0
  448. package/dist/types/utils/format.d.ts.map +1 -0
  449. package/dist/types/utils/generators.d.ts +42 -0
  450. package/dist/types/utils/generators.d.ts.map +1 -0
  451. package/dist/types/utils/hash.d.ts +11 -0
  452. package/dist/types/utils/hash.d.ts.map +1 -0
  453. package/dist/types/utils/interval.d.ts +53 -0
  454. package/dist/types/utils/interval.d.ts.map +1 -0
  455. package/dist/types/utils/lowercase.d.ts +5 -0
  456. package/dist/types/utils/lowercase.d.ts.map +1 -0
  457. package/dist/types/utils/mutex.d.ts +5 -0
  458. package/dist/types/utils/mutex.d.ts.map +1 -0
  459. package/dist/types/utils/never.d.ts +2 -0
  460. package/dist/types/utils/never.d.ts.map +1 -0
  461. package/dist/types/utils/offset.d.ts +8 -0
  462. package/dist/types/utils/offset.d.ts.map +1 -0
  463. package/dist/types/utils/order.d.ts +2 -0
  464. package/dist/types/utils/order.d.ts.map +1 -0
  465. package/dist/types/utils/partition.d.ts +22 -0
  466. package/dist/types/utils/partition.d.ts.map +1 -0
  467. package/dist/types/utils/pg.d.ts +8 -0
  468. package/dist/types/utils/pg.d.ts.map +1 -0
  469. package/dist/types/utils/pglite.d.ts +25 -0
  470. package/dist/types/utils/pglite.d.ts.map +1 -0
  471. package/dist/types/utils/port.d.ts +5 -0
  472. package/dist/types/utils/port.d.ts.map +1 -0
  473. package/dist/types/utils/print.d.ts +2 -0
  474. package/dist/types/utils/print.d.ts.map +1 -0
  475. package/dist/types/utils/promiseAllSettledWithThrow.d.ts +8 -0
  476. package/dist/types/utils/promiseAllSettledWithThrow.d.ts.map +1 -0
  477. package/dist/types/utils/promiseWithResolvers.d.ts +10 -0
  478. package/dist/types/utils/promiseWithResolvers.d.ts.map +1 -0
  479. package/dist/types/utils/queue.d.ts +33 -0
  480. package/dist/types/utils/queue.d.ts.map +1 -0
  481. package/dist/types/utils/range.d.ts +8 -0
  482. package/dist/types/utils/range.d.ts.map +1 -0
  483. package/dist/types/utils/result.d.ts +17 -0
  484. package/dist/types/utils/result.d.ts.map +1 -0
  485. package/dist/types/utils/sql-parse.d.ts +21 -0
  486. package/dist/types/utils/sql-parse.d.ts.map +1 -0
  487. package/dist/types/utils/timer.d.ts +6 -0
  488. package/dist/types/utils/timer.d.ts.map +1 -0
  489. package/dist/types/utils/truncate.d.ts +9 -0
  490. package/dist/types/utils/truncate.d.ts.map +1 -0
  491. package/dist/types/utils/wait.d.ts +6 -0
  492. package/dist/types/utils/wait.d.ts.map +1 -0
  493. package/dist/types/utils/zipper.d.ts +36 -0
  494. package/dist/types/utils/zipper.d.ts.map +1 -0
  495. package/package.json +114 -0
  496. package/src/bin/commands/codegen.ts +56 -0
  497. package/src/bin/commands/createViews.ts +318 -0
  498. package/src/bin/commands/dev.ts +490 -0
  499. package/src/bin/commands/list.ts +208 -0
  500. package/src/bin/commands/prune.ts +322 -0
  501. package/src/bin/commands/serve.ts +236 -0
  502. package/src/bin/commands/start.ts +319 -0
  503. package/src/bin/isolatedController.ts +300 -0
  504. package/src/bin/isolatedWorker.ts +192 -0
  505. package/src/bin/ponder.ts +208 -0
  506. package/src/bin/utils/codegen.ts +32 -0
  507. package/src/bin/utils/exit.ts +112 -0
  508. package/src/build/config.ts +1141 -0
  509. package/src/build/factory.ts +147 -0
  510. package/src/build/index.ts +790 -0
  511. package/src/build/plugin.ts +58 -0
  512. package/src/build/pre.ts +114 -0
  513. package/src/build/schema.ts +358 -0
  514. package/src/build/stacktrace.ts +137 -0
  515. package/src/client/index.ts +551 -0
  516. package/src/config/address.ts +45 -0
  517. package/src/config/eventFilter.ts +33 -0
  518. package/src/config/index.ts +240 -0
  519. package/src/config/utilityTypes.ts +152 -0
  520. package/src/database/actions.ts +873 -0
  521. package/src/database/index.ts +1029 -0
  522. package/src/database/queryBuilder.ts +537 -0
  523. package/src/drizzle/bigint.ts +57 -0
  524. package/src/drizzle/bytes.ts +68 -0
  525. package/src/drizzle/hex.ts +58 -0
  526. package/src/drizzle/index.ts +40 -0
  527. package/src/drizzle/json.ts +159 -0
  528. package/src/drizzle/kit/index.ts +1348 -0
  529. package/src/drizzle/onchain.ts +476 -0
  530. package/src/drizzle/text.ts +77 -0
  531. package/src/graphql/graphiql.html.ts +59 -0
  532. package/src/graphql/index.ts +1351 -0
  533. package/src/graphql/json.ts +62 -0
  534. package/src/graphql/middleware.ts +115 -0
  535. package/src/index.ts +139 -0
  536. package/src/indexing/addStackTrace.ts +69 -0
  537. package/src/indexing/client.ts +1184 -0
  538. package/src/indexing/index.ts +976 -0
  539. package/src/indexing/profile.ts +771 -0
  540. package/src/indexing-store/cache.ts +1057 -0
  541. package/src/indexing-store/index.ts +628 -0
  542. package/src/indexing-store/profile.ts +557 -0
  543. package/src/indexing-store/utils.ts +162 -0
  544. package/src/internal/common.ts +15 -0
  545. package/src/internal/errors.ts +228 -0
  546. package/src/internal/logger.ts +252 -0
  547. package/src/internal/metrics.ts +1030 -0
  548. package/src/internal/options.ts +130 -0
  549. package/src/internal/shutdown.ts +32 -0
  550. package/src/internal/telemetry.ts +303 -0
  551. package/src/internal/types.ts +611 -0
  552. package/src/rpc/actions.ts +1344 -0
  553. package/src/rpc/http.ts +164 -0
  554. package/src/rpc/index.ts +959 -0
  555. package/src/runtime/events.ts +875 -0
  556. package/src/runtime/filter.ts +705 -0
  557. package/src/runtime/fragments.ts +674 -0
  558. package/src/runtime/historical.ts +1522 -0
  559. package/src/runtime/index.ts +569 -0
  560. package/src/runtime/init.ts +49 -0
  561. package/src/runtime/isolated.ts +775 -0
  562. package/src/runtime/multichain.ts +860 -0
  563. package/src/runtime/omnichain.ts +920 -0
  564. package/src/runtime/realtime.ts +1164 -0
  565. package/src/server/error.ts +68 -0
  566. package/src/server/index.ts +173 -0
  567. package/src/sync-historical/index.ts +1065 -0
  568. package/src/sync-realtime/bloom.ts +102 -0
  569. package/src/sync-realtime/index.ts +1304 -0
  570. package/src/sync-store/encode.ts +153 -0
  571. package/src/sync-store/index.ts +1633 -0
  572. package/src/sync-store/migrations.ts +1801 -0
  573. package/src/sync-store/schema.ts +248 -0
  574. package/src/types/db.ts +292 -0
  575. package/src/types/eth.ts +216 -0
  576. package/src/types/utils.ts +47 -0
  577. package/src/types/virtual.ts +244 -0
  578. package/src/types.d.ts +38 -0
  579. package/src/ui/app.ts +207 -0
  580. package/src/ui/index.ts +37 -0
  581. package/src/ui/patch.ts +204 -0
  582. package/src/utils/abi.ts +103 -0
  583. package/src/utils/bigint.ts +41 -0
  584. package/src/utils/chains.ts +22 -0
  585. package/src/utils/checkpoint.ts +203 -0
  586. package/src/utils/chunk.ts +7 -0
  587. package/src/utils/copy.ts +151 -0
  588. package/src/utils/date.ts +26 -0
  589. package/src/utils/debug.ts +110 -0
  590. package/src/utils/decodeAbiParameters.ts +428 -0
  591. package/src/utils/decodeEventLog.ts +100 -0
  592. package/src/utils/dedupe.ts +32 -0
  593. package/src/utils/duplicates.ts +19 -0
  594. package/src/utils/estimate.ts +27 -0
  595. package/src/utils/finality.ts +40 -0
  596. package/src/utils/format.ts +22 -0
  597. package/src/utils/generators.ts +157 -0
  598. package/src/utils/hash.ts +22 -0
  599. package/src/utils/interval.ts +212 -0
  600. package/src/utils/lowercase.ts +6 -0
  601. package/src/utils/mutex.ts +33 -0
  602. package/src/utils/never.ts +3 -0
  603. package/src/utils/offset.ts +133 -0
  604. package/src/utils/order.ts +16 -0
  605. package/src/utils/partition.ts +53 -0
  606. package/src/utils/pg.ts +230 -0
  607. package/src/utils/pglite.ts +97 -0
  608. package/src/utils/port.ts +34 -0
  609. package/src/utils/print.ts +31 -0
  610. package/src/utils/promiseAllSettledWithThrow.ts +27 -0
  611. package/src/utils/promiseWithResolvers.ts +20 -0
  612. package/src/utils/queue.ts +258 -0
  613. package/src/utils/range.ts +8 -0
  614. package/src/utils/result.ts +26 -0
  615. package/src/utils/sql-parse.ts +1477 -0
  616. package/src/utils/timer.ts +8 -0
  617. package/src/utils/truncate.ts +15 -0
  618. package/src/utils/wait.ts +8 -0
  619. package/src/utils/zipper.ts +80 -0
@@ -0,0 +1,976 @@
1
+ import util from "node:util";
2
+ import type { IndexingCache } from "@/indexing-store/cache.js";
3
+ import type { IndexingStore } from "@/indexing-store/index.js";
4
+ import type { CachedViemClient } from "@/indexing/client.js";
5
+ import type { Common } from "@/internal/common.js";
6
+ import {
7
+ BaseError,
8
+ IndexingFunctionError,
9
+ InvalidEventAccessError,
10
+ ShutdownError,
11
+ } from "@/internal/errors.js";
12
+ import type {
13
+ Chain,
14
+ Contract,
15
+ Event,
16
+ Filter,
17
+ IndexingBuild,
18
+ IndexingErrorHandler,
19
+ Schema,
20
+ SetupEvent,
21
+ UserBlock,
22
+ UserLog,
23
+ UserTrace,
24
+ UserTransaction,
25
+ } from "@/internal/types.js";
26
+ import {
27
+ defaultBlockFilterInclude,
28
+ defaultBlockInclude,
29
+ defaultLogFilterInclude,
30
+ defaultTraceFilterInclude,
31
+ defaultTraceInclude,
32
+ defaultTransactionFilterInclude,
33
+ defaultTransactionInclude,
34
+ defaultTransactionReceiptInclude,
35
+ defaultTransferFilterInclude,
36
+ requiredBlockFilterInclude,
37
+ requiredLogFilterInclude,
38
+ requiredTraceFilterInclude,
39
+ requiredTransactionFilterInclude,
40
+ requiredTransactionReceiptInclude,
41
+ requiredTransferFilterInclude,
42
+ } from "@/runtime/filter.js";
43
+ import type { Db } from "@/types/db.js";
44
+ import type {
45
+ Block,
46
+ Trace,
47
+ Transaction,
48
+ TransactionReceipt,
49
+ } from "@/types/eth.js";
50
+ import type { DeepPartial } from "@/types/utils.js";
51
+ import {
52
+ ZERO_CHECKPOINT,
53
+ decodeCheckpoint,
54
+ encodeCheckpoint,
55
+ } from "@/utils/checkpoint.js";
56
+ import { dedupe } from "@/utils/dedupe.js";
57
+ import { prettyPrint } from "@/utils/print.js";
58
+ import { startClock } from "@/utils/timer.js";
59
+ import type { Abi, Address } from "viem";
60
+ import { addStackTrace } from "./addStackTrace.js";
61
+ import type { ReadonlyClient } from "./client.js";
62
+
63
+ declare global {
64
+ var DISABLE_EVENT_PROXY: boolean;
65
+ }
66
+ globalThis.DISABLE_EVENT_PROXY = false;
67
+
68
+ const EVENT_LOOP_UPDATE_INTERVAL = 25;
69
+ const METRICS_UPDATE_INTERVAL = 100;
70
+
71
+ export type Context = {
72
+ chain: { id: number; name: string };
73
+ client: ReadonlyClient;
74
+ db: Db<Schema>;
75
+ contracts: Record<
76
+ string,
77
+ {
78
+ abi: Abi;
79
+ address?: Address | readonly Address[];
80
+ startBlock?: number;
81
+ endBlock?: number;
82
+ }
83
+ >;
84
+ };
85
+
86
+ export type Indexing = {
87
+ processSetupEvents: () => Promise<void>;
88
+ processHistoricalEvents: (params: {
89
+ events: Event[];
90
+ updateIndexingSeconds: (event: Event, chain: Chain) => void;
91
+ }) => Promise<void>;
92
+ processRealtimeEvents: (params: { events: Event[] }) => Promise<void>;
93
+ };
94
+
95
+ export const getEventCount = (
96
+ indexingFunctions: IndexingBuild["indexingFunctions"],
97
+ ) => {
98
+ const eventCount: { [eventName: string]: number } = {};
99
+ for (const { name: eventName } of indexingFunctions) {
100
+ eventCount[eventName] = 0;
101
+ }
102
+ return eventCount;
103
+ };
104
+
105
+ export type ColumnAccessProfile = {
106
+ block: Set<keyof Block>;
107
+ trace: Set<keyof Trace>;
108
+ transaction: Set<keyof Transaction>;
109
+ transactionReceipt: Set<keyof TransactionReceipt>;
110
+ resolved: boolean;
111
+ count: number;
112
+ };
113
+
114
+ export type ColumnAccessPattern = Map<string, ColumnAccessProfile>;
115
+
116
+ export const createColumnAccessPattern = ({
117
+ indexingBuild,
118
+ }: {
119
+ indexingBuild: Pick<IndexingBuild, "indexingFunctions">;
120
+ }): ColumnAccessPattern => {
121
+ const columnAccessPattern = new Map<string, ColumnAccessProfile>();
122
+
123
+ for (const { name: eventName } of indexingBuild.indexingFunctions) {
124
+ columnAccessPattern.set(eventName, {
125
+ block: new Set(),
126
+ trace: new Set(),
127
+ transaction: new Set(),
128
+ transactionReceipt: new Set(),
129
+ resolved: false,
130
+ count: 0,
131
+ });
132
+ }
133
+
134
+ return columnAccessPattern;
135
+ };
136
+
137
+ export const createIndexing = ({
138
+ common,
139
+ indexingBuild: {
140
+ eventCallbacks,
141
+ setupCallbacks,
142
+ chains,
143
+ contracts,
144
+ indexingFunctions,
145
+ },
146
+ indexingStore,
147
+ indexingCache,
148
+ client,
149
+ indexingErrorHandler,
150
+ columnAccessPattern,
151
+ eventCount,
152
+ }: {
153
+ common: Common;
154
+ indexingBuild: Pick<
155
+ IndexingBuild,
156
+ | "eventCallbacks"
157
+ | "setupCallbacks"
158
+ | "chains"
159
+ | "contracts"
160
+ | "indexingFunctions"
161
+ >;
162
+ indexingStore: IndexingStore;
163
+ indexingCache: IndexingCache;
164
+ client: CachedViemClient;
165
+ indexingErrorHandler: IndexingErrorHandler;
166
+ columnAccessPattern: ColumnAccessPattern;
167
+ eventCount: { [eventName: string]: number };
168
+ }): Indexing => {
169
+ const indexingFunctionArg = {
170
+ event: undefined as Event | SetupEvent | undefined,
171
+ context: {
172
+ chain: { name: undefined!, id: undefined! },
173
+ contracts: undefined!,
174
+ client: undefined!,
175
+ db: indexingStore.db,
176
+ } as Context,
177
+ };
178
+
179
+ let lastChainId: number | undefined;
180
+ const clientByChainId: { [chainId: number]: ReadonlyClient } = {};
181
+ const contractsByChainId: {
182
+ [chainId: number]: { [name: string]: Contract };
183
+ } = {};
184
+
185
+ for (const chain of chains) {
186
+ clientByChainId[chain.id] = client.getClient(chain);
187
+ }
188
+
189
+ for (let i = 0; i < chains.length; i++) {
190
+ const chain = chains[i]!;
191
+ contractsByChainId[chain.id] = contracts[i]!;
192
+ }
193
+
194
+ const metricLabels: { [event: string]: { event: string } } = {};
195
+ for (const { name } of indexingFunctions) {
196
+ metricLabels[name] = { event: name };
197
+ }
198
+
199
+ const executeSetup = async (event: SetupEvent): Promise<void> => {
200
+ try {
201
+ if (event.chain.id !== lastChainId) {
202
+ indexingFunctionArg.context.chain.id = event.chain.id;
203
+ indexingFunctionArg.context.chain.name = event.chain.name;
204
+ indexingFunctionArg.context.contracts =
205
+ contractsByChainId[event.chain.id]!;
206
+ indexingFunctionArg.context.client = clientByChainId[event.chain.id]!;
207
+
208
+ lastChainId = event.chain.id;
209
+ }
210
+
211
+ const endClock = startClock();
212
+
213
+ await event.setupCallback.fn(indexingFunctionArg);
214
+
215
+ // Note: Check `getRetryableError` to handle user-code catching errors
216
+ // from the indexing store.
217
+
218
+ if (indexingErrorHandler.getRetryableError()) {
219
+ const retryableError = indexingErrorHandler.getRetryableError()!;
220
+ indexingErrorHandler.clearRetryableError();
221
+ throw retryableError;
222
+ }
223
+
224
+ common.metrics.ponder_indexing_function_duration.observe(
225
+ metricLabels[event.setupCallback.name]!,
226
+ endClock(),
227
+ );
228
+ } catch (_error) {
229
+ let error = _error instanceof Error ? _error : new Error(String(_error));
230
+
231
+ // Note: Use `getRetryableError` rather than `error` to avoid
232
+ // issues with the user-code augmenting errors from the indexing store.
233
+
234
+ if (indexingErrorHandler.getRetryableError()) {
235
+ const retryableError = indexingErrorHandler.getRetryableError()!;
236
+ indexingErrorHandler.clearRetryableError();
237
+ error = retryableError;
238
+ }
239
+
240
+ if (common.shutdown.isKilled) {
241
+ throw new ShutdownError();
242
+ }
243
+
244
+ addStackTrace(error, common.options);
245
+ addErrorMeta(error, toErrorMeta(event));
246
+
247
+ const decodedCheckpoint = decodeCheckpoint(event.checkpoint);
248
+ common.logger.error({
249
+ msg: "Error while processing event",
250
+ event: event.setupCallback.name,
251
+ chain: event.chain.name,
252
+ chain_id: event.chain.id,
253
+ block_number: decodedCheckpoint.blockNumber,
254
+ error,
255
+ });
256
+
257
+ common.metrics.hasError = true;
258
+
259
+ if (error instanceof BaseError === false) {
260
+ error = new IndexingFunctionError(error.message);
261
+ }
262
+
263
+ throw error;
264
+ }
265
+ };
266
+
267
+ // metric label for "ponder_indexing_function_duration"
268
+ const executeEvent = async (event: Event): Promise<void> => {
269
+ try {
270
+ if (event.chain.id !== lastChainId) {
271
+ indexingFunctionArg.context.chain.id = event.chain.id;
272
+ indexingFunctionArg.context.chain.name = event.chain.name;
273
+ indexingFunctionArg.context.contracts =
274
+ contractsByChainId[event.chain.id]!;
275
+ indexingFunctionArg.context.client = clientByChainId[event.chain.id]!;
276
+
277
+ lastChainId = event.chain.id;
278
+ }
279
+ // @ts-ignore
280
+ indexingFunctionArg.event = event.event;
281
+
282
+ const endClock = startClock();
283
+
284
+ await event.eventCallback.fn(indexingFunctionArg);
285
+
286
+ common.metrics.ponder_indexing_function_duration.observe(
287
+ metricLabels[event.eventCallback.name]!,
288
+ endClock(),
289
+ );
290
+
291
+ // Note: Check `getRetryableError` to handle user-code catching errors
292
+ // from the indexing store.
293
+
294
+ if (indexingErrorHandler.getRetryableError()) {
295
+ const retryableError = indexingErrorHandler.getRetryableError()!;
296
+ indexingErrorHandler.clearRetryableError();
297
+ throw retryableError;
298
+ }
299
+ } catch (_error) {
300
+ let error = _error instanceof Error ? _error : new Error(String(_error));
301
+
302
+ // Note: Use `getRetryableError` rather than `error` to avoid
303
+ // issues with the user-code augmenting errors from the indexing store.
304
+
305
+ if (indexingErrorHandler.getRetryableError()) {
306
+ const retryableError = indexingErrorHandler.getRetryableError()!;
307
+ indexingErrorHandler.clearRetryableError();
308
+ error = retryableError;
309
+ }
310
+
311
+ if (common.shutdown.isKilled) {
312
+ throw new ShutdownError();
313
+ }
314
+
315
+ if (error instanceof InvalidEventAccessError) {
316
+ throw error;
317
+ }
318
+
319
+ addStackTrace(error, common.options);
320
+ addErrorMeta(error, toErrorMeta(event));
321
+
322
+ const decodedCheckpoint = decodeCheckpoint(event.checkpoint);
323
+
324
+ common.logger.error({
325
+ msg: "Error while processing event",
326
+ event: event.eventCallback.name,
327
+ chain: event.chain.name,
328
+ chain_id: event.chain.id,
329
+ block_number: decodedCheckpoint.blockNumber,
330
+ error,
331
+ });
332
+
333
+ common.metrics.hasError = true;
334
+
335
+ if (error instanceof BaseError === false) {
336
+ error = new IndexingFunctionError(error.message);
337
+ }
338
+
339
+ throw error;
340
+ }
341
+ };
342
+
343
+ const resetFilterInclude = (eventName: string) => {
344
+ const filters = perEventFilters.get(eventName)!;
345
+ let include: Filter["include"];
346
+
347
+ // Note: It's an invariant that all filters have the same type.
348
+ switch (filters[0]!.type) {
349
+ case "block": {
350
+ include = defaultBlockFilterInclude;
351
+ break;
352
+ }
353
+ case "transaction": {
354
+ include = defaultTransactionFilterInclude;
355
+ break;
356
+ }
357
+ case "trace": {
358
+ include = defaultTraceFilterInclude.concat(
359
+ filters[0]!.hasTransactionReceipt
360
+ ? defaultTransactionReceiptInclude.map(
361
+ (value) => `transactionReceipt.${value}` as const,
362
+ )
363
+ : [],
364
+ );
365
+ break;
366
+ }
367
+ case "log": {
368
+ include = defaultLogFilterInclude.concat(
369
+ filters[0]!.hasTransactionReceipt
370
+ ? defaultTransactionReceiptInclude.map(
371
+ (value) => `transactionReceipt.${value}` as const,
372
+ )
373
+ : [],
374
+ );
375
+ break;
376
+ }
377
+ case "transfer": {
378
+ include = defaultTransferFilterInclude.concat(
379
+ filters[0]!.hasTransactionReceipt
380
+ ? defaultTransactionReceiptInclude.map(
381
+ (value) => `transactionReceipt.${value}` as const,
382
+ )
383
+ : [],
384
+ );
385
+ break;
386
+ }
387
+ }
388
+ for (const filter of filters) {
389
+ isFilterResolved.set(filter, false);
390
+ filter.include = include;
391
+ }
392
+ columnAccessPattern.get(eventName)!.count = 0;
393
+ };
394
+
395
+ const blockProxy = createEventProxy<Block>(
396
+ columnAccessPattern,
397
+ "block",
398
+ indexingErrorHandler,
399
+ resetFilterInclude,
400
+ );
401
+ const transactionProxy = createEventProxy<Transaction>(
402
+ columnAccessPattern,
403
+ "transaction",
404
+ indexingErrorHandler,
405
+ resetFilterInclude,
406
+ );
407
+ const transactionReceiptProxy = createEventProxy<TransactionReceipt>(
408
+ columnAccessPattern,
409
+ "transactionReceipt",
410
+ indexingErrorHandler,
411
+ resetFilterInclude,
412
+ );
413
+ const traceProxy = createEventProxy<Trace>(
414
+ columnAccessPattern,
415
+ "trace",
416
+ indexingErrorHandler,
417
+ resetFilterInclude,
418
+ );
419
+ // Note: There is no `log` proxy because all log columns are required.
420
+
421
+ // Note: Indexing functions map to one or more filters.
422
+ const perEventFilters = new Map<string, Filter[]>();
423
+ const isFilterResolved = new Map<Filter, boolean>();
424
+ for (const eventCallback of eventCallbacks.flat()) {
425
+ if (perEventFilters.has(eventCallback.name) === false) {
426
+ perEventFilters.set(eventCallback.name, [eventCallback.filter]);
427
+ } else {
428
+ perEventFilters.get(eventCallback.name)!.push(eventCallback.filter);
429
+ }
430
+
431
+ isFilterResolved.set(eventCallback.filter, false);
432
+ }
433
+
434
+ return {
435
+ async processSetupEvents() {
436
+ for (const setupCallback of setupCallbacks.flat()) {
437
+ const event = {
438
+ type: "setup",
439
+ chain: setupCallback.chain,
440
+ setupCallback,
441
+ checkpoint: encodeCheckpoint({
442
+ ...ZERO_CHECKPOINT,
443
+ chainId: BigInt(setupCallback.chain.id),
444
+ blockNumber: BigInt(setupCallback.block ?? 0),
445
+ }),
446
+ block: BigInt(setupCallback.block ?? 0),
447
+ } satisfies SetupEvent;
448
+
449
+ client.event = event;
450
+
451
+ await executeSetup(event);
452
+ }
453
+ },
454
+ async processHistoricalEvents({ events, updateIndexingSeconds }) {
455
+ let lastEventLoopUpdate = performance.now();
456
+ let lastMetricsUpdate = performance.now();
457
+
458
+ for (let i = 0; i < events.length; i++) {
459
+ const event = events[i]!;
460
+
461
+ client.event = event;
462
+ indexingCache.event = event;
463
+
464
+ // Note: Create a new event object instead of mutuating the original one because
465
+ // the event object could be reused across multiple indexing functions.
466
+ const proxyEvent: typeof event.event = { ...event.event };
467
+
468
+ switch (event.type) {
469
+ case "block": {
470
+ blockProxy.eventName = event.eventCallback.name;
471
+ blockProxy.underlying = event.event.block as Block;
472
+ proxyEvent.block = blockProxy.proxy;
473
+
474
+ break;
475
+ }
476
+ case "transaction": {
477
+ blockProxy.eventName = event.eventCallback.name;
478
+ blockProxy.underlying = event.event.block as Block;
479
+ proxyEvent.block = blockProxy.proxy;
480
+
481
+ transactionProxy.eventName = event.eventCallback.name;
482
+ transactionProxy.underlying = event.event
483
+ .transaction as Transaction;
484
+ // @ts-expect-error
485
+ proxyEvent.transaction = transactionProxy.proxy;
486
+
487
+ if (event.event.transactionReceipt !== undefined) {
488
+ transactionReceiptProxy.eventName = event.eventCallback.name;
489
+ transactionReceiptProxy.underlying = event.event
490
+ .transactionReceipt as TransactionReceipt;
491
+ // @ts-expect-error
492
+ proxyEvent.transactionReceipt = transactionReceiptProxy.proxy;
493
+ }
494
+
495
+ break;
496
+ }
497
+ case "trace":
498
+ case "transfer": {
499
+ blockProxy.eventName = event.eventCallback.name;
500
+ blockProxy.underlying = event.event.block as Block;
501
+ proxyEvent.block = blockProxy.proxy;
502
+
503
+ transactionProxy.eventName = event.eventCallback.name;
504
+ transactionProxy.underlying = event.event
505
+ .transaction as Transaction;
506
+ // @ts-expect-error
507
+ proxyEvent.transaction = transactionProxy.proxy;
508
+
509
+ if (event.event.transactionReceipt !== undefined) {
510
+ transactionReceiptProxy.eventName = event.eventCallback.name;
511
+ transactionReceiptProxy.underlying = event.event
512
+ .transactionReceipt as TransactionReceipt;
513
+ // @ts-expect-error
514
+ proxyEvent.transactionReceipt = transactionReceiptProxy.proxy;
515
+ }
516
+
517
+ traceProxy.eventName = event.eventCallback.name;
518
+ traceProxy.underlying = event.event.trace as Trace;
519
+ // @ts-expect-error
520
+ proxyEvent.trace = traceProxy.proxy;
521
+
522
+ break;
523
+ }
524
+ case "log": {
525
+ blockProxy.eventName = event.eventCallback.name;
526
+ blockProxy.underlying = event.event.block as Block;
527
+ proxyEvent.block = blockProxy.proxy;
528
+
529
+ if (event.event.transaction !== undefined) {
530
+ transactionProxy.eventName = event.eventCallback.name;
531
+ transactionProxy.underlying = event.event
532
+ .transaction as Transaction;
533
+ // @ts-expect-error
534
+ proxyEvent.transaction = transactionProxy.proxy;
535
+ }
536
+
537
+ if (event.event.transactionReceipt !== undefined) {
538
+ transactionReceiptProxy.eventName = event.eventCallback.name;
539
+ transactionReceiptProxy.underlying = event.event
540
+ .transactionReceipt as TransactionReceipt;
541
+ // @ts-expect-error
542
+ proxyEvent.transactionReceipt = transactionReceiptProxy.proxy;
543
+ }
544
+
545
+ break;
546
+ }
547
+ }
548
+
549
+ // @ts-expect-error
550
+ await executeEvent({ ...event, event: proxyEvent });
551
+
552
+ common.metrics.ponder_indexing_completed_events.inc(
553
+ { event: event.eventCallback.name },
554
+ 1,
555
+ );
556
+ columnAccessPattern.get(event.eventCallback.name)!.count++;
557
+ eventCount[event.eventCallback.name]++;
558
+
559
+ const now = performance.now();
560
+
561
+ if (now - lastEventLoopUpdate > EVENT_LOOP_UPDATE_INTERVAL) {
562
+ lastEventLoopUpdate = now;
563
+ await new Promise(setImmediate);
564
+ }
565
+
566
+ if (now - lastMetricsUpdate > METRICS_UPDATE_INTERVAL) {
567
+ lastMetricsUpdate = now;
568
+ updateIndexingSeconds(event, event.chain);
569
+ }
570
+ }
571
+
572
+ let isEveryFilterResolvedBefore = true;
573
+ let isEveryFilterResolvedAfter = true;
574
+
575
+ for (const eventCallback of eventCallbacks.flat()) {
576
+ if (isFilterResolved.get(eventCallback.filter)) continue;
577
+
578
+ isEveryFilterResolvedBefore = false;
579
+
580
+ if (columnAccessPattern.get(eventCallback.name)!.count < 100) {
581
+ isEveryFilterResolvedAfter = false;
582
+ continue;
583
+ }
584
+ isFilterResolved.set(eventCallback.filter, true);
585
+
586
+ const filterInclude: Filter["include"] = [];
587
+
588
+ const columnAccessProfile = columnAccessPattern.get(
589
+ eventCallback.name,
590
+ )!;
591
+ columnAccessProfile.resolved = true;
592
+
593
+ for (const column of columnAccessProfile.block) {
594
+ filterInclude.push(`block.${column}` as const);
595
+ }
596
+ for (const column of columnAccessProfile.transaction) {
597
+ // @ts-expect-error
598
+ filterInclude.push(`transaction.${column}` as const);
599
+ }
600
+ for (const column of columnAccessProfile.transactionReceipt) {
601
+ // @ts-expect-error
602
+ filterInclude.push(`transactionReceipt.${column}` as const);
603
+ }
604
+ for (const column of columnAccessProfile.trace) {
605
+ // @ts-expect-error
606
+ filterInclude.push(`trace.${column}` as const);
607
+ }
608
+
609
+ switch (eventCallback.filter.type) {
610
+ case "block": {
611
+ filterInclude.push(...requiredBlockFilterInclude);
612
+ break;
613
+ }
614
+ case "transaction": {
615
+ // @ts-expect-error
616
+ filterInclude.push(...requiredTransactionFilterInclude);
617
+ break;
618
+ }
619
+ case "trace": {
620
+ // @ts-expect-error
621
+ filterInclude.push(...requiredTraceFilterInclude);
622
+ if (eventCallback.filter.hasTransactionReceipt) {
623
+ filterInclude.push(
624
+ // @ts-expect-error
625
+ ...requiredTransactionReceiptInclude.map(
626
+ (value) => `transactionReceipt.${value}` as const,
627
+ ),
628
+ );
629
+ }
630
+ break;
631
+ }
632
+ case "log": {
633
+ // @ts-expect-error
634
+ filterInclude.push(...requiredLogFilterInclude);
635
+ if (eventCallback.filter.hasTransactionReceipt) {
636
+ filterInclude.push(
637
+ // @ts-expect-error
638
+ ...requiredTransactionReceiptInclude.map(
639
+ (value) => `transactionReceipt.${value}` as const,
640
+ ),
641
+ );
642
+ }
643
+ break;
644
+ }
645
+ case "transfer": {
646
+ // @ts-expect-error
647
+ filterInclude.push(...requiredTransferFilterInclude);
648
+ if (eventCallback.filter.hasTransactionReceipt) {
649
+ filterInclude.push(
650
+ // @ts-expect-error
651
+ ...requiredTransactionReceiptInclude.map(
652
+ (value) => `transactionReceipt.${value}` as const,
653
+ ),
654
+ );
655
+ }
656
+ break;
657
+ }
658
+ }
659
+
660
+ // @ts-expect-error
661
+ eventCallback.filter.include = dedupe(filterInclude);
662
+ }
663
+
664
+ if (isEveryFilterResolvedBefore === false && isEveryFilterResolvedAfter) {
665
+ const blockInclude = new Set<keyof Block>();
666
+ const transactionInclude = new Set<keyof Transaction>();
667
+ const transactionReceiptInclude = new Set<keyof TransactionReceipt>();
668
+ const traceInclude = new Set<keyof Trace>();
669
+
670
+ for (const [_, columnAccessProfile] of columnAccessPattern) {
671
+ for (const blockAccess of columnAccessProfile.block) {
672
+ blockInclude.add(blockAccess);
673
+ }
674
+ for (const transactionAccess of columnAccessProfile.transaction) {
675
+ transactionInclude.add(transactionAccess);
676
+ }
677
+ for (const transactionReceiptAccess of columnAccessProfile.transactionReceipt) {
678
+ transactionReceiptInclude.add(transactionReceiptAccess);
679
+ }
680
+ for (const traceAccess of columnAccessProfile.trace) {
681
+ traceInclude.add(traceAccess);
682
+ }
683
+ }
684
+
685
+ common.logger.debug(
686
+ {
687
+ msg: "Resolved event property access",
688
+ total_access_count:
689
+ blockInclude.size +
690
+ transactionInclude.size +
691
+ transactionReceiptInclude.size +
692
+ traceInclude.size,
693
+ block_count: blockInclude.size,
694
+ transaction_count: transactionInclude.size,
695
+ transaction_receipt_count: transactionReceiptInclude.size,
696
+ trace_count: traceInclude.size,
697
+ },
698
+ ["total_access_count"],
699
+ );
700
+ }
701
+
702
+ await new Promise(setImmediate);
703
+ if (events.length > 0) {
704
+ updateIndexingSeconds(
705
+ events[events.length - 1]!,
706
+ events[events.length - 1]!.chain,
707
+ );
708
+ }
709
+ },
710
+ async processRealtimeEvents({ events }) {
711
+ for (let i = 0; i < events.length; i++) {
712
+ const event = events[i]!;
713
+
714
+ client.event = event;
715
+
716
+ await executeEvent(event);
717
+
718
+ common.metrics.ponder_indexing_completed_events.inc(
719
+ { event: event.eventCallback.name },
720
+ 1,
721
+ );
722
+ eventCount[event.eventCallback.name]++;
723
+ }
724
+ },
725
+ };
726
+ };
727
+
728
+ export const createEventProxy = <
729
+ T extends Block | Transaction | TransactionReceipt | Trace,
730
+ >(
731
+ columnAccessPattern: ColumnAccessPattern,
732
+ type: "block" | "trace" | "transaction" | "transactionReceipt",
733
+ indexingErrorHandler: IndexingErrorHandler,
734
+ resetFilterInclude: (eventName: string) => void,
735
+ ): { proxy: T; underlying: T; eventName: string } => {
736
+ let underlying: T = undefined!;
737
+ let eventName: string = undefined!;
738
+
739
+ // Note: We rely on the fact that `default[type]Include` is the entire set of possible columns.
740
+ let defaultInclude: Set<keyof T>;
741
+ if (type === "block") {
742
+ // @ts-expect-error
743
+ defaultInclude = new Set(defaultBlockInclude);
744
+ } else if (type === "trace") {
745
+ // @ts-expect-error
746
+ defaultInclude = new Set(defaultTraceInclude);
747
+ } else if (type === "transaction") {
748
+ // @ts-expect-error
749
+ defaultInclude = new Set(defaultTransactionInclude);
750
+ } else if (type === "transactionReceipt") {
751
+ // @ts-expect-error
752
+ defaultInclude = new Set(defaultTransactionReceiptInclude);
753
+ }
754
+
755
+ const proxy = new Proxy<T>(
756
+ // @ts-expect-error
757
+ {
758
+ [util.inspect.custom]: (): T => {
759
+ const printableObject = {} as T;
760
+
761
+ for (const prop of defaultInclude) {
762
+ printableObject[prop] = proxy[prop];
763
+ }
764
+
765
+ return printableObject;
766
+ },
767
+ },
768
+ {
769
+ deleteProperty(_, prop) {
770
+ if (
771
+ // @ts-expect-error
772
+ defaultInclude.has(prop) === false ||
773
+ globalThis.DISABLE_EVENT_PROXY
774
+ ) {
775
+ return Reflect.deleteProperty(underlying, prop);
776
+ }
777
+
778
+ const profile = columnAccessPattern.get(eventName)!;
779
+ const isInvalidAccess = prop in underlying === false;
780
+ // @ts-expect-error
781
+ profile[type].add(prop);
782
+
783
+ if (isInvalidAccess) {
784
+ profile.resolved = false;
785
+ resetFilterInclude(eventName);
786
+ // @ts-expect-error
787
+ const error = new InvalidEventAccessError(`${type}.${prop}`);
788
+ indexingErrorHandler.setRetryableError(error);
789
+ throw error;
790
+ }
791
+
792
+ return Reflect.deleteProperty(underlying, prop);
793
+ },
794
+ has(_, prop) {
795
+ // @ts-expect-error
796
+ return defaultInclude.has(prop);
797
+ },
798
+ ownKeys() {
799
+ return Array.from(defaultInclude);
800
+ },
801
+ set(_, prop, value) {
802
+ if (
803
+ // @ts-expect-error
804
+ defaultInclude.has(prop) === false ||
805
+ globalThis.DISABLE_EVENT_PROXY
806
+ ) {
807
+ return Reflect.set(underlying, prop, value);
808
+ }
809
+
810
+ const profile = columnAccessPattern.get(eventName)!;
811
+ const isInvalidAccess = prop in underlying === false;
812
+ // @ts-expect-error
813
+ profile[type].add(prop);
814
+
815
+ if (isInvalidAccess) {
816
+ profile.resolved = false;
817
+ resetFilterInclude(eventName);
818
+ // @ts-expect-error
819
+ const error = new InvalidEventAccessError(`${type}.${prop}`);
820
+ indexingErrorHandler.setRetryableError(error);
821
+ throw error;
822
+ }
823
+
824
+ return Reflect.set(underlying, prop, value);
825
+ },
826
+ get(_, prop, receiver) {
827
+ if (
828
+ // @ts-expect-error
829
+ defaultInclude.has(prop) === false ||
830
+ globalThis.DISABLE_EVENT_PROXY
831
+ ) {
832
+ return Reflect.get(underlying, prop, receiver);
833
+ }
834
+
835
+ const profile = columnAccessPattern.get(eventName)!;
836
+ const isInvalidAccess = prop in underlying === false;
837
+ // @ts-expect-error
838
+ profile[type].add(prop);
839
+
840
+ if (isInvalidAccess) {
841
+ profile.resolved = false;
842
+ resetFilterInclude(eventName);
843
+ // @ts-expect-error
844
+ const error = new InvalidEventAccessError(`${type}.${prop}`);
845
+ indexingErrorHandler.setRetryableError(error);
846
+ throw error;
847
+ }
848
+
849
+ return Reflect.get(underlying, prop, receiver);
850
+ },
851
+ },
852
+ );
853
+
854
+ return {
855
+ proxy,
856
+ set underlying(_underlying: T) {
857
+ underlying = _underlying;
858
+ },
859
+ set eventName(_eventName: string) {
860
+ eventName = _eventName;
861
+ },
862
+ };
863
+ };
864
+
865
+ export const toErrorMeta = (
866
+ event: DeepPartial<Event> | DeepPartial<SetupEvent>,
867
+ ) => {
868
+ globalThis.DISABLE_EVENT_PROXY = true;
869
+ switch (event?.type) {
870
+ case "setup": {
871
+ const meta = `Block:\n${prettyPrint({
872
+ number: event?.block,
873
+ })}`;
874
+ globalThis.DISABLE_EVENT_PROXY = false;
875
+ return meta;
876
+ }
877
+
878
+ case "log": {
879
+ const meta = [
880
+ `Event arguments:\n${prettyPrint(Array.isArray(event.event?.args) ? undefined : event.event?.args)}`,
881
+ logText(event?.event?.log),
882
+ transactionText(event?.event?.transaction),
883
+ blockText(event?.event?.block),
884
+ ].join("\n");
885
+ globalThis.DISABLE_EVENT_PROXY = false;
886
+ return meta;
887
+ }
888
+
889
+ case "trace": {
890
+ const meta = [
891
+ `Call trace arguments:\n${prettyPrint(Array.isArray(event.event?.args) ? undefined : event.event?.args)}`,
892
+ traceText(event?.event?.trace),
893
+ transactionText(event?.event?.transaction),
894
+ blockText(event?.event?.block),
895
+ ].join("\n");
896
+ globalThis.DISABLE_EVENT_PROXY = false;
897
+ return meta;
898
+ }
899
+
900
+ case "transfer": {
901
+ const meta = [
902
+ `Transfer arguments:\n${prettyPrint(event?.event?.transfer)}`,
903
+ traceText(event?.event?.trace),
904
+ transactionText(event?.event?.transaction),
905
+ blockText(event?.event?.block),
906
+ ].join("\n");
907
+ globalThis.DISABLE_EVENT_PROXY = false;
908
+ return meta;
909
+ }
910
+
911
+ case "block": {
912
+ const meta = blockText(event?.event?.block);
913
+ globalThis.DISABLE_EVENT_PROXY = false;
914
+ return meta;
915
+ }
916
+
917
+ case "transaction": {
918
+ const meta = [
919
+ transactionText(event?.event?.transaction),
920
+ blockText(event?.event?.block),
921
+ ].join("\n");
922
+ globalThis.DISABLE_EVENT_PROXY = false;
923
+ return meta;
924
+ }
925
+
926
+ default: {
927
+ return undefined;
928
+ }
929
+ }
930
+ };
931
+
932
+ export const addErrorMeta = (error: unknown, meta: string | undefined) => {
933
+ // If error isn't an object we can modify, do nothing
934
+ if (typeof error !== "object" || error === null) return;
935
+ if (meta === undefined) return;
936
+
937
+ try {
938
+ const errorObj = error as { meta?: unknown };
939
+ // If meta exists and is an array, try to add to it
940
+ if (Array.isArray(errorObj.meta)) {
941
+ errorObj.meta = [...errorObj.meta, meta];
942
+ } else {
943
+ // Otherwise set meta to be a new array with the meta string
944
+ errorObj.meta = [meta];
945
+ }
946
+ } catch {
947
+ // Ignore errors
948
+ }
949
+ };
950
+
951
+ const blockText = (block?: DeepPartial<UserBlock>) =>
952
+ `Block:\n${prettyPrint({
953
+ hash: block?.hash,
954
+ number: block?.number,
955
+ timestamp: block?.timestamp,
956
+ })}`;
957
+
958
+ const transactionText = (transaction?: DeepPartial<UserTransaction>) =>
959
+ `Transaction:\n${prettyPrint({
960
+ hash: transaction?.hash,
961
+ from: transaction?.from,
962
+ to: transaction?.to,
963
+ })}`;
964
+
965
+ const logText = (log?: DeepPartial<UserLog>) =>
966
+ `Log:\n${prettyPrint({
967
+ index: log?.logIndex,
968
+ address: log?.address,
969
+ })}`;
970
+
971
+ const traceText = (trace?: DeepPartial<UserTrace>) =>
972
+ `Trace:\n${prettyPrint({
973
+ traceIndex: trace?.traceIndex,
974
+ from: trace?.from,
975
+ to: trace?.to,
976
+ })}`;