@hashgraphonline/standards-sdk 0.1.167 → 0.1.169

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 (385) hide show
  1. package/README.md +21 -7
  2. package/dist/browser/hcs-10/sdk.d.ts.map +1 -1
  3. package/dist/browser/hcs-10/types.d.ts +3 -1
  4. package/dist/browser/hcs-10/types.d.ts.map +1 -1
  5. package/dist/browser/hcs-11/client.d.ts.map +1 -1
  6. package/dist/browser/hcs-11/types.d.ts +2 -1
  7. package/dist/browser/hcs-11/types.d.ts.map +1 -1
  8. package/dist/browser/hcs-12/sdk.d.ts +2 -0
  9. package/dist/browser/hcs-12/sdk.d.ts.map +1 -1
  10. package/dist/browser/hcs-15/sdk.d.ts.map +1 -1
  11. package/dist/browser/hcs-15/types.d.ts +2 -1
  12. package/dist/browser/hcs-15/types.d.ts.map +1 -1
  13. package/dist/browser/hcs-16/sdk.d.ts +2 -1
  14. package/dist/browser/hcs-16/sdk.d.ts.map +1 -1
  15. package/dist/browser/hcs-17/sdk.d.ts.map +1 -1
  16. package/dist/browser/hcs-17/types.d.ts +2 -1
  17. package/dist/browser/hcs-17/types.d.ts.map +1 -1
  18. package/dist/browser/hcs-18/sdk.d.ts +2 -1
  19. package/dist/browser/hcs-18/sdk.d.ts.map +1 -1
  20. package/dist/browser/hcs-2/client.d.ts +2 -1
  21. package/dist/browser/hcs-2/client.d.ts.map +1 -1
  22. package/dist/browser/hcs-20/sdk.d.ts.map +1 -1
  23. package/dist/browser/hcs-20/types.d.ts +2 -1
  24. package/dist/browser/hcs-20/types.d.ts.map +1 -1
  25. package/dist/browser/hcs-21/sdk.d.ts +2 -1
  26. package/dist/browser/hcs-21/sdk.d.ts.map +1 -1
  27. package/dist/browser/hcs-27/base-client.d.ts +41 -0
  28. package/dist/browser/hcs-27/base-client.d.ts.map +1 -0
  29. package/dist/browser/hcs-27/index.d.ts +6 -0
  30. package/dist/browser/hcs-27/index.d.ts.map +1 -0
  31. package/dist/browser/hcs-27/memos.d.ts +5 -0
  32. package/dist/browser/hcs-27/memos.d.ts.map +1 -0
  33. package/dist/browser/hcs-27/merkle.d.ts +23 -0
  34. package/dist/browser/hcs-27/merkle.d.ts.map +1 -0
  35. package/dist/browser/hcs-27/sdk.d.ts +23 -0
  36. package/dist/browser/hcs-27/sdk.d.ts.map +1 -0
  37. package/dist/browser/hcs-27/types.d.ts +1611 -0
  38. package/dist/browser/hcs-27/types.d.ts.map +1 -0
  39. package/dist/browser/hcs-5/sdk.d.ts.map +1 -1
  40. package/dist/browser/hcs-5/types.d.ts +2 -1
  41. package/dist/browser/hcs-5/types.d.ts.map +1 -1
  42. package/dist/browser/hcs-6/sdk.d.ts +2 -1
  43. package/dist/browser/hcs-6/sdk.d.ts.map +1 -1
  44. package/dist/browser/hcs-7/sdk.d.ts.map +1 -1
  45. package/dist/browser/hcs-7/types.d.ts +2 -1
  46. package/dist/browser/hcs-7/types.d.ts.map +1 -1
  47. package/dist/browser/index.d.ts +1 -0
  48. package/dist/browser/index.d.ts.map +1 -1
  49. package/dist/browser/standards-sdk.browser.js +33 -8
  50. package/dist/browser/standards-sdk.browser.js.map +1 -1
  51. package/dist/browser/utils/key-type-detector.d.ts.map +1 -1
  52. package/dist/cjs/hcs-10/sdk.d.ts.map +1 -1
  53. package/dist/cjs/hcs-10/types.d.ts +3 -1
  54. package/dist/cjs/hcs-10/types.d.ts.map +1 -1
  55. package/dist/cjs/hcs-11/client.d.ts.map +1 -1
  56. package/dist/cjs/hcs-11/types.d.ts +2 -1
  57. package/dist/cjs/hcs-11/types.d.ts.map +1 -1
  58. package/dist/cjs/hcs-12/sdk.d.ts +2 -0
  59. package/dist/cjs/hcs-12/sdk.d.ts.map +1 -1
  60. package/dist/cjs/hcs-15/sdk.d.ts.map +1 -1
  61. package/dist/cjs/hcs-15/types.d.ts +2 -1
  62. package/dist/cjs/hcs-15/types.d.ts.map +1 -1
  63. package/dist/cjs/hcs-16/sdk.d.ts +2 -1
  64. package/dist/cjs/hcs-16/sdk.d.ts.map +1 -1
  65. package/dist/cjs/hcs-17/sdk.d.ts.map +1 -1
  66. package/dist/cjs/hcs-17/types.d.ts +2 -1
  67. package/dist/cjs/hcs-17/types.d.ts.map +1 -1
  68. package/dist/cjs/hcs-18/sdk.d.ts +2 -1
  69. package/dist/cjs/hcs-18/sdk.d.ts.map +1 -1
  70. package/dist/cjs/hcs-2/client.d.ts +2 -1
  71. package/dist/cjs/hcs-2/client.d.ts.map +1 -1
  72. package/dist/cjs/hcs-20/sdk.d.ts.map +1 -1
  73. package/dist/cjs/hcs-20/types.d.ts +2 -1
  74. package/dist/cjs/hcs-20/types.d.ts.map +1 -1
  75. package/dist/cjs/hcs-21/sdk.d.ts +2 -1
  76. package/dist/cjs/hcs-21/sdk.d.ts.map +1 -1
  77. package/dist/cjs/hcs-27/base-client.d.ts +41 -0
  78. package/dist/cjs/hcs-27/base-client.d.ts.map +1 -0
  79. package/dist/cjs/hcs-27/index.d.ts +6 -0
  80. package/dist/cjs/hcs-27/index.d.ts.map +1 -0
  81. package/dist/cjs/hcs-27/memos.d.ts +5 -0
  82. package/dist/cjs/hcs-27/memos.d.ts.map +1 -0
  83. package/dist/cjs/hcs-27/merkle.d.ts +23 -0
  84. package/dist/cjs/hcs-27/merkle.d.ts.map +1 -0
  85. package/dist/cjs/hcs-27/sdk.d.ts +23 -0
  86. package/dist/cjs/hcs-27/sdk.d.ts.map +1 -0
  87. package/dist/cjs/hcs-27/types.d.ts +1611 -0
  88. package/dist/cjs/hcs-27/types.d.ts.map +1 -0
  89. package/dist/cjs/hcs-5/sdk.d.ts.map +1 -1
  90. package/dist/cjs/hcs-5/types.d.ts +2 -1
  91. package/dist/cjs/hcs-5/types.d.ts.map +1 -1
  92. package/dist/cjs/hcs-6/sdk.d.ts +2 -1
  93. package/dist/cjs/hcs-6/sdk.d.ts.map +1 -1
  94. package/dist/cjs/hcs-7/sdk.d.ts.map +1 -1
  95. package/dist/cjs/hcs-7/types.d.ts +2 -1
  96. package/dist/cjs/hcs-7/types.d.ts.map +1 -1
  97. package/dist/cjs/index.d.ts +1 -0
  98. package/dist/cjs/index.d.ts.map +1 -1
  99. package/dist/cjs/standards-sdk.cjs +2 -2
  100. package/dist/cjs/standards-sdk.cjs.map +1 -1
  101. package/dist/cjs/utils/key-type-detector.d.ts.map +1 -1
  102. package/dist/es/hcs-10/sdk.d.ts.map +1 -1
  103. package/dist/es/hcs-10/types.d.ts +3 -1
  104. package/dist/es/hcs-10/types.d.ts.map +1 -1
  105. package/dist/es/hcs-11/client.d.ts.map +1 -1
  106. package/dist/es/hcs-11/types.d.ts +2 -1
  107. package/dist/es/hcs-11/types.d.ts.map +1 -1
  108. package/dist/es/hcs-12/sdk.d.ts +2 -0
  109. package/dist/es/hcs-12/sdk.d.ts.map +1 -1
  110. package/dist/es/hcs-15/sdk.d.ts.map +1 -1
  111. package/dist/es/hcs-15/types.d.ts +2 -1
  112. package/dist/es/hcs-15/types.d.ts.map +1 -1
  113. package/dist/es/hcs-16/sdk.d.ts +2 -1
  114. package/dist/es/hcs-16/sdk.d.ts.map +1 -1
  115. package/dist/es/hcs-17/sdk.d.ts.map +1 -1
  116. package/dist/es/hcs-17/types.d.ts +2 -1
  117. package/dist/es/hcs-17/types.d.ts.map +1 -1
  118. package/dist/es/hcs-18/sdk.d.ts +2 -1
  119. package/dist/es/hcs-18/sdk.d.ts.map +1 -1
  120. package/dist/es/hcs-2/client.d.ts +2 -1
  121. package/dist/es/hcs-2/client.d.ts.map +1 -1
  122. package/dist/es/hcs-20/sdk.d.ts.map +1 -1
  123. package/dist/es/hcs-20/types.d.ts +2 -1
  124. package/dist/es/hcs-20/types.d.ts.map +1 -1
  125. package/dist/es/hcs-21/sdk.d.ts +2 -1
  126. package/dist/es/hcs-21/sdk.d.ts.map +1 -1
  127. package/dist/es/hcs-27/base-client.d.ts +41 -0
  128. package/dist/es/hcs-27/base-client.d.ts.map +1 -0
  129. package/dist/es/hcs-27/index.d.ts +6 -0
  130. package/dist/es/hcs-27/index.d.ts.map +1 -0
  131. package/dist/es/hcs-27/memos.d.ts +5 -0
  132. package/dist/es/hcs-27/memos.d.ts.map +1 -0
  133. package/dist/es/hcs-27/merkle.d.ts +23 -0
  134. package/dist/es/hcs-27/merkle.d.ts.map +1 -0
  135. package/dist/es/hcs-27/sdk.d.ts +23 -0
  136. package/dist/es/hcs-27/sdk.d.ts.map +1 -0
  137. package/dist/es/hcs-27/types.d.ts +1611 -0
  138. package/dist/es/hcs-27/types.d.ts.map +1 -0
  139. package/dist/es/hcs-5/sdk.d.ts.map +1 -1
  140. package/dist/es/hcs-5/types.d.ts +2 -1
  141. package/dist/es/hcs-5/types.d.ts.map +1 -1
  142. package/dist/es/hcs-6/sdk.d.ts +2 -1
  143. package/dist/es/hcs-6/sdk.d.ts.map +1 -1
  144. package/dist/es/hcs-7/sdk.d.ts.map +1 -1
  145. package/dist/es/hcs-7/types.d.ts +2 -1
  146. package/dist/es/hcs-7/types.d.ts.map +1 -1
  147. package/dist/es/index.d.ts +1 -0
  148. package/dist/es/index.d.ts.map +1 -1
  149. package/dist/es/standards-sdk.es.js +67 -38
  150. package/dist/es/standards-sdk.es.js.map +1 -1
  151. package/dist/es/standards-sdk.es101.js +2 -2
  152. package/dist/es/standards-sdk.es102.js.map +1 -1
  153. package/dist/es/standards-sdk.es103.js +2 -2
  154. package/dist/es/standards-sdk.es104.js +2 -2
  155. package/dist/es/standards-sdk.es104.js.map +1 -1
  156. package/dist/es/standards-sdk.es106.js +1 -1
  157. package/dist/es/standards-sdk.es108.js +3 -3
  158. package/dist/es/standards-sdk.es108.js.map +1 -1
  159. package/dist/es/standards-sdk.es11.js +3 -2
  160. package/dist/es/standards-sdk.es11.js.map +1 -1
  161. package/dist/es/standards-sdk.es110.js +1 -1
  162. package/dist/es/standards-sdk.es111.js +2 -2
  163. package/dist/es/standards-sdk.es112.js +151 -234
  164. package/dist/es/standards-sdk.es112.js.map +1 -1
  165. package/dist/es/standards-sdk.es113.js +20 -471
  166. package/dist/es/standards-sdk.es113.js.map +1 -1
  167. package/dist/es/standards-sdk.es114.js +263 -104
  168. package/dist/es/standards-sdk.es114.js.map +1 -1
  169. package/dist/es/standards-sdk.es115.js +167 -138
  170. package/dist/es/standards-sdk.es115.js.map +1 -1
  171. package/dist/es/standards-sdk.es116.js +315 -29
  172. package/dist/es/standards-sdk.es116.js.map +1 -1
  173. package/dist/es/standards-sdk.es117.js +250 -10
  174. package/dist/es/standards-sdk.es117.js.map +1 -1
  175. package/dist/es/standards-sdk.es118.js +448 -152
  176. package/dist/es/standards-sdk.es118.js.map +1 -1
  177. package/dist/es/standards-sdk.es119.js +101 -25
  178. package/dist/es/standards-sdk.es119.js.map +1 -1
  179. package/dist/es/standards-sdk.es12.js +1 -1
  180. package/dist/es/standards-sdk.es120.js +155 -17
  181. package/dist/es/standards-sdk.es120.js.map +1 -1
  182. package/dist/es/standards-sdk.es121.js +29 -155
  183. package/dist/es/standards-sdk.es121.js.map +1 -1
  184. package/dist/es/standards-sdk.es122.js +9 -200
  185. package/dist/es/standards-sdk.es122.js.map +1 -1
  186. package/dist/es/standards-sdk.es123.js +146 -754
  187. package/dist/es/standards-sdk.es123.js.map +1 -1
  188. package/dist/es/standards-sdk.es124.js +27 -11
  189. package/dist/es/standards-sdk.es124.js.map +1 -1
  190. package/dist/es/standards-sdk.es125.js +19 -564
  191. package/dist/es/standards-sdk.es125.js.map +1 -1
  192. package/dist/es/standards-sdk.es126.js +140 -582
  193. package/dist/es/standards-sdk.es126.js.map +1 -1
  194. package/dist/es/standards-sdk.es127.js +202 -12
  195. package/dist/es/standards-sdk.es127.js.map +1 -1
  196. package/dist/es/standards-sdk.es128.js +790 -2
  197. package/dist/es/standards-sdk.es128.js.map +1 -1
  198. package/dist/es/standards-sdk.es129.js +10 -84
  199. package/dist/es/standards-sdk.es129.js.map +1 -1
  200. package/dist/es/standards-sdk.es13.js +1 -1
  201. package/dist/es/standards-sdk.es130.js +567 -40
  202. package/dist/es/standards-sdk.es130.js.map +1 -1
  203. package/dist/es/standards-sdk.es131.js +626 -2
  204. package/dist/es/standards-sdk.es131.js.map +1 -1
  205. package/dist/es/standards-sdk.es132.js +12 -234
  206. package/dist/es/standards-sdk.es132.js.map +1 -1
  207. package/dist/es/standards-sdk.es133.js +2 -1140
  208. package/dist/es/standards-sdk.es133.js.map +1 -1
  209. package/dist/es/standards-sdk.es134.js +73 -292
  210. package/dist/es/standards-sdk.es134.js.map +1 -1
  211. package/dist/es/standards-sdk.es135.js +36 -418
  212. package/dist/es/standards-sdk.es135.js.map +1 -1
  213. package/dist/es/standards-sdk.es136.js +2 -355
  214. package/dist/es/standards-sdk.es136.js.map +1 -1
  215. package/dist/es/standards-sdk.es137.js +198 -1079
  216. package/dist/es/standards-sdk.es137.js.map +1 -1
  217. package/dist/es/standards-sdk.es138.js +1107 -175
  218. package/dist/es/standards-sdk.es138.js.map +1 -1
  219. package/dist/es/standards-sdk.es139.js +218 -1479
  220. package/dist/es/standards-sdk.es139.js.map +1 -1
  221. package/dist/es/standards-sdk.es14.js +1 -1
  222. package/dist/es/standards-sdk.es140.js +422 -1500
  223. package/dist/es/standards-sdk.es140.js.map +1 -1
  224. package/dist/es/standards-sdk.es141.js +351 -13
  225. package/dist/es/standards-sdk.es141.js.map +1 -1
  226. package/dist/es/standards-sdk.es142.js +1102 -73
  227. package/dist/es/standards-sdk.es142.js.map +1 -1
  228. package/dist/es/standards-sdk.es143.js +203 -76
  229. package/dist/es/standards-sdk.es143.js.map +1 -1
  230. package/dist/es/standards-sdk.es144.js +1459 -830
  231. package/dist/es/standards-sdk.es144.js.map +1 -1
  232. package/dist/es/standards-sdk.es145.js +1499 -59
  233. package/dist/es/standards-sdk.es145.js.map +1 -1
  234. package/dist/es/standards-sdk.es146.js +14 -156
  235. package/dist/es/standards-sdk.es146.js.map +1 -1
  236. package/dist/es/standards-sdk.es147.js +87 -7
  237. package/dist/es/standards-sdk.es147.js.map +1 -1
  238. package/dist/es/standards-sdk.es148.js +74 -79
  239. package/dist/es/standards-sdk.es148.js.map +1 -1
  240. package/dist/es/standards-sdk.es149.js +934 -61
  241. package/dist/es/standards-sdk.es149.js.map +1 -1
  242. package/dist/es/standards-sdk.es15.js +1 -1
  243. package/dist/es/standards-sdk.es150.js +60 -30
  244. package/dist/es/standards-sdk.es150.js.map +1 -1
  245. package/dist/es/standards-sdk.es151.js +159 -34
  246. package/dist/es/standards-sdk.es151.js.map +1 -1
  247. package/dist/es/standards-sdk.es152.js +7 -48
  248. package/dist/es/standards-sdk.es152.js.map +1 -1
  249. package/dist/es/standards-sdk.es153.js +70 -122
  250. package/dist/es/standards-sdk.es153.js.map +1 -1
  251. package/dist/es/standards-sdk.es154.js +58 -35
  252. package/dist/es/standards-sdk.es154.js.map +1 -1
  253. package/dist/es/standards-sdk.es155.js +30 -12482
  254. package/dist/es/standards-sdk.es155.js.map +1 -1
  255. package/dist/es/standards-sdk.es156.js +34 -56
  256. package/dist/es/standards-sdk.es156.js.map +1 -1
  257. package/dist/es/standards-sdk.es157.js +48 -84
  258. package/dist/es/standards-sdk.es157.js.map +1 -1
  259. package/dist/es/standards-sdk.es158.js +128 -71
  260. package/dist/es/standards-sdk.es158.js.map +1 -1
  261. package/dist/es/standards-sdk.es159.js +33 -191
  262. package/dist/es/standards-sdk.es159.js.map +1 -1
  263. package/dist/es/standards-sdk.es16.js +5 -5
  264. package/dist/es/standards-sdk.es160.js +12477 -12
  265. package/dist/es/standards-sdk.es160.js.map +1 -1
  266. package/dist/es/standards-sdk.es161.js +15 -548
  267. package/dist/es/standards-sdk.es161.js.map +1 -1
  268. package/dist/es/standards-sdk.es162.js +51 -167
  269. package/dist/es/standards-sdk.es162.js.map +1 -1
  270. package/dist/es/standards-sdk.es163.js +70 -308
  271. package/dist/es/standards-sdk.es163.js.map +1 -1
  272. package/dist/es/standards-sdk.es164.js +71 -336
  273. package/dist/es/standards-sdk.es164.js.map +1 -1
  274. package/dist/es/standards-sdk.es165.js +186 -439
  275. package/dist/es/standards-sdk.es165.js.map +1 -1
  276. package/dist/es/standards-sdk.es166.js +537 -318
  277. package/dist/es/standards-sdk.es166.js.map +1 -1
  278. package/dist/es/standards-sdk.es167.js +63 -66
  279. package/dist/es/standards-sdk.es167.js.map +1 -1
  280. package/dist/es/standards-sdk.es168.js +165 -66
  281. package/dist/es/standards-sdk.es168.js.map +1 -1
  282. package/dist/es/standards-sdk.es169.js +310 -160
  283. package/dist/es/standards-sdk.es169.js.map +1 -1
  284. package/dist/es/standards-sdk.es170.js +336 -212
  285. package/dist/es/standards-sdk.es170.js.map +1 -1
  286. package/dist/es/standards-sdk.es171.js +437 -223
  287. package/dist/es/standards-sdk.es171.js.map +1 -1
  288. package/dist/es/standards-sdk.es172.js +324 -112
  289. package/dist/es/standards-sdk.es172.js.map +1 -1
  290. package/dist/es/standards-sdk.es173.js +65 -115
  291. package/dist/es/standards-sdk.es173.js.map +1 -1
  292. package/dist/es/standards-sdk.es174.js +151 -140
  293. package/dist/es/standards-sdk.es174.js.map +1 -1
  294. package/dist/es/standards-sdk.es175.js +193 -156
  295. package/dist/es/standards-sdk.es175.js.map +1 -1
  296. package/dist/es/standards-sdk.es176.js +221 -121
  297. package/dist/es/standards-sdk.es176.js.map +1 -1
  298. package/dist/es/standards-sdk.es177.js +81 -293
  299. package/dist/es/standards-sdk.es177.js.map +1 -1
  300. package/dist/es/standards-sdk.es178.js +114 -247
  301. package/dist/es/standards-sdk.es178.js.map +1 -1
  302. package/dist/es/standards-sdk.es179.js +119 -110
  303. package/dist/es/standards-sdk.es179.js.map +1 -1
  304. package/dist/es/standards-sdk.es18.js +15 -14
  305. package/dist/es/standards-sdk.es18.js.map +1 -1
  306. package/dist/es/standards-sdk.es180.js +188 -0
  307. package/dist/es/standards-sdk.es180.js.map +1 -0
  308. package/dist/es/standards-sdk.es181.js +142 -0
  309. package/dist/es/standards-sdk.es181.js.map +1 -0
  310. package/dist/es/standards-sdk.es182.js +334 -0
  311. package/dist/es/standards-sdk.es182.js.map +1 -0
  312. package/dist/es/standards-sdk.es183.js +262 -0
  313. package/dist/es/standards-sdk.es183.js.map +1 -0
  314. package/dist/es/standards-sdk.es184.js +155 -0
  315. package/dist/es/standards-sdk.es184.js.map +1 -0
  316. package/dist/es/standards-sdk.es19.js +9 -9
  317. package/dist/es/standards-sdk.es2.js +2 -2
  318. package/dist/es/standards-sdk.es20.js +1 -1
  319. package/dist/es/standards-sdk.es21.js +1 -1
  320. package/dist/es/standards-sdk.es22.js +1 -1
  321. package/dist/es/standards-sdk.es23.js +1 -1
  322. package/dist/es/standards-sdk.es24.js +1 -1
  323. package/dist/es/standards-sdk.es25.js +1 -1
  324. package/dist/es/standards-sdk.es26.js +1 -1
  325. package/dist/es/standards-sdk.es27.js +13 -13
  326. package/dist/es/standards-sdk.es27.js.map +1 -1
  327. package/dist/es/standards-sdk.es28.js.map +1 -1
  328. package/dist/es/standards-sdk.es30.js +2 -2
  329. package/dist/es/standards-sdk.es31.js +4 -4
  330. package/dist/es/standards-sdk.es32.js +1 -1
  331. package/dist/es/standards-sdk.es35.js +6 -6
  332. package/dist/es/standards-sdk.es36.js +5 -5
  333. package/dist/es/standards-sdk.es36.js.map +1 -1
  334. package/dist/es/standards-sdk.es37.js +2 -2
  335. package/dist/es/standards-sdk.es38.js +2 -2
  336. package/dist/es/standards-sdk.es39.js +1 -1
  337. package/dist/es/standards-sdk.es4.js +3 -3
  338. package/dist/es/standards-sdk.es4.js.map +1 -1
  339. package/dist/es/standards-sdk.es40.js +1 -1
  340. package/dist/es/standards-sdk.es41.js +2 -2
  341. package/dist/es/standards-sdk.es46.js +1 -1
  342. package/dist/es/standards-sdk.es5.js +2 -2
  343. package/dist/es/standards-sdk.es51.js +1 -1
  344. package/dist/es/standards-sdk.es53.js +1 -1
  345. package/dist/es/standards-sdk.es56.js +2 -2
  346. package/dist/es/standards-sdk.es59.js +1 -1
  347. package/dist/es/standards-sdk.es6.js +2 -2
  348. package/dist/es/standards-sdk.es60.js +1 -1
  349. package/dist/es/standards-sdk.es62.js +1 -1
  350. package/dist/es/standards-sdk.es63.js +2 -2
  351. package/dist/es/standards-sdk.es64.js +1 -1
  352. package/dist/es/standards-sdk.es65.js +1 -1
  353. package/dist/es/standards-sdk.es66.js +1 -1
  354. package/dist/es/standards-sdk.es67.js +7 -7
  355. package/dist/es/standards-sdk.es69.js +1 -1
  356. package/dist/es/standards-sdk.es7.js +1 -1
  357. package/dist/es/standards-sdk.es70.js.map +1 -1
  358. package/dist/es/standards-sdk.es71.js +2 -2
  359. package/dist/es/standards-sdk.es72.js +5 -4
  360. package/dist/es/standards-sdk.es72.js.map +1 -1
  361. package/dist/es/standards-sdk.es75.js +6 -6
  362. package/dist/es/standards-sdk.es75.js.map +1 -1
  363. package/dist/es/standards-sdk.es76.js +3 -3
  364. package/dist/es/standards-sdk.es77.js +2 -2
  365. package/dist/es/standards-sdk.es78.js +1 -1
  366. package/dist/es/standards-sdk.es79.js.map +1 -1
  367. package/dist/es/standards-sdk.es8.js.map +1 -1
  368. package/dist/es/standards-sdk.es81.js +2 -2
  369. package/dist/es/standards-sdk.es83.js +7 -5
  370. package/dist/es/standards-sdk.es83.js.map +1 -1
  371. package/dist/es/standards-sdk.es84.js +4 -4
  372. package/dist/es/standards-sdk.es85.js +1 -1
  373. package/dist/es/standards-sdk.es88.js +1 -1
  374. package/dist/es/standards-sdk.es89.js +2 -2
  375. package/dist/es/standards-sdk.es9.js +2 -2
  376. package/dist/es/standards-sdk.es90.js +5 -5
  377. package/dist/es/standards-sdk.es90.js.map +1 -1
  378. package/dist/es/standards-sdk.es94.js +4 -4
  379. package/dist/es/standards-sdk.es94.js.map +1 -1
  380. package/dist/es/standards-sdk.es96.js +2 -2
  381. package/dist/es/standards-sdk.es98.js +1 -1
  382. package/dist/es/standards-sdk.es99.js +4 -4
  383. package/dist/es/standards-sdk.es99.js.map +1 -1
  384. package/dist/es/utils/key-type-detector.d.ts.map +1 -1
  385. package/package.json +1 -1
@@ -1,941 +1,1570 @@
1
- import { Buffer } from "buffer";
2
- import { randomBytes, createHash, createCipheriv, createDecipheriv } from "crypto";
3
- import { secp256k1 } from "@noble/curves/secp256k1.js";
4
- import { ZodError } from "zod";
5
- import { agentFeedbackResponseSchema, agentFeedbackIndexResponseSchema, agentFeedbackEntriesIndexResponseSchema, agentFeedbackEligibilityResponseSchema, agentFeedbackSubmissionResponseSchema, registerAgentResponseSchema } from "./standards-sdk.es140.js";
6
- import { fetchHistorySnapshot, attachDecryptedHistory, registerConversationContextForEncryption, resolveDecryptionContext, decryptHistoryEntryFromContext } from "./standards-sdk.es176.js";
7
- import { createChatApi, createSession, startChat, startConversation, acceptConversation, compactHistory, fetchEncryptionStatus, postEncryptionHandshake, sendMessage, endSession, createPlaintextConversationHandle } from "./standards-sdk.es177.js";
8
- import { EncryptedChatManager } from "./standards-sdk.es178.js";
9
- import { generateEncryptionKeyPair, bootstrapEncryptionOptions, createEncryptionApi } from "./standards-sdk.es169.js";
10
- import { adapters, adaptersDetailed, adapterRegistryCategories, adapterRegistryAdapters, createAdapterRegistryCategory, submitAdapterRegistryAdapter, adapterRegistrySubmissionStatus } from "./standards-sdk.es172.js";
11
- import { resolveUaid, getRegistrationQuote, updateAgent, getRegistrationProgress, waitForRegistrationCompletion, validateUaid, getUaidConnectionStatus, closeUaidConnection, dashboardStats } from "./standards-sdk.es174.js";
12
- import { getRegisterStatus, registerOwnedMoltbookAgent, getVerificationStatus, createVerificationChallenge, getVerificationChallenge, verifyVerificationChallenge, getVerificationOwnership, verifySenderOwnership, verifyUaidDnsTxt, getVerificationDnsStatus } from "./standards-sdk.es179.js";
13
- import { purchaseCreditsWithHbar, getX402Minimums, purchaseCreditsWithX402, buyCreditsWithX402 } from "./standards-sdk.es173.js";
14
- import { createLedgerChallenge, verifyLedgerChallenge, authenticateWithLedger, authenticateWithLedgerCredentials } from "./standards-sdk.es175.js";
15
- import { search, stats, registries, getAdditionalRegistries, popularSearches, listProtocols, detectProtocol, registrySearchByNamespace, vectorSearch, searchStatus, websocketStats, metricsSummary, facets } from "./standards-sdk.es170.js";
16
- import { skillsConfig, listSkills, getSkillSecurityBreakdown, getSkillsCatalog, listSkillVersions, listMySkills, getMySkillsList, quoteSkillPublish, publishSkill, getSkillPublishJob, getSkillOwnership, getRecommendedSkillVersion, setRecommendedSkillVersion, getSkillDeprecations, setSkillDeprecation, getSkillBadge, listSkillTags, listSkillCategories, resolveSkillMarkdown, resolveSkillManifest, getSkillVoteStatus, setSkillVote, requestSkillVerification, getSkillVerificationStatus, createSkillDomainProofChallenge, verifySkillDomainProof } from "./standards-sdk.es161.js";
17
- import { DEFAULT_BASE_URL, normaliseBaseUrl, normaliseHeaderName, isBrowserRuntime, DEFAULT_USER_AGENT, JSON_CONTENT_TYPE, serialiseAgentRegistrationRequest, MINIMUM_REGISTRATION_AUTO_TOP_UP_CREDITS, createAbortError, isJsonObject, DEFAULT_HISTORY_TOP_UP_HBAR } from "./standards-sdk.es171.js";
18
- import { RegistryBrokerError, RegistryBrokerParseError } from "./standards-sdk.es141.js";
19
- class RegistryBrokerClient {
20
- constructor(options = {}) {
21
- this.encryptionBootstrapPromise = null;
22
- this.chatApi = null;
23
- this.encryptedChatManager = null;
24
- this.encryptionApi = null;
25
- this.conversationContexts = /* @__PURE__ */ new Map();
26
- const {
27
- baseUrl = DEFAULT_BASE_URL,
28
- fetchImplementation,
29
- defaultHeaders,
30
- apiKey,
31
- accountId,
32
- ledgerApiKey,
33
- registrationAutoTopUp,
34
- historyAutoTopUp,
35
- encryption
36
- } = options;
37
- this.baseUrl = normaliseBaseUrl(baseUrl);
38
- const resolvedFetch = fetchImplementation ?? (typeof globalThis.fetch === "function" ? globalThis.fetch : null);
39
- if (!resolvedFetch) {
40
- throw new Error(
41
- "A fetch implementation is required for RegistryBrokerClient"
42
- );
43
- }
44
- this.fetchImpl = resolvedFetch;
45
- this.defaultHeaders = {
46
- ...defaultHeaders ?? {}
47
- };
48
- Object.entries(this.defaultHeaders).forEach(([key, value]) => {
49
- const headerName = normaliseHeaderName(key);
50
- if (headerName !== key) {
51
- delete this.defaultHeaders[key];
52
- this.defaultHeaders[headerName] = value;
53
- }
1
+ import { PublicKey, Timestamp, AccountId } from "@hashgraph/sdk";
2
+ import axios from "axios";
3
+ import { Logger } from "./standards-sdk.es123.js";
4
+ import { proto } from "@hashgraph/proto";
5
+ class HederaMirrorNode {
6
+ constructor(network, logger, config) {
7
+ this.maxRetries = 5;
8
+ this.initialDelayMs = 2e3;
9
+ this.maxDelayMs = 3e4;
10
+ this.backoffFactor = 2;
11
+ this.network = network;
12
+ this.apiKey = config?.apiKey;
13
+ this.customHeaders = config?.headers || {};
14
+ this.baseUrl = config?.customUrl || this.getMirrorNodeUrl();
15
+ this.logger = logger || new Logger({
16
+ level: "debug",
17
+ module: "MirrorNode"
54
18
  });
55
- const existingLedgerHeader = this.defaultHeaders["x-ledger-api-key"]?.trim();
56
- if (!this.defaultHeaders["x-api-key"] && existingLedgerHeader) {
57
- this.defaultHeaders["x-api-key"] = existingLedgerHeader;
58
- }
59
- if (apiKey) {
60
- this.defaultHeaders["x-api-key"] = apiKey;
19
+ this.isServerEnvironment = typeof window === "undefined";
20
+ if (config?.customUrl) {
21
+ this.logger.info(`Using custom mirror node URL: ${config.customUrl}`);
22
+ }
23
+ if (config?.apiKey) {
24
+ this.logger.info("Using API key for mirror node requests");
25
+ }
26
+ }
27
+ /**
28
+ * Configures the retry mechanism for API requests.
29
+ * @param config The retry configuration.
30
+ */
31
+ configureRetry(config) {
32
+ this.maxRetries = config.maxRetries ?? this.maxRetries;
33
+ this.initialDelayMs = config.initialDelayMs ?? this.initialDelayMs;
34
+ this.maxDelayMs = config.maxDelayMs ?? this.maxDelayMs;
35
+ this.backoffFactor = config.backoffFactor ?? this.backoffFactor;
36
+ this.logger.info(
37
+ `Retry configuration updated: maxRetries=${this.maxRetries}, initialDelayMs=${this.initialDelayMs}, maxDelayMs=${this.maxDelayMs}, backoffFactor=${this.backoffFactor}`
38
+ );
39
+ }
40
+ /**
41
+ * Updates the mirror node configuration.
42
+ * @param config The new mirror node configuration.
43
+ */
44
+ configureMirrorNode(config) {
45
+ if (config.customUrl) {
46
+ this.baseUrl = config.customUrl;
47
+ this.logger.info(`Updated mirror node URL: ${config.customUrl}`);
61
48
  }
62
- if (typeof accountId === "string" && accountId.trim().length > 0) {
63
- this.defaultHeaders["x-account-id"] = accountId.trim();
49
+ if (config.apiKey) {
50
+ this.apiKey = config.apiKey;
51
+ this.logger.info("Updated API key for mirror node requests");
64
52
  }
65
- if (ledgerApiKey) {
66
- if (!this.defaultHeaders["x-api-key"]) {
67
- this.defaultHeaders["x-api-key"] = ledgerApiKey;
53
+ if (config.headers) {
54
+ this.customHeaders = { ...this.customHeaders, ...config.headers };
55
+ this.logger.info("Updated custom headers for mirror node requests");
56
+ }
57
+ }
58
+ /**
59
+ * Constructs a full URL for API requests, handling custom providers with API keys in the path.
60
+ * @param endpoint The API endpoint (e.g., '/api/v1/accounts/0.0.123')
61
+ * @returns The full URL for the request
62
+ */
63
+ constructUrl(endpoint) {
64
+ if (this.baseUrl.includes("<API-KEY>") && this.apiKey) {
65
+ const baseUrlWithKey = this.baseUrl.replace("<API-KEY>", this.apiKey);
66
+ return endpoint.startsWith("/") ? `${baseUrlWithKey}${endpoint}` : `${baseUrlWithKey}/${endpoint}`;
67
+ }
68
+ return endpoint.startsWith("/") ? `${this.baseUrl}${endpoint}` : `${this.baseUrl}/${endpoint}`;
69
+ }
70
+ /**
71
+ * Returns the base URL for the Hedera mirror node based on the network type
72
+ * @returns The mirror node base URL
73
+ * @private
74
+ */
75
+ getMirrorNodeUrl() {
76
+ return this.network === "mainnet" ? "https://mainnet-public.mirrornode.hedera.com" : "https://testnet.mirrornode.hedera.com";
77
+ }
78
+ getBaseUrl() {
79
+ return this.baseUrl;
80
+ }
81
+ /**
82
+ * Retrieves the public key for a given account ID from the mirror node.
83
+ * @param accountId The ID of the account to retrieve the public key for.
84
+ * @returns A promise that resolves to the public key for the given account.
85
+ * @throws An error if the account ID is invalid or the public key cannot be retrieved.
86
+ */
87
+ async getPublicKey(accountId) {
88
+ this.logger.debug(`Getting public key for account ${accountId}`);
89
+ const accountInfo = await this.requestAccount(accountId);
90
+ try {
91
+ if (!accountInfo || !accountInfo.key) {
92
+ throw new Error(
93
+ `Failed to retrieve public key for account ID: ${accountId}`
94
+ );
68
95
  }
69
- }
70
- this.registrationAutoTopUp = registrationAutoTopUp;
71
- this.historyAutoTopUp = historyAutoTopUp;
72
- this.encryptionOptions = encryption;
73
- if (this.encryptionOptions) {
74
- this.encryptionBootstrapPromise = this.initializeEncryptionBootstrap(
75
- this.encryptionOptions
96
+ return PublicKey.fromString(accountInfo.key.key);
97
+ } catch (e) {
98
+ const error = e;
99
+ const logMessage = `Error fetching public key from Mirror Node: ${error.message}`;
100
+ this.logger.error(logMessage);
101
+ throw new Error(logMessage);
102
+ }
103
+ }
104
+ /**
105
+ * Retrieves the memo for a given account ID from the mirror node.
106
+ * @param accountId The ID of the account to retrieve the memo for.
107
+ * @returns A promise that resolves to the memo for the given account.
108
+ * @throws An error if the account ID is invalid or the memo cannot be retrieved.
109
+ */
110
+ async getAccountMemo(accountId) {
111
+ this.logger.debug(`Getting account memo for account ID: ${accountId}`);
112
+ try {
113
+ const accountInfo = await this._requestWithRetry(
114
+ `/api/v1/accounts/${accountId}`
76
115
  );
116
+ if (accountInfo?.memo) {
117
+ return accountInfo.memo;
118
+ }
119
+ this.logger.warn(`No memo found for account ${accountId}`);
120
+ return null;
121
+ } catch (e) {
122
+ const error = e;
123
+ this.logger.error(
124
+ `Failed to get account memo for ${accountId} after retries: ${error.message}`
125
+ );
126
+ return null;
77
127
  }
78
128
  }
79
- static async initializeAgent(options) {
80
- const { uaid, ensureEncryptionKey = true, ...clientOptions } = options;
81
- const client = new RegistryBrokerClient(clientOptions);
82
- let encryption = null;
83
- if (ensureEncryptionKey) {
84
- const ensureOptions = typeof ensureEncryptionKey === "object" ? ensureEncryptionKey : { generateIfMissing: true };
85
- encryption = await client.encryption.ensureAgentKey({
86
- uaid,
87
- ...ensureOptions
88
- });
129
+ /**
130
+ * Retrieves topic information for a given topic ID from the mirror node.
131
+ * @param topicId The ID of the topic to retrieve information for.
132
+ * @returns A promise that resolves to the topic information.
133
+ * @throws An error if the topic ID is invalid or the information cannot be retrieved.
134
+ */
135
+ async getTopicInfo(topicId) {
136
+ try {
137
+ this.logger.debug(`Fetching topic info for ${topicId}`);
138
+ const data = await this._requestWithRetry(
139
+ `/api/v1/topics/${topicId}`
140
+ );
141
+ return data;
142
+ } catch (e) {
143
+ const error = e;
144
+ const logMessage = `Error retrieving topic information for ${topicId} after retries: ${error.message}`;
145
+ this.logger.error(logMessage);
146
+ throw new Error(logMessage);
147
+ }
148
+ }
149
+ /**
150
+ * Retrieves custom fees for a given topic ID from the mirror node.
151
+ * @param topicId The ID of the topic to retrieve custom fees for.
152
+ * @returns A promise that resolves to the custom fees for the given topic.
153
+ * @throws An error if the topic ID is invalid or the custom fees cannot be retrieved.
154
+ */
155
+ async getTopicFees(topicId) {
156
+ try {
157
+ const topicInfo = await this.getTopicInfo(topicId);
158
+ return topicInfo.custom_fees;
159
+ } catch (e) {
160
+ const error = e;
161
+ const logMessage = `Error retrieving topic fees: ${error.message}`;
162
+ this.logger.error(logMessage);
163
+ return null;
89
164
  }
90
- return { client, encryption };
91
165
  }
92
- get chat() {
93
- if (this.chatApi) {
94
- return this.chatApi;
166
+ /**
167
+ * Retrieves the current HBAR price from the mirror node.
168
+ * @param date The date to retrieve the HBAR price for.
169
+ * @returns A promise that resolves to the HBAR price for the given date.
170
+ * @throws An error if the date is invalid or the price cannot be retrieved.
171
+ */
172
+ async getHBARPrice(date) {
173
+ try {
174
+ const timestamp = Timestamp.fromDate(date).toString();
175
+ this.logger.debug(`Fetching HBAR price for timestamp ${timestamp}`);
176
+ const response = await this._requestWithRetry(
177
+ `/api/v1/network/exchangerate?timestamp=${timestamp}`
178
+ );
179
+ const usdPrice = Number(response?.current_rate?.cent_equivalent) / Number(response?.current_rate?.hbar_equivalent) / 100;
180
+ return usdPrice;
181
+ } catch (e) {
182
+ const error = e;
183
+ const logMessage = `Error retrieving HBAR price: ${error.message}`;
184
+ this.logger.error(logMessage);
185
+ return null;
95
186
  }
96
- const api = createChatApi(this, this.getEncryptedChatManager());
97
- this.chatApi = api;
98
- return api;
99
187
  }
100
- get encryption() {
101
- if (this.encryptionApi) {
102
- return this.encryptionApi;
188
+ /**
189
+ * Retrieves token information for a given token ID from the mirror node.
190
+ * @param tokenId The ID of the token to retrieve information for.
191
+ * @returns A promise that resolves to the token information.
192
+ * @throws An error if the token ID is invalid or the information cannot be retrieved.
193
+ */
194
+ async getTokenInfo(tokenId) {
195
+ this.logger.debug(`Fetching token info for ${tokenId}`);
196
+ try {
197
+ const data = await this._requestWithRetry(
198
+ `/api/v1/tokens/${tokenId}`
199
+ );
200
+ if (data) {
201
+ this.logger.trace(`Token info found for ${tokenId}:`, data);
202
+ return data;
203
+ }
204
+ this.logger.warn(`No token info found for ${tokenId}`);
205
+ return null;
206
+ } catch (e) {
207
+ const error = e;
208
+ const logMessage = `Error fetching token info for ${tokenId}: ${error.message}`;
209
+ this.logger.error(logMessage);
210
+ return null;
103
211
  }
104
- const api = createEncryptionApi(this);
105
- this.encryptionApi = api;
106
- return api;
107
212
  }
108
- setApiKey(apiKey) {
109
- this.setDefaultHeader("x-api-key", apiKey);
110
- }
111
- setLedgerApiKey(apiKey) {
112
- this.setDefaultHeader("x-api-key", apiKey);
113
- delete this.defaultHeaders["x-ledger-api-key"];
114
- }
115
- setDefaultHeader(name, value) {
116
- if (!name || name.trim().length === 0) {
117
- return;
213
+ /**
214
+ * Retrieves messages for a given topic ID from the mirror node. Supports filtering by sequence number
215
+ * based on the OpenAPI specification.
216
+ * @param topicId The ID of the topic to retrieve messages for.
217
+ * @param options Optional filtering parameters.
218
+ * @returns A promise that resolves to the messages for the given topic.
219
+ */
220
+ async getTopicMessages(topicId, options) {
221
+ this.logger.trace(
222
+ `Querying messages for topic ${topicId}${options ? " with filters" : ""}`
223
+ );
224
+ let endpoint = `/api/v1/topics/${topicId}/messages`;
225
+ const params = new URLSearchParams();
226
+ if (options) {
227
+ if (options.sequenceNumber !== void 0) {
228
+ const seqNum = typeof options.sequenceNumber === "number" ? options.sequenceNumber.toString() : options.sequenceNumber;
229
+ if (!seqNum.match(/^(gt|gte|lt|lte|eq|ne):/)) {
230
+ params.append("sequencenumber", `gt:${seqNum}`);
231
+ } else {
232
+ params.append("sequencenumber", seqNum);
233
+ }
234
+ }
235
+ if (options.limit) {
236
+ params.append("limit", options.limit.toString());
237
+ }
238
+ if (options.order) {
239
+ params.append("order", options.order);
240
+ }
118
241
  }
119
- const headerName = normaliseHeaderName(name);
120
- if (!value || value.trim().length === 0) {
121
- delete this.defaultHeaders[headerName];
122
- return;
242
+ const queryString = params.toString();
243
+ if (queryString) {
244
+ endpoint += `?${queryString}`;
123
245
  }
124
- this.defaultHeaders[headerName] = value.trim();
125
- }
126
- getDefaultHeaders() {
127
- return { ...this.defaultHeaders };
128
- }
129
- async encryptionReady() {
130
- if (!this.encryptionBootstrapPromise) {
131
- return;
246
+ const messages = [];
247
+ let nextEndpoint = endpoint;
248
+ while (nextEndpoint) {
249
+ try {
250
+ const data = await this._requestWithRetry(nextEndpoint);
251
+ if (data.messages && data.messages.length > 0) {
252
+ for (const message of data.messages) {
253
+ try {
254
+ if (!message.message) {
255
+ continue;
256
+ }
257
+ let messageContent;
258
+ try {
259
+ if (this.isServerEnvironment) {
260
+ messageContent = Buffer.from(
261
+ message.message,
262
+ "base64"
263
+ ).toString("utf-8");
264
+ } else {
265
+ messageContent = new TextDecoder().decode(
266
+ Uint8Array.from(
267
+ atob(message.message),
268
+ (c) => c.charCodeAt(0)
269
+ )
270
+ );
271
+ }
272
+ } catch (error) {
273
+ const logMessage = `Error decoding message: ${error}`;
274
+ this.logger.error(logMessage);
275
+ continue;
276
+ }
277
+ let messageJson;
278
+ try {
279
+ messageJson = JSON.parse(messageContent);
280
+ } catch (error) {
281
+ const logMessage = `Invalid JSON message content: ${messageContent}`;
282
+ this.logger.error(logMessage);
283
+ continue;
284
+ }
285
+ messageJson.sequence_number = message.sequence_number;
286
+ messages.push({
287
+ ...messageJson,
288
+ consensus_timestamp: message.consensus_timestamp,
289
+ sequence_number: message.sequence_number,
290
+ running_hash: message.running_hash,
291
+ running_hash_version: message.running_hash_version,
292
+ topic_id: message.topic_id,
293
+ payer: message.payer_account_id,
294
+ created: new Date(Number(message.consensus_timestamp) * 1e3)
295
+ });
296
+ } catch (error) {
297
+ const logMessage = `Error processing message: ${error.message}`;
298
+ this.logger.error(logMessage);
299
+ }
300
+ }
301
+ }
302
+ nextEndpoint = data.links?.next || "";
303
+ } catch (e) {
304
+ const error = e;
305
+ const logMessage = `Error querying topic messages for topic ${topicId} (endpoint: ${nextEndpoint}) after retries: ${error.message}`;
306
+ this.logger.error(logMessage);
307
+ throw new Error(logMessage);
308
+ }
132
309
  }
133
- await this.encryptionBootstrapPromise;
134
- }
135
- buildUrl(path) {
136
- const normalisedPath = path.startsWith("/") ? path : `/${path}`;
137
- return `${this.baseUrl}${normalisedPath}`;
310
+ return messages;
138
311
  }
139
- async request(path, config) {
140
- const headers = new Headers();
141
- Object.entries(this.defaultHeaders).forEach(([key, value]) => {
142
- headers.set(key, value);
143
- });
144
- if (config.headers) {
145
- Object.entries(config.headers).forEach(([key, value]) => {
146
- headers.set(key, value);
147
- });
148
- }
149
- if (!headers.has("accept")) {
150
- headers.set("accept", "application/json");
151
- }
152
- if (!headers.has("user-agent") && !isBrowserRuntime()) {
153
- headers.set("user-agent", DEFAULT_USER_AGENT);
154
- }
155
- const init = {
156
- method: config.method ?? "GET",
157
- headers
158
- };
159
- if (config.body !== void 0) {
160
- init.body = JSON.stringify(config.body);
161
- if (!headers.has("content-type")) {
162
- headers.set("content-type", "application/json");
312
+ /**
313
+ * Requests account information for a given account ID from the mirror node.
314
+ * @param accountId The ID of the account to retrieve information for.
315
+ * @returns A promise that resolves to the account information.
316
+ * @throws An error if the account ID is invalid or the information cannot be retrieved.
317
+ */
318
+ async requestAccount(accountId) {
319
+ try {
320
+ this.logger.debug(`Requesting account info for ${accountId}`);
321
+ const data = await this._requestWithRetry(
322
+ `/api/v1/accounts/${accountId}`
323
+ );
324
+ if (!data) {
325
+ throw new Error(
326
+ `No data received from mirror node for account: ${accountId}`
327
+ );
328
+ }
329
+ return data;
330
+ } catch (e) {
331
+ const error = e;
332
+ const logMessage = `Failed to fetch account ${accountId} after retries: ${error.message}`;
333
+ this.logger.error(logMessage);
334
+ throw new Error(logMessage);
335
+ }
336
+ }
337
+ /**
338
+ * Checks if a user has access to a given key list.
339
+ * @param keyBytes The key list to check access for.
340
+ * @param userPublicKey The public key of the user to check access for.
341
+ * @returns A promise that resolves to true if the user has access, false otherwise.
342
+ */
343
+ async checkKeyListAccess(keyBytes, userPublicKey) {
344
+ try {
345
+ const key = proto.Key.decode(keyBytes);
346
+ return this.evaluateKeyAccess(key, userPublicKey);
347
+ } catch (e) {
348
+ const error = e;
349
+ const logMessage = `Error decoding protobuf key: ${error.message}`;
350
+ this.logger.error(logMessage);
351
+ throw new Error(logMessage);
352
+ }
353
+ }
354
+ /**
355
+ * Evaluates the access of a given key to a user's public key.
356
+ * @param key The key to evaluate access for.
357
+ * @param userPublicKey The public key of the user to evaluate access for.
358
+ * @returns A promise that resolves to true if the key has access, false otherwise.
359
+ */
360
+ async evaluateKeyAccess(key, userPublicKey) {
361
+ if (key.ed25519) {
362
+ return this.compareEd25519Key(key.ed25519, userPublicKey);
363
+ }
364
+ if (key.keyList) {
365
+ return this.evaluateKeyList(key.keyList, userPublicKey);
366
+ }
367
+ if (key.thresholdKey && key.thresholdKey.keys) {
368
+ return this.evaluateKeyList(key.thresholdKey.keys, userPublicKey);
369
+ }
370
+ return false;
371
+ }
372
+ /**
373
+ * Evaluates the access of a given key list to a user's public key.
374
+ * @param keyList The key list to evaluate access for.
375
+ * @param userPublicKey The public key of the user to evaluate access for.
376
+ * @returns A promise that resolves to true if the key list has access, false otherwise.
377
+ */
378
+ async evaluateKeyList(keyList, userPublicKey) {
379
+ const keys = keyList.keys || [];
380
+ for (const listKey of keys) {
381
+ if (!listKey) continue;
382
+ if (listKey.ed25519) {
383
+ if (this.compareEd25519Key(listKey.ed25519, userPublicKey)) {
384
+ return true;
385
+ }
386
+ } else if (listKey.keyList || listKey.thresholdKey) {
387
+ try {
388
+ const nestedKeyBytes = proto.Key.encode({
389
+ ...listKey.keyList ? { keyList: listKey.keyList } : {},
390
+ ...listKey.thresholdKey ? { thresholdKey: listKey.thresholdKey } : {}
391
+ }).finish();
392
+ const hasNestedAccess = await this.checkKeyListAccess(
393
+ Buffer.from(nestedKeyBytes),
394
+ userPublicKey
395
+ );
396
+ if (hasNestedAccess) {
397
+ return true;
398
+ }
399
+ } catch (e) {
400
+ const error = e;
401
+ const logMessage = `Error in nested key: ${error.message}`;
402
+ this.logger.debug(logMessage);
403
+ }
163
404
  }
164
405
  }
165
- const response = await this.fetchImpl(this.buildUrl(path), init);
166
- if (response.ok) {
167
- return response;
406
+ return false;
407
+ }
408
+ /**
409
+ * Compares an Ed25519 key with a user's public key.
410
+ * @param keyData The Ed25519 key data to compare.
411
+ * @param userPublicKey The public key of the user to compare with.
412
+ * @returns A boolean indicating whether the key matches the user's public key.
413
+ */
414
+ compareEd25519Key(keyData, userPublicKey) {
415
+ try {
416
+ const decodedKey = PublicKey.fromBytes(Buffer.from(keyData));
417
+ return decodedKey.toString() === userPublicKey.toString();
418
+ } catch (e) {
419
+ const error = e;
420
+ const logMessage = `Error comparing Ed25519 key: ${error.message}`;
421
+ this.logger.debug(logMessage);
422
+ return false;
168
423
  }
169
- const errorBody = await this.extractErrorBody(response);
170
- throw new RegistryBrokerError("Registry broker request failed", {
171
- status: response.status,
172
- statusText: response.statusText,
173
- body: errorBody
174
- });
175
424
  }
176
- async requestJson(path, config) {
177
- const response = await this.request(path, config);
178
- const contentType = response.headers?.get("content-type") ?? "";
179
- if (!JSON_CONTENT_TYPE.test(contentType)) {
180
- const body = await response.text();
181
- throw new RegistryBrokerParseError(
182
- "Expected JSON response from registry broker",
183
- body
425
+ /**
426
+ * Retrieves information about a scheduled transaction
427
+ * @param scheduleId The ID of the scheduled transaction
428
+ * @returns A promise that resolves to the scheduled transaction information
429
+ */
430
+ async getScheduleInfo(scheduleId) {
431
+ try {
432
+ this.logger.info(
433
+ `Getting information for scheduled transaction ${scheduleId}`
434
+ );
435
+ const data = await this._requestWithRetry(
436
+ `/api/v1/schedules/${scheduleId}`
437
+ );
438
+ if (data) {
439
+ return data;
440
+ }
441
+ this.logger.warn(
442
+ `No schedule info found for ${scheduleId} after retries.`
443
+ );
444
+ return null;
445
+ } catch (error) {
446
+ this.logger.error(
447
+ `Error fetching schedule info for ${scheduleId} after retries: ${error.message}`
184
448
  );
449
+ return null;
185
450
  }
186
- return await response.json();
187
451
  }
188
- async getAgentFeedback(uaid, options = {}) {
189
- const normalized = uaid.trim();
190
- if (!normalized) {
191
- throw new Error("uaid is required");
192
- }
193
- const query = options.includeRevoked === true ? "?includeRevoked=true" : "";
194
- const raw = await this.requestJson(
195
- `/agents/${encodeURIComponent(normalized)}/feedback${query}`,
196
- { method: "GET" }
197
- );
198
- return this.parseWithSchema(
199
- raw,
200
- agentFeedbackResponseSchema,
201
- "agent feedback response"
452
+ /**
453
+ * Checks the status of a scheduled transaction
454
+ * @param scheduleId The schedule ID to check
455
+ * @returns Status of the scheduled transaction
456
+ */
457
+ async getScheduledTransactionStatus(scheduleId) {
458
+ try {
459
+ this.logger.info(
460
+ `Checking status of scheduled transaction ${scheduleId}`
461
+ );
462
+ const scheduleInfo = await this.getScheduleInfo(scheduleId);
463
+ if (!scheduleInfo) {
464
+ throw new Error(`Schedule ${scheduleId} not found`);
465
+ }
466
+ return {
467
+ executed: Boolean(scheduleInfo.executed_timestamp),
468
+ executedDate: scheduleInfo.executed_timestamp ? new Date(Number(scheduleInfo.executed_timestamp) * 1e3) : void 0,
469
+ deleted: scheduleInfo.deleted || false
470
+ };
471
+ } catch (error) {
472
+ this.logger.error(
473
+ `Error checking scheduled transaction status: ${error}`
474
+ );
475
+ throw error;
476
+ }
477
+ }
478
+ /**
479
+ * Retrieves details for a given transaction ID or hash from the mirror node.
480
+ * @param transactionIdOrHash The ID or hash of the transaction.
481
+ * @returns A promise that resolves to the transaction details.
482
+ * @throws An error if the transaction ID/hash is invalid or details cannot be retrieved.
483
+ */
484
+ async getTransaction(transactionIdOrHash) {
485
+ this.logger.info(
486
+ `Getting transaction details for ID/hash: ${transactionIdOrHash}`
202
487
  );
203
- }
204
- async listAgentFeedbackIndex(options = {}) {
205
- const params = new URLSearchParams();
206
- if (typeof options.page === "number" && Number.isFinite(options.page)) {
207
- params.set("page", String(Math.trunc(options.page)));
208
- }
209
- if (typeof options.limit === "number" && Number.isFinite(options.limit)) {
210
- params.set("limit", String(Math.trunc(options.limit)));
211
- }
212
- if (options.registries?.length) {
213
- params.set("registry", options.registries.join(","));
488
+ try {
489
+ const response = await this._requestWithRetry(`/api/v1/transactions/${transactionIdOrHash}`);
490
+ if (response?.transactions?.length > 0) {
491
+ this.logger.trace(
492
+ `Transaction details found for ${transactionIdOrHash}:`,
493
+ response.transactions[0]
494
+ );
495
+ return response.transactions[0];
496
+ }
497
+ this.logger.warn(
498
+ `No transaction details found for ${transactionIdOrHash} or unexpected response structure.`
499
+ );
500
+ return null;
501
+ } catch (e) {
502
+ const error = e;
503
+ this.logger.error(
504
+ `Failed to get transaction details for ${transactionIdOrHash} after retries: ${error.message}`
505
+ );
506
+ return null;
214
507
  }
215
- const suffix = params.size > 0 ? `?${params.toString()}` : "";
216
- const raw = await this.requestJson(`/agents/feedback${suffix}`, {
217
- method: "GET"
218
- });
219
- return this.parseWithSchema(
220
- raw,
221
- agentFeedbackIndexResponseSchema,
222
- "agent feedback index response"
223
- );
224
508
  }
225
- async listAgentFeedbackEntriesIndex(options = {}) {
226
- const params = new URLSearchParams();
227
- if (typeof options.page === "number" && Number.isFinite(options.page)) {
228
- params.set("page", String(Math.trunc(options.page)));
229
- }
230
- if (typeof options.limit === "number" && Number.isFinite(options.limit)) {
231
- params.set("limit", String(Math.trunc(options.limit)));
509
+ /**
510
+ * Private helper to make GET requests with retry logic using Axios.
511
+ */
512
+ async _requestWithRetry(endpoint, axiosConfig) {
513
+ let attempt = 0;
514
+ let delay = this.initialDelayMs;
515
+ const url = this.constructUrl(endpoint);
516
+ const config = {
517
+ ...axiosConfig,
518
+ headers: {
519
+ ...this.customHeaders,
520
+ ...axiosConfig?.headers
521
+ }
522
+ };
523
+ if (this.apiKey) {
524
+ config.headers = {
525
+ ...config.headers,
526
+ Authorization: `Bearer ${this.apiKey}`,
527
+ "X-API-Key": this.apiKey
528
+ };
232
529
  }
233
- if (options.registries?.length) {
234
- params.set("registry", options.registries.join(","));
530
+ while (attempt < this.maxRetries) {
531
+ try {
532
+ const response = await axios.get(url, config);
533
+ return response.data;
534
+ } catch (error) {
535
+ attempt++;
536
+ const isLastAttempt = attempt >= this.maxRetries;
537
+ const statusCode = error.response?.status;
538
+ if (statusCode && statusCode > 404 && statusCode < 500 && statusCode !== 429) {
539
+ this.logger.error(
540
+ `Client error for ${url} (status ${statusCode}): ${error.message}. Not retrying.`
541
+ );
542
+ throw error;
543
+ }
544
+ if (isLastAttempt) {
545
+ this.logger.error(
546
+ `Max retries (${this.maxRetries}) reached for ${url}. Last error: ${error.message}`
547
+ );
548
+ throw error;
549
+ }
550
+ this.logger.warn(
551
+ `Attempt ${attempt}/${this.maxRetries} failed for ${url}: ${error.message}. Retrying in ${delay}ms...`
552
+ );
553
+ await new Promise((resolve) => setTimeout(resolve, delay));
554
+ delay = Math.min(delay * this.backoffFactor, this.maxDelayMs);
555
+ }
235
556
  }
236
- const suffix = params.size > 0 ? `?${params.toString()}` : "";
237
- const raw = await this.requestJson(
238
- `/agents/feedback/entries${suffix}`,
239
- { method: "GET" }
240
- );
241
- return this.parseWithSchema(
242
- raw,
243
- agentFeedbackEntriesIndexResponseSchema,
244
- "agent feedback entries index response"
557
+ throw new Error(
558
+ `Failed to fetch data from ${url} after ${this.maxRetries} attempts.`
245
559
  );
246
560
  }
247
- async checkAgentFeedbackEligibility(uaid, payload) {
248
- const normalized = uaid.trim();
249
- if (!normalized) {
250
- throw new Error("uaid is required");
251
- }
252
- const raw = await this.requestJson(
253
- `/agents/${encodeURIComponent(normalized)}/feedback/eligibility`,
254
- {
255
- method: "POST",
256
- body: payload,
257
- headers: { "content-type": "application/json" }
561
+ /**
562
+ * Private helper to make fetch requests with retry logic.
563
+ */
564
+ async _fetchWithRetry(url, fetchOptions) {
565
+ let attempt = 0;
566
+ let delay = this.initialDelayMs;
567
+ const headers = {
568
+ ...this.customHeaders
569
+ };
570
+ if (fetchOptions?.headers) {
571
+ if (fetchOptions.headers instanceof Headers) {
572
+ fetchOptions.headers.forEach((value, key) => {
573
+ headers[key] = value;
574
+ });
575
+ } else if (Array.isArray(fetchOptions.headers)) {
576
+ fetchOptions.headers.forEach(([key, value]) => {
577
+ headers[key] = value;
578
+ });
579
+ } else {
580
+ Object.assign(headers, fetchOptions.headers);
258
581
  }
259
- );
260
- return this.parseWithSchema(
261
- raw,
262
- agentFeedbackEligibilityResponseSchema,
263
- "agent feedback eligibility response"
264
- );
265
- }
266
- async submitAgentFeedback(uaid, payload) {
267
- const normalized = uaid.trim();
268
- if (!normalized) {
269
- throw new Error("uaid is required");
270
- }
271
- const raw = await this.requestJson(
272
- `/agents/${encodeURIComponent(normalized)}/feedback`,
273
- {
274
- method: "POST",
275
- body: payload,
276
- headers: { "content-type": "application/json" }
582
+ }
583
+ if (this.apiKey) {
584
+ headers["Authorization"] = `Bearer ${this.apiKey}`;
585
+ headers["X-API-Key"] = this.apiKey;
586
+ }
587
+ const options = {
588
+ ...fetchOptions,
589
+ headers
590
+ };
591
+ while (attempt < this.maxRetries) {
592
+ try {
593
+ const request = await fetch(url, options);
594
+ if (!request.ok) {
595
+ if (request.status >= 400 && request.status < 500 && request.status !== 429) {
596
+ this.logger.error(
597
+ `Client error for ${url} (status ${request.status}): ${request.statusText}. Not retrying.`
598
+ );
599
+ throw new Error(
600
+ `Fetch failed with status ${request.status}: ${request.statusText} for URL: ${url}`
601
+ );
602
+ }
603
+ throw new Error(
604
+ `Fetch failed with status ${request.status}: ${request.statusText} for URL: ${url}`
605
+ );
606
+ }
607
+ const response = await request.json();
608
+ return response;
609
+ } catch (error) {
610
+ attempt++;
611
+ if (attempt >= this.maxRetries) {
612
+ this.logger.error(
613
+ `Max retries (${this.maxRetries}) reached for ${url}. Last error: ${error.message}`
614
+ );
615
+ throw error;
616
+ }
617
+ this.logger.warn(
618
+ `Attempt ${attempt}/${this.maxRetries} failed for ${url}: ${error.message}. Retrying in ${delay}ms...`
619
+ );
620
+ await new Promise((resolve) => setTimeout(resolve, delay));
621
+ delay = Math.min(delay * this.backoffFactor, this.maxDelayMs);
277
622
  }
278
- );
279
- return this.parseWithSchema(
280
- raw,
281
- agentFeedbackSubmissionResponseSchema,
282
- "agent feedback submission response"
623
+ }
624
+ throw new Error(
625
+ `Failed to fetch data from ${url} after ${this.maxRetries} attempts.`
283
626
  );
284
627
  }
285
- async search(params = {}) {
286
- return search(this, params);
287
- }
288
- async searchErc8004ByAgentId(params) {
289
- const chainId = Math.floor(params.chainId);
290
- if (!Number.isFinite(chainId) || chainId <= 0) {
291
- throw new Error("chainId must be a positive integer");
292
- }
293
- const rawAgentId = typeof params.agentId === "bigint" ? params.agentId.toString() : String(params.agentId);
294
- const agentId = rawAgentId.trim();
295
- if (!agentId) {
296
- throw new Error("agentId is required");
297
- }
298
- const nativeId = `${chainId}:${agentId}`;
299
- return search(this, {
300
- registries: ["erc-8004"],
301
- limit: params.limit ?? 1,
302
- ...typeof params.page === "number" ? { page: params.page } : {},
303
- ...typeof params.sortBy === "string" ? { sortBy: params.sortBy } : {},
304
- ...typeof params.sortOrder === "string" ? { sortOrder: params.sortOrder } : {},
305
- metadata: {
306
- nativeId: [nativeId],
307
- networkKey: [`eip155:${chainId}`]
628
+ /**
629
+ * Retrieves the numerical balance (in HBAR) for a given account ID.
630
+ * @param accountId The ID of the account.
631
+ * @returns A promise that resolves to the HBAR balance or null if an error occurs.
632
+ */
633
+ async getAccountBalance(accountId) {
634
+ this.logger.info(`Getting balance for account ${accountId}`);
635
+ try {
636
+ const accountInfo = await this.requestAccount(accountId);
637
+ if (accountInfo && accountInfo.balance) {
638
+ const hbarBalance = accountInfo.balance.balance / 1e8;
639
+ return hbarBalance;
308
640
  }
309
- });
310
- }
311
- async stats() {
312
- return stats(this);
313
- }
314
- async registries() {
315
- return registries(this);
316
- }
317
- async getAdditionalRegistries() {
318
- return getAdditionalRegistries(this);
319
- }
320
- async popularSearches() {
321
- return popularSearches(this);
322
- }
323
- async listProtocols() {
324
- return listProtocols(this);
325
- }
326
- async detectProtocol(message) {
327
- return detectProtocol(this, message);
328
- }
329
- async registrySearchByNamespace(registry, query) {
330
- return registrySearchByNamespace(this, registry, query);
331
- }
332
- async vectorSearch(request) {
333
- return vectorSearch(this, request);
334
- }
335
- async searchStatus() {
336
- return searchStatus(this);
337
- }
338
- async websocketStats() {
339
- return websocketStats(this);
340
- }
341
- async metricsSummary() {
342
- return metricsSummary(this);
343
- }
344
- async facets(adapter) {
345
- return facets(this, adapter);
346
- }
347
- async adapters() {
348
- return adapters(this);
349
- }
350
- async skillsConfig() {
351
- return skillsConfig(this);
352
- }
353
- async listSkills(options) {
354
- return listSkills(this, options);
355
- }
356
- async getSkillSecurityBreakdown(params) {
357
- return getSkillSecurityBreakdown(this, params);
358
- }
359
- async getSkillsCatalog(options) {
360
- return getSkillsCatalog(this, options);
361
- }
362
- async listSkillVersions(params) {
363
- return listSkillVersions(this, params);
364
- }
365
- async listMySkills(params) {
366
- return listMySkills(this, params);
367
- }
368
- async getMySkillsList(params) {
369
- return getMySkillsList(this, params);
370
- }
371
- async quoteSkillPublish(payload) {
372
- return quoteSkillPublish(this, payload);
373
- }
374
- async publishSkill(payload) {
375
- return publishSkill(this, payload);
376
- }
377
- async getSkillPublishJob(jobId, params) {
378
- return getSkillPublishJob(this, jobId, params);
379
- }
380
- async getSkillOwnership(params) {
381
- return getSkillOwnership(this, params);
382
- }
383
- async getRecommendedSkillVersion(params) {
384
- return getRecommendedSkillVersion(this, params);
385
- }
386
- async setRecommendedSkillVersion(payload) {
387
- return setRecommendedSkillVersion(this, payload);
388
- }
389
- async getSkillDeprecations(params) {
390
- return getSkillDeprecations(this, params);
391
- }
392
- async setSkillDeprecation(payload) {
393
- return setSkillDeprecation(this, payload);
394
- }
395
- async getSkillBadge(params) {
396
- return getSkillBadge(this, params);
397
- }
398
- async listSkillTags() {
399
- return listSkillTags(this);
400
- }
401
- async listSkillCategories() {
402
- return listSkillCategories(this);
403
- }
404
- async resolveSkillMarkdown(skillRef) {
405
- return resolveSkillMarkdown(this, skillRef);
406
- }
407
- async resolveSkillManifest(skillRef) {
408
- return resolveSkillManifest(this, skillRef);
409
- }
410
- async getSkillVoteStatus(params) {
411
- return getSkillVoteStatus(this, params);
412
- }
413
- async setSkillVote(payload) {
414
- return setSkillVote(this, payload);
415
- }
416
- async requestSkillVerification(payload) {
417
- return requestSkillVerification(this, payload);
418
- }
419
- async getSkillVerificationStatus(params) {
420
- return getSkillVerificationStatus(this, params);
421
- }
422
- async createSkillDomainProofChallenge(payload) {
423
- return createSkillDomainProofChallenge(this, payload);
424
- }
425
- async verifySkillDomainProof(payload) {
426
- return verifySkillDomainProof(this, payload);
427
- }
428
- async adaptersDetailed() {
429
- return adaptersDetailed(this);
430
- }
431
- async adapterRegistryCategories() {
432
- return adapterRegistryCategories(this);
433
- }
434
- async adapterRegistryAdapters(filters) {
435
- return adapterRegistryAdapters(this, filters);
436
- }
437
- async createAdapterRegistryCategory(payload) {
438
- return createAdapterRegistryCategory(this, payload);
439
- }
440
- async submitAdapterRegistryAdapter(payload) {
441
- return submitAdapterRegistryAdapter(this, payload);
442
- }
443
- async adapterRegistrySubmissionStatus(submissionId) {
444
- return adapterRegistrySubmissionStatus(this, submissionId);
445
- }
446
- async resolveUaid(uaid) {
447
- return resolveUaid(this, uaid);
641
+ this.logger.warn(
642
+ `Could not retrieve balance for account ${accountId} from account info.`
643
+ );
644
+ return null;
645
+ } catch (error) {
646
+ this.logger.error(
647
+ `Error fetching numerical balance for account ${accountId}: ${error.message}`
648
+ );
649
+ return null;
650
+ }
448
651
  }
449
- async performRegisterAgent(payload) {
450
- const raw = await this.requestJson("/register", {
451
- method: "POST",
452
- body: serialiseAgentRegistrationRequest(payload),
453
- headers: { "content-type": "application/json" }
454
- });
455
- return this.parseWithSchema(
456
- raw,
457
- registerAgentResponseSchema,
458
- "register agent response"
652
+ /**
653
+ * Retrieves messages for a given topic ID with optional filters.
654
+ * @param topicId The ID of the topic.
655
+ * @param sequenceNumber Filter by sequence number (e.g., "gt:10", "lte:20").
656
+ * @param startTime Filter by consensus timestamp (e.g., "gt:1629400000.000000000").
657
+ * @param endTime Filter by consensus timestamp (e.g., "lt:1629500000.000000000").
658
+ * @param limit The maximum number of messages to return.
659
+ * @returns A promise that resolves to an array of HCSMessages or null.
660
+ */
661
+ async getTopicMessagesByFilter(topicId, options) {
662
+ this.logger.trace(
663
+ `Querying messages for topic ${topicId} with filters: ${JSON.stringify(
664
+ options
665
+ )}`
459
666
  );
460
- }
461
- calculateHbarAmount(creditsToPurchase, creditsPerHbar) {
462
- if (creditsPerHbar <= 0) {
463
- throw new Error("creditsPerHbar must be positive");
667
+ let nextUrl = `/api/v1/topics/${topicId}/messages`;
668
+ const params = new URLSearchParams();
669
+ if (options?.limit) {
670
+ params.append("limit", options.limit.toString());
464
671
  }
465
- if (creditsToPurchase <= 0) {
466
- throw new Error("creditsToPurchase must be positive");
672
+ if (options?.sequenceNumber) {
673
+ params.append("sequencenumber", options.sequenceNumber);
467
674
  }
468
- const rawHbar = creditsToPurchase / creditsPerHbar;
469
- const tinybars = Math.ceil(rawHbar * 1e8);
470
- return tinybars / 1e8;
471
- }
472
- resolveCreditsToPurchase(shortfallCredits) {
473
- if (!Number.isFinite(shortfallCredits) || shortfallCredits <= 0) {
474
- return 0;
675
+ if (options?.startTime) {
676
+ params.append("timestamp", `gte:${options.startTime}`);
475
677
  }
476
- return Math.max(
477
- Math.ceil(shortfallCredits),
478
- MINIMUM_REGISTRATION_AUTO_TOP_UP_CREDITS
479
- );
480
- }
481
- async ensureCreditsForRegistration(payload, autoTopUp) {
482
- const details = autoTopUp ?? null;
483
- if (!details) {
484
- return;
678
+ if (options?.endTime) {
679
+ params.append("timestamp", `lt:${options.endTime}`);
485
680
  }
486
- if (!details.accountId || !details.accountId.trim()) {
487
- throw new Error("autoTopUp.accountId is required");
681
+ if (options?.order) {
682
+ params.append("order", options.order);
488
683
  }
489
- if (!details.privateKey || !details.privateKey.trim()) {
490
- throw new Error("autoTopUp.privateKey is required");
684
+ const queryString = params.toString();
685
+ if (queryString) {
686
+ nextUrl += `?${queryString}`;
491
687
  }
492
- for (let attempt = 0; attempt < 3; attempt += 1) {
493
- const quote = await this.getRegistrationQuote(payload);
494
- const shortfall = quote.shortfallCredits ?? 0;
495
- if (shortfall <= 0) {
496
- return;
497
- }
498
- const creditsToPurchase = this.resolveCreditsToPurchase(shortfall);
499
- if (creditsToPurchase <= 0) {
500
- return;
501
- }
502
- const creditsPerHbar = quote.creditsPerHbar ?? null;
503
- if (!creditsPerHbar || creditsPerHbar <= 0) {
504
- throw new Error("Unable to determine credits per HBAR for auto top-up");
505
- }
506
- const hbarAmount = this.calculateHbarAmount(
507
- creditsToPurchase,
508
- creditsPerHbar
509
- );
510
- await this.purchaseCreditsWithHbar({
511
- accountId: details.accountId.trim(),
512
- privateKey: details.privateKey.trim(),
513
- hbarAmount,
514
- memo: details.memo ?? "Registry Broker auto top-up",
515
- metadata: {
516
- shortfallCredits: shortfall,
517
- requiredCredits: quote.requiredCredits,
518
- purchasedCredits: creditsToPurchase
688
+ const messages = [];
689
+ let pagesFetched = 0;
690
+ const maxPages = 10;
691
+ try {
692
+ while (nextUrl && pagesFetched < maxPages) {
693
+ pagesFetched++;
694
+ const data = await this._requestWithRetry(nextUrl);
695
+ if (data.messages && data.messages.length > 0) {
696
+ for (const message of data.messages) {
697
+ try {
698
+ if (!message.message) {
699
+ continue;
700
+ }
701
+ let messageContent;
702
+ if (this.isServerEnvironment) {
703
+ messageContent = Buffer.from(
704
+ message.message,
705
+ "base64"
706
+ ).toString("utf-8");
707
+ } else {
708
+ messageContent = new TextDecoder().decode(
709
+ Uint8Array.from(atob(message.message), (c) => c.charCodeAt(0))
710
+ );
711
+ }
712
+ let messageJson = {};
713
+ try {
714
+ messageJson = JSON.parse(messageContent);
715
+ } catch (parseError) {
716
+ this.logger.debug(
717
+ `Message content is not valid JSON, using raw: ${messageContent}`
718
+ );
719
+ messageJson = { raw_content: messageContent };
720
+ }
721
+ const parsedContent = messageJson;
722
+ const hcsMsg = {
723
+ ...parsedContent,
724
+ consensus_timestamp: message.consensus_timestamp,
725
+ sequence_number: message.sequence_number,
726
+ payer_account_id: message.payer_account_id,
727
+ topic_id: message.topic_id,
728
+ running_hash: message.running_hash,
729
+ running_hash_version: message.running_hash_version,
730
+ chunk_info: message.chunk_info,
731
+ created: new Date(
732
+ Number(message.consensus_timestamp.split(".")[0]) * 1e3 + Number(message.consensus_timestamp.split(".")[1] || 0) / 1e6
733
+ ),
734
+ payer: message.payer_account_id
735
+ };
736
+ messages.push(hcsMsg);
737
+ } catch (error) {
738
+ this.logger.error(
739
+ `Error processing individual message: ${error.message}`
740
+ );
741
+ }
742
+ }
519
743
  }
520
- });
744
+ if (options?.limit && messages.length >= options.limit) break;
745
+ nextUrl = data.links?.next ? `${data.links.next}` : "";
746
+ }
747
+ return messages;
748
+ } catch (e) {
749
+ const error = e;
750
+ this.logger.error(
751
+ `Error querying filtered topic messages for ${topicId}: ${error.message}`
752
+ );
753
+ return null;
521
754
  }
522
- const finalQuote = await this.getRegistrationQuote(payload);
523
- if ((finalQuote.shortfallCredits ?? 0) > 0) {
524
- throw new Error("Unable to purchase sufficient credits for registration");
755
+ }
756
+ /**
757
+ * Retrieves token balances for a given account ID.
758
+ * @param accountId The ID of the account.
759
+ * @param limit The maximum number of tokens to return.
760
+ * @returns A promise that resolves to an array of AccountTokenBalance or null.
761
+ */
762
+ async getAccountTokens(accountId, limit = 100) {
763
+ this.logger.info(`Getting tokens for account ${accountId}`);
764
+ let allTokens = [];
765
+ let endpoint = `/api/v1/accounts/${accountId}/tokens?limit=${limit}`;
766
+ try {
767
+ for (let i = 0; i < 10 && endpoint; i++) {
768
+ const response = await this._requestWithRetry(endpoint);
769
+ if (response && response.tokens) {
770
+ allTokens = allTokens.concat(response.tokens);
771
+ }
772
+ endpoint = response.links?.next || "";
773
+ if (!endpoint || limit && allTokens.length >= limit) {
774
+ if (limit && allTokens.length > limit) {
775
+ allTokens = allTokens.slice(0, limit);
776
+ }
777
+ break;
778
+ }
779
+ }
780
+ return allTokens;
781
+ } catch (error) {
782
+ this.logger.error(
783
+ `Error fetching tokens for account ${accountId}: ${error.message}`
784
+ );
785
+ return null;
525
786
  }
526
787
  }
527
- async registerAgent(payload, options) {
528
- const autoTopUp = options?.autoTopUp ?? this.registrationAutoTopUp;
529
- if (!autoTopUp) {
530
- return this.performRegisterAgent(payload);
788
+ /**
789
+ * Retrieves transaction details by consensus timestamp.
790
+ * @param timestamp The consensus timestamp of the transaction (e.g., "1629400000.000000000").
791
+ * @returns A promise that resolves to the transaction details or null.
792
+ */
793
+ async getTransactionByTimestamp(timestamp) {
794
+ this.logger.info(`Getting transaction by timestamp: ${timestamp}`);
795
+ try {
796
+ const response = await this._requestWithRetry(`/api/v1/transactions?timestamp=${timestamp}&limit=1`);
797
+ return response.transactions;
798
+ } catch (error) {
799
+ this.logger.error(
800
+ `Error fetching transaction by timestamp ${timestamp}: ${error}`
801
+ );
802
+ return [];
803
+ }
804
+ }
805
+ /**
806
+ * Retrieves NFTs for a given account ID, optionally filtered by token ID.
807
+ * @param accountId The ID of the account.
808
+ * @param tokenId Optional ID of the token to filter NFTs by.
809
+ * @param limit The maximum number of NFTs to return per page (API has its own max).
810
+ * @returns A promise that resolves to an array of NftDetail or null.
811
+ */
812
+ async getAccountNfts(accountId, tokenId, limit = 100) {
813
+ this.logger.info(
814
+ `Getting NFTs for account ${accountId}${tokenId ? ` for token ${tokenId}` : ""}`
815
+ );
816
+ let allNfts = [];
817
+ let endpoint = `/api/v1/accounts/${accountId}/nfts?limit=${limit}`;
818
+ if (tokenId) {
819
+ endpoint += `&token.id=${tokenId}`;
531
820
  }
532
- await this.ensureCreditsForRegistration(payload, autoTopUp);
533
- let retried = false;
534
- while (true) {
535
- try {
536
- return await this.performRegisterAgent(payload);
537
- } catch (error) {
538
- const shortfall = this.extractInsufficientCreditsDetails(error);
539
- if (shortfall && !retried) {
540
- await this.ensureCreditsForRegistration(payload, autoTopUp);
541
- retried = true;
542
- continue;
821
+ try {
822
+ for (let i = 0; i < 10 && endpoint; i++) {
823
+ const response = await this._requestWithRetry(endpoint);
824
+ if (response && response.nfts) {
825
+ const nftsWithUri = response.nfts.map((nft) => {
826
+ let tokenUri = void 0;
827
+ if (nft.metadata) {
828
+ try {
829
+ if (this.isServerEnvironment) {
830
+ tokenUri = Buffer.from(nft.metadata, "base64").toString(
831
+ "utf-8"
832
+ );
833
+ } else {
834
+ tokenUri = new TextDecoder().decode(
835
+ Uint8Array.from(atob(nft.metadata), (c) => c.charCodeAt(0))
836
+ );
837
+ }
838
+ } catch (e) {
839
+ this.logger.warn(
840
+ `Failed to decode metadata for NFT ${nft.token_id} SN ${nft.serial_number}: ${e.message}`
841
+ );
842
+ }
843
+ }
844
+ return { ...nft, token_uri: tokenUri };
845
+ });
846
+ allNfts = allNfts.concat(nftsWithUri);
543
847
  }
544
- throw error;
848
+ endpoint = response.links?.next || "";
849
+ if (!endpoint) break;
545
850
  }
851
+ return allNfts;
852
+ } catch (error) {
853
+ this.logger.error(
854
+ `Error fetching NFTs for account ${accountId}: ${error.message}`
855
+ );
856
+ return null;
546
857
  }
547
858
  }
548
- async getRegistrationQuote(payload) {
549
- return getRegistrationQuote(this, payload);
550
- }
551
- async updateAgent(uaid, payload) {
552
- return updateAgent(this, uaid, payload);
553
- }
554
- async getRegisterStatus(uaid) {
555
- return getRegisterStatus(this, uaid);
556
- }
557
- async registerOwnedMoltbookAgent(uaid, payload) {
558
- return registerOwnedMoltbookAgent(this, uaid, payload);
559
- }
560
- async getRegistrationProgress(attemptId) {
561
- return getRegistrationProgress(this, attemptId);
562
- }
563
- async waitForRegistrationCompletion(attemptId, options) {
564
- return waitForRegistrationCompletion(this, attemptId, options);
565
- }
566
- async validateUaid(uaid) {
567
- return validateUaid(this, uaid);
568
- }
569
- async getUaidConnectionStatus(uaid) {
570
- return getUaidConnectionStatus(this, uaid);
571
- }
572
- async closeUaidConnection(uaid) {
573
- return closeUaidConnection(this, uaid);
574
- }
575
- async dashboardStats() {
576
- return dashboardStats(this);
577
- }
578
- async purchaseCreditsWithHbar(params) {
579
- return purchaseCreditsWithHbar(this, params);
580
- }
581
- async getX402Minimums() {
582
- return getX402Minimums(this);
583
- }
584
- async purchaseCreditsWithX402(params) {
585
- return purchaseCreditsWithX402(this, params);
586
- }
587
- async buyCreditsWithX402(params) {
588
- return buyCreditsWithX402(this, params);
589
- }
590
- async generateEncryptionKeyPair(options = {}) {
591
- return generateEncryptionKeyPair(this, options);
592
- }
593
- async createLedgerChallenge(payload) {
594
- return createLedgerChallenge(this, payload);
595
- }
596
- async verifyLedgerChallenge(payload) {
597
- return verifyLedgerChallenge(this, payload);
598
- }
599
- async authenticateWithLedger(options) {
600
- return authenticateWithLedger(this, options);
601
- }
602
- async authenticateWithLedgerCredentials(options) {
603
- return authenticateWithLedgerCredentials(this, options);
604
- }
605
- async getVerificationStatus(uaid) {
606
- return getVerificationStatus(this, uaid);
607
- }
608
- async createVerificationChallenge(uaid) {
609
- return createVerificationChallenge(this, uaid);
610
- }
611
- async getVerificationChallenge(challengeId) {
612
- return getVerificationChallenge(this, challengeId);
613
- }
614
- async verifyVerificationChallenge(params) {
615
- return verifyVerificationChallenge(this, params);
616
- }
617
- async getVerificationOwnership(uaid) {
618
- return getVerificationOwnership(this, uaid);
619
- }
620
- async verifySenderOwnership(uaid) {
621
- return verifySenderOwnership(this, uaid);
622
- }
623
- async verifyUaidDnsTxt(payload) {
624
- return verifyUaidDnsTxt(this, payload);
625
- }
626
- async getVerificationDnsStatus(uaid, query) {
627
- return getVerificationDnsStatus(this, uaid, query);
628
- }
629
- async fetchHistorySnapshot(sessionId, options) {
630
- return fetchHistorySnapshot(
631
- this.conversationContexts,
632
- this,
633
- sessionId,
634
- options
859
+ /**
860
+ * Validates NFT ownership by checking if a specific serial number of a token ID exists for an account.
861
+ * @param accountId The ID of the account.
862
+ * @param tokenId The ID of the NFT's token.
863
+ * @param serialNumber The serial number of the NFT.
864
+ * @returns A promise that resolves to the NftDetail if owned, or null otherwise.
865
+ */
866
+ async validateNFTOwnership(accountId, tokenId, serialNumber) {
867
+ this.logger.info(
868
+ `Validating ownership of NFT ${tokenId} SN ${serialNumber} for account ${accountId}`
635
869
  );
870
+ try {
871
+ const nfts = await this.getAccountNfts(accountId, tokenId);
872
+ if (nfts) {
873
+ const foundNft = nfts.find(
874
+ (nft) => nft.token_id === tokenId && nft.serial_number === serialNumber
875
+ );
876
+ return foundNft || null;
877
+ }
878
+ return null;
879
+ } catch (error) {
880
+ this.logger.error(`Error validating NFT ownership: ${error.message}`);
881
+ return null;
882
+ }
636
883
  }
637
- attachDecryptedHistory(sessionId, snapshot, options) {
638
- return attachDecryptedHistory(
639
- this.conversationContexts,
640
- this,
641
- sessionId,
642
- snapshot,
643
- options
884
+ /**
885
+ * Performs a read-only query against a smart contract (eth_call like).
886
+ * @param contractIdOrAddress The contract ID (e.g., "0.0.123") or EVM address (e.g., "0x...").
887
+ * @param functionSelector The function selector and encoded parameters (e.g., "0xabcdef12...").
888
+ * @param payerAccountId The account ID of the payer (not strictly payer for read-only, but often required as 'from').
889
+ * @param estimate Whether this is an estimate call. Mirror node might not support this directly in /contracts/call for true estimation.
890
+ * @param block Block parameter, e.g., "latest", "pending", or block number.
891
+ * @param value The value in tinybars to send with the call (for payable view/pure functions, usually 0).
892
+ * @returns A promise that resolves to the contract call query response or null.
893
+ */
894
+ async readSmartContractQuery(contractIdOrAddress, functionSelector, payerAccountId, options) {
895
+ this.logger.info(
896
+ `Reading smart contract ${contractIdOrAddress} with selector ${functionSelector}`
644
897
  );
898
+ const toAddress = contractIdOrAddress.startsWith("0x") ? contractIdOrAddress : `0x${AccountId.fromString(contractIdOrAddress).toSolidityAddress()}`;
899
+ const fromAddress = payerAccountId.startsWith("0x") ? payerAccountId : `0x${AccountId.fromString(payerAccountId).toSolidityAddress()}`;
900
+ const body = {
901
+ block: options?.block || "latest",
902
+ data: functionSelector,
903
+ estimate: options?.estimate || false,
904
+ from: fromAddress,
905
+ to: toAddress,
906
+ gas: options?.gas,
907
+ gasPrice: options?.gasPrice,
908
+ value: options?.value || 0
909
+ };
910
+ Object.keys(body).forEach((key) => {
911
+ const K = key;
912
+ if (body[K] === void 0) {
913
+ delete body[K];
914
+ }
915
+ });
916
+ try {
917
+ const url = this.constructUrl("/api/v1/contracts/call");
918
+ const response = await this._fetchWithRetry(
919
+ url,
920
+ {
921
+ method: "POST",
922
+ body: JSON.stringify(body),
923
+ headers: {
924
+ "Content-Type": "application/json"
925
+ }
926
+ }
927
+ );
928
+ return response;
929
+ } catch (error) {
930
+ this.logger.error(
931
+ `Error reading smart contract ${contractIdOrAddress}: ${error.message}`
932
+ );
933
+ return null;
934
+ }
645
935
  }
646
- registerConversationContextForEncryption(context) {
647
- registerConversationContextForEncryption(
648
- this.conversationContexts,
649
- context
936
+ /**
937
+ * Retrieves outstanding token airdrops sent by an account.
938
+ * @param accountId The ID of the account that sent the airdrops.
939
+ * @param options Optional parameters for filtering airdrops.
940
+ * @returns A promise that resolves to an array of TokenAirdrop or null.
941
+ */
942
+ async getOutstandingTokenAirdrops(accountId, options) {
943
+ this.logger.info(
944
+ `Getting outstanding token airdrops sent by account ${accountId}`
650
945
  );
946
+ let endpoint = `/api/v1/accounts/${accountId}/airdrops/outstanding`;
947
+ const params = new URLSearchParams();
948
+ if (options?.limit) {
949
+ params.append("limit", options.limit.toString());
950
+ }
951
+ if (options?.order) {
952
+ params.append("order", options.order);
953
+ }
954
+ if (options?.receiverId) {
955
+ params.append("receiver.id", options.receiverId);
956
+ }
957
+ if (options?.serialNumber) {
958
+ params.append("serialnumber", options.serialNumber);
959
+ }
960
+ if (options?.tokenId) {
961
+ params.append("token.id", options.tokenId);
962
+ }
963
+ const queryString = params.toString();
964
+ if (queryString) {
965
+ endpoint += `?${queryString}`;
966
+ }
967
+ try {
968
+ const response = await this._requestWithRetry(endpoint);
969
+ return response.airdrops || [];
970
+ } catch (error) {
971
+ this.logger.error(
972
+ `Error fetching outstanding token airdrops for account ${accountId}: ${error.message}`
973
+ );
974
+ return null;
975
+ }
651
976
  }
652
- resolveDecryptionContext(sessionId, options) {
653
- return resolveDecryptionContext(
654
- this.conversationContexts,
655
- this,
656
- sessionId,
657
- options
977
+ /**
978
+ * Retrieves pending token airdrops received by an account.
979
+ * @param accountId The ID of the account that received the airdrops.
980
+ * @param options Optional parameters for filtering airdrops.
981
+ * @returns A promise that resolves to an array of TokenAirdrop or null.
982
+ */
983
+ async getPendingTokenAirdrops(accountId, options) {
984
+ this.logger.info(
985
+ `Getting pending token airdrops received by account ${accountId}`
658
986
  );
987
+ let endpoint = `/api/v1/accounts/${accountId}/airdrops/pending`;
988
+ const params = new URLSearchParams();
989
+ if (options?.limit) {
990
+ params.append("limit", options.limit.toString());
991
+ }
992
+ if (options?.order) {
993
+ params.append("order", options.order);
994
+ }
995
+ if (options?.senderId) {
996
+ params.append("sender.id", options.senderId);
997
+ }
998
+ if (options?.serialNumber) {
999
+ params.append("serialnumber", options.serialNumber);
1000
+ }
1001
+ if (options?.tokenId) {
1002
+ params.append("token.id", options.tokenId);
1003
+ }
1004
+ const queryString = params.toString();
1005
+ if (queryString) {
1006
+ endpoint += `?${queryString}`;
1007
+ }
1008
+ try {
1009
+ const response = await this._requestWithRetry(endpoint);
1010
+ return response.airdrops || [];
1011
+ } catch (error) {
1012
+ this.logger.error(
1013
+ `Error fetching pending token airdrops for account ${accountId}: ${error.message}`
1014
+ );
1015
+ return null;
1016
+ }
659
1017
  }
660
- decryptHistoryEntryFromContext(_sessionId, entry, context) {
661
- return decryptHistoryEntryFromContext(this, entry, context);
662
- }
663
- async createSession(payload, allowHistoryAutoTopUp = true) {
664
- return createSession(this, payload, allowHistoryAutoTopUp);
665
- }
666
- async startChat(options) {
667
- return startChat(this, this.getEncryptedChatManager(), options);
668
- }
669
- async startConversation(options) {
670
- return startConversation(this, this.getEncryptedChatManager(), options);
671
- }
672
- async acceptConversation(options) {
673
- return acceptConversation(
674
- this,
675
- this.getEncryptedChatManager(),
676
- options
677
- );
1018
+ /**
1019
+ * Retrieves blocks from the network.
1020
+ * @param options Optional parameters for filtering blocks.
1021
+ * @returns A promise that resolves to an array of Block or null.
1022
+ */
1023
+ async getBlocks(options) {
1024
+ this.logger.info("Getting blocks from the network");
1025
+ let endpoint = `/api/v1/blocks`;
1026
+ const params = new URLSearchParams();
1027
+ if (options?.limit) {
1028
+ params.append("limit", options.limit.toString());
1029
+ }
1030
+ if (options?.order) {
1031
+ params.append("order", options.order);
1032
+ }
1033
+ if (options?.timestamp) {
1034
+ params.append("timestamp", options.timestamp);
1035
+ }
1036
+ if (options?.blockNumber) {
1037
+ params.append("block.number", options.blockNumber);
1038
+ }
1039
+ const queryString = params.toString();
1040
+ if (queryString) {
1041
+ endpoint += `?${queryString}`;
1042
+ }
1043
+ try {
1044
+ const response = await this._requestWithRetry(endpoint);
1045
+ return response.blocks || [];
1046
+ } catch (error) {
1047
+ this.logger.error(`Error fetching blocks: ${error.message}`);
1048
+ return null;
1049
+ }
678
1050
  }
679
- compactHistory(payload) {
680
- return compactHistory(this, payload);
1051
+ /**
1052
+ * Retrieves a specific block by number or hash.
1053
+ * @param blockNumberOrHash The block number or hash.
1054
+ * @returns A promise that resolves to a Block or null.
1055
+ */
1056
+ async getBlock(blockNumberOrHash) {
1057
+ this.logger.info(`Getting block ${blockNumberOrHash}`);
1058
+ try {
1059
+ const response = await this._requestWithRetry(
1060
+ `/api/v1/blocks/${blockNumberOrHash}`
1061
+ );
1062
+ return response;
1063
+ } catch (error) {
1064
+ this.logger.error(
1065
+ `Error fetching block ${blockNumberOrHash}: ${error.message}`
1066
+ );
1067
+ return null;
1068
+ }
681
1069
  }
682
- fetchEncryptionStatus(sessionId) {
683
- return fetchEncryptionStatus(this, sessionId);
1070
+ /**
1071
+ * Retrieves contract entities from the network.
1072
+ * @param options Optional parameters for filtering contracts.
1073
+ * @returns A promise that resolves to an array of ContractEntity or null.
1074
+ */
1075
+ async getContracts(options) {
1076
+ this.logger.info("Getting contracts from the network");
1077
+ let url = `/api/v1/contracts`;
1078
+ const params = new URLSearchParams();
1079
+ if (options?.contractId) {
1080
+ params.append("contract.id", options.contractId);
1081
+ }
1082
+ if (options?.limit) {
1083
+ params.append("limit", options.limit.toString());
1084
+ }
1085
+ if (options?.order) {
1086
+ params.append("order", options.order);
1087
+ }
1088
+ const queryString = params.toString();
1089
+ if (queryString) {
1090
+ url += `?${queryString}`;
1091
+ }
1092
+ try {
1093
+ const response = await this._requestWithRetry(url);
1094
+ return response.contracts || [];
1095
+ } catch (error) {
1096
+ this.logger.error(`Error fetching contracts: ${error.message}`);
1097
+ return null;
1098
+ }
684
1099
  }
685
- postEncryptionHandshake(sessionId, payload) {
686
- return postEncryptionHandshake(this, sessionId, payload);
1100
+ /**
1101
+ * Retrieves a specific contract by ID or address.
1102
+ * @param contractIdOrAddress The contract ID or EVM address.
1103
+ * @param timestamp Optional timestamp for historical data.
1104
+ * @returns A promise that resolves to a ContractEntity or null.
1105
+ */
1106
+ async getContract(contractIdOrAddress, timestamp) {
1107
+ this.logger.info(`Getting contract ${contractIdOrAddress}`);
1108
+ let url = `/api/v1/contracts/${contractIdOrAddress}`;
1109
+ if (timestamp) {
1110
+ url += `?timestamp=${timestamp}`;
1111
+ }
1112
+ try {
1113
+ const response = await this._requestWithRetry(url);
1114
+ return response;
1115
+ } catch (error) {
1116
+ this.logger.error(
1117
+ `Error fetching contract ${contractIdOrAddress}: ${error.message}`
1118
+ );
1119
+ return null;
1120
+ }
687
1121
  }
688
- sendMessage(payload) {
689
- return sendMessage(this, payload);
1122
+ /**
1123
+ * Retrieves contract results from the network.
1124
+ * @param options Optional parameters for filtering contract results.
1125
+ * @returns A promise that resolves to an array of ContractResult or null.
1126
+ */
1127
+ async getContractResults(options) {
1128
+ this.logger.info("Getting contract results from the network");
1129
+ let url = `/api/v1/contracts/results`;
1130
+ const params = new URLSearchParams();
1131
+ if (options?.from) {
1132
+ params.append("from", options.from);
1133
+ }
1134
+ if (options?.blockHash) {
1135
+ params.append("block.hash", options.blockHash);
1136
+ }
1137
+ if (options?.blockNumber) {
1138
+ params.append("block.number", options.blockNumber);
1139
+ }
1140
+ if (options?.internal !== void 0) {
1141
+ params.append("internal", options.internal.toString());
1142
+ }
1143
+ if (options?.limit) {
1144
+ params.append("limit", options.limit.toString());
1145
+ }
1146
+ if (options?.order) {
1147
+ params.append("order", options.order);
1148
+ }
1149
+ if (options?.timestamp) {
1150
+ params.append("timestamp", options.timestamp);
1151
+ }
1152
+ if (options?.transactionIndex) {
1153
+ params.append("transaction.index", options.transactionIndex.toString());
1154
+ }
1155
+ const queryString = params.toString();
1156
+ if (queryString) {
1157
+ url += `?${queryString}`;
1158
+ }
1159
+ try {
1160
+ const response = await this._requestWithRetry(url);
1161
+ return response.results || [];
1162
+ } catch (error) {
1163
+ this.logger.error(`Error fetching contract results: ${error.message}`);
1164
+ return null;
1165
+ }
690
1166
  }
691
- endSession(sessionId) {
692
- return endSession(this, sessionId);
1167
+ /**
1168
+ * Retrieves a specific contract result by transaction ID or hash.
1169
+ * @param transactionIdOrHash The transaction ID or hash.
1170
+ * @param nonce Optional nonce filter.
1171
+ * @returns A promise that resolves to a ContractResult or null.
1172
+ */
1173
+ async getContractResult(transactionIdOrHash, nonce) {
1174
+ this.logger.info(`Getting contract result for ${transactionIdOrHash}`);
1175
+ let url = `/api/v1/contracts/results/${transactionIdOrHash}`;
1176
+ if (nonce !== void 0) {
1177
+ url += `?nonce=${nonce}`;
1178
+ }
1179
+ try {
1180
+ const response = await this._requestWithRetry(url);
1181
+ return response;
1182
+ } catch (error) {
1183
+ this.logger.error(
1184
+ `Error fetching contract result for ${transactionIdOrHash}: ${error.message}`
1185
+ );
1186
+ return null;
1187
+ }
693
1188
  }
694
- createPlaintextConversationHandle(sessionId, summary, defaultAuth, context) {
695
- return createPlaintextConversationHandle(
696
- this,
697
- sessionId,
698
- summary,
699
- defaultAuth,
700
- context
1189
+ /**
1190
+ * Retrieves contract results for a specific contract.
1191
+ * @param contractIdOrAddress The contract ID or EVM address.
1192
+ * @param options Optional parameters for filtering.
1193
+ * @returns A promise that resolves to an array of ContractResult or null.
1194
+ */
1195
+ async getContractResultsByContract(contractIdOrAddress, options) {
1196
+ this.logger.info(
1197
+ `Getting contract results for contract ${contractIdOrAddress}`
701
1198
  );
702
- }
703
- getEncryptedChatManager() {
704
- if (this.encryptedChatManager) {
705
- return this.encryptedChatManager;
1199
+ let url = `/api/v1/contracts/${contractIdOrAddress}/results`;
1200
+ const params = new URLSearchParams();
1201
+ if (options?.blockHash) {
1202
+ params.append("block.hash", options.blockHash);
706
1203
  }
707
- const manager = new EncryptedChatManager(this);
708
- this.encryptedChatManager = manager;
709
- return manager;
710
- }
711
- async extractErrorBody(response) {
712
- const contentType = response.headers?.get("content-type") ?? "";
713
- if (JSON_CONTENT_TYPE.test(contentType)) {
714
- try {
715
- return await response.json();
716
- } catch (error) {
717
- return { parseError: String(error) };
718
- }
1204
+ if (options?.blockNumber) {
1205
+ params.append("block.number", options.blockNumber);
1206
+ }
1207
+ if (options?.from) {
1208
+ params.append("from", options.from);
1209
+ }
1210
+ if (options?.internal !== void 0) {
1211
+ params.append("internal", options.internal.toString());
1212
+ }
1213
+ if (options?.limit) {
1214
+ params.append("limit", options.limit.toString());
1215
+ }
1216
+ if (options?.order) {
1217
+ params.append("order", options.order);
1218
+ }
1219
+ if (options?.timestamp) {
1220
+ params.append("timestamp", options.timestamp);
1221
+ }
1222
+ if (options?.transactionIndex) {
1223
+ params.append("transaction.index", options.transactionIndex.toString());
1224
+ }
1225
+ const queryString = params.toString();
1226
+ if (queryString) {
1227
+ url += `?${queryString}`;
719
1228
  }
720
1229
  try {
721
- return await response.text();
1230
+ const response = await this._requestWithRetry(url);
1231
+ return response.results || [];
722
1232
  } catch (error) {
723
- return { parseError: String(error) };
1233
+ this.logger.error(
1234
+ `Error fetching contract results for ${contractIdOrAddress}: ${error.message}`
1235
+ );
1236
+ return null;
724
1237
  }
725
1238
  }
726
- parseWithSchema(value, schema, context) {
1239
+ /**
1240
+ * Retrieves contract state for a specific contract.
1241
+ * @param contractIdOrAddress The contract ID or EVM address.
1242
+ * @param options Optional parameters for filtering.
1243
+ * @returns A promise that resolves to an array of ContractState or null.
1244
+ */
1245
+ async getContractState(contractIdOrAddress, options) {
1246
+ this.logger.info(`Getting contract state for ${contractIdOrAddress}`);
1247
+ let url = `/api/v1/contracts/${contractIdOrAddress}/state`;
1248
+ const params = new URLSearchParams();
1249
+ if (options?.limit) {
1250
+ params.append("limit", options.limit.toString());
1251
+ }
1252
+ if (options?.order) {
1253
+ params.append("order", options.order);
1254
+ }
1255
+ if (options?.slot) {
1256
+ params.append("slot", options.slot);
1257
+ }
1258
+ if (options?.timestamp) {
1259
+ params.append("timestamp", options.timestamp);
1260
+ }
1261
+ const queryString = params.toString();
1262
+ if (queryString) {
1263
+ url += `?${queryString}`;
1264
+ }
727
1265
  try {
728
- return schema.parse(value);
1266
+ const response = await this._requestWithRetry(url);
1267
+ return response.state || [];
729
1268
  } catch (error) {
730
- throw new RegistryBrokerParseError(
731
- `Failed to parse ${context}`,
732
- error instanceof ZodError || error instanceof Error ? error : String(error),
733
- value
1269
+ this.logger.error(
1270
+ `Error fetching contract state for ${contractIdOrAddress}: ${error.message}`
734
1271
  );
1272
+ return null;
735
1273
  }
736
1274
  }
737
- async delay(ms, signal) {
738
- if (ms <= 0) {
739
- if (signal?.aborted) {
740
- throw createAbortError();
741
- }
742
- return;
1275
+ /**
1276
+ * Retrieves contract actions for a specific transaction.
1277
+ * @param transactionIdOrHash The transaction ID or hash.
1278
+ * @param options Optional parameters for filtering.
1279
+ * @returns A promise that resolves to an array of ContractAction or null.
1280
+ */
1281
+ async getContractActions(transactionIdOrHash, options) {
1282
+ this.logger.info(`Getting contract actions for ${transactionIdOrHash}`);
1283
+ let url = `/api/v1/contracts/results/${transactionIdOrHash}/actions`;
1284
+ const params = new URLSearchParams();
1285
+ if (options?.index) {
1286
+ params.append("index", options.index);
743
1287
  }
744
- await new Promise((resolve, reject) => {
745
- const timer = setTimeout(() => {
746
- if (signal) {
747
- signal.removeEventListener("abort", onAbort);
748
- }
749
- resolve();
750
- }, ms);
751
- const onAbort = () => {
752
- clearTimeout(timer);
753
- signal?.removeEventListener("abort", onAbort);
754
- reject(createAbortError());
755
- };
756
- if (signal) {
757
- if (signal.aborted) {
758
- clearTimeout(timer);
759
- reject(createAbortError());
760
- return;
761
- }
762
- signal.addEventListener("abort", onAbort, { once: true });
763
- }
764
- });
765
- }
766
- assertNodeRuntime(feature) {
767
- if (typeof process === "undefined" || !process.versions?.node) {
768
- throw new Error(`${feature} is only available in Node.js environments`);
1288
+ if (options?.limit) {
1289
+ params.append("limit", options.limit.toString());
769
1290
  }
770
- }
771
- createEphemeralKeyPair() {
772
- this.assertNodeRuntime("generateEphemeralKeyPair");
773
- const privateKeyBytes = randomBytes(32);
774
- const publicKey = secp256k1.getPublicKey(privateKeyBytes, true);
775
- return {
776
- privateKey: Buffer.from(privateKeyBytes).toString("hex"),
777
- publicKey: Buffer.from(publicKey).toString("hex")
778
- };
779
- }
780
- deriveSharedSecret(options) {
781
- this.assertNodeRuntime("deriveSharedSecret");
782
- const privateKey = this.hexToBuffer(options.privateKey);
783
- const peerPublicKey = this.hexToBuffer(options.peerPublicKey);
784
- const shared = secp256k1.getSharedSecret(privateKey, peerPublicKey, true);
785
- return createHash("sha256").update(Buffer.from(shared)).digest();
786
- }
787
- buildCipherEnvelope(options) {
788
- this.assertNodeRuntime("encryptCipherEnvelope");
789
- const sharedSecret = this.normalizeSharedSecret(options.sharedSecret);
790
- const iv = randomBytes(12);
791
- const cipher = createCipheriv("aes-256-gcm", sharedSecret, iv);
792
- const aadSource = options.associatedData ?? options.sessionId;
793
- const associatedDataEncoded = aadSource ? Buffer.from(aadSource, "utf8").toString("base64") : void 0;
794
- if (aadSource) {
795
- cipher.setAAD(Buffer.from(aadSource, "utf8"));
796
- }
797
- const ciphertext = Buffer.concat([
798
- cipher.update(Buffer.from(options.plaintext, "utf8")),
799
- cipher.final()
800
- ]);
801
- const tag = cipher.getAuthTag();
802
- const payload = Buffer.concat([ciphertext, tag]);
803
- return {
804
- algorithm: "aes-256-gcm",
805
- ciphertext: payload.toString("base64"),
806
- nonce: iv.toString("base64"),
807
- associatedData: associatedDataEncoded,
808
- keyLocator: {
809
- sessionId: options.sessionId,
810
- revision: options.revision ?? 1
811
- },
812
- recipients: options.recipients.map((recipient) => ({
813
- ...recipient,
814
- encryptedShare: ""
815
- }))
816
- };
817
- }
818
- openCipherEnvelope(options) {
819
- this.assertNodeRuntime("decryptCipherEnvelope");
820
- const sharedSecret = this.normalizeSharedSecret(options.sharedSecret);
821
- const payload = Buffer.from(options.envelope.ciphertext, "base64");
822
- const nonce = Buffer.from(options.envelope.nonce, "base64");
823
- const ciphertext = payload.slice(0, payload.length - 16);
824
- const tag = payload.slice(payload.length - 16);
825
- const decipher = createDecipheriv("aes-256-gcm", sharedSecret, nonce);
826
- if (options.envelope.associatedData) {
827
- decipher.setAAD(Buffer.from(options.envelope.associatedData, "base64"));
1291
+ if (options?.order) {
1292
+ params.append("order", options.order);
1293
+ }
1294
+ const queryString = params.toString();
1295
+ if (queryString) {
1296
+ url += `?${queryString}`;
1297
+ }
1298
+ try {
1299
+ const response = await this._requestWithRetry(url);
1300
+ return response.actions || [];
1301
+ } catch (error) {
1302
+ this.logger.error(
1303
+ `Error fetching contract actions for ${transactionIdOrHash}: ${error.message}`
1304
+ );
1305
+ return null;
828
1306
  }
829
- decipher.setAuthTag(tag);
830
- const plaintext = Buffer.concat([
831
- decipher.update(ciphertext),
832
- decipher.final()
833
- ]);
834
- return plaintext.toString(options.encoding ?? "utf8");
835
1307
  }
836
- normalizeSharedSecret(input) {
837
- if (Buffer.isBuffer(input)) {
838
- return Buffer.from(input);
1308
+ /**
1309
+ * Retrieves contract logs from the network.
1310
+ * @param options Optional parameters for filtering logs.
1311
+ * @returns A promise that resolves to an array of ContractLog or null.
1312
+ */
1313
+ async getContractLogs(options) {
1314
+ this.logger.info("Getting contract logs from the network");
1315
+ let url = `/api/v1/contracts/results/logs`;
1316
+ const params = new URLSearchParams();
1317
+ if (options?.index) {
1318
+ params.append("index", options.index);
1319
+ }
1320
+ if (options?.limit) {
1321
+ params.append("limit", options.limit.toString());
1322
+ }
1323
+ if (options?.order) {
1324
+ params.append("order", options.order);
1325
+ }
1326
+ if (options?.timestamp) {
1327
+ params.append("timestamp", options.timestamp);
1328
+ }
1329
+ if (options?.topic0) {
1330
+ params.append("topic0", options.topic0);
1331
+ }
1332
+ if (options?.topic1) {
1333
+ params.append("topic1", options.topic1);
1334
+ }
1335
+ if (options?.topic2) {
1336
+ params.append("topic2", options.topic2);
839
1337
  }
840
- if (input instanceof Uint8Array) {
841
- return Buffer.from(input);
1338
+ if (options?.topic3) {
1339
+ params.append("topic3", options.topic3);
842
1340
  }
843
- if (typeof input === "string") {
844
- return this.bufferFromString(input);
1341
+ if (options?.transactionHash) {
1342
+ params.append("transaction.hash", options.transactionHash);
1343
+ }
1344
+ const queryString = params.toString();
1345
+ if (queryString) {
1346
+ url += `?${queryString}`;
1347
+ }
1348
+ try {
1349
+ const response = await this._requestWithRetry(url);
1350
+ return response.logs || [];
1351
+ } catch (error) {
1352
+ this.logger.error(`Error fetching contract logs: ${error.message}`);
1353
+ return null;
845
1354
  }
846
- throw new Error("Unsupported shared secret input");
847
1355
  }
848
- bufferFromString(value) {
849
- const trimmed = value.trim();
850
- if (!trimmed) {
851
- throw new Error("sharedSecret string cannot be empty");
1356
+ /**
1357
+ * Retrieves contract logs for a specific contract.
1358
+ * @param contractIdOrAddress The contract ID or EVM address.
1359
+ * @param options Optional parameters for filtering logs.
1360
+ * @returns A promise that resolves to an array of ContractLog or null.
1361
+ */
1362
+ async getContractLogsByContract(contractIdOrAddress, options) {
1363
+ this.logger.info(
1364
+ `Getting contract logs for contract ${contractIdOrAddress}`
1365
+ );
1366
+ let url = `/api/v1/contracts/${contractIdOrAddress}/results/logs`;
1367
+ const params = new URLSearchParams();
1368
+ if (options?.index) {
1369
+ params.append("index", options.index);
1370
+ }
1371
+ if (options?.limit) {
1372
+ params.append("limit", options.limit.toString());
1373
+ }
1374
+ if (options?.order) {
1375
+ params.append("order", options.order);
1376
+ }
1377
+ if (options?.timestamp) {
1378
+ params.append("timestamp", options.timestamp);
1379
+ }
1380
+ if (options?.topic0) {
1381
+ params.append("topic0", options.topic0);
1382
+ }
1383
+ if (options?.topic1) {
1384
+ params.append("topic1", options.topic1);
1385
+ }
1386
+ if (options?.topic2) {
1387
+ params.append("topic2", options.topic2);
852
1388
  }
853
- const normalized = trimmed.startsWith("0x") ? trimmed.slice(2) : trimmed;
854
- if (/^[0-9a-fA-F]+$/.test(normalized) && normalized.length % 2 === 0) {
855
- return Buffer.from(normalized, "hex");
1389
+ if (options?.topic3) {
1390
+ params.append("topic3", options.topic3);
1391
+ }
1392
+ const queryString = params.toString();
1393
+ if (queryString) {
1394
+ url += `?${queryString}`;
1395
+ }
1396
+ try {
1397
+ const response = await this._requestWithRetry(url);
1398
+ return response.logs || [];
1399
+ } catch (error) {
1400
+ this.logger.error(
1401
+ `Error fetching contract logs for ${contractIdOrAddress}: ${error.message}`
1402
+ );
1403
+ return null;
856
1404
  }
857
- return Buffer.from(trimmed, "base64");
858
1405
  }
859
- hexToBuffer(value) {
860
- const normalized = value.startsWith("0x") ? value.slice(2) : value;
861
- if (!/^[0-9a-fA-F]+$/.test(normalized) || normalized.length % 2 !== 0) {
862
- throw new Error("Expected hex-encoded value");
1406
+ /**
1407
+ * Retrieves NFT information by token ID and serial number.
1408
+ * @param tokenId The token ID.
1409
+ * @param serialNumber The serial number of the NFT.
1410
+ * @returns A promise that resolves to an NftInfo or null.
1411
+ */
1412
+ async getNftInfo(tokenId, serialNumber) {
1413
+ this.logger.info(`Getting NFT info for ${tokenId}/${serialNumber}`);
1414
+ const url = `/api/v1/tokens/${tokenId}/nfts/${serialNumber}`;
1415
+ try {
1416
+ const response = await this._requestWithRetry(url);
1417
+ return response;
1418
+ } catch (error) {
1419
+ this.logger.error(
1420
+ `Error fetching NFT info for ${tokenId}/${serialNumber}: ${error.message}`
1421
+ );
1422
+ return null;
863
1423
  }
864
- return Buffer.from(normalized, "hex");
865
1424
  }
866
- extractInsufficientCreditsDetails(error) {
867
- if (!(error instanceof RegistryBrokerError) || error.status !== 402) {
1425
+ /**
1426
+ * Retrieves NFTs for a specific token.
1427
+ * @param tokenId The token ID.
1428
+ * @param options Optional parameters for filtering NFTs.
1429
+ * @returns A promise that resolves to an array of NftInfo or null.
1430
+ */
1431
+ async getNftsByToken(tokenId, options) {
1432
+ this.logger.info(`Getting NFTs for token ${tokenId}`);
1433
+ let url = `/api/v1/tokens/${tokenId}/nfts`;
1434
+ const params = new URLSearchParams();
1435
+ if (options?.accountId) {
1436
+ params.append("account.id", options.accountId);
1437
+ }
1438
+ if (options?.limit) {
1439
+ params.append("limit", options.limit.toString());
1440
+ }
1441
+ if (options?.order) {
1442
+ params.append("order", options.order);
1443
+ }
1444
+ if (options?.serialNumber) {
1445
+ params.append("serialnumber", options.serialNumber);
1446
+ }
1447
+ const queryString = params.toString();
1448
+ if (queryString) {
1449
+ url += `?${queryString}`;
1450
+ }
1451
+ try {
1452
+ const response = await this._requestWithRetry(url);
1453
+ return response.nfts || [];
1454
+ } catch (error) {
1455
+ this.logger.error(
1456
+ `Error fetching NFTs for token ${tokenId}: ${error.message}`
1457
+ );
868
1458
  return null;
869
1459
  }
870
- const body = error.body;
871
- if (!body || typeof body !== "object" || Array.isArray(body)) {
1460
+ }
1461
+ /**
1462
+ * Retrieves network information.
1463
+ * @returns A promise that resolves to NetworkInfo or null.
1464
+ */
1465
+ async getNetworkInfo() {
1466
+ this.logger.info("Getting network information");
1467
+ const url = `/api/v1/network/nodes`;
1468
+ try {
1469
+ const response = await this._requestWithRetry(url);
1470
+ return response;
1471
+ } catch (error) {
1472
+ this.logger.error(`Error fetching network info: ${error.message}`);
872
1473
  return null;
873
1474
  }
874
- const maybeShortfall = body["shortfallCredits"];
875
- if (typeof maybeShortfall !== "number" || maybeShortfall <= 0) {
1475
+ }
1476
+ /**
1477
+ * Retrieves network fees.
1478
+ * @param timestamp Optional timestamp for historical fees.
1479
+ * @returns A promise that resolves to NetworkFees or null.
1480
+ */
1481
+ async getNetworkFees(timestamp) {
1482
+ this.logger.info("Getting network fees");
1483
+ let url = `/api/v1/network/fees`;
1484
+ if (timestamp) {
1485
+ url += `?timestamp=${timestamp}`;
1486
+ }
1487
+ try {
1488
+ const response = await this._requestWithRetry(url);
1489
+ return response;
1490
+ } catch (error) {
1491
+ this.logger.error(`Error fetching network fees: ${error.message}`);
876
1492
  return null;
877
1493
  }
878
- return { shortfallCredits: maybeShortfall };
879
1494
  }
880
- extractErrorMessage(body) {
881
- if (typeof body === "string") {
882
- return body;
1495
+ /**
1496
+ * Retrieves network supply information.
1497
+ * @param timestamp Optional timestamp for historical supply data.
1498
+ * @returns A promise that resolves to NetworkSupply or null.
1499
+ */
1500
+ async getNetworkSupply(timestamp) {
1501
+ this.logger.info("Getting network supply");
1502
+ let url = `/api/v1/network/supply`;
1503
+ if (timestamp) {
1504
+ url += `?timestamp=${timestamp}`;
1505
+ }
1506
+ try {
1507
+ const response = await this._requestWithRetry(url);
1508
+ return response;
1509
+ } catch (error) {
1510
+ this.logger.error(`Error fetching network supply: ${error.message}`);
1511
+ return null;
883
1512
  }
884
- if (isJsonObject(body) && typeof body.error === "string") {
885
- return body.error;
1513
+ }
1514
+ /**
1515
+ * Retrieves network stake information.
1516
+ * @param timestamp Optional timestamp for historical stake data.
1517
+ * @returns A promise that resolves to NetworkStake or null.
1518
+ */
1519
+ async getNetworkStake(timestamp) {
1520
+ this.logger.info("Getting network stake");
1521
+ let url = `/api/v1/network/stake`;
1522
+ if (timestamp) {
1523
+ url += `?timestamp=${timestamp}`;
886
1524
  }
887
- if (isJsonObject(body) && typeof body.message === "string") {
888
- return body.message;
1525
+ try {
1526
+ const response = await this._requestWithRetry(url);
1527
+ return response;
1528
+ } catch (error) {
1529
+ this.logger.error(`Error fetching network stake: ${error.message}`);
1530
+ return null;
889
1531
  }
890
- return void 0;
891
1532
  }
892
- shouldAutoTopUpHistory(payload, error) {
893
- if (!this.historyAutoTopUp || payload.historyTtlSeconds === void 0) {
894
- return false;
1533
+ /**
1534
+ * Retrieves opcode traces for a specific transaction.
1535
+ * @param transactionIdOrHash The transaction ID or hash.
1536
+ * @param options Optional parameters for trace details.
1537
+ * @returns A promise that resolves to an OpcodesResponse or null.
1538
+ */
1539
+ async getOpcodeTraces(transactionIdOrHash, options) {
1540
+ this.logger.info(`Getting opcode traces for ${transactionIdOrHash}`);
1541
+ let url = `/api/v1/contracts/results/${transactionIdOrHash}/opcodes`;
1542
+ const params = new URLSearchParams();
1543
+ if (options?.stack !== void 0) {
1544
+ params.append("stack", options.stack.toString());
895
1545
  }
896
- if (!(error instanceof RegistryBrokerError)) {
897
- return false;
1546
+ if (options?.memory !== void 0) {
1547
+ params.append("memory", options.memory.toString());
898
1548
  }
899
- if (error.status !== 402) {
900
- return false;
1549
+ if (options?.storage !== void 0) {
1550
+ params.append("storage", options.storage.toString());
1551
+ }
1552
+ const queryString = params.toString();
1553
+ if (queryString) {
1554
+ url += `?${queryString}`;
1555
+ }
1556
+ try {
1557
+ const response = await this._requestWithRetry(url);
1558
+ return response;
1559
+ } catch (error) {
1560
+ this.logger.error(
1561
+ `Error fetching opcode traces for ${transactionIdOrHash}: ${error.message}`
1562
+ );
1563
+ return null;
901
1564
  }
902
- const message = this.extractErrorMessage(error.body);
903
- if (!message) {
904
- return true;
905
- }
906
- const normalised = message.toLowerCase();
907
- return normalised.includes("history") || normalised.includes("chat history");
908
- }
909
- async executeHistoryAutoTopUp(reason) {
910
- if (!this.historyAutoTopUp) {
911
- return;
912
- }
913
- const hbarAmount = this.historyAutoTopUp.hbarAmount && this.historyAutoTopUp.hbarAmount > 0 ? this.historyAutoTopUp.hbarAmount : DEFAULT_HISTORY_TOP_UP_HBAR;
914
- await this.purchaseCreditsWithHbar({
915
- accountId: this.historyAutoTopUp.accountId,
916
- privateKey: this.historyAutoTopUp.privateKey,
917
- hbarAmount,
918
- memo: this.historyAutoTopUp.memo ?? "registry-broker-client:chat-history-topup",
919
- metadata: {
920
- purpose: "chat-history",
921
- reason
922
- }
923
- });
924
- }
925
- initializeEncryptionBootstrap(options) {
926
- return this.bootstrapEncryptionOptions(options).then(() => void 0);
927
- }
928
- bootstrapEncryptionOptions(options) {
929
- return bootstrapEncryptionOptions(this, options);
930
1565
  }
931
1566
  }
932
- const isPendingRegisterAgentResponse = (response) => response.status === "pending";
933
- const isPartialRegisterAgentResponse = (response) => response.status === "partial" && response.success === false;
934
- const isSuccessRegisterAgentResponse = (response) => response.success === true && response.status !== "pending";
935
1567
  export {
936
- RegistryBrokerClient,
937
- isPartialRegisterAgentResponse,
938
- isPendingRegisterAgentResponse,
939
- isSuccessRegisterAgentResponse
1568
+ HederaMirrorNode
940
1569
  };
941
1570
  //# sourceMappingURL=standards-sdk.es144.js.map