@coinbase/cdp-hooks 0.0.52 → 0.0.53

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 (286) hide show
  1. package/dist/esm/index10.js +6 -3
  2. package/dist/esm/index100.js +73 -5
  3. package/dist/esm/index101.js +5 -35
  4. package/dist/esm/index102.js +5 -75
  5. package/dist/esm/index103.js +36 -3
  6. package/dist/esm/index104.js +67 -15
  7. package/dist/esm/index105.js +3 -452
  8. package/dist/esm/index106.js +15 -22
  9. package/dist/esm/index107.js +440 -15
  10. package/dist/esm/index108.js +21 -24
  11. package/dist/esm/index109.js +24 -32
  12. package/dist/esm/index11.js +10 -6
  13. package/dist/esm/index110.js +22 -182
  14. package/dist/esm/index111.js +32 -6
  15. package/dist/esm/index112.js +194 -2
  16. package/dist/esm/index113.js +6 -10
  17. package/dist/esm/index114.js +2 -19
  18. package/dist/esm/index115.js +10 -25
  19. package/dist/esm/index116.js +18 -8
  20. package/dist/esm/index117.js +24 -52
  21. package/dist/esm/index118.js +8 -45
  22. package/dist/esm/index119.js +55 -8
  23. package/dist/esm/index12.js +51 -34
  24. package/dist/esm/index120.js +45 -7
  25. package/dist/esm/index121.js +8 -16
  26. package/dist/esm/index122.js +7 -18
  27. package/dist/esm/index123.js +16 -24
  28. package/dist/esm/index124.js +18 -16
  29. package/dist/esm/index125.js +22 -52
  30. package/dist/esm/index126.js +16 -11
  31. package/dist/esm/index127.js +53 -159
  32. package/dist/esm/index128.js +11 -21
  33. package/dist/esm/index129.js +157 -124
  34. package/dist/esm/index13.js +9 -18
  35. package/dist/esm/index130.js +20 -37
  36. package/dist/esm/index131.js +127 -6
  37. package/dist/esm/index132.js +35 -24
  38. package/dist/esm/index133.js +6 -191
  39. package/dist/esm/index134.js +28 -4
  40. package/dist/esm/index135.js +184 -57
  41. package/dist/esm/index136.js +4 -3
  42. package/dist/esm/index137.js +60 -16
  43. package/dist/esm/index138.js +3 -17
  44. package/dist/esm/index139.js +19 -22
  45. package/dist/esm/index14.js +34 -12
  46. package/dist/esm/index140.js +16 -11
  47. package/dist/esm/index141.js +22 -33
  48. package/dist/esm/index142.js +12 -3
  49. package/dist/esm/index143.js +33 -17
  50. package/dist/esm/index144.js +3 -28
  51. package/dist/esm/index145.js +18 -35
  52. package/dist/esm/index146.js +27 -7
  53. package/dist/esm/index147.js +34 -24
  54. package/dist/esm/index148.js +7 -28
  55. package/dist/esm/index149.js +24 -63
  56. package/dist/esm/index15.js +18 -12
  57. package/dist/esm/index150.js +28 -9
  58. package/dist/esm/index151.js +62 -31
  59. package/dist/esm/index152.js +9 -27
  60. package/dist/esm/index153.js +32 -23
  61. package/dist/esm/index154.js +27 -3
  62. package/dist/esm/index155.js +24 -14
  63. package/dist/esm/index156.js +3 -103
  64. package/dist/esm/index157.js +14 -64
  65. package/dist/esm/index158.js +103 -5
  66. package/dist/esm/index159.js +64 -6
  67. package/dist/esm/index16.js +12 -54
  68. package/dist/esm/index160.js +5 -27
  69. package/dist/esm/index161.js +6 -39
  70. package/dist/esm/index162.js +27 -13
  71. package/dist/esm/index163.js +38 -41
  72. package/dist/esm/index164.js +13 -5
  73. package/dist/esm/index165.js +42 -11
  74. package/dist/esm/index166.js +5 -19
  75. package/dist/esm/index167.js +11 -78
  76. package/dist/esm/index168.js +20 -2
  77. package/dist/esm/index169.js +74 -33
  78. package/dist/esm/index17.js +11 -57
  79. package/dist/esm/index170.js +2 -111
  80. package/dist/esm/index171.js +27 -38
  81. package/dist/esm/index172.js +108 -30
  82. package/dist/esm/index173.js +48 -8
  83. package/dist/esm/index174.js +32 -6
  84. package/dist/esm/index175.js +8 -6
  85. package/dist/esm/index176.js +6 -11
  86. package/dist/esm/index177.js +6 -10
  87. package/dist/esm/index178.js +11 -13
  88. package/dist/esm/index179.js +9 -31
  89. package/dist/esm/index18.js +21 -23
  90. package/dist/esm/index180.js +14 -5
  91. package/dist/esm/index181.js +32 -8
  92. package/dist/esm/index182.js +5 -20
  93. package/dist/esm/index183.js +6 -29
  94. package/dist/esm/index184.js +18 -19
  95. package/dist/esm/index185.js +31 -3
  96. package/dist/esm/index186.js +17 -14
  97. package/dist/esm/index187.js +3 -10
  98. package/dist/esm/index188.js +17 -21
  99. package/dist/esm/index189.js +10 -22
  100. package/dist/esm/index19.js +56 -31
  101. package/dist/esm/index190.js +21 -5
  102. package/dist/esm/index191.js +22 -5
  103. package/dist/esm/index192.js +5 -8
  104. package/dist/esm/index193.js +5 -104
  105. package/dist/esm/index194.js +9 -3
  106. package/dist/esm/index195.js +104 -18
  107. package/dist/esm/index196.js +3 -172
  108. package/dist/esm/index197.js +15 -14
  109. package/dist/esm/index198.js +172 -10
  110. package/dist/esm/index199.js +16 -39
  111. package/dist/esm/index20.js +56 -4
  112. package/dist/esm/index200.js +10 -2
  113. package/dist/esm/index201.js +5 -5
  114. package/dist/esm/index202.js +39 -9
  115. package/dist/esm/index203.js +2 -20
  116. package/dist/esm/index204.js +4 -7
  117. package/dist/esm/index205.js +9 -10
  118. package/dist/esm/index206.js +19 -66
  119. package/dist/esm/index207.js +7 -65
  120. package/dist/esm/index208.js +10 -184
  121. package/dist/esm/index209.js +66 -22
  122. package/dist/esm/index21.js +31 -8
  123. package/dist/esm/index210.js +61 -38
  124. package/dist/esm/index211.js +178 -69
  125. package/dist/esm/index212.js +21 -39
  126. package/dist/esm/index213.js +35 -9
  127. package/dist/esm/index214.js +70 -7
  128. package/dist/esm/index215.js +40 -36
  129. package/dist/esm/index216.js +16 -15
  130. package/dist/esm/index217.js +13 -8
  131. package/dist/esm/index22.js +3 -68
  132. package/dist/esm/index220.js +35 -11
  133. package/dist/esm/index221.js +15 -9
  134. package/dist/esm/index222.js +8 -16
  135. package/dist/esm/index223.js +9 -22
  136. package/dist/esm/index224.js +16 -30
  137. package/dist/esm/index225.js +23 -2
  138. package/dist/esm/index226.js +30 -13
  139. package/dist/esm/index227.js +2 -13
  140. package/dist/esm/index228.js +13 -47
  141. package/dist/esm/index229.js +12 -9
  142. package/dist/esm/index23.js +8 -8
  143. package/dist/esm/index230.js +47 -13
  144. package/dist/esm/index231.js +9 -14
  145. package/dist/esm/index232.js +13 -8
  146. package/dist/esm/index233.js +14 -15
  147. package/dist/esm/index234.js +8 -24
  148. package/dist/esm/index235.js +14 -10
  149. package/dist/esm/index236.js +24 -24
  150. package/dist/esm/index237.js +11 -51
  151. package/dist/esm/index238.js +24 -17
  152. package/dist/esm/index239.js +48 -11
  153. package/dist/esm/index24.js +67 -27
  154. package/dist/esm/index240.js +17 -11
  155. package/dist/esm/index241.js +13 -102
  156. package/dist/esm/index242.js +11 -6
  157. package/dist/esm/index243.js +10 -222
  158. package/dist/esm/index244.js +103 -6
  159. package/dist/esm/index245.js +7 -7
  160. package/dist/esm/index246.js +223 -25
  161. package/dist/esm/index247.js +6 -19
  162. package/dist/esm/index248.js +7 -147
  163. package/dist/esm/index249.js +26 -12
  164. package/dist/esm/index25.js +9 -70
  165. package/dist/esm/index250.js +20 -36
  166. package/dist/esm/index251.js +146 -41
  167. package/dist/esm/index252.js +13 -69
  168. package/dist/esm/index253.js +36 -4
  169. package/dist/esm/index254.js +41 -136
  170. package/dist/esm/index255.js +69 -156
  171. package/dist/esm/index256.js +38 -9
  172. package/dist/esm/index257.js +2 -17
  173. package/dist/esm/index258.js +68 -112
  174. package/dist/esm/index259.js +33 -133
  175. package/dist/esm/index26.js +26 -17
  176. package/dist/esm/index260.js +18 -76
  177. package/dist/esm/index261.js +4 -2
  178. package/dist/esm/index262.js +126 -688
  179. package/dist/esm/index263.js +153 -137
  180. package/dist/esm/index264.js +9 -42
  181. package/dist/esm/index265.js +16 -201
  182. package/dist/esm/index266.js +103 -55
  183. package/dist/esm/index267.js +134 -4
  184. package/dist/esm/index268.js +75 -37
  185. package/dist/esm/index269.js +2 -8
  186. package/dist/esm/index27.js +68 -108
  187. package/dist/esm/index270.js +690 -54
  188. package/dist/esm/index271.js +133 -71
  189. package/dist/esm/index272.js +43 -4
  190. package/dist/esm/index273.js +188 -181
  191. package/dist/esm/index274.js +2 -64
  192. package/dist/esm/index275.js +64 -43
  193. package/dist/esm/index276.js +4 -4
  194. package/dist/esm/index277.js +41 -5
  195. package/dist/esm/index278.js +8 -2
  196. package/dist/esm/index279.js +59 -18
  197. package/dist/esm/index28.js +19 -60
  198. package/dist/esm/index280.js +80 -0
  199. package/dist/esm/index281.js +6 -0
  200. package/dist/esm/index282.js +197 -0
  201. package/dist/esm/index283.js +6 -0
  202. package/dist/esm/index284.js +66 -0
  203. package/dist/esm/index285.js +47 -0
  204. package/dist/esm/index286.js +7 -0
  205. package/dist/esm/index287.js +7 -0
  206. package/dist/esm/index288.js +4 -0
  207. package/dist/esm/index289.js +24 -0
  208. package/dist/esm/index29.js +110 -24
  209. package/dist/esm/index3.js +114 -101
  210. package/dist/esm/index30.js +51 -31
  211. package/dist/esm/index31.js +23 -36
  212. package/dist/esm/index32.js +28 -46
  213. package/dist/esm/index33.js +34 -160
  214. package/dist/esm/index34.js +55 -36
  215. package/dist/esm/index35.js +162 -8
  216. package/dist/esm/index36.js +39 -31
  217. package/dist/esm/index37.js +8 -35
  218. package/dist/esm/index38.js +30 -8
  219. package/dist/esm/index39.js +35 -28
  220. package/dist/esm/index4.js +14 -11
  221. package/dist/esm/index40.js +9 -46
  222. package/dist/esm/index41.js +24 -83
  223. package/dist/esm/index42.js +43 -37
  224. package/dist/esm/index43.js +88 -8
  225. package/dist/esm/index44.js +40 -6
  226. package/dist/esm/index45.js +8 -16
  227. package/dist/esm/index46.js +6 -8
  228. package/dist/esm/index47.js +16 -13
  229. package/dist/esm/index48.js +8 -7
  230. package/dist/esm/index49.js +13 -9
  231. package/dist/esm/index5.js +12 -9
  232. package/dist/esm/index50.js +7 -16
  233. package/dist/esm/index51.js +9 -46
  234. package/dist/esm/index52.js +16 -13
  235. package/dist/esm/index53.js +46 -16
  236. package/dist/esm/index54.js +13 -13
  237. package/dist/esm/index55.js +15 -5
  238. package/dist/esm/index56.js +13 -35
  239. package/dist/esm/index57.js +5 -8
  240. package/dist/esm/index58.js +34 -7
  241. package/dist/esm/index59.js +9 -25
  242. package/dist/esm/index6.js +15 -12
  243. package/dist/esm/index60.js +8 -10
  244. package/dist/esm/index61.js +25 -14
  245. package/dist/esm/index62.js +10 -11
  246. package/dist/esm/index63.js +14 -116
  247. package/dist/esm/index64.js +11 -33
  248. package/dist/esm/index65.js +113 -76
  249. package/dist/esm/index66.js +30 -174
  250. package/dist/esm/index67.js +77 -42
  251. package/dist/esm/index68.js +177 -6
  252. package/dist/esm/index69.js +44 -13
  253. package/dist/esm/index7.js +9 -5
  254. package/dist/esm/index70.js +5 -12
  255. package/dist/esm/index71.js +13 -99
  256. package/dist/esm/index72.js +13 -72
  257. package/dist/esm/index73.js +95 -83
  258. package/dist/esm/index74.js +61 -137
  259. package/dist/esm/index75.js +71 -120
  260. package/dist/esm/index76.js +126 -46
  261. package/dist/esm/index77.js +136 -23
  262. package/dist/esm/index78.js +65 -102
  263. package/dist/esm/index79.js +23 -6
  264. package/dist/esm/index8.js +8 -4
  265. package/dist/esm/index80.js +102 -128
  266. package/dist/esm/index81.js +7 -276
  267. package/dist/esm/index82.js +132 -3
  268. package/dist/esm/index83.js +276 -4
  269. package/dist/esm/index84.js +3 -9
  270. package/dist/esm/index85.js +4 -2
  271. package/dist/esm/index86.js +9 -2
  272. package/dist/esm/index87.js +2 -3
  273. package/dist/esm/index88.js +2 -327
  274. package/dist/esm/index89.js +3 -14
  275. package/dist/esm/index9.js +7 -4
  276. package/dist/esm/index90.js +326 -4
  277. package/dist/esm/index91.js +12 -54
  278. package/dist/esm/index92.js +5 -2
  279. package/dist/esm/index93.js +54 -6
  280. package/dist/esm/index94.js +2 -215
  281. package/dist/esm/index95.js +8 -32
  282. package/dist/esm/index96.js +213 -20
  283. package/dist/esm/index97.js +32 -6
  284. package/dist/esm/index98.js +21 -73
  285. package/dist/esm/index99.js +5 -5
  286. package/package.json +3 -3
@@ -1,90 +1,102 @@
1
- import { getAction as p } from "./index218.js";
2
- import { observe as h } from "./index215.js";
3
- import { poll as v } from "./index216.js";
4
- import { stringify as S } from "./index112.js";
5
- import { getBlock as i } from "./index45.js";
6
- function P(r, { blockTag: l = r.experimental_blockTag ?? "latest", emitMissed: y = !1, emitOnBegin: m = !1, onBlock: k, onError: f, includeTransactions: B, poll: d, pollingInterval: w = r.pollingInterval }) {
7
- const g = typeof d < "u" ? d : !(r.transport.type === "webSocket" || r.transport.type === "ipc" || r.transport.type === "fallback" && (r.transport.transports[0].config.type === "webSocket" || r.transport.transports[0].config.type === "ipc")), a = B ?? !1;
8
- let e;
9
- return g ? (() => {
10
- const o = S([
11
- "watchBlocks",
12
- r.uid,
13
- l,
14
- y,
15
- m,
16
- a,
17
- w
18
- ]);
19
- return h(o, { onBlock: k, onError: f }, (s) => v(async () => {
20
- try {
21
- const t = await p(r, i, "getBlock")({
22
- blockTag: l,
23
- includeTransactions: a
24
- });
25
- if (t.number !== null && e?.number != null) {
26
- if (t.number === e.number)
27
- return;
28
- if (t.number - e.number > 1 && y)
29
- for (let u = e?.number + 1n; u < t.number; u++) {
30
- const b = await p(r, i, "getBlock")({
31
- blockNumber: u,
32
- includeTransactions: a
33
- });
34
- s.onBlock(b, e), e = b;
1
+ import { BlockNotFoundError as D } from "./index95.js";
2
+ import { WaitForTransactionReceiptTimeoutError as M, TransactionNotFoundError as O, TransactionReceiptNotFoundError as W } from "./index104.js";
3
+ import { getAction as l } from "./index218.js";
4
+ import { observe as q } from "./index220.js";
5
+ import { withResolvers as z } from "./index222.js";
6
+ import { withRetry as B } from "./index186.js";
7
+ import { stringify as G } from "./index114.js";
8
+ import { getBlock as H } from "./index47.js";
9
+ import { getTransaction as J } from "./index61.js";
10
+ import { getTransactionReceipt as g } from "./index64.js";
11
+ import { watchBlockNumber as K } from "./index74.js";
12
+ async function re(r, b) {
13
+ const {
14
+ checkReplacement: F = !0,
15
+ confirmations: n = 1,
16
+ hash: s,
17
+ onReplaced: _,
18
+ retryCount: v = 6,
19
+ retryDelay: y = ({ count: t }) => ~~(1 << t) * 200,
20
+ // exponential backoff
21
+ timeout: N = 18e4
22
+ } = b, I = G(["waitForTransactionReceipt", r.uid, s]), E = b.pollingInterval ? b.pollingInterval : r.chain?.experimental_preconfirmationTime ? r.chain.experimental_preconfirmationTime : r.pollingInterval;
23
+ let i, a, e, c = !1, p, d;
24
+ const { promise: j, resolve: x, reject: R } = z(), w = N ? setTimeout(() => {
25
+ d(), p(), R(new M({ hash: s }));
26
+ }, N) : void 0;
27
+ return p = q(I, { onReplaced: _, resolve: x, reject: R }, async (t) => {
28
+ if (e = await l(r, g, "getTransactionReceipt")({ hash: s }).catch(() => {
29
+ }), e && n <= 1) {
30
+ clearTimeout(w), t.resolve(e), p();
31
+ return;
32
+ }
33
+ d = l(r, K, "watchBlockNumber")({
34
+ emitMissed: !0,
35
+ emitOnBegin: !0,
36
+ poll: !0,
37
+ pollingInterval: E,
38
+ async onBlockNumber(A) {
39
+ const u = (f) => {
40
+ clearTimeout(w), d(), f(), p();
41
+ };
42
+ let m = A;
43
+ if (!c)
44
+ try {
45
+ if (e) {
46
+ if (n > 1 && (!e.blockNumber || m - e.blockNumber + 1n < n))
47
+ return;
48
+ u(() => t.resolve(e));
49
+ return;
35
50
  }
36
- }
37
- // If no previous block exists, emit.
38
- (e?.number == null || // If the block tag is "pending" with no block number, emit.
39
- l === "pending" && t?.number == null || // If the next block number is greater than the previous block number, emit.
40
- // We don't want to emit blocks in the past.
41
- t.number !== null && t.number > e.number) && (s.onBlock(t, e), e = t);
42
- } catch (t) {
43
- s.onError?.(t);
44
- }
45
- }, {
46
- emitOnBegin: m,
47
- interval: w
48
- }));
49
- })() : (() => {
50
- let o = !0, s = !0, t = () => o = !1;
51
- return (async () => {
52
- try {
53
- m && p(r, i, "getBlock")({
54
- blockTag: l,
55
- includeTransactions: a
56
- }).then((n) => {
57
- o && s && (k(n, void 0), s = !1);
58
- }).catch(f);
59
- const u = (() => {
60
- if (r.transport.type === "fallback") {
61
- const n = r.transport.transports.find((c) => c.config.type === "webSocket" || c.config.type === "ipc");
62
- return n ? n.value : r.transport;
63
- }
64
- return r.transport;
65
- })(), { unsubscribe: b } = await u.subscribe({
66
- params: ["newHeads"],
67
- async onData(n) {
68
- if (!o)
51
+ if (F && !i && (c = !0, await B(async () => {
52
+ i = await l(r, J, "getTransaction")({ hash: s }), i.blockNumber && (m = i.blockNumber);
53
+ }, {
54
+ delay: y,
55
+ retryCount: v
56
+ }), c = !1), e = await l(r, g, "getTransactionReceipt")({ hash: s }), n > 1 && (!e.blockNumber || m - e.blockNumber + 1n < n))
69
57
  return;
70
- const c = await p(r, i, "getBlock")({
71
- blockNumber: n.result?.number,
72
- includeTransactions: a
73
- }).catch(() => {
74
- });
75
- o && (k(c, e), s = !1, e = c);
76
- },
77
- onError(n) {
78
- f?.(n);
58
+ u(() => t.resolve(e));
59
+ } catch (f) {
60
+ if (f instanceof O || f instanceof W) {
61
+ if (!i) {
62
+ c = !1;
63
+ return;
64
+ }
65
+ try {
66
+ a = i, c = !0;
67
+ const T = await B(() => l(r, H, "getBlock")({
68
+ blockNumber: m,
69
+ includeTransactions: !0
70
+ }), {
71
+ delay: y,
72
+ retryCount: v,
73
+ shouldRetry: ({ error: k }) => k instanceof D
74
+ });
75
+ c = !1;
76
+ const o = T.transactions.find(({ from: k, nonce: C }) => k === a.from && C === a.nonce);
77
+ if (!o || (e = await l(r, g, "getTransactionReceipt")({
78
+ hash: o.hash
79
+ }), n > 1 && (!e.blockNumber || m - e.blockNumber + 1n < n)))
80
+ return;
81
+ let h = "replaced";
82
+ o.to === a.to && o.value === a.value && o.input === a.input ? h = "repriced" : o.from === o.to && o.value === 0n && (h = "cancelled"), u(() => {
83
+ t.onReplaced?.({
84
+ reason: h,
85
+ replacedTransaction: a,
86
+ transaction: o,
87
+ transactionReceipt: e
88
+ }), t.resolve(e);
89
+ });
90
+ } catch (T) {
91
+ u(() => t.reject(T));
92
+ }
93
+ } else
94
+ u(() => t.reject(f));
79
95
  }
80
- });
81
- t = b, o || t();
82
- } catch (u) {
83
- f?.(u);
84
96
  }
85
- })(), () => t();
86
- })();
97
+ });
98
+ }), j;
87
99
  }
88
100
  export {
89
- P as watchBlocks
101
+ re as waitForTransactionReceipt
90
102
  };
@@ -1,151 +1,75 @@
1
- import { DecodeLogDataMismatch as M, DecodeLogTopicsMismatch as P } from "./index88.js";
2
- import { InvalidInputRpcError as T } from "./index105.js";
3
- import { decodeEventLog as z } from "./index135.js";
4
- import { encodeEventTopics as A } from "./index145.js";
5
- import { formatLog as B } from "./index126.js";
1
+ import { hexToBigInt as w } from "./index153.js";
6
2
  import { getAction as g } from "./index218.js";
7
- import { observe as F } from "./index215.js";
8
- import { poll as O } from "./index216.js";
9
- import { stringify as D } from "./index112.js";
10
- import { createContractEventFilter as R } from "./index36.js";
11
- import { getBlockNumber as U } from "./index46.js";
12
- import { getContractEvents as j } from "./index50.js";
13
- import { getFilterChanges as q } from "./index53.js";
14
- import { uninstallFilter as x } from "./index68.js";
15
- function st(t, S) {
16
- const { abi: b, address: p, args: l, batch: E = !0, eventName: c, fromBlock: m, onError: h, onLogs: N, poll: L, pollingInterval: w = t.pollingInterval, strict: v } = S;
17
- return (typeof L < "u" ? L : typeof m == "bigint" ? !0 : !(t.transport.type === "webSocket" || t.transport.type === "ipc" || t.transport.type === "fallback" && (t.transport.transports[0].config.type === "webSocket" || t.transport.transports[0].config.type === "ipc"))) ? (() => {
18
- const u = v ?? !1, C = D([
19
- "watchContractEvent",
20
- p,
21
- l,
22
- E,
23
- t.uid,
3
+ import { observe as k } from "./index220.js";
4
+ import { poll as h } from "./index221.js";
5
+ import { stringify as y } from "./index114.js";
6
+ import { getBlockNumber as v } from "./index48.js";
7
+ function H(r, { emitOnBegin: c = !1, emitMissed: a = !1, onBlockNumber: l, onError: b, poll: i, pollingInterval: m = r.pollingInterval }) {
8
+ const N = typeof i < "u" ? i : !(r.transport.type === "webSocket" || r.transport.type === "ipc" || r.transport.type === "fallback" && (r.transport.transports[0].config.type === "webSocket" || r.transport.transports[0].config.type === "ipc"));
9
+ let t;
10
+ return N ? (() => {
11
+ const p = y([
12
+ "watchBlockNumber",
13
+ r.uid,
24
14
  c,
25
- w,
26
- u,
15
+ a,
27
16
  m
28
17
  ]);
29
- return F(C, { onLogs: N, onError: h }, (a) => {
30
- let n;
31
- m !== void 0 && (n = m - 1n);
32
- let e, s = !1;
33
- const k = O(async () => {
34
- if (!s) {
35
- try {
36
- e = await g(t, R, "createContractEventFilter")({
37
- abi: b,
38
- address: p,
39
- args: l,
40
- eventName: c,
41
- strict: u,
42
- fromBlock: m
43
- });
44
- } catch {
45
- }
46
- s = !0;
47
- return;
48
- }
49
- try {
50
- let o;
51
- if (e)
52
- o = await g(t, q, "getFilterChanges")({ filter: e });
53
- else {
54
- const r = await g(t, U, "getBlockNumber")({});
55
- n && n < r ? o = await g(t, j, "getContractEvents")({
56
- abi: b,
57
- address: p,
58
- args: l,
59
- eventName: c,
60
- fromBlock: n + 1n,
61
- toBlock: r,
62
- strict: u
63
- }) : o = [], n = r;
64
- }
65
- if (o.length === 0)
18
+ return k(p, { onBlockNumber: l, onError: b }, (s) => h(async () => {
19
+ try {
20
+ const o = await g(r, v, "getBlockNumber")({ cacheTime: 0 });
21
+ if (t) {
22
+ if (o === t)
66
23
  return;
67
- if (E)
68
- a.onLogs(o);
69
- else
70
- for (const r of o)
71
- a.onLogs([r]);
72
- } catch (o) {
73
- e && o instanceof T && (s = !1), a.onError?.(o);
24
+ if (o - t > 1 && a)
25
+ for (let e = t + 1n; e < o; e++)
26
+ s.onBlockNumber(e, t), t = e;
74
27
  }
75
- }, {
76
- emitOnBegin: !0,
77
- interval: w
78
- });
79
- return async () => {
80
- e && await g(t, x, "uninstallFilter")({ filter: e }), k();
81
- };
82
- });
28
+ (!t || o > t) && (s.onBlockNumber(o, t), t = o);
29
+ } catch (o) {
30
+ s.onError?.(o);
31
+ }
32
+ }, {
33
+ emitOnBegin: c,
34
+ interval: m
35
+ }));
83
36
  })() : (() => {
84
- const u = v ?? !1, C = D([
85
- "watchContractEvent",
86
- p,
87
- l,
88
- E,
89
- t.uid,
37
+ const p = y([
38
+ "watchBlockNumber",
39
+ r.uid,
90
40
  c,
91
- w,
92
- u
41
+ a
93
42
  ]);
94
- let a = !0, n = () => a = !1;
95
- return F(C, { onLogs: N, onError: h }, (e) => ((async () => {
96
- try {
97
- const s = (() => {
98
- if (t.transport.type === "fallback") {
99
- const r = t.transport.transports.find((i) => i.config.type === "webSocket" || i.config.type === "ipc");
100
- return r ? r.value : t.transport;
101
- }
102
- return t.transport;
103
- })(), k = c ? A({
104
- abi: b,
105
- eventName: c,
106
- args: l
107
- }) : [], { unsubscribe: o } = await s.subscribe({
108
- params: ["logs", { address: p, topics: k }],
109
- onData(r) {
110
- if (!a)
111
- return;
112
- const i = r.result;
113
- try {
114
- const { eventName: f, args: d } = z({
115
- abi: b,
116
- data: i.data,
117
- topics: i.topics,
118
- strict: v
119
- }), y = B(i, {
120
- args: d,
121
- eventName: f
122
- });
123
- e.onLogs([y]);
124
- } catch (f) {
125
- let d, y;
126
- if (f instanceof M || f instanceof P) {
127
- if (v)
128
- return;
129
- d = f.abiItem.name, y = f.abiItem.inputs?.some((I) => !("name" in I && I.name));
130
- }
131
- const _ = B(i, {
132
- args: y ? [] : {},
133
- eventName: d
134
- });
135
- e.onLogs([_]);
43
+ return k(p, { onBlockNumber: l, onError: b }, (s) => {
44
+ let o = !0, e = () => o = !1;
45
+ return (async () => {
46
+ try {
47
+ const f = (() => {
48
+ if (r.transport.type === "fallback") {
49
+ const n = r.transport.transports.find((u) => u.config.type === "webSocket" || u.config.type === "ipc");
50
+ return n ? n.value : r.transport;
136
51
  }
137
- },
138
- onError(r) {
139
- e.onError?.(r);
140
- }
141
- });
142
- n = o, a || n();
143
- } catch (s) {
144
- h?.(s);
145
- }
146
- })(), () => n()));
52
+ return r.transport;
53
+ })(), { unsubscribe: B } = await f.subscribe({
54
+ params: ["newHeads"],
55
+ onData(n) {
56
+ if (!o)
57
+ return;
58
+ const u = w(n.result?.number);
59
+ s.onBlockNumber(u, t), t = u;
60
+ },
61
+ onError(n) {
62
+ s.onError?.(n);
63
+ }
64
+ });
65
+ e = B, o || e();
66
+ } catch (f) {
67
+ b?.(f);
68
+ }
69
+ })(), () => e();
70
+ });
147
71
  })();
148
72
  }
149
73
  export {
150
- st as watchContractEvent
74
+ H as watchBlockNumber
151
75
  };
@@ -1,139 +1,90 @@
1
- import { encodeEventTopics as S } from "./index145.js";
2
- import { observe as B } from "./index215.js";
3
- import { poll as C } from "./index216.js";
4
- import { stringify as T } from "./index112.js";
5
- import { DecodeLogDataMismatch as z, DecodeLogTopicsMismatch as A } from "./index88.js";
6
- import { InvalidInputRpcError as O } from "./index105.js";
7
- import { decodeEventLog as P } from "./index135.js";
8
- import { formatLog as I } from "./index126.js";
9
- import { getAction as u } from "./index218.js";
10
- import { createEventFilter as R } from "./index37.js";
11
- import { getBlockNumber as U } from "./index46.js";
12
- import { getFilterChanges as j } from "./index53.js";
13
- import { getLogs as q } from "./index56.js";
14
- import { uninstallFilter as x } from "./index68.js";
15
- function nt(r, { address: m, args: l, batch: h = !0, event: s, events: d, fromBlock: c, onError: y, onLogs: v, poll: E, pollingInterval: k = r.pollingInterval, strict: N }) {
16
- const D = typeof E < "u" ? E : typeof c == "bigint" ? !0 : !(r.transport.type === "webSocket" || r.transport.type === "ipc" || r.transport.type === "fallback" && (r.transport.transports[0].config.type === "webSocket" || r.transport.transports[0].config.type === "ipc")), F = N ?? !1;
17
- return D ? (() => {
18
- const p = T([
19
- "watchEvent",
20
- m,
21
- l,
22
- h,
1
+ import { getAction as p } from "./index218.js";
2
+ import { observe as h } from "./index220.js";
3
+ import { poll as v } from "./index221.js";
4
+ import { stringify as S } from "./index114.js";
5
+ import { getBlock as i } from "./index47.js";
6
+ function P(r, { blockTag: l = r.experimental_blockTag ?? "latest", emitMissed: y = !1, emitOnBegin: m = !1, onBlock: k, onError: f, includeTransactions: B, poll: d, pollingInterval: w = r.pollingInterval }) {
7
+ const g = typeof d < "u" ? d : !(r.transport.type === "webSocket" || r.transport.type === "ipc" || r.transport.type === "fallback" && (r.transport.transports[0].config.type === "webSocket" || r.transport.transports[0].config.type === "ipc")), a = B ?? !1;
8
+ let e;
9
+ return g ? (() => {
10
+ const o = S([
11
+ "watchBlocks",
23
12
  r.uid,
24
- s,
25
- k,
26
- c
13
+ l,
14
+ y,
15
+ m,
16
+ a,
17
+ w
27
18
  ]);
28
- return B(p, { onLogs: v, onError: y }, (a) => {
29
- let n;
30
- c !== void 0 && (n = c - 1n);
31
- let o, i = !1;
32
- const w = C(async () => {
33
- if (!i) {
34
- try {
35
- o = await u(r, R, "createEventFilter")({
36
- address: m,
37
- args: l,
38
- event: s,
39
- events: d,
40
- strict: F,
41
- fromBlock: c
42
- });
43
- } catch {
44
- }
45
- i = !0;
46
- return;
47
- }
48
- try {
49
- let t;
50
- if (o)
51
- t = await u(r, j, "getFilterChanges")({ filter: o });
52
- else {
53
- const e = await u(r, U, "getBlockNumber")({});
54
- n && n !== e ? t = await u(r, q, "getLogs")({
55
- address: m,
56
- args: l,
57
- event: s,
58
- events: d,
59
- fromBlock: n + 1n,
60
- toBlock: e
61
- }) : t = [], n = e;
62
- }
63
- if (t.length === 0)
19
+ return h(o, { onBlock: k, onError: f }, (s) => v(async () => {
20
+ try {
21
+ const t = await p(r, i, "getBlock")({
22
+ blockTag: l,
23
+ includeTransactions: a
24
+ });
25
+ if (t.number !== null && e?.number != null) {
26
+ if (t.number === e.number)
64
27
  return;
65
- if (h)
66
- a.onLogs(t);
67
- else
68
- for (const e of t)
69
- a.onLogs([e]);
70
- } catch (t) {
71
- o && t instanceof O && (i = !1), a.onError?.(t);
28
+ if (t.number - e.number > 1 && y)
29
+ for (let u = e?.number + 1n; u < t.number; u++) {
30
+ const b = await p(r, i, "getBlock")({
31
+ blockNumber: u,
32
+ includeTransactions: a
33
+ });
34
+ s.onBlock(b, e), e = b;
35
+ }
72
36
  }
73
- }, {
74
- emitOnBegin: !0,
75
- interval: k
76
- });
77
- return async () => {
78
- o && await u(r, x, "uninstallFilter")({ filter: o }), w();
79
- };
80
- });
37
+ // If no previous block exists, emit.
38
+ (e?.number == null || // If the block tag is "pending" with no block number, emit.
39
+ l === "pending" && t?.number == null || // If the next block number is greater than the previous block number, emit.
40
+ // We don't want to emit blocks in the past.
41
+ t.number !== null && t.number > e.number) && (s.onBlock(t, e), e = t);
42
+ } catch (t) {
43
+ s.onError?.(t);
44
+ }
45
+ }, {
46
+ emitOnBegin: m,
47
+ interval: w
48
+ }));
81
49
  })() : (() => {
82
- let p = !0, a = () => p = !1;
50
+ let o = !0, s = !0, t = () => o = !1;
83
51
  return (async () => {
84
52
  try {
85
- const n = (() => {
53
+ m && p(r, i, "getBlock")({
54
+ blockTag: l,
55
+ includeTransactions: a
56
+ }).then((n) => {
57
+ o && s && (k(n, void 0), s = !1);
58
+ }).catch(f);
59
+ const u = (() => {
86
60
  if (r.transport.type === "fallback") {
87
- const t = r.transport.transports.find((e) => e.config.type === "webSocket" || e.config.type === "ipc");
88
- return t ? t.value : r.transport;
61
+ const n = r.transport.transports.find((c) => c.config.type === "webSocket" || c.config.type === "ipc");
62
+ return n ? n.value : r.transport;
89
63
  }
90
64
  return r.transport;
91
- })(), o = d ?? (s ? [s] : void 0);
92
- let i = [];
93
- o && (i = [o.flatMap((e) => S({
94
- abi: [e],
95
- eventName: e.name,
96
- args: l
97
- }))], s && (i = i[0]));
98
- const { unsubscribe: w } = await n.subscribe({
99
- params: ["logs", { address: m, topics: i }],
100
- onData(t) {
101
- if (!p)
65
+ })(), { unsubscribe: b } = await u.subscribe({
66
+ params: ["newHeads"],
67
+ async onData(n) {
68
+ if (!o)
102
69
  return;
103
- const e = t.result;
104
- try {
105
- const { eventName: f, args: b } = P({
106
- abi: o ?? [],
107
- data: e.data,
108
- topics: e.topics,
109
- strict: F
110
- }), g = I(e, { args: b, eventName: f });
111
- v([g]);
112
- } catch (f) {
113
- let b, g;
114
- if (f instanceof z || f instanceof A) {
115
- if (N)
116
- return;
117
- b = f.abiItem.name, g = f.abiItem.inputs?.some((L) => !("name" in L && L.name));
118
- }
119
- const M = I(e, {
120
- args: g ? [] : {},
121
- eventName: b
122
- });
123
- v([M]);
124
- }
70
+ const c = await p(r, i, "getBlock")({
71
+ blockNumber: n.result?.number,
72
+ includeTransactions: a
73
+ }).catch(() => {
74
+ });
75
+ o && (k(c, e), s = !1, e = c);
125
76
  },
126
- onError(t) {
127
- y?.(t);
77
+ onError(n) {
78
+ f?.(n);
128
79
  }
129
80
  });
130
- a = w, p || a();
131
- } catch (n) {
132
- y?.(n);
81
+ t = b, o || t();
82
+ } catch (u) {
83
+ f?.(u);
133
84
  }
134
- })(), () => a();
85
+ })(), () => t();
135
86
  })();
136
87
  }
137
88
  export {
138
- nt as watchEvent
89
+ P as watchBlocks
139
90
  };