@hugomrdias/foxer 0.0.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 (311) hide show
  1. package/README.md +56 -0
  2. package/dist/src/api/index.d.ts +2 -0
  3. package/dist/src/api/index.d.ts.map +1 -0
  4. package/dist/src/api/index.js +2 -0
  5. package/dist/src/api/index.js.map +1 -0
  6. package/dist/src/api/runner.d.ts +12 -0
  7. package/dist/src/api/runner.d.ts.map +1 -0
  8. package/dist/src/api/runner.js +29 -0
  9. package/dist/src/api/runner.js.map +1 -0
  10. package/dist/src/api/server.d.ts +18 -0
  11. package/dist/src/api/server.d.ts.map +1 -0
  12. package/dist/src/api/server.js +21 -0
  13. package/dist/src/api/server.js.map +1 -0
  14. package/dist/src/api/sql-middleware.d.ts +7 -0
  15. package/dist/src/api/sql-middleware.d.ts.map +1 -0
  16. package/dist/src/api/sql-middleware.js +95 -0
  17. package/dist/src/api/sql-middleware.js.map +1 -0
  18. package/dist/src/api/sql.d.ts +14 -0
  19. package/dist/src/api/sql.d.ts.map +1 -0
  20. package/dist/src/api/sql.js +108 -0
  21. package/dist/src/api/sql.js.map +1 -0
  22. package/dist/src/api/sse.d.ts +3 -0
  23. package/dist/src/api/sse.d.ts.map +1 -0
  24. package/dist/src/api/sse.js +11 -0
  25. package/dist/src/api/sse.js.map +1 -0
  26. package/dist/src/bin/dev.d.ts +3 -0
  27. package/dist/src/bin/dev.d.ts.map +1 -0
  28. package/dist/src/bin/dev.js +76 -0
  29. package/dist/src/bin/dev.js.map +1 -0
  30. package/dist/src/bin/flags.d.ts +32 -0
  31. package/dist/src/bin/flags.d.ts.map +1 -0
  32. package/dist/src/bin/flags.js +55 -0
  33. package/dist/src/bin/flags.js.map +1 -0
  34. package/dist/src/bin/index.d.ts +3 -0
  35. package/dist/src/bin/index.d.ts.map +1 -0
  36. package/dist/src/bin/index.js +22 -0
  37. package/dist/src/bin/index.js.map +1 -0
  38. package/dist/src/bin/utils.d.ts +4 -0
  39. package/dist/src/bin/utils.d.ts.map +1 -0
  40. package/dist/src/bin/utils.js +52 -0
  41. package/dist/src/bin/utils.js.map +1 -0
  42. package/dist/src/client/index.d.ts +18 -0
  43. package/dist/src/client/index.d.ts.map +1 -0
  44. package/dist/src/client/index.js +150 -0
  45. package/dist/src/client/index.js.map +1 -0
  46. package/dist/src/config/config.d.ts +157 -0
  47. package/dist/src/config/config.d.ts.map +1 -0
  48. package/dist/src/config/config.js +65 -0
  49. package/dist/src/config/config.js.map +1 -0
  50. package/dist/src/config/env.d.ts +25 -0
  51. package/dist/src/config/env.d.ts.map +1 -0
  52. package/dist/src/config/env.js +21 -0
  53. package/dist/src/config/env.js.map +1 -0
  54. package/dist/src/contants.d.ts +4 -0
  55. package/dist/src/contants.d.ts.map +1 -0
  56. package/dist/src/contants.js +4 -0
  57. package/dist/src/contants.js.map +1 -0
  58. package/dist/src/db/actions/blocks.d.ts +44 -0
  59. package/dist/src/db/actions/blocks.d.ts.map +1 -0
  60. package/dist/src/db/actions/blocks.js +152 -0
  61. package/dist/src/db/actions/blocks.js.map +1 -0
  62. package/dist/src/db/actions/index.d.ts +2 -0
  63. package/dist/src/db/actions/index.d.ts.map +1 -0
  64. package/dist/src/db/actions/index.js +2 -0
  65. package/dist/src/db/actions/index.js.map +1 -0
  66. package/dist/src/db/actions/transactions.d.ts +11 -0
  67. package/dist/src/db/actions/transactions.d.ts.map +1 -0
  68. package/dist/src/db/actions/transactions.js +22 -0
  69. package/dist/src/db/actions/transactions.js.map +1 -0
  70. package/dist/src/db/client.d.ts +329 -0
  71. package/dist/src/db/client.d.ts.map +1 -0
  72. package/dist/src/db/client.js +108 -0
  73. package/dist/src/db/client.js.map +1 -0
  74. package/dist/src/db/column-types.d.ts +132 -0
  75. package/dist/src/db/column-types.d.ts.map +1 -0
  76. package/dist/src/db/column-types.js +86 -0
  77. package/dist/src/db/column-types.js.map +1 -0
  78. package/dist/src/db/encode.d.ts +10 -0
  79. package/dist/src/db/encode.d.ts.map +1 -0
  80. package/dist/src/db/encode.js +79 -0
  81. package/dist/src/db/encode.js.map +1 -0
  82. package/dist/src/db/migrate.d.ts +31 -0
  83. package/dist/src/db/migrate.d.ts.map +1 -0
  84. package/dist/src/db/migrate.js +147 -0
  85. package/dist/src/db/migrate.js.map +1 -0
  86. package/dist/src/db/schema/blocks.d.ts +369 -0
  87. package/dist/src/db/schema/blocks.d.ts.map +1 -0
  88. package/dist/src/db/schema/blocks.js +24 -0
  89. package/dist/src/db/schema/blocks.js.map +1 -0
  90. package/dist/src/db/schema/index.d.ts +1415 -0
  91. package/dist/src/db/schema/index.d.ts.map +1 -0
  92. package/dist/src/db/schema/index.js +18 -0
  93. package/dist/src/db/schema/index.js.map +1 -0
  94. package/dist/src/db/schema/transactions.d.ts +336 -0
  95. package/dist/src/db/schema/transactions.d.ts.map +1 -0
  96. package/dist/src/db/schema/transactions.js +33 -0
  97. package/dist/src/db/schema/transactions.js.map +1 -0
  98. package/dist/src/db/transaction.d.ts +7 -0
  99. package/dist/src/db/transaction.d.ts.map +1 -0
  100. package/dist/src/db/transaction.js +8 -0
  101. package/dist/src/db/transaction.js.map +1 -0
  102. package/dist/src/hooks/default-hooks.d.ts +2 -0
  103. package/dist/src/hooks/default-hooks.d.ts.map +1 -0
  104. package/dist/src/hooks/default-hooks.js +107 -0
  105. package/dist/src/hooks/default-hooks.js.map +1 -0
  106. package/dist/src/hooks/registry.d.ts +51 -0
  107. package/dist/src/hooks/registry.d.ts.map +1 -0
  108. package/dist/src/hooks/registry.js +32 -0
  109. package/dist/src/hooks/registry.js.map +1 -0
  110. package/dist/src/index.d.ts +10 -0
  111. package/dist/src/index.d.ts.map +1 -0
  112. package/dist/src/index.js +4 -0
  113. package/dist/src/index.js.map +1 -0
  114. package/dist/src/indexer/backfill.d.ts +15 -0
  115. package/dist/src/indexer/backfill.d.ts.map +1 -0
  116. package/dist/src/indexer/backfill.js +95 -0
  117. package/dist/src/indexer/backfill.js.map +1 -0
  118. package/dist/src/indexer/live.d.ts +20 -0
  119. package/dist/src/indexer/live.d.ts.map +1 -0
  120. package/dist/src/indexer/live.js +51 -0
  121. package/dist/src/indexer/live.js.map +1 -0
  122. package/dist/src/indexer/process-block.d.ts +29 -0
  123. package/dist/src/indexer/process-block.d.ts.map +1 -0
  124. package/dist/src/indexer/process-block.js +91 -0
  125. package/dist/src/indexer/process-block.js.map +1 -0
  126. package/dist/src/indexer/queue-block.d.ts +18 -0
  127. package/dist/src/indexer/queue-block.d.ts.map +1 -0
  128. package/dist/src/indexer/queue-block.js +38 -0
  129. package/dist/src/indexer/queue-block.js.map +1 -0
  130. package/dist/src/indexer/reorg.d.ts +24 -0
  131. package/dist/src/indexer/reorg.d.ts.map +1 -0
  132. package/dist/src/indexer/reorg.js +83 -0
  133. package/dist/src/indexer/reorg.js.map +1 -0
  134. package/dist/src/indexer/runner.d.ts +14 -0
  135. package/dist/src/indexer/runner.d.ts.map +1 -0
  136. package/dist/src/indexer/runner.js +22 -0
  137. package/dist/src/indexer/runner.js.map +1 -0
  138. package/dist/src/rpc/client.d.ts +11 -0
  139. package/dist/src/rpc/client.d.ts.map +1 -0
  140. package/dist/src/rpc/client.js +18 -0
  141. package/dist/src/rpc/client.js.map +1 -0
  142. package/dist/src/rpc/get-block.d.ts +16 -0
  143. package/dist/src/rpc/get-block.d.ts.map +1 -0
  144. package/dist/src/rpc/get-block.js +77 -0
  145. package/dist/src/rpc/get-block.js.map +1 -0
  146. package/dist/src/rpc/get-logs.d.ts +11 -0
  147. package/dist/src/rpc/get-logs.d.ts.map +1 -0
  148. package/dist/src/rpc/get-logs.js +23 -0
  149. package/dist/src/rpc/get-logs.js.map +1 -0
  150. package/dist/src/schema.d.ts +3 -0
  151. package/dist/src/schema.d.ts.map +1 -0
  152. package/dist/src/schema.js +9 -0
  153. package/dist/src/schema.js.map +1 -0
  154. package/dist/src/types.d.ts +22 -0
  155. package/dist/src/types.d.ts.map +1 -0
  156. package/dist/src/types.js +1 -0
  157. package/dist/src/types.js.map +1 -0
  158. package/dist/src/utils/bloom.d.ts +6 -0
  159. package/dist/src/utils/bloom.d.ts.map +1 -0
  160. package/dist/src/utils/bloom.js +30 -0
  161. package/dist/src/utils/bloom.js.map +1 -0
  162. package/dist/src/utils/build-conflict-columns.d.ts +4 -0
  163. package/dist/src/utils/build-conflict-columns.d.ts.map +1 -0
  164. package/dist/src/utils/build-conflict-columns.js +14 -0
  165. package/dist/src/utils/build-conflict-columns.js.map +1 -0
  166. package/dist/src/utils/common.d.ts +2 -0
  167. package/dist/src/utils/common.d.ts.map +1 -0
  168. package/dist/src/utils/common.js +4 -0
  169. package/dist/src/utils/common.js.map +1 -0
  170. package/dist/src/utils/cursor.d.ts +5 -0
  171. package/dist/src/utils/cursor.d.ts.map +1 -0
  172. package/dist/src/utils/cursor.js +8 -0
  173. package/dist/src/utils/cursor.js.map +1 -0
  174. package/dist/src/utils/format.d.ts +2 -0
  175. package/dist/src/utils/format.d.ts.map +1 -0
  176. package/dist/src/utils/format.js +16 -0
  177. package/dist/src/utils/format.js.map +1 -0
  178. package/dist/src/utils/hash.d.ts +9 -0
  179. package/dist/src/utils/hash.d.ts.map +1 -0
  180. package/dist/src/utils/hash.js +15 -0
  181. package/dist/src/utils/hash.js.map +1 -0
  182. package/dist/src/utils/json.d.ts +5 -0
  183. package/dist/src/utils/json.d.ts.map +1 -0
  184. package/dist/src/utils/json.js +11 -0
  185. package/dist/src/utils/json.js.map +1 -0
  186. package/dist/src/utils/logger.d.ts +11 -0
  187. package/dist/src/utils/logger.d.ts.map +1 -0
  188. package/dist/src/utils/logger.js +111 -0
  189. package/dist/src/utils/logger.js.map +1 -0
  190. package/dist/src/utils/shutdown.d.ts +9 -0
  191. package/dist/src/utils/shutdown.d.ts.map +1 -0
  192. package/dist/src/utils/shutdown.js +24 -0
  193. package/dist/src/utils/shutdown.js.map +1 -0
  194. package/dist/src/utils/timer.d.ts +6 -0
  195. package/dist/src/utils/timer.d.ts.map +1 -0
  196. package/dist/src/utils/timer.js +9 -0
  197. package/dist/src/utils/timer.js.map +1 -0
  198. package/dist/src/utils/types.d.ts +39 -0
  199. package/dist/src/utils/types.d.ts.map +1 -0
  200. package/dist/src/utils/types.js +1 -0
  201. package/dist/src/utils/types.js.map +1 -0
  202. package/dist/tsconfig.tsbuildinfo +1 -0
  203. package/hello/apps/foc-api/README.md +69 -0
  204. package/hello/apps/foc-api/biome.json +8 -0
  205. package/hello/apps/foc-api/index.html +13 -0
  206. package/hello/apps/foc-api/package.json +39 -0
  207. package/hello/apps/foc-api/public/vite.svg +1 -0
  208. package/hello/apps/foc-api/src/app.css +45 -0
  209. package/hello/apps/foc-api/src/app.tsx +43 -0
  210. package/hello/apps/foc-api/src/assets/Cloudflare_Logo.svg +51 -0
  211. package/hello/apps/foc-api/src/assets/react.svg +1 -0
  212. package/hello/apps/foc-api/src/client.ts +41 -0
  213. package/hello/apps/foc-api/src/components/account.tsx +100 -0
  214. package/hello/apps/foc-api/src/components/wallet-options.tsx +43 -0
  215. package/hello/apps/foc-api/src/index.css +68 -0
  216. package/hello/apps/foc-api/src/main.tsx +38 -0
  217. package/hello/apps/foc-api/src/vite-env.d.ts +1 -0
  218. package/hello/apps/foc-api/tsconfig.app.json +44 -0
  219. package/hello/apps/foc-api/tsconfig.json +17 -0
  220. package/hello/apps/foc-api/tsconfig.node.json +25 -0
  221. package/hello/apps/foc-api/tsconfig.worker.json +8 -0
  222. package/hello/apps/foc-api/vite.config.ts +8 -0
  223. package/hello/apps/foc-api/worker/capabilities.ts +25 -0
  224. package/hello/apps/foc-api/worker/index.ts +64 -0
  225. package/hello/apps/foc-api/worker/router.ts +35 -0
  226. package/hello/apps/foc-api/worker-configuration.d.ts +7357 -0
  227. package/hello/apps/foc-api/wrangler.jsonc +50 -0
  228. package/hello/apps/foc-app/README.md +69 -0
  229. package/hello/apps/foc-app/biome.json +8 -0
  230. package/hello/apps/foc-app/index.html +13 -0
  231. package/hello/apps/foc-app/package.json +39 -0
  232. package/hello/apps/foc-app/public/vite.svg +1 -0
  233. package/hello/apps/foc-app/src/app.css +45 -0
  234. package/hello/apps/foc-app/src/app.tsx +43 -0
  235. package/hello/apps/foc-app/src/assets/Cloudflare_Logo.svg +51 -0
  236. package/hello/apps/foc-app/src/assets/react.svg +1 -0
  237. package/hello/apps/foc-app/src/client.ts +41 -0
  238. package/hello/apps/foc-app/src/components/account.tsx +100 -0
  239. package/hello/apps/foc-app/src/components/wallet-options.tsx +43 -0
  240. package/hello/apps/foc-app/src/index.css +68 -0
  241. package/hello/apps/foc-app/src/main.tsx +38 -0
  242. package/hello/apps/foc-app/src/vite-env.d.ts +1 -0
  243. package/hello/apps/foc-app/tsconfig.app.json +44 -0
  244. package/hello/apps/foc-app/tsconfig.json +17 -0
  245. package/hello/apps/foc-app/tsconfig.node.json +25 -0
  246. package/hello/apps/foc-app/tsconfig.worker.json +8 -0
  247. package/hello/apps/foc-app/vite.config.ts +8 -0
  248. package/hello/apps/foc-app/worker/capabilities.ts +25 -0
  249. package/hello/apps/foc-app/worker/index.ts +64 -0
  250. package/hello/apps/foc-app/worker/router.ts +35 -0
  251. package/hello/apps/foc-app/worker-configuration.d.ts +7357 -0
  252. package/hello/apps/foc-app/wrangler.jsonc +50 -0
  253. package/hello/biome.json +50 -0
  254. package/hello/package.json +22 -0
  255. package/hello/pnpm-workspace.yaml +3 -0
  256. package/hello/tsconfig.json +37 -0
  257. package/package.json +78 -0
  258. package/src/api/index.ts +1 -0
  259. package/src/api/runner.ts +43 -0
  260. package/src/api/server.ts +38 -0
  261. package/src/api/sql-middleware.ts +131 -0
  262. package/src/api/sql.ts +149 -0
  263. package/src/api/sse.ts +12 -0
  264. package/src/bin/create.ts +199 -0
  265. package/src/bin/dev.ts +91 -0
  266. package/src/bin/flags.ts +65 -0
  267. package/src/bin/index.ts +28 -0
  268. package/src/bin/utils.ts +55 -0
  269. package/src/config/config.ts +221 -0
  270. package/src/config/env.ts +28 -0
  271. package/src/contants.ts +3 -0
  272. package/src/db/actions/blocks.ts +209 -0
  273. package/src/db/actions/index.ts +1 -0
  274. package/src/db/actions/transactions.ts +32 -0
  275. package/src/db/client.ts +186 -0
  276. package/src/db/column-types.ts +105 -0
  277. package/src/db/encode.ts +99 -0
  278. package/src/db/migrate.ts +222 -0
  279. package/src/db/schema/blocks.ts +24 -0
  280. package/src/db/schema/index.ts +21 -0
  281. package/src/db/schema/transactions.ts +39 -0
  282. package/src/db/transaction.ts +20 -0
  283. package/src/hooks/registry.ts +107 -0
  284. package/src/index.ts +9 -0
  285. package/src/indexer/backfill.ts +133 -0
  286. package/src/indexer/live.ts +76 -0
  287. package/src/indexer/process-block.ts +142 -0
  288. package/src/indexer/queue-block.ts +74 -0
  289. package/src/indexer/reorg.ts +120 -0
  290. package/src/indexer/runner.ts +35 -0
  291. package/src/rpc/client.ts +27 -0
  292. package/src/rpc/get-block.ts +100 -0
  293. package/src/rpc/get-logs.ts +38 -0
  294. package/src/schema.ts +10 -0
  295. package/src/types.ts +32 -0
  296. package/src/utils/bloom.ts +41 -0
  297. package/src/utils/build-conflict-columns.ts +26 -0
  298. package/src/utils/common.ts +3 -0
  299. package/src/utils/cursor.ts +7 -0
  300. package/src/utils/format.ts +18 -0
  301. package/src/utils/hash.ts +17 -0
  302. package/src/utils/json.ts +11 -0
  303. package/src/utils/logger.ts +149 -0
  304. package/src/utils/shutdown.ts +36 -0
  305. package/src/utils/timer.ts +8 -0
  306. package/src/utils/types.ts +87 -0
  307. package/template/biome.json +50 -0
  308. package/template/package.json +22 -0
  309. package/template/pnpm-workspace.yaml +3 -0
  310. package/template/tsconfig.json +37 -0
  311. package/tsconfig.json +8 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blocks.d.ts","sourceRoot":"","sources":["../../../../src/db/actions/blocks.ts"],"names":[],"mappings":"AAAA,6DAA6D;AAG7D,OAAO,EAEL,KAAK,kBAAkB,EAEvB,KAAK,gBAAgB,EAEtB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,MAAM,CAAA;AACxC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAG/D,OAAO,KAAK,EACV,4BAA4B,EAE7B,MAAM,gBAAgB,CAAA;AACvB,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAA;AAEnD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAG3D;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,EAAE,EAAE,QAAQ,EACZ,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,IAAI,CAAC,CAef;AAmBD;;;;;;;GAOG;AACH,wBAAsB,yBAAyB,CAAC,IAAI,EAAE;IACpD,EAAE,EAAE,QAAQ,CAAC,OAAO,MAAM,EAAE,OAAO,SAAS,CAAC,CAAA;IAC7C,KAAK,EAAE,4BAA4B,CAAA;IACnC,MAAM,EAAE,MAAM,CAAA;CACf,GAAG,OAAO,CAAC,IAAI,CAAC,CAahB;AAED;;;;;;;;;GASG;AACH,wBAAsB,gBAAgB,CACpC,MAAM,EAAE,MAAM,EACd,EAAE,EAAE,QAAQ,CAAC,OAAO,MAAM,EAAE,OAAO,SAAS,CAAC,EAC7C,YAAY,EAAE,MAAM,EAAE,EACtB,MAAM,EAAE,YAAY,EACpB,SAAS,EAAE,iBAAiB,GAC3B,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,4BAA4B,CAAC,CAAC,CA+EpD;AAED;;GAEG;AACH,wBAAsB,oBAAoB,CAAC,IAAI,EAAE;IAC/C,EAAE,EAAE,kBAAkB,CAAC,gBAAgB,EAAE,OAAO,MAAM,CAAC,CAAA;IACvD,MAAM,EAAE,4BAA4B,EAAE,CAAA;CACvC,GAAG,OAAO,CAAC,IAAI,CAAC,CAchB"}
@@ -0,0 +1,152 @@
1
+ /** biome-ignore-all lint/style/noNonNullAssertion: its ok */
2
+ import { gte } from 'drizzle-orm';
3
+ import { getTableConfig, } from 'drizzle-orm/pg-core';
4
+ import { MAX_QUERY_PARAMS } from "../../contants.js";
5
+ import { safeGetBlock } from "../../rpc/get-block.js";
6
+ import { startClock } from "../../utils/timer.js";
7
+ import { schema } from "../schema/index.js";
8
+ import { insertTransactionsInChunks } from "./transactions.js";
9
+ /**
10
+ * Deletes canonical block rows from a specific block onward.
11
+ */
12
+ export async function deleteBlocksFrom(db, fromBlock) {
13
+ const deleteTargets = getTablesWithBlockNumberColumn(db._.fullSchema);
14
+ await db.transaction(async (tx) => {
15
+ for (const target of deleteTargets) {
16
+ await tx
17
+ .delete(target.table)
18
+ .where(gte(target.blockNumberColumn, fromBlock));
19
+ }
20
+ // blocks uses `number` instead of blockNumber
21
+ await tx.delete(schema.blocks).where(gte(schema.blocks.number, fromBlock));
22
+ });
23
+ }
24
+ function getTablesWithBlockNumberColumn(fullSchema) {
25
+ const targets = [];
26
+ for (const table of Object.values(fullSchema)) {
27
+ const pgTable = table;
28
+ const config = getTableConfig(pgTable);
29
+ const blockNumberColumn = config.columns.find((column) => ['blockNumber', 'block_number'].includes(column.name));
30
+ if (!blockNumberColumn)
31
+ continue;
32
+ targets.push({ table: pgTable, blockNumberColumn });
33
+ }
34
+ return targets;
35
+ }
36
+ /**
37
+ * Caches a block and its transactions in the database.
38
+ *
39
+ * @param args - The arguments for the function
40
+ * @param args.db - The database instance
41
+ * @param args.block - The block to cache
42
+ * @returns The cached block and transactions
43
+ */
44
+ export async function cacheBlockAndTransactions(args) {
45
+ const { db, block } = args;
46
+ await db.transaction(async (tx) => {
47
+ await insertBlocksInChunks({
48
+ db: tx,
49
+ blocks: [block],
50
+ });
51
+ await insertTransactionsInChunks({
52
+ db: tx,
53
+ transactions: block.transactions,
54
+ });
55
+ });
56
+ }
57
+ /**
58
+ * Gets blocks and their transactions from the database in a range and fetches missing blocks from the RPC.
59
+ *
60
+ * @param args - The arguments for the function
61
+ * @param args.logger - The logger instance
62
+ * @param args.db - The database instance
63
+ * @param args.blockNumbers - The block numbers to get
64
+ * @param args.client - The client instance
65
+ * @returns The blocks and their transactions
66
+ */
67
+ export async function getBlocksInRange(logger, db, blockNumbers, client, contracts) {
68
+ const endClock = startClock();
69
+ const firstBlockNumber = blockNumbers[0];
70
+ const lastBlockNumber = blockNumbers[blockNumbers.length - 1];
71
+ // const r = await db.$prepared.getBlocksInRange.execute({
72
+ // firstBlockNumber,
73
+ // lastBlockNumber,
74
+ // contractAddresses: contracts.addresses,
75
+ // })
76
+ const r = await db.query.blocks.findMany({
77
+ with: {
78
+ transactions: {
79
+ where: {
80
+ AND: [
81
+ { blockNumber: { gte: firstBlockNumber } },
82
+ { blockNumber: { lte: lastBlockNumber } },
83
+ {
84
+ to: {
85
+ in: contracts.addresses,
86
+ },
87
+ },
88
+ ],
89
+ },
90
+ },
91
+ },
92
+ where: {
93
+ AND: [
94
+ { number: { gte: firstBlockNumber } },
95
+ { number: { lte: lastBlockNumber } },
96
+ ],
97
+ },
98
+ });
99
+ const blocksByNumber = new Map();
100
+ const missing = new Set(blockNumbers);
101
+ for (const block of r) {
102
+ blocksByNumber.set(block.number, block);
103
+ missing.delete(block.number);
104
+ }
105
+ const missingBlockNumbers = [...missing];
106
+ const newBlocks = [];
107
+ const newTransactions = [];
108
+ await Promise.all(missingBlockNumbers.map(async (blockNumber) => {
109
+ const block = await safeGetBlock({ client, blockNumber, db });
110
+ const transactions = block.transactions;
111
+ blocksByNumber.set(blockNumber, block);
112
+ newBlocks.push(block);
113
+ if (transactions.length > 0) {
114
+ newTransactions.push(...transactions);
115
+ }
116
+ }));
117
+ await db.transaction(async (tx) => {
118
+ await insertBlocksInChunks({
119
+ db: tx,
120
+ blocks: newBlocks,
121
+ });
122
+ await insertTransactionsInChunks({
123
+ db: tx,
124
+ transactions: newTransactions,
125
+ });
126
+ });
127
+ logger.info({
128
+ blocks: blocksByNumber.size,
129
+ missing: missingBlockNumbers.length,
130
+ duration: endClock(),
131
+ }, 'get blocks');
132
+ return blocksByNumber;
133
+ }
134
+ /**
135
+ * Inserts blocks in chunks to avoid query parameter limit.
136
+ */
137
+ export async function insertBlocksInChunks(args) {
138
+ const { db, blocks } = args;
139
+ if (blocks.length === 0)
140
+ return;
141
+ const batchSize = Math.floor(MAX_QUERY_PARAMS / Object.keys(blocks[0]).length);
142
+ for (let i = 0; i < blocks.length; i += batchSize) {
143
+ const chunk = blocks.slice(i, i + batchSize);
144
+ await db
145
+ .insert(schema.blocks)
146
+ .values(chunk)
147
+ .onConflictDoNothing({
148
+ target: [schema.blocks.number],
149
+ });
150
+ }
151
+ }
152
+ //# sourceMappingURL=blocks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blocks.js","sourceRoot":"","sources":["../../../../src/db/actions/blocks.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * as blocks from './blocks.ts';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/db/actions/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,aAAa,CAAA"}
@@ -0,0 +1,2 @@
1
+ export * as blocks from "./blocks.js";
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/db/actions/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,aAAa,CAAA"}
@@ -0,0 +1,11 @@
1
+ import type { PgAsyncTransaction, PgQueryResultHKT } from 'drizzle-orm/pg-core';
2
+ import type { EncodedTransaction } from '../../types.ts';
3
+ import { schema } from '../schema/index.ts';
4
+ /**
5
+ * Inserts transactions in chunks to avoid query parameter limit.
6
+ */
7
+ export declare function insertTransactionsInChunks(args: {
8
+ db: PgAsyncTransaction<PgQueryResultHKT, typeof schema>;
9
+ transactions: EncodedTransaction[];
10
+ }): Promise<void>;
11
+ //# sourceMappingURL=transactions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transactions.d.ts","sourceRoot":"","sources":["../../../../src/db/actions/transactions.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAA;AAE/E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAE3C;;GAEG;AACH,wBAAsB,0BAA0B,CAAC,IAAI,EAAE;IACrD,EAAE,EAAE,kBAAkB,CAAC,gBAAgB,EAAE,OAAO,MAAM,CAAC,CAAA;IACvD,YAAY,EAAE,kBAAkB,EAAE,CAAA;CACnC,GAAG,OAAO,CAAC,IAAI,CAAC,CAoBhB"}
@@ -0,0 +1,22 @@
1
+ import { MAX_QUERY_PARAMS } from "../../contants.js";
2
+ import { schema } from "../schema/index.js";
3
+ /**
4
+ * Inserts transactions in chunks to avoid query parameter limit.
5
+ */
6
+ export async function insertTransactionsInChunks(args) {
7
+ const { db, transactions } = args;
8
+ if (transactions.length === 0) {
9
+ return;
10
+ }
11
+ const batchSize = Math.floor(MAX_QUERY_PARAMS / Object.keys(transactions[0]).length);
12
+ for (let i = 0; i < transactions.length; i += batchSize) {
13
+ const chunk = transactions.slice(i, i + batchSize);
14
+ await db
15
+ .insert(schema.transactions)
16
+ .values(chunk)
17
+ .onConflictDoNothing({
18
+ target: [schema.transactions.hash],
19
+ });
20
+ }
21
+ }
22
+ //# sourceMappingURL=transactions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transactions.js","sourceRoot":"","sources":["../../../../src/db/actions/transactions.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAA;AAEpD,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAE3C;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,0BAA0B,CAAC,IAGhD;IACC,MAAM,EAAE,EAAE,EAAE,YAAY,EAAE,GAAG,IAAI,CAAA;IACjC,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC9B,OAAM;IACR,CAAC;IAED,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAC1B,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CACvD,CAAA;IAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC,IAAI,SAAS,EAAE,CAAC;QACxD,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,CAAA;QAElD,MAAM,EAAE;aACL,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC;aAC3B,MAAM,CAAC,KAAK,CAAC;aACb,mBAAmB,CAAC;YACnB,MAAM,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC;SACnC,CAAC,CAAA;IACN,CAAC;AACH,CAAC"}
@@ -0,0 +1,329 @@
1
+ import { PGlite } from '@electric-sql/pglite';
2
+ import { type NodePgDatabase } from 'drizzle-orm/node-postgres';
3
+ import { type PgliteDatabase } from 'drizzle-orm/pglite';
4
+ import type { AnyRelations, EmptyRelations } from 'drizzle-orm/relations';
5
+ import { Pool } from 'pg';
6
+ import type { DatabaseConfig } from '../config/config.ts';
7
+ import type { Env } from '../config/env.ts';
8
+ import { type relations, schema } from './schema/index.ts';
9
+ export type Database<TSchema extends Record<string, unknown> = Record<string, unknown>, TRelations extends AnyRelations = EmptyRelations> = (PgliteDatabase<TSchema, TRelations> & {
10
+ $client: PGlite;
11
+ $prepared: ReturnType<typeof generatePrepared>;
12
+ }) | (NodePgDatabase<TSchema, TRelations> & {
13
+ $client: Pool;
14
+ $prepared: ReturnType<typeof generatePrepared>;
15
+ });
16
+ export type DbDriver = 'pglite' | 'postgres';
17
+ export type DatabaseContext<TSchema extends Record<string, unknown> = Record<string, unknown>, TRelations extends AnyRelations = EmptyRelations> = {
18
+ db: NodePgDatabase<TSchema, TRelations> & {
19
+ $client: Pool;
20
+ $prepared: ReturnType<typeof generatePrepared>;
21
+ };
22
+ driver: 'postgres';
23
+ close: () => Promise<void>;
24
+ } | {
25
+ db: PgliteDatabase<TSchema, TRelations> & {
26
+ $client: PGlite;
27
+ $prepared: ReturnType<typeof generatePrepared>;
28
+ };
29
+ driver: 'pglite';
30
+ close: () => Promise<void>;
31
+ };
32
+ /**
33
+ * Creates a typed Drizzle database context for either Postgres or PGlite.
34
+ */
35
+ export declare function createDatabase<TSchema extends Record<string, unknown> = Record<string, unknown>, TRelations extends AnyRelations = EmptyRelations>({ env, config, schema, relations, }: {
36
+ env: Env;
37
+ config?: DatabaseConfig;
38
+ schema: TSchema;
39
+ relations: TRelations;
40
+ }): DatabaseContext<TSchema, TRelations>;
41
+ declare function generatePrepared(db: Omit<Database<typeof schema, typeof relations>, '$prepared'>): {
42
+ getLatestBlock: import("drizzle-orm/pg-core").PgAsyncSelectPrepare<import("drizzle-orm/pg-core").PgAsyncSelectBase<"blocks", {
43
+ number: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetIsPrimaryKey<import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
44
+ dataType: "custom";
45
+ data: bigint;
46
+ driverParam: string;
47
+ }>>>, {
48
+ name: string;
49
+ tableName: "blocks";
50
+ dataType: "custom";
51
+ data: bigint;
52
+ driverParam: string;
53
+ notNull: true;
54
+ hasDefault: false;
55
+ isPrimaryKey: false;
56
+ isAutoincrement: false;
57
+ hasRuntimeDefault: false;
58
+ enumValues: undefined;
59
+ identity: undefined;
60
+ generated: undefined;
61
+ }>;
62
+ hash: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
63
+ dataType: "custom";
64
+ data: `0x${string}`;
65
+ driverParam: string;
66
+ }>>, {
67
+ name: string;
68
+ tableName: "blocks";
69
+ dataType: "custom";
70
+ data: `0x${string}`;
71
+ driverParam: string;
72
+ notNull: true;
73
+ hasDefault: false;
74
+ isPrimaryKey: false;
75
+ isAutoincrement: false;
76
+ hasRuntimeDefault: false;
77
+ enumValues: undefined;
78
+ identity: undefined;
79
+ generated: undefined;
80
+ }>;
81
+ parentHash: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
82
+ dataType: "custom";
83
+ data: `0x${string}`;
84
+ driverParam: string;
85
+ }>>, {
86
+ name: string;
87
+ tableName: "blocks";
88
+ dataType: "custom";
89
+ data: `0x${string}`;
90
+ driverParam: string;
91
+ notNull: true;
92
+ hasDefault: false;
93
+ isPrimaryKey: false;
94
+ isAutoincrement: false;
95
+ hasRuntimeDefault: false;
96
+ enumValues: undefined;
97
+ identity: undefined;
98
+ generated: undefined;
99
+ }>;
100
+ }, "partial", Record<"blocks", "not-null">, false, "from" | "orderBy" | "limit", {
101
+ number: bigint;
102
+ hash: `0x${string}`;
103
+ parentHash: `0x${string}`;
104
+ }[], {
105
+ number: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetIsPrimaryKey<import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
106
+ dataType: "custom";
107
+ data: bigint;
108
+ driverParam: string;
109
+ }>>>, {
110
+ name: string;
111
+ tableName: "blocks";
112
+ dataType: "custom";
113
+ data: bigint;
114
+ driverParam: string;
115
+ notNull: true;
116
+ hasDefault: false;
117
+ isPrimaryKey: false;
118
+ isAutoincrement: false;
119
+ hasRuntimeDefault: false;
120
+ enumValues: undefined;
121
+ identity: undefined;
122
+ generated: undefined;
123
+ }>;
124
+ hash: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
125
+ dataType: "custom";
126
+ data: `0x${string}`;
127
+ driverParam: string;
128
+ }>>, {
129
+ name: string;
130
+ tableName: "blocks";
131
+ dataType: "custom";
132
+ data: `0x${string}`;
133
+ driverParam: string;
134
+ notNull: true;
135
+ hasDefault: false;
136
+ isPrimaryKey: false;
137
+ isAutoincrement: false;
138
+ hasRuntimeDefault: false;
139
+ enumValues: undefined;
140
+ identity: undefined;
141
+ generated: undefined;
142
+ }>;
143
+ parentHash: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
144
+ dataType: "custom";
145
+ data: `0x${string}`;
146
+ driverParam: string;
147
+ }>>, {
148
+ name: string;
149
+ tableName: "blocks";
150
+ dataType: "custom";
151
+ data: `0x${string}`;
152
+ driverParam: string;
153
+ notNull: true;
154
+ hasDefault: false;
155
+ isPrimaryKey: false;
156
+ isAutoincrement: false;
157
+ hasRuntimeDefault: false;
158
+ enumValues: undefined;
159
+ identity: undefined;
160
+ generated: undefined;
161
+ }>;
162
+ }>>;
163
+ getBlockById: import("drizzle-orm/pg-core").PgAsyncSelectPrepare<import("drizzle-orm/pg-core").PgAsyncSelectBase<"blocks", {
164
+ number: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetIsPrimaryKey<import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
165
+ dataType: "custom";
166
+ data: bigint;
167
+ driverParam: string;
168
+ }>>>, {
169
+ name: string;
170
+ tableName: "blocks";
171
+ dataType: "custom";
172
+ data: bigint;
173
+ driverParam: string;
174
+ notNull: true;
175
+ hasDefault: false;
176
+ isPrimaryKey: false;
177
+ isAutoincrement: false;
178
+ hasRuntimeDefault: false;
179
+ enumValues: undefined;
180
+ identity: undefined;
181
+ generated: undefined;
182
+ }>;
183
+ hash: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
184
+ dataType: "custom";
185
+ data: `0x${string}`;
186
+ driverParam: string;
187
+ }>>, {
188
+ name: string;
189
+ tableName: "blocks";
190
+ dataType: "custom";
191
+ data: `0x${string}`;
192
+ driverParam: string;
193
+ notNull: true;
194
+ hasDefault: false;
195
+ isPrimaryKey: false;
196
+ isAutoincrement: false;
197
+ hasRuntimeDefault: false;
198
+ enumValues: undefined;
199
+ identity: undefined;
200
+ generated: undefined;
201
+ }>;
202
+ parentHash: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
203
+ dataType: "custom";
204
+ data: `0x${string}`;
205
+ driverParam: string;
206
+ }>>, {
207
+ name: string;
208
+ tableName: "blocks";
209
+ dataType: "custom";
210
+ data: `0x${string}`;
211
+ driverParam: string;
212
+ notNull: true;
213
+ hasDefault: false;
214
+ isPrimaryKey: false;
215
+ isAutoincrement: false;
216
+ hasRuntimeDefault: false;
217
+ enumValues: undefined;
218
+ identity: undefined;
219
+ generated: undefined;
220
+ }>;
221
+ }, "partial", Record<"blocks", "not-null">, false, "from" | "where", {
222
+ number: bigint;
223
+ hash: `0x${string}`;
224
+ parentHash: `0x${string}`;
225
+ }[], {
226
+ number: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetIsPrimaryKey<import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
227
+ dataType: "custom";
228
+ data: bigint;
229
+ driverParam: string;
230
+ }>>>, {
231
+ name: string;
232
+ tableName: "blocks";
233
+ dataType: "custom";
234
+ data: bigint;
235
+ driverParam: string;
236
+ notNull: true;
237
+ hasDefault: false;
238
+ isPrimaryKey: false;
239
+ isAutoincrement: false;
240
+ hasRuntimeDefault: false;
241
+ enumValues: undefined;
242
+ identity: undefined;
243
+ generated: undefined;
244
+ }>;
245
+ hash: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
246
+ dataType: "custom";
247
+ data: `0x${string}`;
248
+ driverParam: string;
249
+ }>>, {
250
+ name: string;
251
+ tableName: "blocks";
252
+ dataType: "custom";
253
+ data: `0x${string}`;
254
+ driverParam: string;
255
+ notNull: true;
256
+ hasDefault: false;
257
+ isPrimaryKey: false;
258
+ isAutoincrement: false;
259
+ hasRuntimeDefault: false;
260
+ enumValues: undefined;
261
+ identity: undefined;
262
+ generated: undefined;
263
+ }>;
264
+ parentHash: import("drizzle-orm/pg-core").PgBuildColumn<"blocks", import("drizzle-orm/pg-core").SetNotNull<import("drizzle-orm/pg-core").PgCustomColumnBuilder<{
265
+ dataType: "custom";
266
+ data: `0x${string}`;
267
+ driverParam: string;
268
+ }>>, {
269
+ name: string;
270
+ tableName: "blocks";
271
+ dataType: "custom";
272
+ data: `0x${string}`;
273
+ driverParam: string;
274
+ notNull: true;
275
+ hasDefault: false;
276
+ isPrimaryKey: false;
277
+ isAutoincrement: false;
278
+ hasRuntimeDefault: false;
279
+ enumValues: undefined;
280
+ identity: undefined;
281
+ generated: undefined;
282
+ }>;
283
+ }>>;
284
+ getBlocksInRange: import("drizzle-orm/pg-core").PgAsyncPreparedQuery<import("drizzle-orm/pg-core").PreparedQueryConfig & {
285
+ execute: {
286
+ number: bigint;
287
+ timestamp: bigint;
288
+ hash: `0x${string}`;
289
+ parentHash: `0x${string}`;
290
+ logsBloom: `0x${string}`;
291
+ miner: `0x${string}`;
292
+ gasUsed: bigint;
293
+ gasLimit: bigint;
294
+ baseFeePerGas: bigint | null;
295
+ nonce: `0x${string}`;
296
+ mixHash: `0x${string}`;
297
+ stateRoot: `0x${string}`;
298
+ receiptsRoot: `0x${string}`;
299
+ transactionsRoot: `0x${string}`;
300
+ sha3Uncles: `0x${string}`;
301
+ size: bigint;
302
+ difficulty: bigint;
303
+ totalDifficulty: bigint | null;
304
+ extraData: `0x${string}`;
305
+ transactions: {
306
+ hash: `0x${string}`;
307
+ nonce: number;
308
+ blockNumber: bigint;
309
+ transactionIndex: number;
310
+ blockHash: `0x${string}`;
311
+ from: `0x${string}`;
312
+ to: `0x${string}` | null;
313
+ input: `0x${string}`;
314
+ value: bigint;
315
+ r: `0x${string}`;
316
+ s: `0x${string}`;
317
+ v: bigint;
318
+ type: "legacy" | "eip1559" | "eip2930" | "eip4844" | "eip7702";
319
+ gas: bigint;
320
+ gasPrice: bigint | null;
321
+ maxFeePerGas: bigint | null;
322
+ maxPriorityFeePerGas: bigint | null;
323
+ accessList: import("viem").AccessList | null;
324
+ }[];
325
+ }[];
326
+ }>;
327
+ };
328
+ export {};
329
+ //# sourceMappingURL=client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../src/db/client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,108 @@
1
+ import { PGlite } from '@electric-sql/pglite';
2
+ import { desc, eq, sql } from 'drizzle-orm';
3
+ import { drizzle as drizzleNodePostgres, } from 'drizzle-orm/node-postgres';
4
+ import { drizzle as drizzlePglite, } from 'drizzle-orm/pglite';
5
+ import { Pool } from 'pg';
6
+ import { schema } from "./schema/index.js";
7
+ /**
8
+ * Creates a typed Drizzle database context for either Postgres or PGlite.
9
+ */
10
+ export function createDatabase({ env, config, schema, relations, }) {
11
+ let driver = 'pglite';
12
+ let url;
13
+ let options;
14
+ if (env.DATABASE_URL && typeof env.DATABASE_URL === 'string') {
15
+ driver = 'postgres';
16
+ url = env.DATABASE_URL;
17
+ }
18
+ else if (config?.driver === 'postgres') {
19
+ driver = config.driver;
20
+ url = config.url;
21
+ options = config.options;
22
+ }
23
+ if (driver === 'postgres' && url) {
24
+ const pool = new Pool({
25
+ ...options,
26
+ connectionString: url,
27
+ });
28
+ const db = drizzleNodePostgres({
29
+ client: pool,
30
+ relations: relations,
31
+ schema: schema,
32
+ casing: 'snake_case',
33
+ });
34
+ // @ts-expect-error - TODO: fix this
35
+ db.$prepared = generatePrepared(db);
36
+ return {
37
+ db,
38
+ driver: 'postgres',
39
+ close: async () => {
40
+ await pool.end();
41
+ },
42
+ };
43
+ }
44
+ const client = new PGlite(config?.driver === 'pglite' && config.directory
45
+ ? config.directory
46
+ : '.pglite');
47
+ const db = drizzlePglite({
48
+ client: client,
49
+ relations: relations,
50
+ schema: schema,
51
+ casing: 'snake_case',
52
+ });
53
+ // @ts-expect-error - TODO: fix this
54
+ db.$prepared = generatePrepared(db);
55
+ return {
56
+ db,
57
+ driver: 'pglite',
58
+ close: async () => {
59
+ await client.close();
60
+ },
61
+ };
62
+ }
63
+ function generatePrepared(db) {
64
+ const getLatestBlock = db
65
+ .select({
66
+ number: schema.blocks.number,
67
+ hash: schema.blocks.hash,
68
+ parentHash: schema.blocks.parentHash,
69
+ })
70
+ .from(schema.blocks)
71
+ .orderBy(desc(schema.blocks.number))
72
+ .limit(1)
73
+ .prepare('get_latest_block');
74
+ const getBlockById = db
75
+ .select({
76
+ number: schema.blocks.number,
77
+ hash: schema.blocks.hash,
78
+ parentHash: schema.blocks.parentHash,
79
+ })
80
+ .from(schema.blocks)
81
+ .where(eq(schema.blocks.number, sql.placeholder('blockNumber')))
82
+ .prepare('get_block_by_id');
83
+ const getBlocksInRange = db.query.blocks
84
+ .findMany({
85
+ with: {
86
+ transactions: {
87
+ where: {
88
+ to: {
89
+ in: sql.placeholder('contractAddresses'),
90
+ },
91
+ },
92
+ },
93
+ },
94
+ where: {
95
+ AND: [
96
+ { number: { gte: sql.placeholder('firstBlockNumber') } },
97
+ { number: { lte: sql.placeholder('lastBlockNumber') } },
98
+ ],
99
+ },
100
+ })
101
+ .prepare('get_blocks_in_range');
102
+ return {
103
+ getLatestBlock,
104
+ getBlockById,
105
+ getBlocksInRange,
106
+ };
107
+ }
108
+ //# sourceMappingURL=client.js.map