@hashgraphonline/standards-sdk 0.1.144 → 0.1.145

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 (423) hide show
  1. package/dist/cjs/hcs-10/base-client.d.ts.map +1 -1
  2. package/dist/cjs/hcs-10/sdk.d.ts +8 -0
  3. package/dist/cjs/hcs-10/sdk.d.ts.map +1 -1
  4. package/dist/cjs/hcs-11/client.d.ts +2 -2
  5. package/dist/cjs/hcs-11/client.d.ts.map +1 -1
  6. package/dist/cjs/hcs-11/person-builder.d.ts +1 -0
  7. package/dist/cjs/hcs-11/person-builder.d.ts.map +1 -1
  8. package/dist/cjs/hcs-11/types.d.ts +1 -0
  9. package/dist/cjs/hcs-11/types.d.ts.map +1 -1
  10. package/dist/cjs/hcs-12/rendering/resource-manager.d.ts.map +1 -1
  11. package/dist/cjs/hcs-14/issuers/hiero.d.ts.map +1 -1
  12. package/dist/cjs/hcs-15/browser.d.ts +2 -0
  13. package/dist/cjs/hcs-15/browser.d.ts.map +1 -1
  14. package/dist/cjs/hcs-15/sdk.d.ts +7 -1
  15. package/dist/cjs/hcs-15/sdk.d.ts.map +1 -1
  16. package/dist/cjs/hcs-15/tx.d.ts +4 -0
  17. package/dist/cjs/hcs-15/tx.d.ts.map +1 -1
  18. package/dist/cjs/hcs-15/types.d.ts +16 -1
  19. package/dist/cjs/hcs-15/types.d.ts.map +1 -1
  20. package/dist/cjs/hcs-16/browser.d.ts +11 -2
  21. package/dist/cjs/hcs-16/browser.d.ts.map +1 -1
  22. package/dist/cjs/hcs-16/sdk.d.ts +62 -1
  23. package/dist/cjs/hcs-16/sdk.d.ts.map +1 -1
  24. package/dist/cjs/hcs-16/tx.d.ts +21 -3
  25. package/dist/cjs/hcs-16/tx.d.ts.map +1 -1
  26. package/dist/cjs/hcs-17/base-client.d.ts +1 -0
  27. package/dist/cjs/hcs-17/base-client.d.ts.map +1 -1
  28. package/dist/cjs/hcs-17/sdk.d.ts.map +1 -1
  29. package/dist/cjs/hcs-17/tx.d.ts +2 -0
  30. package/dist/cjs/hcs-17/tx.d.ts.map +1 -1
  31. package/dist/cjs/hcs-17/types.d.ts +4 -0
  32. package/dist/cjs/hcs-17/types.d.ts.map +1 -1
  33. package/dist/cjs/index.d.ts.map +1 -1
  34. package/dist/cjs/services/registry-broker/client/base-client.d.ts +14 -1
  35. package/dist/cjs/services/registry-broker/client/base-client.d.ts.map +1 -1
  36. package/dist/cjs/services/registry-broker/client/feedback.d.ts +2 -0
  37. package/dist/cjs/services/registry-broker/client/feedback.d.ts.map +1 -0
  38. package/dist/cjs/services/registry-broker/private-key-signer.d.ts +1 -0
  39. package/dist/cjs/services/registry-broker/private-key-signer.d.ts.map +1 -1
  40. package/dist/cjs/services/registry-broker/schemas.d.ts +998 -577
  41. package/dist/cjs/services/registry-broker/schemas.d.ts.map +1 -1
  42. package/dist/cjs/services/registry-broker/types.d.ts +20 -1
  43. package/dist/cjs/services/registry-broker/types.d.ts.map +1 -1
  44. package/dist/cjs/standards-sdk.cjs +2 -2
  45. package/dist/cjs/standards-sdk.cjs.map +1 -1
  46. package/dist/cjs/utils/crypto-abstraction.d.ts.map +1 -1
  47. package/dist/cjs/utils/crypto-env.d.ts.map +1 -1
  48. package/dist/cjs/utils/dynamic-import.d.ts +5 -1
  49. package/dist/cjs/utils/dynamic-import.d.ts.map +1 -1
  50. package/dist/cjs/utils/hash-adapter.d.ts.map +1 -1
  51. package/dist/es/hcs-10/base-client.d.ts.map +1 -1
  52. package/dist/es/hcs-10/sdk.d.ts +8 -0
  53. package/dist/es/hcs-10/sdk.d.ts.map +1 -1
  54. package/dist/es/hcs-11/client.d.ts +2 -2
  55. package/dist/es/hcs-11/client.d.ts.map +1 -1
  56. package/dist/es/hcs-11/person-builder.d.ts +1 -0
  57. package/dist/es/hcs-11/person-builder.d.ts.map +1 -1
  58. package/dist/es/hcs-11/types.d.ts +1 -0
  59. package/dist/es/hcs-11/types.d.ts.map +1 -1
  60. package/dist/es/hcs-12/rendering/resource-manager.d.ts.map +1 -1
  61. package/dist/es/hcs-14/issuers/hiero.d.ts.map +1 -1
  62. package/dist/es/hcs-15/browser.d.ts +2 -0
  63. package/dist/es/hcs-15/browser.d.ts.map +1 -1
  64. package/dist/es/hcs-15/sdk.d.ts +7 -1
  65. package/dist/es/hcs-15/sdk.d.ts.map +1 -1
  66. package/dist/es/hcs-15/tx.d.ts +4 -0
  67. package/dist/es/hcs-15/tx.d.ts.map +1 -1
  68. package/dist/es/hcs-15/types.d.ts +16 -1
  69. package/dist/es/hcs-15/types.d.ts.map +1 -1
  70. package/dist/es/hcs-16/browser.d.ts +11 -2
  71. package/dist/es/hcs-16/browser.d.ts.map +1 -1
  72. package/dist/es/hcs-16/sdk.d.ts +62 -1
  73. package/dist/es/hcs-16/sdk.d.ts.map +1 -1
  74. package/dist/es/hcs-16/tx.d.ts +21 -3
  75. package/dist/es/hcs-16/tx.d.ts.map +1 -1
  76. package/dist/es/hcs-17/base-client.d.ts +1 -0
  77. package/dist/es/hcs-17/base-client.d.ts.map +1 -1
  78. package/dist/es/hcs-17/sdk.d.ts.map +1 -1
  79. package/dist/es/hcs-17/tx.d.ts +2 -0
  80. package/dist/es/hcs-17/tx.d.ts.map +1 -1
  81. package/dist/es/hcs-17/types.d.ts +4 -0
  82. package/dist/es/hcs-17/types.d.ts.map +1 -1
  83. package/dist/es/index.d.ts.map +1 -1
  84. package/dist/es/services/registry-broker/client/base-client.d.ts +14 -1
  85. package/dist/es/services/registry-broker/client/base-client.d.ts.map +1 -1
  86. package/dist/es/services/registry-broker/client/feedback.d.ts +2 -0
  87. package/dist/es/services/registry-broker/client/feedback.d.ts.map +1 -0
  88. package/dist/es/services/registry-broker/private-key-signer.d.ts +1 -0
  89. package/dist/es/services/registry-broker/private-key-signer.d.ts.map +1 -1
  90. package/dist/es/services/registry-broker/schemas.d.ts +998 -577
  91. package/dist/es/services/registry-broker/schemas.d.ts.map +1 -1
  92. package/dist/es/services/registry-broker/types.d.ts +20 -1
  93. package/dist/es/services/registry-broker/types.d.ts.map +1 -1
  94. package/dist/es/standards-sdk.es.js +141 -135
  95. package/dist/es/standards-sdk.es.js.map +1 -1
  96. package/dist/es/standards-sdk.es10.js +70 -90
  97. package/dist/es/standards-sdk.es10.js.map +1 -1
  98. package/dist/es/standards-sdk.es100.js +229 -26
  99. package/dist/es/standards-sdk.es100.js.map +1 -1
  100. package/dist/es/standards-sdk.es101.js +109 -228
  101. package/dist/es/standards-sdk.es101.js.map +1 -1
  102. package/dist/es/standards-sdk.es102.js +15 -94
  103. package/dist/es/standards-sdk.es102.js.map +1 -1
  104. package/dist/es/standards-sdk.es103.js +80 -30
  105. package/dist/es/standards-sdk.es103.js.map +1 -1
  106. package/dist/es/standards-sdk.es104.js +27 -80
  107. package/dist/es/standards-sdk.es104.js.map +1 -1
  108. package/dist/es/standards-sdk.es105.js +136 -25
  109. package/dist/es/standards-sdk.es105.js.map +1 -1
  110. package/dist/es/standards-sdk.es106.js +27 -140
  111. package/dist/es/standards-sdk.es106.js.map +1 -1
  112. package/dist/es/standards-sdk.es107.js +20 -27
  113. package/dist/es/standards-sdk.es107.js.map +1 -1
  114. package/dist/es/standards-sdk.es108.js +156 -18
  115. package/dist/es/standards-sdk.es108.js.map +1 -1
  116. package/dist/es/standards-sdk.es109.js +198 -148
  117. package/dist/es/standards-sdk.es109.js.map +1 -1
  118. package/dist/es/standards-sdk.es11.js +121 -45
  119. package/dist/es/standards-sdk.es11.js.map +1 -1
  120. package/dist/es/standards-sdk.es110.js +747 -166
  121. package/dist/es/standards-sdk.es110.js.map +1 -1
  122. package/dist/es/standards-sdk.es111.js +9 -786
  123. package/dist/es/standards-sdk.es111.js.map +1 -1
  124. package/dist/es/standards-sdk.es112.js +567 -13
  125. package/dist/es/standards-sdk.es112.js.map +1 -1
  126. package/dist/es/standards-sdk.es113.js +576 -541
  127. package/dist/es/standards-sdk.es113.js.map +1 -1
  128. package/dist/es/standards-sdk.es114.js +12 -601
  129. package/dist/es/standards-sdk.es114.js.map +1 -1
  130. package/dist/es/standards-sdk.es115.js +2 -13
  131. package/dist/es/standards-sdk.es115.js.map +1 -1
  132. package/dist/es/standards-sdk.es116.js +87 -2
  133. package/dist/es/standards-sdk.es116.js.map +1 -1
  134. package/dist/es/standards-sdk.es117.js +37 -80
  135. package/dist/es/standards-sdk.es117.js.map +1 -1
  136. package/dist/es/standards-sdk.es118.js +2 -39
  137. package/dist/es/standards-sdk.es118.js.map +1 -1
  138. package/dist/es/standards-sdk.es119.js +231 -2
  139. package/dist/es/standards-sdk.es119.js.map +1 -1
  140. package/dist/es/standards-sdk.es12.js +60 -159
  141. package/dist/es/standards-sdk.es12.js.map +1 -1
  142. package/dist/es/standards-sdk.es120.js +1110 -193
  143. package/dist/es/standards-sdk.es120.js.map +1 -1
  144. package/dist/es/standards-sdk.es121.js +225 -1059
  145. package/dist/es/standards-sdk.es121.js.map +1 -1
  146. package/dist/es/standards-sdk.es122.js +419 -303
  147. package/dist/es/standards-sdk.es122.js.map +1 -1
  148. package/dist/es/standards-sdk.es123.js +351 -418
  149. package/dist/es/standards-sdk.es123.js.map +1 -1
  150. package/dist/es/standards-sdk.es124.js +872 -347
  151. package/dist/es/standards-sdk.es124.js.map +1 -1
  152. package/dist/es/standards-sdk.es125.js +182 -854
  153. package/dist/es/standards-sdk.es125.js.map +1 -1
  154. package/dist/es/standards-sdk.es126.js +1512 -153
  155. package/dist/es/standards-sdk.es126.js.map +1 -1
  156. package/dist/es/standards-sdk.es127.js +157 -1547
  157. package/dist/es/standards-sdk.es127.js.map +1 -1
  158. package/dist/es/standards-sdk.es128.js +192 -162
  159. package/dist/es/standards-sdk.es128.js.map +1 -1
  160. package/dist/es/standards-sdk.es129.js +61 -164
  161. package/dist/es/standards-sdk.es129.js.map +1 -1
  162. package/dist/es/standards-sdk.es13.js +200 -60
  163. package/dist/es/standards-sdk.es13.js.map +1 -1
  164. package/dist/es/standards-sdk.es130.js +102 -85
  165. package/dist/es/standards-sdk.es130.js.map +1 -1
  166. package/dist/es/standards-sdk.es131.js +222 -96
  167. package/dist/es/standards-sdk.es131.js.map +1 -1
  168. package/dist/es/standards-sdk.es132.js +153 -220
  169. package/dist/es/standards-sdk.es132.js.map +1 -1
  170. package/dist/es/standards-sdk.es133.js +104 -162
  171. package/dist/es/standards-sdk.es133.js.map +1 -1
  172. package/dist/es/standards-sdk.es134.js +296 -92
  173. package/dist/es/standards-sdk.es134.js.map +1 -1
  174. package/dist/es/standards-sdk.es135.js +432 -294
  175. package/dist/es/standards-sdk.es135.js.map +1 -1
  176. package/dist/es/standards-sdk.es136.js +14 -363
  177. package/dist/es/standards-sdk.es136.js.map +1 -1
  178. package/dist/es/standards-sdk.es137.js +79 -15
  179. package/dist/es/standards-sdk.es137.js.map +1 -1
  180. package/dist/es/standards-sdk.es138.js +79 -59
  181. package/dist/es/standards-sdk.es138.js.map +1 -1
  182. package/dist/es/standards-sdk.es139.js +152 -80
  183. package/dist/es/standards-sdk.es139.js.map +1 -1
  184. package/dist/es/standards-sdk.es14.js +149 -178
  185. package/dist/es/standards-sdk.es14.js.map +1 -1
  186. package/dist/es/standards-sdk.es140.js +7 -159
  187. package/dist/es/standards-sdk.es140.js.map +1 -1
  188. package/dist/es/standards-sdk.es141.js +86 -7
  189. package/dist/es/standards-sdk.es141.js.map +1 -1
  190. package/dist/es/standards-sdk.es142.js +44 -65
  191. package/dist/es/standards-sdk.es142.js.map +1 -1
  192. package/dist/es/standards-sdk.es143.js +30 -65
  193. package/dist/es/standards-sdk.es143.js.map +1 -1
  194. package/dist/es/standards-sdk.es144.js +34 -28
  195. package/dist/es/standards-sdk.es144.js.map +1 -1
  196. package/dist/es/standards-sdk.es145.js +28 -138
  197. package/dist/es/standards-sdk.es145.js.map +1 -1
  198. package/dist/es/standards-sdk.es146.js +133 -37
  199. package/dist/es/standards-sdk.es146.js.map +1 -1
  200. package/dist/es/standards-sdk.es147.js +34 -12281
  201. package/dist/es/standards-sdk.es147.js.map +1 -1
  202. package/dist/es/standards-sdk.es148.js +12284 -12
  203. package/dist/es/standards-sdk.es148.js.map +1 -1
  204. package/dist/es/standards-sdk.es149.js +958 -56
  205. package/dist/es/standards-sdk.es149.js.map +1 -1
  206. package/dist/es/standards-sdk.es15.js +152 -151
  207. package/dist/es/standards-sdk.es15.js.map +1 -1
  208. package/dist/es/standards-sdk.es150.js +48 -74
  209. package/dist/es/standards-sdk.es150.js.map +1 -1
  210. package/dist/es/standards-sdk.es151.js +72 -160
  211. package/dist/es/standards-sdk.es151.js.map +1 -1
  212. package/dist/es/standards-sdk.es152.js +13 -318
  213. package/dist/es/standards-sdk.es152.js.map +1 -1
  214. package/dist/es/standards-sdk.es153.js +120 -294
  215. package/dist/es/standards-sdk.es153.js.map +1 -1
  216. package/dist/es/standards-sdk.es154.js +191 -322
  217. package/dist/es/standards-sdk.es154.js.map +1 -1
  218. package/dist/es/standards-sdk.es155.js +294 -279
  219. package/dist/es/standards-sdk.es155.js.map +1 -1
  220. package/dist/es/standards-sdk.es156.js +440 -63
  221. package/dist/es/standards-sdk.es156.js.map +1 -1
  222. package/dist/es/standards-sdk.es157.js +331 -871
  223. package/dist/es/standards-sdk.es157.js.map +1 -1
  224. package/dist/es/standards-sdk.es158.js +68 -231
  225. package/dist/es/standards-sdk.es158.js.map +1 -1
  226. package/dist/es/standards-sdk.es159.js +218 -223
  227. package/dist/es/standards-sdk.es159.js.map +1 -1
  228. package/dist/es/standards-sdk.es16.js +917 -136
  229. package/dist/es/standards-sdk.es16.js.map +1 -1
  230. package/dist/es/standards-sdk.es160.js +247 -0
  231. package/dist/es/standards-sdk.es160.js.map +1 -0
  232. package/dist/es/standards-sdk.es17.js +23 -944
  233. package/dist/es/standards-sdk.es17.js.map +1 -1
  234. package/dist/es/standards-sdk.es18.js +2422 -24
  235. package/dist/es/standards-sdk.es18.js.map +1 -1
  236. package/dist/es/standards-sdk.es19.js +817 -2071
  237. package/dist/es/standards-sdk.es19.js.map +1 -1
  238. package/dist/es/standards-sdk.es2.js +654 -189
  239. package/dist/es/standards-sdk.es2.js.map +1 -1
  240. package/dist/es/standards-sdk.es20.js +205 -1091
  241. package/dist/es/standards-sdk.es20.js.map +1 -1
  242. package/dist/es/standards-sdk.es21.js +858 -221
  243. package/dist/es/standards-sdk.es21.js.map +1 -1
  244. package/dist/es/standards-sdk.es22.js +179 -903
  245. package/dist/es/standards-sdk.es22.js.map +1 -1
  246. package/dist/es/standards-sdk.es23.js +164 -179
  247. package/dist/es/standards-sdk.es23.js.map +1 -1
  248. package/dist/es/standards-sdk.es24.js +62 -118
  249. package/dist/es/standards-sdk.es24.js.map +1 -1
  250. package/dist/es/standards-sdk.es25.js +377 -52
  251. package/dist/es/standards-sdk.es25.js.map +1 -1
  252. package/dist/es/standards-sdk.es26.js +36 -394
  253. package/dist/es/standards-sdk.es26.js.map +1 -1
  254. package/dist/es/standards-sdk.es27.js +901 -50
  255. package/dist/es/standards-sdk.es27.js.map +1 -1
  256. package/dist/es/standards-sdk.es28.js +134 -902
  257. package/dist/es/standards-sdk.es28.js.map +1 -1
  258. package/dist/es/standards-sdk.es29.js +7 -134
  259. package/dist/es/standards-sdk.es29.js.map +1 -1
  260. package/dist/es/standards-sdk.es3.js +63 -680
  261. package/dist/es/standards-sdk.es3.js.map +1 -1
  262. package/dist/es/standards-sdk.es30.js +344 -7
  263. package/dist/es/standards-sdk.es30.js.map +1 -1
  264. package/dist/es/standards-sdk.es31.js +302 -287
  265. package/dist/es/standards-sdk.es31.js.map +1 -1
  266. package/dist/es/standards-sdk.es32.js +94 -322
  267. package/dist/es/standards-sdk.es32.js.map +1 -1
  268. package/dist/es/standards-sdk.es33.js +458 -101
  269. package/dist/es/standards-sdk.es33.js.map +1 -1
  270. package/dist/es/standards-sdk.es34.js +132 -451
  271. package/dist/es/standards-sdk.es34.js.map +1 -1
  272. package/dist/es/standards-sdk.es35.js +216 -130
  273. package/dist/es/standards-sdk.es35.js.map +1 -1
  274. package/dist/es/standards-sdk.es36.js +273 -195
  275. package/dist/es/standards-sdk.es36.js.map +1 -1
  276. package/dist/es/standards-sdk.es37.js +148 -87
  277. package/dist/es/standards-sdk.es37.js.map +1 -1
  278. package/dist/es/standards-sdk.es38.js +183 -320
  279. package/dist/es/standards-sdk.es38.js.map +1 -1
  280. package/dist/es/standards-sdk.es39.js +238 -161
  281. package/dist/es/standards-sdk.es39.js.map +1 -1
  282. package/dist/es/standards-sdk.es4.js +425 -63
  283. package/dist/es/standards-sdk.es4.js.map +1 -1
  284. package/dist/es/standards-sdk.es40.js +136 -254
  285. package/dist/es/standards-sdk.es40.js.map +1 -1
  286. package/dist/es/standards-sdk.es41.js +225 -176
  287. package/dist/es/standards-sdk.es41.js.map +1 -1
  288. package/dist/es/standards-sdk.es42.js +199 -261
  289. package/dist/es/standards-sdk.es42.js.map +1 -1
  290. package/dist/es/standards-sdk.es43.js +237 -199
  291. package/dist/es/standards-sdk.es43.js.map +1 -1
  292. package/dist/es/standards-sdk.es44.js +209 -201
  293. package/dist/es/standards-sdk.es44.js.map +1 -1
  294. package/dist/es/standards-sdk.es45.js +305 -201
  295. package/dist/es/standards-sdk.es45.js.map +1 -1
  296. package/dist/es/standards-sdk.es46.js +371 -261
  297. package/dist/es/standards-sdk.es46.js.map +1 -1
  298. package/dist/es/standards-sdk.es47.js +316 -371
  299. package/dist/es/standards-sdk.es47.js.map +1 -1
  300. package/dist/es/standards-sdk.es48.js +404 -336
  301. package/dist/es/standards-sdk.es48.js.map +1 -1
  302. package/dist/es/standards-sdk.es49.js +83 -449
  303. package/dist/es/standards-sdk.es49.js.map +1 -1
  304. package/dist/es/standards-sdk.es5.js +232 -354
  305. package/dist/es/standards-sdk.es5.js.map +1 -1
  306. package/dist/es/standards-sdk.es50.js +179 -89
  307. package/dist/es/standards-sdk.es50.js.map +1 -1
  308. package/dist/es/standards-sdk.es51.js +231 -165
  309. package/dist/es/standards-sdk.es51.js.map +1 -1
  310. package/dist/es/standards-sdk.es52.js +25 -262
  311. package/dist/es/standards-sdk.es52.js.map +1 -1
  312. package/dist/es/standards-sdk.es53.js +56 -26
  313. package/dist/es/standards-sdk.es53.js.map +1 -1
  314. package/dist/es/standards-sdk.es54.js +12 -57
  315. package/dist/es/standards-sdk.es54.js.map +1 -1
  316. package/dist/es/standards-sdk.es55.js +49 -12
  317. package/dist/es/standards-sdk.es55.js.map +1 -1
  318. package/dist/es/standards-sdk.es56.js +115 -43
  319. package/dist/es/standards-sdk.es56.js.map +1 -1
  320. package/dist/es/standards-sdk.es57.js +42 -115
  321. package/dist/es/standards-sdk.es57.js.map +1 -1
  322. package/dist/es/standards-sdk.es58.js +52 -43
  323. package/dist/es/standards-sdk.es58.js.map +1 -1
  324. package/dist/es/standards-sdk.es59.js +36 -50
  325. package/dist/es/standards-sdk.es59.js.map +1 -1
  326. package/dist/es/standards-sdk.es6.js +125 -246
  327. package/dist/es/standards-sdk.es6.js.map +1 -1
  328. package/dist/es/standards-sdk.es60.js +207 -39
  329. package/dist/es/standards-sdk.es60.js.map +1 -1
  330. package/dist/es/standards-sdk.es61.js +24 -200
  331. package/dist/es/standards-sdk.es61.js.map +1 -1
  332. package/dist/es/standards-sdk.es62.js +87 -25
  333. package/dist/es/standards-sdk.es62.js.map +1 -1
  334. package/dist/es/standards-sdk.es63.js +3 -51
  335. package/dist/es/standards-sdk.es63.js.map +1 -1
  336. package/dist/es/standards-sdk.es64.js +100 -3
  337. package/dist/es/standards-sdk.es64.js.map +1 -1
  338. package/dist/es/standards-sdk.es65.js +61 -62
  339. package/dist/es/standards-sdk.es65.js.map +1 -1
  340. package/dist/es/standards-sdk.es66.js +17 -98
  341. package/dist/es/standards-sdk.es66.js.map +1 -1
  342. package/dist/es/standards-sdk.es67.js +77 -19
  343. package/dist/es/standards-sdk.es67.js.map +1 -1
  344. package/dist/es/standards-sdk.es68.js +458 -77
  345. package/dist/es/standards-sdk.es68.js.map +1 -1
  346. package/dist/es/standards-sdk.es69.js +106 -240
  347. package/dist/es/standards-sdk.es69.js.map +1 -1
  348. package/dist/es/standards-sdk.es7.js +28 -183
  349. package/dist/es/standards-sdk.es7.js.map +1 -1
  350. package/dist/es/standards-sdk.es70.js +170 -286
  351. package/dist/es/standards-sdk.es70.js.map +1 -1
  352. package/dist/es/standards-sdk.es71.js +71 -207
  353. package/dist/es/standards-sdk.es71.js.map +1 -1
  354. package/dist/es/standards-sdk.es72.js +71 -72
  355. package/dist/es/standards-sdk.es72.js.map +1 -1
  356. package/dist/es/standards-sdk.es73.js +143 -71
  357. package/dist/es/standards-sdk.es73.js.map +1 -1
  358. package/dist/es/standards-sdk.es74.js +62 -136
  359. package/dist/es/standards-sdk.es74.js.map +1 -1
  360. package/dist/es/standards-sdk.es75.js +380 -45
  361. package/dist/es/standards-sdk.es75.js.map +1 -1
  362. package/dist/es/standards-sdk.es76.js +222 -130
  363. package/dist/es/standards-sdk.es76.js.map +1 -1
  364. package/dist/es/standards-sdk.es77.js +320 -444
  365. package/dist/es/standards-sdk.es77.js.map +1 -1
  366. package/dist/es/standards-sdk.es78.js +88 -370
  367. package/dist/es/standards-sdk.es78.js.map +1 -1
  368. package/dist/es/standards-sdk.es79.js +125 -89
  369. package/dist/es/standards-sdk.es79.js.map +1 -1
  370. package/dist/es/standards-sdk.es8.js +80 -29
  371. package/dist/es/standards-sdk.es8.js.map +1 -1
  372. package/dist/es/standards-sdk.es80.js +8 -125
  373. package/dist/es/standards-sdk.es80.js.map +1 -1
  374. package/dist/es/standards-sdk.es81.js +45 -6
  375. package/dist/es/standards-sdk.es81.js.map +1 -1
  376. package/dist/es/standards-sdk.es82.js +98 -44
  377. package/dist/es/standards-sdk.es82.js.map +1 -1
  378. package/dist/es/standards-sdk.es83.js +331 -84
  379. package/dist/es/standards-sdk.es83.js.map +1 -1
  380. package/dist/es/standards-sdk.es84.js +93 -160
  381. package/dist/es/standards-sdk.es84.js.map +1 -1
  382. package/dist/es/standards-sdk.es85.js +55 -275
  383. package/dist/es/standards-sdk.es85.js.map +1 -1
  384. package/dist/es/standards-sdk.es86.js +43 -55
  385. package/dist/es/standards-sdk.es86.js.map +1 -1
  386. package/dist/es/standards-sdk.es87.js +145 -22
  387. package/dist/es/standards-sdk.es87.js.map +1 -1
  388. package/dist/es/standards-sdk.es88.js +34 -47
  389. package/dist/es/standards-sdk.es88.js.map +1 -1
  390. package/dist/es/standards-sdk.es89.js +22 -57
  391. package/dist/es/standards-sdk.es89.js.map +1 -1
  392. package/dist/es/standards-sdk.es9.js +104 -80
  393. package/dist/es/standards-sdk.es9.js.map +1 -1
  394. package/dist/es/standards-sdk.es90.js +23 -28
  395. package/dist/es/standards-sdk.es90.js.map +1 -1
  396. package/dist/es/standards-sdk.es91.js +238 -23
  397. package/dist/es/standards-sdk.es91.js.map +1 -1
  398. package/dist/es/standards-sdk.es92.js +265 -152
  399. package/dist/es/standards-sdk.es92.js.map +1 -1
  400. package/dist/es/standards-sdk.es93.js +95 -68
  401. package/dist/es/standards-sdk.es93.js.map +1 -1
  402. package/dist/es/standards-sdk.es94.js +124 -136
  403. package/dist/es/standards-sdk.es94.js.map +1 -1
  404. package/dist/es/standards-sdk.es95.js +42 -138
  405. package/dist/es/standards-sdk.es95.js.map +1 -1
  406. package/dist/es/standards-sdk.es96.js +259 -42
  407. package/dist/es/standards-sdk.es96.js.map +1 -1
  408. package/dist/es/standards-sdk.es97.js +82 -243
  409. package/dist/es/standards-sdk.es97.js.map +1 -1
  410. package/dist/es/standards-sdk.es98.js +48 -47
  411. package/dist/es/standards-sdk.es98.js.map +1 -1
  412. package/dist/es/standards-sdk.es99.js +29 -100
  413. package/dist/es/standards-sdk.es99.js.map +1 -1
  414. package/dist/es/utils/crypto-abstraction.d.ts.map +1 -1
  415. package/dist/es/utils/crypto-env.d.ts.map +1 -1
  416. package/dist/es/utils/dynamic-import.d.ts +5 -1
  417. package/dist/es/utils/dynamic-import.d.ts.map +1 -1
  418. package/dist/es/utils/hash-adapter.d.ts.map +1 -1
  419. package/package.json +8 -7
  420. package/dist/cjs/patches/topic-autorenew-patch.d.ts +0 -2
  421. package/dist/cjs/patches/topic-autorenew-patch.d.ts.map +0 -1
  422. package/dist/es/patches/topic-autorenew-patch.d.ts +0 -2
  423. package/dist/es/patches/topic-autorenew-patch.d.ts.map +0 -1
@@ -1,211 +1,1570 @@
1
- import { InscriptionSDK } from "./standards-sdk.es147.js";
2
- class QuoteCache {
3
- constructor() {
4
- this.cache = /* @__PURE__ */ new Map();
5
- this.maxSize = 100;
6
- this.defaultTtlMs = 5 * 60 * 1e3;
1
+ import { PublicKey, Timestamp, AccountId } from "@hashgraph/sdk";
2
+ import axios from "axios";
3
+ import { Logger } from "./standards-sdk.es105.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"
18
+ });
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
+ }
7
26
  }
8
- // 5 minutes
9
27
  /**
10
- * Generate cache key from input parameters
28
+ * Configures the retry mechanism for API requests.
29
+ * @param config The retry configuration.
11
30
  */
12
- generateKey(key) {
13
- return `${key.inputHash}-${key.clientConfigHash}-${key.optionsHash}`;
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
+ );
14
39
  }
15
40
  /**
16
- * Hash object to string for cache key
41
+ * Updates the mirror node configuration.
42
+ * @param config The new mirror node configuration.
17
43
  */
18
- hashObject(obj) {
19
- return Buffer.from(JSON.stringify(obj)).toString("base64").slice(0, 16);
44
+ configureMirrorNode(config) {
45
+ if (config.customUrl) {
46
+ this.baseUrl = config.customUrl;
47
+ this.logger.info(`Updated mirror node URL: ${config.customUrl}`);
48
+ }
49
+ if (config.apiKey) {
50
+ this.apiKey = config.apiKey;
51
+ this.logger.info("Updated API key for mirror node requests");
52
+ }
53
+ if (config.headers) {
54
+ this.customHeaders = { ...this.customHeaders, ...config.headers };
55
+ this.logger.info("Updated custom headers for mirror node requests");
56
+ }
20
57
  }
21
58
  /**
22
- * Create cache key from parameters
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
23
62
  */
24
- createCacheKey(input, clientConfig, options) {
25
- return {
26
- inputHash: this.hashObject(input),
27
- clientConfigHash: this.hashObject({
28
- accountId: clientConfig.accountId,
29
- network: clientConfig.network
30
- }),
31
- optionsHash: this.hashObject({
32
- mode: options.mode,
33
- apiKey: options.apiKey ? "present" : "absent",
34
- network: options.network,
35
- metadata: options.metadata
36
- })
37
- };
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}`;
38
69
  }
39
70
  /**
40
- * Get cached quote if available and not expired
71
+ * Returns the base URL for the Hedera mirror node based on the network type
72
+ * @returns The mirror node base URL
73
+ * @private
41
74
  */
42
- get(key) {
43
- const cacheKey = this.generateKey(key);
44
- const entry = this.cache.get(cacheKey);
45
- if (!entry) {
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
+ );
95
+ }
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}`
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
+ );
46
126
  return null;
47
127
  }
48
- const now = Date.now();
49
- if (now - entry.timestamp > entry.ttlMs) {
50
- this.cache.delete(cacheKey);
128
+ }
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;
164
+ }
165
+ }
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);
51
185
  return null;
52
186
  }
53
- this.cache.delete(cacheKey);
54
- this.cache.set(cacheKey, entry);
55
- return entry.quote;
56
187
  }
57
188
  /**
58
- * Store quote in cache
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.
59
193
  */
60
- set(key, quote, ttlMs = this.defaultTtlMs) {
61
- const cacheKey = this.generateKey(key);
62
- if (this.cache.size >= this.maxSize) {
63
- const firstKey = this.cache.keys().next().value;
64
- if (firstKey) {
65
- this.cache.delete(firstKey);
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;
66
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;
67
211
  }
68
- this.cache.set(cacheKey, {
69
- quote,
70
- timestamp: Date.now(),
71
- ttlMs
72
- });
73
212
  }
74
213
  /**
75
- * Clear all cached entries
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
+ }
241
+ }
242
+ const queryString = params.toString();
243
+ if (queryString) {
244
+ endpoint += `?${queryString}`;
245
+ }
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
+ }
309
+ }
310
+ return messages;
311
+ }
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.
76
317
  */
77
- clear() {
78
- this.cache.clear();
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
+ }
79
336
  }
80
- }
81
- class SDKCache {
82
- constructor() {
83
- this.cache = /* @__PURE__ */ new Map();
84
- this.maxSize = 10;
85
- this.defaultTtlMs = 30 * 60 * 1e3;
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
+ }
404
+ }
405
+ }
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;
423
+ }
424
+ }
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}`
448
+ );
449
+ return null;
450
+ }
451
+ }
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
+ }
86
477
  }
87
- // 30 minutes
88
478
  /**
89
- * Generate config key for SDK instance
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.
90
483
  */
91
- generateConfigKey(config) {
92
- return Buffer.from(JSON.stringify(config)).toString("base64");
484
+ async getTransaction(transactionIdOrHash) {
485
+ this.logger.info(
486
+ `Getting transaction details for ID/hash: ${transactionIdOrHash}`
487
+ );
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;
507
+ }
93
508
  }
94
509
  /**
95
- * Get cached SDK instance
510
+ * Private helper to make GET requests with retry logic using Axios.
96
511
  */
97
- get(config) {
98
- const configKey = this.generateConfigKey(config);
99
- const entry = this.cache.get(configKey);
100
- if (!entry) {
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
+ };
529
+ }
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
+ }
556
+ }
557
+ throw new Error(
558
+ `Failed to fetch data from ${url} after ${this.maxRetries} attempts.`
559
+ );
560
+ }
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);
581
+ }
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);
622
+ }
623
+ }
624
+ throw new Error(
625
+ `Failed to fetch data from ${url} after ${this.maxRetries} attempts.`
626
+ );
627
+ }
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;
640
+ }
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
+ }
651
+ }
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
+ )}`
666
+ );
667
+ let nextUrl = `/api/v1/topics/${topicId}/messages`;
668
+ const params = new URLSearchParams();
669
+ if (options?.limit) {
670
+ params.append("limit", options.limit.toString());
671
+ }
672
+ if (options?.sequenceNumber) {
673
+ params.append("sequencenumber", options.sequenceNumber);
674
+ }
675
+ if (options?.startTime) {
676
+ params.append("timestamp", `gte:${options.startTime}`);
677
+ }
678
+ if (options?.endTime) {
679
+ params.append("timestamp", `lt:${options.endTime}`);
680
+ }
681
+ if (options?.order) {
682
+ params.append("order", options.order);
683
+ }
684
+ const queryString = params.toString();
685
+ if (queryString) {
686
+ nextUrl += `?${queryString}`;
687
+ }
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
+ }
743
+ }
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
+ );
101
753
  return null;
102
754
  }
103
- const now = Date.now();
104
- if (now - entry.timestamp > this.defaultTtlMs) {
105
- this.cache.delete(configKey);
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
+ );
106
785
  return null;
107
786
  }
108
- return entry.sdk;
109
787
  }
110
788
  /**
111
- * Store SDK instance in cache
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.
112
792
  */
113
- set(config, sdk) {
114
- const configKey = this.generateConfigKey(config);
115
- if (this.cache.size >= this.maxSize) {
116
- const firstKey = this.cache.keys().next().value;
117
- if (firstKey) {
118
- this.cache.delete(firstKey);
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}`;
820
+ }
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);
847
+ }
848
+ endpoint = response.links?.next || "";
849
+ if (!endpoint) break;
119
850
  }
851
+ return allNfts;
852
+ } catch (error) {
853
+ this.logger.error(
854
+ `Error fetching NFTs for account ${accountId}: ${error.message}`
855
+ );
856
+ return null;
120
857
  }
121
- this.cache.set(configKey, {
122
- sdk,
123
- timestamp: Date.now(),
124
- config: configKey
125
- });
126
858
  }
127
859
  /**
128
- * Clear all cached SDK instances
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.
129
865
  */
130
- clear() {
131
- this.cache.clear();
866
+ async validateNFTOwnership(accountId, tokenId, serialNumber) {
867
+ this.logger.info(
868
+ `Validating ownership of NFT ${tokenId} SN ${serialNumber} for account ${accountId}`
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
+ }
132
883
  }
133
- }
134
- const quoteCache = new QuoteCache();
135
- const sdkCache = new SDKCache();
136
- async function getOrCreateSDK(clientConfig, options, existingSDK) {
137
- if (existingSDK) {
138
- return existingSDK;
139
- }
140
- const connectionMode = options.connectionMode ?? "auto";
141
- const cacheConfig = {
142
- apiKey: options.apiKey,
143
- accountId: clientConfig.accountId,
144
- network: clientConfig.network || "mainnet",
145
- authType: options.apiKey ? "api" : "server",
146
- connectionMode
147
- };
148
- const cachedSDK = sdkCache.get(cacheConfig);
149
- if (cachedSDK) {
150
- return cachedSDK;
151
- }
152
- let sdk;
153
- if (options.apiKey) {
154
- sdk = new InscriptionSDK({
155
- apiKey: options.apiKey,
156
- network: clientConfig.network || "mainnet",
157
- connectionMode
158
- });
159
- } else {
160
- sdk = await InscriptionSDK.createWithAuth({
161
- type: "server",
162
- accountId: clientConfig.accountId,
163
- privateKey: typeof clientConfig.privateKey === "string" ? clientConfig.privateKey : clientConfig.privateKey.toString(),
164
- network: clientConfig.network || "mainnet",
165
- connectionMode
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}`
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
+ }
166
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
+ }
167
935
  }
168
- sdkCache.set(cacheConfig, sdk);
169
- return sdk;
170
- }
171
- function getCachedQuote(input, clientConfig, options) {
172
- const cacheKey = quoteCache.createCacheKey(input, clientConfig, options);
173
- return quoteCache.get(cacheKey);
174
- }
175
- function cacheQuote(input, clientConfig, options, quote) {
176
- const cacheKey = quoteCache.createCacheKey(input, clientConfig, options);
177
- const quoteTtlMs = 10 * 60 * 1e3;
178
- quoteCache.set(cacheKey, quote, quoteTtlMs);
179
- }
180
- function validateQuoteParameters(input, clientConfig, options) {
181
- if (!input || typeof input !== "object" || !("type" in input)) {
182
- throw new Error("Invalid inscription input: type is required");
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}`
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
+ }
976
+ }
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}`
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
+ }
1017
+ }
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
+ }
1050
+ }
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
+ }
1069
+ }
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
+ }
1099
+ }
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
+ }
183
1121
  }
184
- if (!clientConfig || !clientConfig.accountId) {
185
- throw new Error("Invalid client config: accountId is required");
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
+ }
1166
+ }
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
+ }
1188
+ }
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}`
1198
+ );
1199
+ let url = `/api/v1/contracts/${contractIdOrAddress}/results`;
1200
+ const params = new URLSearchParams();
1201
+ if (options?.blockHash) {
1202
+ params.append("block.hash", options.blockHash);
1203
+ }
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}`;
1228
+ }
1229
+ try {
1230
+ const response = await this._requestWithRetry(url);
1231
+ return response.results || [];
1232
+ } catch (error) {
1233
+ this.logger.error(
1234
+ `Error fetching contract results for ${contractIdOrAddress}: ${error.message}`
1235
+ );
1236
+ return null;
1237
+ }
1238
+ }
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
+ }
1265
+ try {
1266
+ const response = await this._requestWithRetry(url);
1267
+ return response.state || [];
1268
+ } catch (error) {
1269
+ this.logger.error(
1270
+ `Error fetching contract state for ${contractIdOrAddress}: ${error.message}`
1271
+ );
1272
+ return null;
1273
+ }
186
1274
  }
187
- if (!options) {
188
- throw new Error("Options are required");
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);
1287
+ }
1288
+ if (options?.limit) {
1289
+ params.append("limit", options.limit.toString());
1290
+ }
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;
1306
+ }
189
1307
  }
190
- if (options.mode === "hashinal") {
191
- if (!options.metadata) {
192
- throw new Error("Hashinal mode requires metadata");
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);
1337
+ }
1338
+ if (options?.topic3) {
1339
+ params.append("topic3", options.topic3);
193
1340
  }
194
- const requiredFields = ["name", "creator", "description", "type"];
195
- const missingFields = requiredFields.filter(
196
- (field) => !options.metadata || !options.metadata[field]
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;
1354
+ }
1355
+ }
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}`
197
1365
  );
198
- if (missingFields.length > 0) {
199
- throw new Error(
200
- `Missing required Hashinal metadata fields: ${missingFields.join(", ")}`
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);
1388
+ }
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;
1404
+ }
1405
+ }
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}`
201
1421
  );
1422
+ return null;
1423
+ }
1424
+ }
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
+ );
1458
+ return null;
1459
+ }
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}`);
1473
+ return null;
1474
+ }
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}`);
1492
+ return null;
1493
+ }
1494
+ }
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;
1512
+ }
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}`;
1524
+ }
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;
1531
+ }
1532
+ }
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());
1545
+ }
1546
+ if (options?.memory !== void 0) {
1547
+ params.append("memory", options.memory.toString());
1548
+ }
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;
202
1564
  }
203
1565
  }
204
1566
  }
205
1567
  export {
206
- cacheQuote,
207
- getCachedQuote,
208
- getOrCreateSDK,
209
- validateQuoteParameters
1568
+ HederaMirrorNode
210
1569
  };
211
1570
  //# sourceMappingURL=standards-sdk.es126.js.map