@hashgraphonline/standards-sdk 0.0.103 → 0.0.105

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 (215) hide show
  1. package/dist/es/services/mirror-node.d.ts +1 -1
  2. package/dist/es/services/mirror-node.d.ts.map +1 -1
  3. package/dist/es/standards-sdk.es100.js +2 -65
  4. package/dist/es/standards-sdk.es100.js.map +1 -1
  5. package/dist/es/standards-sdk.es101.js +135 -5
  6. package/dist/es/standards-sdk.es101.js.map +1 -1
  7. package/dist/es/standards-sdk.es102.js +170 -13
  8. package/dist/es/standards-sdk.es102.js.map +1 -1
  9. package/dist/es/standards-sdk.es103.js +10 -4
  10. package/dist/es/standards-sdk.es103.js.map +1 -1
  11. package/dist/es/standards-sdk.es104.js +13 -45
  12. package/dist/es/standards-sdk.es104.js.map +1 -1
  13. package/dist/es/standards-sdk.es105.js +32 -2
  14. package/dist/es/standards-sdk.es105.js.map +1 -1
  15. package/dist/es/standards-sdk.es106.js +14 -135
  16. package/dist/es/standards-sdk.es106.js.map +1 -1
  17. package/dist/es/standards-sdk.es107.js +4 -172
  18. package/dist/es/standards-sdk.es107.js.map +1 -1
  19. package/dist/es/standards-sdk.es108.js +4 -13
  20. package/dist/es/standards-sdk.es108.js.map +1 -1
  21. package/dist/es/standards-sdk.es109.js +16 -13
  22. package/dist/es/standards-sdk.es109.js.map +1 -1
  23. package/dist/es/standards-sdk.es110.js +4 -31
  24. package/dist/es/standards-sdk.es110.js.map +1 -1
  25. package/dist/es/standards-sdk.es111.js +39 -15
  26. package/dist/es/standards-sdk.es111.js.map +1 -1
  27. package/dist/es/standards-sdk.es112.js +40 -4
  28. package/dist/es/standards-sdk.es112.js.map +1 -1
  29. package/dist/es/standards-sdk.es113.js +37 -4
  30. package/dist/es/standards-sdk.es113.js.map +1 -1
  31. package/dist/es/standards-sdk.es114.js +77 -15
  32. package/dist/es/standards-sdk.es114.js.map +1 -1
  33. package/dist/es/standards-sdk.es115.js +3 -5
  34. package/dist/es/standards-sdk.es115.js.map +1 -1
  35. package/dist/es/standards-sdk.es116.js +2 -39
  36. package/dist/es/standards-sdk.es116.js.map +1 -1
  37. package/dist/es/standards-sdk.es117.js +2 -40
  38. package/dist/es/standards-sdk.es117.js.map +1 -1
  39. package/dist/es/standards-sdk.es118.js +34 -37
  40. package/dist/es/standards-sdk.es118.js.map +1 -1
  41. package/dist/es/standards-sdk.es119.js +29 -74
  42. package/dist/es/standards-sdk.es119.js.map +1 -1
  43. package/dist/es/standards-sdk.es120.js +9 -3
  44. package/dist/es/standards-sdk.es120.js.map +1 -1
  45. package/dist/es/standards-sdk.es121.js +34 -2
  46. package/dist/es/standards-sdk.es121.js.map +1 -1
  47. package/dist/es/standards-sdk.es122.js +10 -2
  48. package/dist/es/standards-sdk.es122.js.map +1 -1
  49. package/dist/es/standards-sdk.es123.js +10 -33
  50. package/dist/es/standards-sdk.es123.js.map +1 -1
  51. package/dist/es/standards-sdk.es124.js +16 -31
  52. package/dist/es/standards-sdk.es124.js.map +1 -1
  53. package/dist/es/standards-sdk.es125.js +6 -9
  54. package/dist/es/standards-sdk.es125.js.map +1 -1
  55. package/dist/es/standards-sdk.es126.js +9 -34
  56. package/dist/es/standards-sdk.es126.js.map +1 -1
  57. package/dist/es/standards-sdk.es15.js +1 -1
  58. package/dist/es/standards-sdk.es18.js +2 -2
  59. package/dist/es/standards-sdk.es19.js +109 -11
  60. package/dist/es/standards-sdk.es19.js.map +1 -1
  61. package/dist/es/standards-sdk.es21.js +5 -13
  62. package/dist/es/standards-sdk.es21.js.map +1 -1
  63. package/dist/es/standards-sdk.es24.js +9 -9
  64. package/dist/es/standards-sdk.es26.js +1 -1
  65. package/dist/es/standards-sdk.es28.js +1 -1
  66. package/dist/es/standards-sdk.es29.js +36 -9
  67. package/dist/es/standards-sdk.es29.js.map +1 -1
  68. package/dist/es/standards-sdk.es30.js +48 -2
  69. package/dist/es/standards-sdk.es30.js.map +1 -1
  70. package/dist/es/standards-sdk.es31.js +5 -36
  71. package/dist/es/standards-sdk.es31.js.map +1 -1
  72. package/dist/es/standards-sdk.es32.js +9 -47
  73. package/dist/es/standards-sdk.es32.js.map +1 -1
  74. package/dist/es/standards-sdk.es33.js +9 -5
  75. package/dist/es/standards-sdk.es33.js.map +1 -1
  76. package/dist/es/standards-sdk.es34.js +2 -10
  77. package/dist/es/standards-sdk.es34.js.map +1 -1
  78. package/dist/es/standards-sdk.es36.js +74 -185
  79. package/dist/es/standards-sdk.es36.js.map +1 -1
  80. package/dist/es/standards-sdk.es37.js +18 -433
  81. package/dist/es/standards-sdk.es37.js.map +1 -1
  82. package/dist/es/standards-sdk.es38.js +144 -21
  83. package/dist/es/standards-sdk.es38.js.map +1 -1
  84. package/dist/es/standards-sdk.es39.js +82 -130
  85. package/dist/es/standards-sdk.es39.js.map +1 -1
  86. package/dist/es/standards-sdk.es40.js +191 -14
  87. package/dist/es/standards-sdk.es40.js.map +1 -1
  88. package/dist/es/standards-sdk.es41.js +430 -21
  89. package/dist/es/standards-sdk.es41.js.map +1 -1
  90. package/dist/es/standards-sdk.es42.js +15 -19
  91. package/dist/es/standards-sdk.es42.js.map +1 -1
  92. package/dist/es/standards-sdk.es43.js +131 -13
  93. package/dist/es/standards-sdk.es43.js.map +1 -1
  94. package/dist/es/standards-sdk.es44.js +9 -35
  95. package/dist/es/standards-sdk.es44.js.map +1 -1
  96. package/dist/es/standards-sdk.es45.js +22 -11
  97. package/dist/es/standards-sdk.es45.js.map +1 -1
  98. package/dist/es/standards-sdk.es46.js +17 -49
  99. package/dist/es/standards-sdk.es46.js.map +1 -1
  100. package/dist/es/standards-sdk.es47.js +15 -1283
  101. package/dist/es/standards-sdk.es47.js.map +1 -1
  102. package/dist/es/standards-sdk.es48.js +38 -142
  103. package/dist/es/standards-sdk.es48.js.map +1 -1
  104. package/dist/es/standards-sdk.es49.js +13 -86
  105. package/dist/es/standards-sdk.es49.js.map +1 -1
  106. package/dist/es/standards-sdk.es50.js +56 -79
  107. package/dist/es/standards-sdk.es50.js.map +1 -1
  108. package/dist/es/standards-sdk.es51.js +1282 -25
  109. package/dist/es/standards-sdk.es51.js.map +1 -1
  110. package/dist/es/standards-sdk.es52.js +31 -5
  111. package/dist/es/standards-sdk.es52.js.map +1 -1
  112. package/dist/es/standards-sdk.es53.js +5 -158
  113. package/dist/es/standards-sdk.es53.js.map +1 -1
  114. package/dist/es/standards-sdk.es54.js +158 -22
  115. package/dist/es/standards-sdk.es54.js.map +1 -1
  116. package/dist/es/standards-sdk.es55.js +2 -2
  117. package/dist/es/standards-sdk.es56.js +162 -131
  118. package/dist/es/standards-sdk.es56.js.map +1 -1
  119. package/dist/es/standards-sdk.es57.js +131 -162
  120. package/dist/es/standards-sdk.es57.js.map +1 -1
  121. package/dist/es/standards-sdk.es58.js +7109 -74
  122. package/dist/es/standards-sdk.es58.js.map +1 -1
  123. package/dist/es/standards-sdk.es59.js +101 -2
  124. package/dist/es/standards-sdk.es59.js.map +1 -1
  125. package/dist/es/standards-sdk.es60.js +2 -16
  126. package/dist/es/standards-sdk.es60.js.map +1 -1
  127. package/dist/es/standards-sdk.es61.js +15 -408
  128. package/dist/es/standards-sdk.es61.js.map +1 -1
  129. package/dist/es/standards-sdk.es62.js +405 -17
  130. package/dist/es/standards-sdk.es62.js.map +1 -1
  131. package/dist/es/standards-sdk.es63.js +19 -25
  132. package/dist/es/standards-sdk.es63.js.map +1 -1
  133. package/dist/es/standards-sdk.es64.js +418 -25
  134. package/dist/es/standards-sdk.es64.js.map +1 -1
  135. package/dist/es/standards-sdk.es65.js +2 -38
  136. package/dist/es/standards-sdk.es65.js.map +1 -1
  137. package/dist/es/standards-sdk.es66.js +120 -2282
  138. package/dist/es/standards-sdk.es66.js.map +1 -1
  139. package/dist/es/standards-sdk.es67.js +22 -159
  140. package/dist/es/standards-sdk.es67.js.map +1 -1
  141. package/dist/es/standards-sdk.es68.js +26 -3
  142. package/dist/es/standards-sdk.es68.js.map +1 -1
  143. package/dist/es/standards-sdk.es69.js +37 -7135
  144. package/dist/es/standards-sdk.es69.js.map +1 -1
  145. package/dist/es/standards-sdk.es7.js +1 -1
  146. package/dist/es/standards-sdk.es70.js +3 -10
  147. package/dist/es/standards-sdk.es70.js.map +1 -1
  148. package/dist/es/standards-sdk.es71.js +2282 -11
  149. package/dist/es/standards-sdk.es71.js.map +1 -1
  150. package/dist/es/standards-sdk.es72.js +160 -14
  151. package/dist/es/standards-sdk.es72.js.map +1 -1
  152. package/dist/es/standards-sdk.es73.js +362 -4
  153. package/dist/es/standards-sdk.es73.js.map +1 -1
  154. package/dist/es/standards-sdk.es74.js +5 -8
  155. package/dist/es/standards-sdk.es74.js.map +1 -1
  156. package/dist/es/standards-sdk.es75.js +160 -400
  157. package/dist/es/standards-sdk.es75.js.map +1 -1
  158. package/dist/es/standards-sdk.es76.js +81 -2
  159. package/dist/es/standards-sdk.es76.js.map +1 -1
  160. package/dist/es/standards-sdk.es77.js +102 -108
  161. package/dist/es/standards-sdk.es77.js.map +1 -1
  162. package/dist/es/standards-sdk.es78.js +51 -3
  163. package/dist/es/standards-sdk.es78.js.map +1 -1
  164. package/dist/es/standards-sdk.es79.js +10 -364
  165. package/dist/es/standards-sdk.es79.js.map +1 -1
  166. package/dist/es/standards-sdk.es80.js +96 -5
  167. package/dist/es/standards-sdk.es80.js.map +1 -1
  168. package/dist/es/standards-sdk.es81.js +3 -178
  169. package/dist/es/standards-sdk.es81.js.map +1 -1
  170. package/dist/es/standards-sdk.es82.js +2 -81
  171. package/dist/es/standards-sdk.es82.js.map +1 -1
  172. package/dist/es/standards-sdk.es83.js +103 -104
  173. package/dist/es/standards-sdk.es83.js.map +1 -1
  174. package/dist/es/standards-sdk.es84.js +71 -49
  175. package/dist/es/standards-sdk.es84.js.map +1 -1
  176. package/dist/es/standards-sdk.es85.js +5 -9
  177. package/dist/es/standards-sdk.es85.js.map +1 -1
  178. package/dist/es/standards-sdk.es86.js +4 -96
  179. package/dist/es/standards-sdk.es86.js.map +1 -1
  180. package/dist/es/standards-sdk.es87.js +220 -3
  181. package/dist/es/standards-sdk.es87.js.map +1 -1
  182. package/dist/es/standards-sdk.es88.js +58 -2
  183. package/dist/es/standards-sdk.es88.js.map +1 -1
  184. package/dist/es/standards-sdk.es89.js +68 -112
  185. package/dist/es/standards-sdk.es89.js.map +1 -1
  186. package/dist/es/standards-sdk.es9.js +1 -1
  187. package/dist/es/standards-sdk.es90.js +3 -73
  188. package/dist/es/standards-sdk.es90.js.map +1 -1
  189. package/dist/es/standards-sdk.es91.js +31 -5
  190. package/dist/es/standards-sdk.es91.js.map +1 -1
  191. package/dist/es/standards-sdk.es92.js +62 -4
  192. package/dist/es/standards-sdk.es92.js.map +1 -1
  193. package/dist/es/standards-sdk.es93.js +46 -217
  194. package/dist/es/standards-sdk.es93.js.map +1 -1
  195. package/dist/es/standards-sdk.es94.js +9 -57
  196. package/dist/es/standards-sdk.es94.js.map +1 -1
  197. package/dist/es/standards-sdk.es95.js +64 -68
  198. package/dist/es/standards-sdk.es95.js.map +1 -1
  199. package/dist/es/standards-sdk.es96.js +6 -32
  200. package/dist/es/standards-sdk.es96.js.map +1 -1
  201. package/dist/es/standards-sdk.es97.js +13 -61
  202. package/dist/es/standards-sdk.es97.js.map +1 -1
  203. package/dist/es/standards-sdk.es98.js +7 -50
  204. package/dist/es/standards-sdk.es98.js.map +1 -1
  205. package/dist/es/standards-sdk.es99.js +45 -10
  206. package/dist/es/standards-sdk.es99.js.map +1 -1
  207. package/dist/es/utils/transaction-parser.d.ts +61 -0
  208. package/dist/es/utils/transaction-parser.d.ts.map +1 -1
  209. package/dist/umd/services/mirror-node.d.ts +1 -1
  210. package/dist/umd/services/mirror-node.d.ts.map +1 -1
  211. package/dist/umd/standards-sdk.umd.js +8 -8
  212. package/dist/umd/standards-sdk.umd.js.map +1 -1
  213. package/dist/umd/utils/transaction-parser.d.ts +61 -0
  214. package/dist/umd/utils/transaction-parser.d.ts.map +1 -1
  215. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es19.js","sources":["../../src/utils/transaction-parser.ts"],"sourcesContent":["import { proto } from '@hashgraph/proto';\nimport { Buffer } from 'buffer';\nimport {\n AccountId,\n ContractId,\n TokenId,\n Hbar,\n HbarUnit,\n Long,\n} from '@hashgraph/sdk';\nimport { ethers } from 'ethers';\n\n/**\n * Types for transaction parsing results\n */\nexport type AccountAmount = {\n accountId: string;\n amount: string;\n isDecimal?: boolean;\n};\n\nexport type TokenAmount = {\n tokenId: string;\n accountId: string;\n amount: number;\n};\n\nexport type ContractCallData = {\n contractId: string;\n gas: number;\n amount: number;\n functionParameters?: string;\n functionName?: string;\n};\n\nexport type TokenMintData = {\n tokenId: string;\n amount: number;\n metadata?: string[];\n};\n\nexport type TokenBurnData = {\n tokenId: string;\n amount: number;\n serialNumbers?: number[];\n};\n\nexport type TokenCreationData = {\n tokenName?: string;\n tokenSymbol?: string;\n initialSupply?: string;\n decimals?: number;\n maxSupply?: string;\n tokenType?: string;\n supplyType?: string;\n memo?: string;\n treasuryAccountId?: string;\n adminKey?: string;\n kycKey?: string;\n freezeKey?: string;\n wipeKey?: string;\n supplyKey?: string;\n feeScheduleKey?: string;\n pauseKey?: string;\n autoRenewAccount?: string;\n autoRenewPeriod?: string; // seconds as string\n};\n\nexport type ParsedTransaction = {\n type: string;\n humanReadableType: string;\n transfers: AccountAmount[];\n tokenTransfers: TokenAmount[];\n memo?: string;\n transactionFee?: string;\n contractCall?: ContractCallData;\n tokenMint?: TokenMintData;\n tokenBurn?: TokenBurnData;\n tokenCreation?: TokenCreationData;\n raw: proto.SchedulableTransactionBody;\n};\n\nexport class TransactionParser {\n /**\n * Parse a base64 encoded transaction body and return structured data\n * @param transactionBodyBase64 - The base64 encoded transaction body\n * @returns The parsed transaction\n */\n static parseTransactionBody(\n transactionBodyBase64: string\n ): ParsedTransaction {\n try {\n const buffer = ethers.decodeBase64(transactionBodyBase64);\n const txBody = proto.SchedulableTransactionBody.decode(buffer);\n\n const transactionType = this.getTransactionType(txBody);\n\n const result: ParsedTransaction = {\n type: transactionType,\n humanReadableType: this.getHumanReadableType(transactionType),\n transfers: [],\n tokenTransfers: [],\n raw: txBody,\n };\n\n if (txBody.memo) {\n result.memo = txBody.memo;\n }\n\n if (txBody.transactionFee) {\n const hbarAmount = Hbar.fromTinybars(\n Long.fromValue(txBody.transactionFee)\n );\n result.transactionFee = hbarAmount.toString(HbarUnit.Hbar);\n }\n\n if (txBody.cryptoTransfer) {\n this.parseCryptoTransfers(txBody.cryptoTransfer, result);\n }\n\n if (txBody.contractCall) {\n this.parseContractCall(txBody.contractCall, result);\n }\n\n if (txBody.tokenMint) {\n this.parseTokenMint(txBody.tokenMint, result);\n }\n\n if (txBody.tokenBurn) {\n this.parseTokenBurn(txBody.tokenBurn, result);\n }\n\n if (txBody.tokenCreation) {\n this.parseTokenCreation(txBody.tokenCreation, result);\n }\n\n return result;\n } catch (error) {\n throw new Error(`Failed to parse transaction body: ${error}`);\n }\n }\n\n /**\n * Parse details from a complete schedule response\n * @param scheduleResponse - The schedule response to parse\n * @returns The parsed transaction\n */\n static parseScheduleResponse(scheduleResponse: {\n transaction_body: string;\n memo?: string;\n }): ParsedTransaction {\n if (!scheduleResponse.transaction_body) {\n throw new Error('Schedule response missing transaction_body');\n }\n\n const parsed = this.parseTransactionBody(scheduleResponse.transaction_body);\n\n if (scheduleResponse.memo) {\n parsed.memo = scheduleResponse.memo;\n }\n\n return parsed;\n }\n\n /**\n * Determine the transaction type\n * @param txBody - The transaction body to determine the type of\n * @returns The type of the transaction\n */\n private static getTransactionType(\n txBody: proto.SchedulableTransactionBody\n ): string {\n let transactionType = 'unknown';\n\n if (txBody.cryptoTransfer) {\n transactionType = 'cryptoTransfer';\n } else if (txBody.cryptoCreateAccount) {\n transactionType = 'cryptoCreateAccount';\n } else if (txBody.cryptoUpdateAccount) {\n transactionType = 'cryptoUpdateAccount';\n } else if (txBody.cryptoApproveAllowance) {\n transactionType = 'cryptoApproveAllowance';\n } else if (txBody.cryptoDeleteAllowance) {\n transactionType = 'cryptoDeleteAllowance';\n } else if (txBody.consensusCreateTopic) {\n transactionType = 'consensusCreateTopic';\n } else if (txBody.consensusUpdateTopic) {\n transactionType = 'consensusUpdateTopic';\n } else if (txBody.consensusSubmitMessage) {\n transactionType = 'consensusSubmitMessage';\n } else if (txBody.consensusDeleteTopic) {\n transactionType = 'consensusDeleteTopic';\n } else if (txBody.fileCreate) {\n transactionType = 'fileCreate';\n } else if (txBody.fileAppend) {\n transactionType = 'fileAppend';\n } else if (txBody.fileUpdate) {\n transactionType = 'fileUpdate';\n } else if (txBody.fileDelete) {\n transactionType = 'fileDelete';\n } else if (txBody.contractCall) {\n transactionType = 'contractCall';\n } else if (txBody.contractCreateInstance) {\n transactionType = 'contractCreate';\n } else if (txBody.contractUpdateInstance) {\n transactionType = 'contractUpdate';\n } else if (txBody.contractDeleteInstance) {\n transactionType = 'contractDelete';\n } else if (txBody.tokenCreation) {\n transactionType = 'tokenCreate';\n } else if (txBody.tokenUpdate) {\n transactionType = 'tokenUpdate';\n } else if (txBody.tokenDeletion) {\n transactionType = 'tokenDelete';\n } else if (txBody.tokenAssociate) {\n transactionType = 'tokenAssociate';\n } else if (txBody.tokenDissociate) {\n transactionType = 'tokenDissociate';\n } else if (txBody.tokenMint) {\n transactionType = 'tokenMint';\n } else if (txBody.tokenBurn) {\n transactionType = 'tokenBurn';\n } else if (txBody.tokenFeeScheduleUpdate) {\n transactionType = 'tokenFeeScheduleUpdate';\n } else if (txBody.tokenFreeze) {\n transactionType = 'tokenFreeze';\n } else if (txBody.tokenUnfreeze) {\n transactionType = 'tokenUnfreeze';\n } else if (txBody.tokenGrantKyc) {\n transactionType = 'tokenGrantKyc';\n } else if (txBody.tokenRevokeKyc) {\n transactionType = 'tokenRevokeKyc';\n } else if (txBody.tokenPause) {\n transactionType = 'tokenPause';\n } else if (txBody.tokenUnpause) {\n transactionType = 'tokenUnpause';\n } else if (txBody.tokenWipe) {\n transactionType = 'tokenWipe';\n } else if (txBody.scheduleDelete) {\n transactionType = 'scheduleDelete';\n }\n\n return transactionType;\n }\n\n /**\n * Convert technical transaction type to human-readable format\n * @param type - The technical transaction type\n * @returns The human-readable transaction type\n */\n private static getHumanReadableType(type: string): string {\n const typeMap: Record<string, string> = {\n cryptoTransfer: 'HBAR Transfer',\n cryptoCreateAccount: 'Create Account',\n cryptoUpdateAccount: 'Update Account',\n cryptoDeleteAccount: 'Delete Account',\n cryptoApproveAllowance: 'Approve Allowance',\n cryptoDeleteAllowance: 'Delete Allowance',\n\n consensusCreateTopic: 'Create Topic',\n consensusUpdateTopic: 'Update Topic',\n consensusSubmitMessage: 'Submit Message',\n consensusDeleteTopic: 'Delete Topic',\n\n fileCreate: 'Create File',\n fileAppend: 'Append File',\n fileUpdate: 'Update File',\n fileDelete: 'Delete File',\n\n contractCall: 'Contract Call',\n contractCreate: 'Create Contract',\n contractUpdate: 'Update Contract',\n contractDelete: 'Delete Contract',\n ethereumTransaction: 'Ethereum Transaction',\n\n tokenCreate: 'Create Token',\n tokenUpdate: 'Update Token',\n tokenDelete: 'Delete Token',\n tokenAssociate: 'Associate Token',\n tokenDissociate: 'Dissociate Token',\n tokenMint: 'Mint Token',\n tokenBurn: 'Burn Token',\n tokenFeeScheduleUpdate: 'Update Token Fee Schedule',\n tokenFreeze: 'Freeze Token',\n tokenUnfreeze: 'Unfreeze Token',\n tokenGrantKyc: 'Grant KYC',\n tokenRevokeKyc: 'Revoke KYC',\n tokenPause: 'Pause Token',\n tokenUnpause: 'Unpause Token',\n tokenWipe: 'Wipe Token',\n\n scheduleCreate: 'Create Schedule',\n scheduleDelete: 'Delete Schedule',\n scheduleSign: 'Sign Schedule',\n\n systemDelete: 'System Delete',\n systemUndelete: 'System Undelete',\n\n unknown: 'Unknown Transaction',\n };\n\n let result: string;\n if (typeMap[type]) {\n result = typeMap[type];\n } else {\n result = 'Unknown Transaction';\n }\n\n return result;\n }\n\n /**\n * Parse crypto transfers from the transaction\n * @param cryptoTransfer - The crypto transfer transaction body\n * @param result - The parsed transaction\n */\n private static parseCryptoTransfers(\n cryptoTransfer: proto.ICryptoTransferTransactionBody,\n result: ParsedTransaction\n ): void {\n if (cryptoTransfer.transfers) {\n if (cryptoTransfer.transfers.accountAmounts) {\n result.transfers = cryptoTransfer.transfers.accountAmounts.map(\n (amount) => {\n const shard = amount.accountID?.shardNum\n ? Long.fromValue(amount.accountID.shardNum).toNumber()\n : 0;\n const realm = amount.accountID?.realmNum\n ? Long.fromValue(amount.accountID.realmNum).toNumber()\n : 0;\n const accountNum = amount.accountID?.accountNum\n ? Long.fromValue(amount.accountID.accountNum).toNumber()\n : 0;\n\n const accountId = AccountId.fromString(\n `${shard}.${realm}.${accountNum}`\n );\n\n const hbarValue = amount.amount\n ? Long.fromValue(amount.amount)\n : Long.ZERO;\n const hbarAmount = Hbar.fromTinybars(hbarValue);\n\n return {\n accountId: accountId.toString(),\n amount: hbarAmount.toString(HbarUnit.Hbar),\n isDecimal: true,\n };\n }\n );\n }\n }\n\n if (cryptoTransfer.tokenTransfers) {\n for (const tokenTransfer of cryptoTransfer.tokenTransfers) {\n const shard = tokenTransfer.token?.shardNum\n ? Long.fromValue(tokenTransfer.token.shardNum).toNumber()\n : 0;\n const realm = tokenTransfer.token?.realmNum\n ? Long.fromValue(tokenTransfer.token.realmNum).toNumber()\n : 0;\n const tokenNum = tokenTransfer.token?.tokenNum\n ? Long.fromValue(tokenTransfer.token.tokenNum).toNumber()\n : 0;\n\n const tokenId = TokenId.fromString(`${shard}.${realm}.${tokenNum}`);\n\n if (tokenTransfer.transfers) {\n for (const transfer of tokenTransfer.transfers) {\n const accShard = transfer.accountID?.shardNum\n ? Long.fromValue(transfer.accountID.shardNum).toNumber()\n : 0;\n const accRealm = transfer.accountID?.realmNum\n ? Long.fromValue(transfer.accountID.realmNum).toNumber()\n : 0;\n const accNum = transfer.accountID?.accountNum\n ? Long.fromValue(transfer.accountID.accountNum).toNumber()\n : 0;\n\n const accountId = AccountId.fromString(\n `${accShard}.${accRealm}.${accNum}`\n );\n\n const tokenAmount = transfer.amount\n ? Long.fromValue(transfer.amount).toNumber()\n : 0;\n\n result.tokenTransfers.push({\n tokenId: tokenId.toString(),\n accountId: accountId.toString(),\n amount: tokenAmount,\n });\n }\n }\n }\n }\n }\n\n /**\n * Parse contract call transaction data\n * @param contractCall - The contract call transaction body\n * @param result - The parsed transaction\n */\n private static parseContractCall(\n contractCall: proto.IContractCallTransactionBody,\n result: ParsedTransaction\n ): void {\n if (contractCall) {\n const shard = contractCall.contractID?.shardNum\n ? Long.fromValue(contractCall.contractID.shardNum).toNumber()\n : 0;\n const realm = contractCall.contractID?.realmNum\n ? Long.fromValue(contractCall.contractID.realmNum).toNumber()\n : 0;\n const contractNum = contractCall.contractID?.contractNum\n ? Long.fromValue(contractCall.contractID.contractNum).toNumber()\n : 0;\n\n const contractId = ContractId.fromString(\n `${shard}.${realm}.${contractNum}`\n );\n\n const gasLimit = contractCall.gas\n ? Long.fromValue(contractCall.gas).toNumber()\n : 0;\n\n let amount = 0;\n if (contractCall.amount) {\n const hbar = Hbar.fromTinybars(Long.fromValue(contractCall.amount));\n amount = parseFloat(hbar.toString(HbarUnit.Hbar));\n }\n\n const functionParameters = contractCall.functionParameters\n ? Buffer.from(contractCall.functionParameters).toString('hex')\n : undefined;\n\n let functionName;\n if (functionParameters && functionParameters.length >= 8) {\n functionName = functionParameters.substring(0, 8);\n }\n\n result.contractCall = {\n contractId: contractId.toString(),\n gas: gasLimit,\n amount: amount,\n functionParameters: functionParameters,\n functionName: functionName,\n };\n }\n }\n\n /**\n * Parse token mint transaction data\n * @param tokenMint - The token mint transaction body\n * @param result - The parsed transaction\n */\n private static parseTokenMint(\n tokenMint: proto.ITokenMintTransactionBody,\n result: ParsedTransaction\n ): void {\n if (tokenMint) {\n const shard = tokenMint.token?.shardNum\n ? Long.fromValue(tokenMint.token.shardNum).toNumber()\n : 0;\n const realm = tokenMint.token?.realmNum\n ? Long.fromValue(tokenMint.token.realmNum).toNumber()\n : 0;\n const tokenNum = tokenMint.token?.tokenNum\n ? Long.fromValue(tokenMint.token.tokenNum).toNumber()\n : 0;\n\n const tokenId = TokenId.fromString(`${shard}.${realm}.${tokenNum}`);\n\n const amount = tokenMint.amount\n ? Long.fromValue(tokenMint.amount).toNumber()\n : 0;\n\n const metadata: string[] = [];\n if (tokenMint.metadata) {\n for (const meta of tokenMint.metadata) {\n if (meta) {\n metadata.push(Buffer.from(meta).toString('base64'));\n }\n }\n }\n\n result.tokenMint = {\n tokenId: tokenId.toString(),\n amount: amount,\n metadata: metadata.length > 0 ? metadata : undefined,\n };\n }\n }\n\n /**\n * Parse token burn transaction data\n * @param tokenBurn - The token burn transaction body\n * @param result - The parsed transaction\n */\n private static parseTokenBurn(\n tokenBurn: proto.ITokenBurnTransactionBody,\n result: ParsedTransaction\n ): void {\n if (tokenBurn) {\n const shard = tokenBurn.token?.shardNum\n ? Long.fromValue(tokenBurn.token.shardNum).toNumber()\n : 0;\n const realm = tokenBurn.token?.realmNum\n ? Long.fromValue(tokenBurn.token.realmNum).toNumber()\n : 0;\n const tokenNum = tokenBurn.token?.tokenNum\n ? Long.fromValue(tokenBurn.token.tokenNum).toNumber()\n : 0;\n\n const tokenId = TokenId.fromString(`${shard}.${realm}.${tokenNum}`);\n\n const amount = tokenBurn.amount\n ? Long.fromValue(tokenBurn.amount).toNumber()\n : 0;\n\n const serialNumbers: number[] = [];\n if (tokenBurn.serialNumbers) {\n for (const serial of tokenBurn.serialNumbers) {\n if (serial) {\n serialNumbers.push(Long.fromValue(serial).toNumber());\n }\n }\n }\n\n result.tokenBurn = {\n tokenId: tokenId.toString(),\n amount: amount,\n serialNumbers: serialNumbers.length > 0 ? serialNumbers : undefined,\n };\n }\n }\n\n /**\n * Parse token creation transaction data\n * @param tokenCreation - The token creation transaction body\n * @param result - The parsed transaction\n */\n private static parseTokenCreation(\n tokenCreation: proto.ITokenCreateTransactionBody,\n result: ParsedTransaction\n ): void {\n if (tokenCreation) {\n const creationData: TokenCreationData = {};\n if (tokenCreation.name) creationData.tokenName = tokenCreation.name;\n if (tokenCreation.symbol) creationData.tokenSymbol = tokenCreation.symbol;\n if (tokenCreation.treasury) {\n const t = tokenCreation.treasury;\n creationData.treasuryAccountId = new AccountId(\n t.shardNum ? Long.fromValue(t.shardNum).toNumber() : 0,\n t.realmNum ? Long.fromValue(t.realmNum).toNumber() : 0,\n t.accountNum ? Long.fromValue(t.accountNum).toNumber() : 0\n ).toString();\n }\n if (tokenCreation.initialSupply) {\n creationData.initialSupply = Long.fromValue(tokenCreation.initialSupply).toString();\n }\n if (tokenCreation.decimals !== undefined && tokenCreation.decimals !== null) {\n creationData.decimals = Long.fromValue(tokenCreation.decimals).toNumber();\n }\n if (tokenCreation.maxSupply) {\n creationData.maxSupply = Long.fromValue(tokenCreation.maxSupply).toString();\n }\n if (tokenCreation.memo) creationData.memo = tokenCreation.memo;\n\n if (tokenCreation.tokenType !== null && tokenCreation.tokenType !== undefined) {\n creationData.tokenType = proto.TokenType[tokenCreation.tokenType];\n }\n if (tokenCreation.supplyType !== null && tokenCreation.supplyType !== undefined) {\n creationData.supplyType = proto.TokenSupplyType[tokenCreation.supplyType];\n }\n\n creationData.adminKey = tokenCreation.adminKey ? 'Present' : 'Not Present';\n creationData.kycKey = tokenCreation.kycKey ? 'Present' : 'Not Present';\n creationData.freezeKey = tokenCreation.freezeKey ? 'Present' : 'Not Present';\n creationData.wipeKey = tokenCreation.wipeKey ? 'Present' : 'Not Present';\n creationData.supplyKey = tokenCreation.supplyKey ? 'Present' : 'Not Present';\n creationData.feeScheduleKey = tokenCreation.feeScheduleKey ? 'Present' : 'Not Present';\n creationData.pauseKey = tokenCreation.pauseKey ? 'Present' : 'Not Present';\n\n if (tokenCreation.autoRenewAccount) {\n const ara = tokenCreation.autoRenewAccount;\n creationData.autoRenewAccount = new AccountId(\n ara.shardNum ? Long.fromValue(ara.shardNum).toNumber() : 0,\n ara.realmNum ? Long.fromValue(ara.realmNum).toNumber() : 0,\n ara.accountNum ? Long.fromValue(ara.accountNum).toNumber() : 0\n ).toString();\n }\n if (tokenCreation.autoRenewPeriod && tokenCreation.autoRenewPeriod.seconds) {\n creationData.autoRenewPeriod = Long.fromValue(tokenCreation.autoRenewPeriod.seconds).toString();\n }\n\n result.tokenCreation = creationData;\n }\n }\n\n /**\n * Get a human-readable summary of the transaction\n * @param parsedTx - The parsed transaction\n * @returns The human-readable summary of the transaction\n */\n static getTransactionSummary(parsedTx: ParsedTransaction): string {\n let summary: string;\n\n if (parsedTx.type === 'cryptoTransfer') {\n const senders = [];\n const receivers = [];\n\n for (const transfer of parsedTx.transfers) {\n const originalAmountFloat = parseFloat(transfer.amount);\n\n let displayStr = transfer.amount;\n if (displayStr.startsWith('-')) {\n displayStr = displayStr.substring(1);\n }\n displayStr = displayStr.replace(/\\s*ℏ$/, '');\n\n if (originalAmountFloat < 0) {\n senders.push(\n `${transfer.accountId} (${displayStr} ℏ)`\n );\n } else if (originalAmountFloat > 0) {\n receivers.push(\n `${transfer.accountId} (${displayStr} ℏ)`\n );\n }\n }\n\n if (senders.length > 0 && receivers.length > 0) {\n summary = `Transfer of HBAR from ${senders.join(\n ', '\n )} to ${receivers.join(', ')}`;\n } else {\n summary = parsedTx.humanReadableType;\n }\n } else if (parsedTx.contractCall) {\n let contractCallSummary = `Contract call to ${parsedTx.contractCall.contractId} with ${parsedTx.contractCall.gas} gas`;\n\n if (parsedTx.contractCall.amount > 0) {\n contractCallSummary += ` and ${parsedTx.contractCall.amount} HBAR`;\n }\n\n if (parsedTx.contractCall.functionName) {\n contractCallSummary += ` calling function ${parsedTx.contractCall.functionName}`;\n }\n\n summary = contractCallSummary;\n } else if (parsedTx.tokenMint) {\n summary = `Mint ${parsedTx.tokenMint.amount} tokens for token ${parsedTx.tokenMint.tokenId}`;\n } else if (parsedTx.tokenBurn) {\n summary = `Burn ${parsedTx.tokenBurn.amount} tokens for token ${parsedTx.tokenBurn.tokenId}`;\n } else if (parsedTx.tokenTransfers.length > 0) {\n const tokenGroups: Record<string, TokenAmount[]> = {};\n\n for (const transfer of parsedTx.tokenTransfers) {\n if (!tokenGroups[transfer.tokenId]) {\n tokenGroups[transfer.tokenId] = [];\n }\n tokenGroups[transfer.tokenId].push(transfer);\n }\n\n const tokenSummaries = [];\n\n for (const [tokenId, transfers] of Object.entries(tokenGroups)) {\n const tokenSenders = [];\n const tokenReceivers = [];\n\n for (const transfer of transfers) {\n const transferAmountValue = parseFloat(transfer.amount.toString());\n if (transferAmountValue < 0) {\n tokenSenders.push(\n `${transfer.accountId} (${Math.abs(transferAmountValue)})`\n );\n } else if (transferAmountValue > 0) {\n tokenReceivers.push(\n `${transfer.accountId} (${transferAmountValue})`\n );\n }\n }\n\n if (tokenSenders.length > 0 && tokenReceivers.length > 0) {\n tokenSummaries.push(\n `Transfer of token ${tokenId} from ${tokenSenders.join(\n ', '\n )} to ${tokenReceivers.join(', ')}`\n );\n }\n }\n\n if (tokenSummaries.length > 0) {\n summary = tokenSummaries.join('; ');\n } else {\n summary = parsedTx.humanReadableType;\n }\n } else {\n summary = parsedTx.humanReadableType;\n }\n\n return summary;\n }\n}\n"],"names":["ethers.decodeBase64","Buffer"],"mappings":"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"}
1
+ {"version":3,"file":"standards-sdk.es19.js","sources":["../../src/utils/transaction-parser.ts"],"sourcesContent":["import { proto } from '@hashgraph/proto';\nimport { Buffer } from 'buffer';\nimport {\n AccountId,\n ContractId,\n TokenId,\n Hbar,\n HbarUnit,\n Long,\n} from '@hashgraph/sdk';\nimport { ethers } from 'ethers';\n\n/**\n * Types for transaction parsing results\n */\nexport type AccountAmount = {\n accountId: string;\n amount: string;\n isDecimal?: boolean;\n};\n\nexport type TokenAmount = {\n tokenId: string;\n accountId: string;\n amount: number;\n};\n\nexport type ContractCallData = {\n contractId: string;\n gas: number;\n amount: number;\n functionParameters?: string;\n functionName?: string;\n};\n\nexport type TokenMintData = {\n tokenId: string;\n amount: number;\n metadata?: string[];\n};\n\nexport type TokenBurnData = {\n tokenId: string;\n amount: number;\n serialNumbers?: number[];\n};\n\nexport type TokenCreationData = {\n tokenName?: string;\n tokenSymbol?: string;\n initialSupply?: string;\n decimals?: number;\n maxSupply?: string;\n tokenType?: string;\n supplyType?: string;\n memo?: string;\n treasuryAccountId?: string;\n adminKey?: string;\n kycKey?: string;\n freezeKey?: string;\n wipeKey?: string;\n supplyKey?: string;\n feeScheduleKey?: string;\n pauseKey?: string;\n autoRenewAccount?: string;\n autoRenewPeriod?: string;\n};\n\nexport type ConsensusCreateTopicData = {\n memo?: string;\n adminKey?: string;\n submitKey?: string;\n autoRenewPeriod?: string;\n autoRenewAccountId?: string;\n};\n\nexport type ConsensusSubmitMessageData = {\n topicId?: string;\n message?: string;\n chunkInfoInitialTransactionID?: string;\n chunkInfoNumber?: number;\n chunkInfoTotal?: number;\n};\n\nexport type CryptoDeleteData = {\n deleteAccountId?: string;\n transferAccountId?: string;\n};\n\nexport type ScheduleCreateData = {\n scheduledTransaction?: ParsedTransaction;\n payerAccountId?: string;\n adminKey?: string;\n memo?: string;\n waitForExpiry?: boolean;\n};\n\nexport type ScheduleSignData = {\n scheduleId?: string;\n};\n\nexport type EthereumTransactionData = {\n ethereumData?: string;\n callDataFileId?: string;\n maxGasAllowanceHbar?: string;\n};\n\nexport type SystemDeleteData = {\n fileId?: string;\n contractId?: string;\n};\n\nexport type SystemUndeleteData = {\n fileId?: string;\n contractId?: string;\n};\n\nexport type ParsedTransaction = {\n type: string;\n humanReadableType: string;\n transfers: AccountAmount[];\n tokenTransfers: TokenAmount[];\n memo?: string;\n transactionFee?: string;\n contractCall?: ContractCallData;\n tokenMint?: TokenMintData;\n tokenBurn?: TokenBurnData;\n tokenCreation?: TokenCreationData;\n consensusCreateTopic?: ConsensusCreateTopicData;\n consensusSubmitMessage?: ConsensusSubmitMessageData;\n cryptoDelete?: CryptoDeleteData;\n scheduleCreate?: ScheduleCreateData;\n scheduleSign?: ScheduleSignData;\n ethereumTransaction?: EthereumTransactionData;\n systemDelete?: SystemDeleteData;\n systemUndelete?: SystemUndeleteData;\n raw: proto.SchedulableTransactionBody;\n};\n\nexport class TransactionParser {\n /**\n * Parse a base64 encoded transaction body and return structured data\n * @param transactionBodyBase64 - The base64 encoded transaction body\n * @returns The parsed transaction\n */\n static parseTransactionBody(\n transactionBodyBase64: string\n ): ParsedTransaction {\n try {\n const buffer = ethers.decodeBase64(transactionBodyBase64);\n const txBody = proto.SchedulableTransactionBody.decode(buffer);\n\n const transactionType = this.getTransactionType(txBody);\n\n const result: ParsedTransaction = {\n type: transactionType,\n humanReadableType: this.getHumanReadableType(transactionType),\n transfers: [],\n tokenTransfers: [],\n raw: txBody,\n };\n\n if (txBody.memo) {\n result.memo = txBody.memo;\n }\n\n if (txBody.transactionFee) {\n const hbarAmount = Hbar.fromTinybars(\n Long.fromValue(txBody.transactionFee)\n );\n result.transactionFee = hbarAmount.toString(HbarUnit.Hbar);\n }\n\n if (txBody.cryptoTransfer) {\n this.parseCryptoTransfers(txBody.cryptoTransfer, result);\n }\n\n if (txBody.contractCall) {\n this.parseContractCall(txBody.contractCall, result);\n }\n\n if (txBody.tokenMint) {\n this.parseTokenMint(txBody.tokenMint, result);\n }\n\n if (txBody.tokenBurn) {\n this.parseTokenBurn(txBody.tokenBurn, result);\n }\n\n if (txBody.tokenCreation) {\n this.parseTokenCreation(txBody.tokenCreation, result);\n }\n\n if (txBody.consensusCreateTopic) {\n this.parseConsensusCreateTopic(txBody.consensusCreateTopic, result);\n }\n\n if (txBody.consensusSubmitMessage) {\n this.parseConsensusSubmitMessage(txBody.consensusSubmitMessage, result);\n }\n\n return result;\n } catch (error) {\n throw new Error(`Failed to parse transaction body: ${error}`);\n }\n }\n\n /**\n * Parse details from a complete schedule response\n * @param scheduleResponse - The schedule response to parse\n * @returns The parsed transaction\n */\n static parseScheduleResponse(scheduleResponse: {\n transaction_body: string;\n memo?: string;\n }): ParsedTransaction {\n if (!scheduleResponse.transaction_body) {\n throw new Error('Schedule response missing transaction_body');\n }\n\n const parsed = this.parseTransactionBody(scheduleResponse.transaction_body);\n\n if (scheduleResponse.memo) {\n parsed.memo = scheduleResponse.memo;\n }\n\n return parsed;\n }\n\n /**\n * Determine the transaction type\n * @param txBody - The transaction body to determine the type of\n * @returns The type of the transaction\n */\n private static getTransactionType(\n txBody: proto.SchedulableTransactionBody\n ): string {\n let transactionType = 'unknown';\n\n if (txBody.cryptoTransfer) {\n transactionType = 'cryptoTransfer';\n } else if (txBody.cryptoCreateAccount) {\n transactionType = 'cryptoCreateAccount';\n } else if (txBody.cryptoUpdateAccount) {\n transactionType = 'cryptoUpdateAccount';\n } else if (txBody.cryptoApproveAllowance) {\n transactionType = 'cryptoApproveAllowance';\n } else if (txBody.cryptoDeleteAllowance) {\n transactionType = 'cryptoDeleteAllowance';\n } else if (txBody.cryptoDelete) {\n transactionType = 'cryptoDelete';\n } else if (txBody.consensusCreateTopic) {\n transactionType = 'consensusCreateTopic';\n } else if (txBody.consensusUpdateTopic) {\n transactionType = 'consensusUpdateTopic';\n } else if (txBody.consensusSubmitMessage) {\n transactionType = 'consensusSubmitMessage';\n } else if (txBody.consensusDeleteTopic) {\n transactionType = 'consensusDeleteTopic';\n } else if (txBody.fileCreate) {\n transactionType = 'fileCreate';\n } else if (txBody.fileAppend) {\n transactionType = 'fileAppend';\n } else if (txBody.fileUpdate) {\n transactionType = 'fileUpdate';\n } else if (txBody.fileDelete) {\n transactionType = 'fileDelete';\n } else if (txBody.contractCall) {\n transactionType = 'contractCall';\n } else if (txBody.contractCreateInstance) {\n transactionType = 'contractCreate';\n } else if (txBody.contractUpdateInstance) {\n transactionType = 'contractUpdate';\n } else if (txBody.contractDeleteInstance) {\n transactionType = 'contractDelete';\n } else if (txBody.tokenCreation) {\n transactionType = 'tokenCreate';\n } else if (txBody.tokenUpdate) {\n transactionType = 'tokenUpdate';\n } else if (txBody.tokenDeletion) {\n transactionType = 'tokenDelete';\n } else if (txBody.tokenAssociate) {\n transactionType = 'tokenAssociate';\n } else if (txBody.tokenDissociate) {\n transactionType = 'tokenDissociate';\n } else if (txBody.tokenMint) {\n transactionType = 'tokenMint';\n } else if (txBody.tokenBurn) {\n transactionType = 'tokenBurn';\n } else if (txBody.tokenFeeScheduleUpdate) {\n transactionType = 'tokenFeeScheduleUpdate';\n } else if (txBody.tokenFreeze) {\n transactionType = 'tokenFreeze';\n } else if (txBody.tokenUnfreeze) {\n transactionType = 'tokenUnfreeze';\n } else if (txBody.tokenGrantKyc) {\n transactionType = 'tokenGrantKyc';\n } else if (txBody.tokenRevokeKyc) {\n transactionType = 'tokenRevokeKyc';\n } else if (txBody.tokenPause) {\n transactionType = 'tokenPause';\n } else if (txBody.tokenUnpause) {\n transactionType = 'tokenUnpause';\n } else if (txBody.tokenWipe) {\n transactionType = 'tokenWipe';\n } else if (txBody.scheduleDelete) {\n transactionType = 'scheduleDelete';\n } else if (txBody.systemDelete) {\n transactionType = 'systemDelete';\n } else if (txBody.systemUndelete) {\n transactionType = 'systemUndelete';\n }\n\n return transactionType;\n }\n\n /**\n * Convert technical transaction type to human-readable format\n * @param type - The technical transaction type\n * @returns The human-readable transaction type\n */\n private static getHumanReadableType(type: string): string {\n const typeMap: Record<string, string> = {\n cryptoTransfer: 'HBAR Transfer',\n cryptoCreateAccount: 'Create Account',\n cryptoUpdateAccount: 'Update Account',\n cryptoDeleteAccount: 'Delete Account',\n cryptoApproveAllowance: 'Approve Allowance',\n cryptoDeleteAllowance: 'Delete Allowance',\n cryptoDelete: 'Delete Account',\n\n consensusCreateTopic: 'Create Topic',\n consensusUpdateTopic: 'Update Topic',\n consensusSubmitMessage: 'Submit Message',\n consensusDeleteTopic: 'Delete Topic',\n\n fileCreate: 'Create File',\n fileAppend: 'Append File',\n fileUpdate: 'Update File',\n fileDelete: 'Delete File',\n\n contractCall: 'Contract Call',\n contractCreate: 'Create Contract',\n contractUpdate: 'Update Contract',\n contractDelete: 'Delete Contract',\n ethereumTransaction: 'Ethereum Transaction',\n\n tokenCreate: 'Create Token',\n tokenUpdate: 'Update Token',\n tokenDelete: 'Delete Token',\n tokenAssociate: 'Associate Token',\n tokenDissociate: 'Dissociate Token',\n tokenMint: 'Mint Token',\n tokenBurn: 'Burn Token',\n tokenFeeScheduleUpdate: 'Update Token Fee Schedule',\n tokenFreeze: 'Freeze Token',\n tokenUnfreeze: 'Unfreeze Token',\n tokenGrantKyc: 'Grant KYC',\n tokenRevokeKyc: 'Revoke KYC',\n tokenPause: 'Pause Token',\n tokenUnpause: 'Unpause Token',\n tokenWipe: 'Wipe Token',\n\n scheduleCreate: 'Create Schedule',\n scheduleDelete: 'Delete Schedule',\n scheduleSign: 'Sign Schedule',\n\n systemDelete: 'System Delete',\n systemUndelete: 'System Undelete',\n\n unknown: 'Unknown Transaction',\n };\n\n let result: string;\n if (typeMap[type]) {\n result = typeMap[type];\n } else {\n result = 'Unknown Transaction';\n }\n\n return result;\n }\n\n /**\n * Parse crypto transfers from the transaction\n * @param cryptoTransfer - The crypto transfer transaction body\n * @param result - The parsed transaction\n */\n private static parseCryptoTransfers(\n cryptoTransfer: proto.ICryptoTransferTransactionBody,\n result: ParsedTransaction\n ): void {\n if (cryptoTransfer.transfers) {\n if (cryptoTransfer.transfers.accountAmounts) {\n result.transfers = cryptoTransfer.transfers.accountAmounts.map(\n (amount) => {\n const shard = amount.accountID?.shardNum\n ? Long.fromValue(amount.accountID.shardNum).toNumber()\n : 0;\n const realm = amount.accountID?.realmNum\n ? Long.fromValue(amount.accountID.realmNum).toNumber()\n : 0;\n const accountNum = amount.accountID?.accountNum\n ? Long.fromValue(amount.accountID.accountNum).toNumber()\n : 0;\n\n const accountId = AccountId.fromString(\n `${shard}.${realm}.${accountNum}`\n );\n\n const hbarValue = amount.amount\n ? Long.fromValue(amount.amount)\n : Long.ZERO;\n const hbarAmount = Hbar.fromTinybars(hbarValue);\n\n return {\n accountId: accountId.toString(),\n amount: hbarAmount.toString(HbarUnit.Hbar),\n isDecimal: true,\n };\n }\n );\n }\n }\n\n if (cryptoTransfer.tokenTransfers) {\n for (const tokenTransfer of cryptoTransfer.tokenTransfers) {\n const shard = tokenTransfer.token?.shardNum\n ? Long.fromValue(tokenTransfer.token.shardNum).toNumber()\n : 0;\n const realm = tokenTransfer.token?.realmNum\n ? Long.fromValue(tokenTransfer.token.realmNum).toNumber()\n : 0;\n const tokenNum = tokenTransfer.token?.tokenNum\n ? Long.fromValue(tokenTransfer.token.tokenNum).toNumber()\n : 0;\n\n const tokenId = TokenId.fromString(`${shard}.${realm}.${tokenNum}`);\n\n if (tokenTransfer.transfers) {\n for (const transfer of tokenTransfer.transfers) {\n const accShard = transfer.accountID?.shardNum\n ? Long.fromValue(transfer.accountID.shardNum).toNumber()\n : 0;\n const accRealm = transfer.accountID?.realmNum\n ? Long.fromValue(transfer.accountID.realmNum).toNumber()\n : 0;\n const accNum = transfer.accountID?.accountNum\n ? Long.fromValue(transfer.accountID.accountNum).toNumber()\n : 0;\n\n const accountId = AccountId.fromString(\n `${accShard}.${accRealm}.${accNum}`\n );\n\n const tokenAmount = transfer.amount\n ? Long.fromValue(transfer.amount).toNumber()\n : 0;\n\n result.tokenTransfers.push({\n tokenId: tokenId.toString(),\n accountId: accountId.toString(),\n amount: tokenAmount,\n });\n }\n }\n }\n }\n }\n\n /**\n * Parse contract call transaction data\n * @param contractCall - The contract call transaction body\n * @param result - The parsed transaction\n */\n private static parseContractCall(\n contractCall: proto.IContractCallTransactionBody,\n result: ParsedTransaction\n ): void {\n if (contractCall) {\n const shard = contractCall.contractID?.shardNum\n ? Long.fromValue(contractCall.contractID.shardNum).toNumber()\n : 0;\n const realm = contractCall.contractID?.realmNum\n ? Long.fromValue(contractCall.contractID.realmNum).toNumber()\n : 0;\n const contractNum = contractCall.contractID?.contractNum\n ? Long.fromValue(contractCall.contractID.contractNum).toNumber()\n : 0;\n\n const contractId = ContractId.fromString(\n `${shard}.${realm}.${contractNum}`\n );\n\n const gasLimit = contractCall.gas\n ? Long.fromValue(contractCall.gas).toNumber()\n : 0;\n\n let amount = 0;\n if (contractCall.amount) {\n const hbar = Hbar.fromTinybars(Long.fromValue(contractCall.amount));\n amount = parseFloat(hbar.toString(HbarUnit.Hbar));\n }\n\n const functionParameters = contractCall.functionParameters\n ? Buffer.from(contractCall.functionParameters).toString('hex')\n : undefined;\n\n let functionName;\n if (functionParameters && functionParameters.length >= 8) {\n functionName = functionParameters.substring(0, 8);\n }\n\n result.contractCall = {\n contractId: contractId.toString(),\n gas: gasLimit,\n amount: amount,\n functionParameters: functionParameters,\n functionName: functionName,\n };\n }\n }\n\n /**\n * Parse token mint transaction data\n * @param tokenMint - The token mint transaction body\n * @param result - The parsed transaction\n */\n private static parseTokenMint(\n tokenMint: proto.ITokenMintTransactionBody,\n result: ParsedTransaction\n ): void {\n if (tokenMint) {\n const shard = tokenMint.token?.shardNum\n ? Long.fromValue(tokenMint.token.shardNum).toNumber()\n : 0;\n const realm = tokenMint.token?.realmNum\n ? Long.fromValue(tokenMint.token.realmNum).toNumber()\n : 0;\n const tokenNum = tokenMint.token?.tokenNum\n ? Long.fromValue(tokenMint.token.tokenNum).toNumber()\n : 0;\n\n const tokenId = TokenId.fromString(`${shard}.${realm}.${tokenNum}`);\n\n const amount = tokenMint.amount\n ? Long.fromValue(tokenMint.amount).toNumber()\n : 0;\n\n const metadata: string[] = [];\n if (tokenMint.metadata) {\n for (const meta of tokenMint.metadata) {\n if (meta) {\n metadata.push(Buffer.from(meta).toString('base64'));\n }\n }\n }\n\n result.tokenMint = {\n tokenId: tokenId.toString(),\n amount: amount,\n metadata: metadata.length > 0 ? metadata : undefined,\n };\n }\n }\n\n /**\n * Parse token burn transaction data\n * @param tokenBurn - The token burn transaction body\n * @param result - The parsed transaction\n */\n private static parseTokenBurn(\n tokenBurn: proto.ITokenBurnTransactionBody,\n result: ParsedTransaction\n ): void {\n if (tokenBurn) {\n const shard = tokenBurn.token?.shardNum\n ? Long.fromValue(tokenBurn.token.shardNum).toNumber()\n : 0;\n const realm = tokenBurn.token?.realmNum\n ? Long.fromValue(tokenBurn.token.realmNum).toNumber()\n : 0;\n const tokenNum = tokenBurn.token?.tokenNum\n ? Long.fromValue(tokenBurn.token.tokenNum).toNumber()\n : 0;\n\n const tokenId = TokenId.fromString(`${shard}.${realm}.${tokenNum}`);\n\n const amount = tokenBurn.amount\n ? Long.fromValue(tokenBurn.amount).toNumber()\n : 0;\n\n const serialNumbers: number[] = [];\n if (tokenBurn.serialNumbers) {\n for (const serial of tokenBurn.serialNumbers) {\n if (serial) {\n serialNumbers.push(Long.fromValue(serial).toNumber());\n }\n }\n }\n\n result.tokenBurn = {\n tokenId: tokenId.toString(),\n amount: amount,\n serialNumbers: serialNumbers.length > 0 ? serialNumbers : undefined,\n };\n }\n }\n\n /**\n * Parse token creation transaction data\n * @param tokenCreation - The token creation transaction body\n * @param result - The parsed transaction\n */\n private static parseTokenCreation(\n tokenCreation: proto.ITokenCreateTransactionBody,\n result: ParsedTransaction\n ): void {\n if (tokenCreation) {\n const creationData: TokenCreationData = {};\n if (tokenCreation.name) creationData.tokenName = tokenCreation.name;\n if (tokenCreation.symbol) creationData.tokenSymbol = tokenCreation.symbol;\n if (tokenCreation.treasury) {\n const t = tokenCreation.treasury;\n creationData.treasuryAccountId = new AccountId(\n t.shardNum ? Long.fromValue(t.shardNum).toNumber() : 0,\n t.realmNum ? Long.fromValue(t.realmNum).toNumber() : 0,\n t.accountNum ? Long.fromValue(t.accountNum).toNumber() : 0\n ).toString();\n }\n if (tokenCreation.initialSupply) {\n creationData.initialSupply = Long.fromValue(\n tokenCreation.initialSupply\n ).toString();\n }\n if (\n tokenCreation.decimals !== undefined &&\n tokenCreation.decimals !== null\n ) {\n creationData.decimals = Long.fromValue(\n tokenCreation.decimals\n ).toNumber();\n }\n if (tokenCreation.maxSupply) {\n creationData.maxSupply = Long.fromValue(\n tokenCreation.maxSupply\n ).toString();\n }\n if (tokenCreation.memo) creationData.memo = tokenCreation.memo;\n\n if (\n tokenCreation.tokenType !== null &&\n tokenCreation.tokenType !== undefined\n ) {\n creationData.tokenType = proto.TokenType[tokenCreation.tokenType];\n }\n if (\n tokenCreation.supplyType !== null &&\n tokenCreation.supplyType !== undefined\n ) {\n creationData.supplyType =\n proto.TokenSupplyType[tokenCreation.supplyType];\n }\n\n creationData.adminKey = tokenCreation.adminKey\n ? 'Present'\n : 'Not Present';\n creationData.kycKey = tokenCreation.kycKey ? 'Present' : 'Not Present';\n creationData.freezeKey = tokenCreation.freezeKey\n ? 'Present'\n : 'Not Present';\n creationData.wipeKey = tokenCreation.wipeKey ? 'Present' : 'Not Present';\n creationData.supplyKey = tokenCreation.supplyKey\n ? 'Present'\n : 'Not Present';\n creationData.feeScheduleKey = tokenCreation.feeScheduleKey\n ? 'Present'\n : 'Not Present';\n creationData.pauseKey = tokenCreation.pauseKey\n ? 'Present'\n : 'Not Present';\n\n if (tokenCreation.autoRenewAccount) {\n const ara = tokenCreation.autoRenewAccount;\n creationData.autoRenewAccount = new AccountId(\n ara.shardNum ? Long.fromValue(ara.shardNum).toNumber() : 0,\n ara.realmNum ? Long.fromValue(ara.realmNum).toNumber() : 0,\n ara.accountNum ? Long.fromValue(ara.accountNum).toNumber() : 0\n ).toString();\n }\n if (\n tokenCreation.autoRenewPeriod &&\n tokenCreation.autoRenewPeriod.seconds\n ) {\n creationData.autoRenewPeriod = Long.fromValue(\n tokenCreation.autoRenewPeriod.seconds\n ).toString();\n }\n\n result.tokenCreation = creationData;\n }\n }\n\n /**\n * Parse consensus create topic transaction data\n * @param createTopicBody - The consensus create topic transaction body\n * @param result - The parsed transaction\n */\n private static parseConsensusCreateTopic(\n createTopicBody: proto.IConsensusCreateTopicTransactionBody,\n result: ParsedTransaction\n ): void {\n if (createTopicBody) {\n const topicData: ConsensusCreateTopicData = {};\n if (createTopicBody.memo) topicData.memo = createTopicBody.memo;\n topicData.adminKey = createTopicBody.adminKey ? 'Present' : 'Not Present';\n topicData.submitKey = createTopicBody.submitKey\n ? 'Present'\n : 'Not Present';\n\n if (createTopicBody.autoRenewAccount) {\n const ara = createTopicBody.autoRenewAccount;\n topicData.autoRenewAccountId = new AccountId(\n ara.shardNum ? Long.fromValue(ara.shardNum).toNumber() : 0,\n ara.realmNum ? Long.fromValue(ara.realmNum).toNumber() : 0,\n ara.accountNum ? Long.fromValue(ara.accountNum).toNumber() : 0\n ).toString();\n }\n if (\n createTopicBody.autoRenewPeriod &&\n createTopicBody.autoRenewPeriod.seconds\n ) {\n topicData.autoRenewPeriod = Long.fromValue(\n createTopicBody.autoRenewPeriod.seconds\n ).toString();\n }\n result.consensusCreateTopic = topicData;\n }\n }\n\n /**\n * Parse consensus submit message transaction data\n * @param submitMessageBody - The consensus submit message transaction body\n * @param result - The parsed transaction\n */\n private static parseConsensusSubmitMessage(\n submitMessageBody: proto.IConsensusSubmitMessageTransactionBody,\n result: ParsedTransaction\n ): void {\n if (submitMessageBody) {\n const messageData: ConsensusSubmitMessageData = {};\n if (submitMessageBody.topicID) {\n const tid = submitMessageBody.topicID;\n messageData.topicId = `${\n tid.shardNum ? Long.fromValue(tid.shardNum).toNumber() : 0\n }.${tid.realmNum ? Long.fromValue(tid.realmNum).toNumber() : 0}.${\n tid.topicNum ? Long.fromValue(tid.topicNum).toNumber() : 0\n }`;\n }\n if (submitMessageBody.message) {\n messageData.message = Buffer.from(submitMessageBody.message).toString(\n 'base64'\n );\n }\n if (submitMessageBody.chunkInfo) {\n if (submitMessageBody.chunkInfo.initialTransactionID) {\n const txId =\n submitMessageBody.chunkInfo.initialTransactionID.accountID;\n const taValidStart =\n submitMessageBody.chunkInfo.initialTransactionID\n .transactionValidStart;\n if (txId && taValidStart) {\n messageData.chunkInfoInitialTransactionID = `${\n txId.shardNum ? Long.fromValue(txId.shardNum).toNumber() : 0\n }.${txId.realmNum ? Long.fromValue(txId.realmNum).toNumber() : 0}.${\n txId.accountNum ? Long.fromValue(txId.accountNum).toNumber() : 0\n }@${\n taValidStart.seconds\n ? Long.fromValue(taValidStart.seconds).toNumber()\n : 0\n }.${\n taValidStart.nanos\n ? Long.fromValue(taValidStart.nanos).toNumber()\n : 0\n }`;\n }\n }\n if (\n submitMessageBody.chunkInfo.number !== undefined &&\n submitMessageBody.chunkInfo.number !== null\n ) {\n messageData.chunkInfoNumber = submitMessageBody.chunkInfo.number;\n }\n if (\n submitMessageBody.chunkInfo.total !== undefined &&\n submitMessageBody.chunkInfo.total !== null\n ) {\n messageData.chunkInfoTotal = submitMessageBody.chunkInfo.total;\n }\n }\n result.consensusSubmitMessage = messageData;\n }\n }\n\n /**\n * Get a human-readable summary of the transaction\n * @param parsedTx - The parsed transaction\n * @returns The human-readable summary of the transaction\n */\n static getTransactionSummary(parsedTx: ParsedTransaction): string {\n let summary: string;\n\n if (parsedTx.type === 'cryptoTransfer') {\n const senders = [];\n const receivers = [];\n\n for (const transfer of parsedTx.transfers) {\n const originalAmountFloat = parseFloat(transfer.amount);\n\n let displayStr = transfer.amount;\n if (displayStr.startsWith('-')) {\n displayStr = displayStr.substring(1);\n }\n displayStr = displayStr.replace(/\\s*ℏ$/, '');\n\n if (originalAmountFloat < 0) {\n senders.push(`${transfer.accountId} (${displayStr} ℏ)`);\n } else if (originalAmountFloat > 0) {\n receivers.push(`${transfer.accountId} (${displayStr} ℏ)`);\n }\n }\n\n if (senders.length > 0 && receivers.length > 0) {\n summary = `Transfer of HBAR from ${senders.join(\n ', '\n )} to ${receivers.join(', ')}`;\n } else {\n summary = parsedTx.humanReadableType;\n }\n } else if (parsedTx.contractCall) {\n let contractCallSummary = `Contract call to ${parsedTx.contractCall.contractId} with ${parsedTx.contractCall.gas} gas`;\n\n if (parsedTx.contractCall.amount > 0) {\n contractCallSummary += ` and ${parsedTx.contractCall.amount} HBAR`;\n }\n\n if (parsedTx.contractCall.functionName) {\n contractCallSummary += ` calling function ${parsedTx.contractCall.functionName}`;\n }\n\n summary = contractCallSummary;\n } else if (parsedTx.tokenMint) {\n summary = `Mint ${parsedTx.tokenMint.amount} tokens for token ${parsedTx.tokenMint.tokenId}`;\n } else if (parsedTx.tokenBurn) {\n summary = `Burn ${parsedTx.tokenBurn.amount} tokens for token ${parsedTx.tokenBurn.tokenId}`;\n } else if (parsedTx.tokenTransfers.length > 0) {\n const tokenGroups: Record<string, TokenAmount[]> = {};\n\n for (const transfer of parsedTx.tokenTransfers) {\n if (!tokenGroups[transfer.tokenId]) {\n tokenGroups[transfer.tokenId] = [];\n }\n tokenGroups[transfer.tokenId].push(transfer);\n }\n\n const tokenSummaries = [];\n\n for (const [tokenId, transfers] of Object.entries(tokenGroups)) {\n const tokenSenders = [];\n const tokenReceivers = [];\n\n for (const transfer of transfers) {\n const transferAmountValue = parseFloat(transfer.amount.toString());\n if (transferAmountValue < 0) {\n tokenSenders.push(\n `${transfer.accountId} (${Math.abs(transferAmountValue)})`\n );\n } else if (transferAmountValue > 0) {\n tokenReceivers.push(\n `${transfer.accountId} (${transferAmountValue})`\n );\n }\n }\n\n if (tokenSenders.length > 0 && tokenReceivers.length > 0) {\n tokenSummaries.push(\n `Transfer of token ${tokenId} from ${tokenSenders.join(\n ', '\n )} to ${tokenReceivers.join(', ')}`\n );\n }\n }\n\n if (tokenSummaries.length > 0) {\n summary = tokenSummaries.join('; ');\n } else {\n summary = parsedTx.humanReadableType;\n }\n } else if (parsedTx.consensusCreateTopic) {\n summary = `Create new topic`;\n if (parsedTx.consensusCreateTopic.memo) {\n summary += ` with memo \"${parsedTx.consensusCreateTopic.memo}\"`;\n }\n if (parsedTx.consensusCreateTopic.autoRenewAccountId) {\n summary += `, auto-renew by ${parsedTx.consensusCreateTopic.autoRenewAccountId}`;\n }\n } else if (parsedTx.consensusSubmitMessage) {\n summary = `Submit message`;\n if (parsedTx.consensusSubmitMessage.topicId) {\n summary += ` to topic ${parsedTx.consensusSubmitMessage.topicId}`;\n }\n if (parsedTx.consensusSubmitMessage.message) {\n summary += ` (message length: ${\n Buffer.from(parsedTx.consensusSubmitMessage.message, 'base64').length\n } bytes)`;\n }\n if (\n parsedTx.consensusSubmitMessage.chunkInfoNumber &&\n parsedTx.consensusSubmitMessage.chunkInfoTotal\n ) {\n summary += ` (chunk ${parsedTx.consensusSubmitMessage.chunkInfoNumber}/${parsedTx.consensusSubmitMessage.chunkInfoTotal})`;\n }\n } else {\n summary = parsedTx.humanReadableType;\n }\n\n return summary;\n }\n}\n"],"names":["ethers.decodeBase64","Buffer"],"mappings":"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"}
@@ -1,9 +1,9 @@
1
1
  import Buffer from "./standards-sdk.es25.js";
2
2
  import { PublicKey, Timestamp, AccountId } from "@hashgraph/sdk";
3
- import "./standards-sdk.es31.js";
3
+ import "./standards-sdk.es29.js";
4
4
  import { Logger } from "./standards-sdk.es15.js";
5
5
  import { proto } from "@hashgraph/proto";
6
- import axios from "./standards-sdk.es32.js";
6
+ import axios from "./standards-sdk.es30.js";
7
7
  class HederaMirrorNode {
8
8
  constructor(network, logger) {
9
9
  this.maxRetries = 3;
@@ -694,20 +694,12 @@ class HederaMirrorNode {
694
694
  const url = `${this.baseUrl}/api/v1/transactions?timestamp=${timestamp}&limit=1`;
695
695
  try {
696
696
  const response = await this._requestWithRetry(url);
697
- if (response && response.transactions && response.transactions.length > 0) {
698
- const specificTransactionId = response.transactions[0].transaction_id;
699
- this.logger.debug(
700
- `Transaction found by timestamp, fetching full details for ID: ${specificTransactionId}`
701
- );
702
- return this.getTransaction(specificTransactionId);
703
- }
704
- this.logger.warn(`No transaction found for timestamp: ${timestamp}`);
705
- return null;
697
+ return response.transactions;
706
698
  } catch (error) {
707
699
  this.logger.error(
708
- `Error fetching transaction by timestamp ${timestamp}: ${error.message}`
700
+ `Error fetching transaction by timestamp ${timestamp}: ${error}`
709
701
  );
710
- return null;
702
+ return [];
711
703
  }
712
704
  }
713
705
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es21.js","sources":["../../src/services/mirror-node.ts"],"sourcesContent":["import { PublicKey, Timestamp, AccountId } from '@hashgraph/sdk';\nimport axios, { AxiosRequestConfig } from 'axios';\nimport { Logger } from '../utils/logger';\nimport { HCSMessage } from '../hcs-10/base-client';\nimport { proto } from '@hashgraph/proto';\nimport {\n AccountResponse,\n CustomFees,\n HBARPrice,\n ScheduleInfo,\n TokenInfoResponse,\n TopicMessagesResponse,\n TopicResponse,\n Transaction as HederaTransaction,\n AccountTokenBalance,\n AccountTokensResponse,\n NftDetail,\n AccountNftsResponse,\n ContractCallQueryResponse,\n} from './types';\nimport { NetworkType } from '../utils/types';\n\n/**\n * Configuration for retry attempts.\n */\nexport interface RetryConfig {\n maxRetries?: number;\n initialDelayMs?: number;\n maxDelayMs?: number;\n backoffFactor?: number;\n}\n\nexport class HederaMirrorNode {\n private network: NetworkType;\n private baseUrl: string;\n private logger: Logger;\n private isServerEnvironment: boolean;\n\n private maxRetries: number = 3;\n private initialDelayMs: number = 1000;\n private maxDelayMs: number = 30000;\n private backoffFactor: number = 2;\n\n constructor(network: NetworkType, logger: Logger) {\n this.network = network;\n this.baseUrl = this.getMirrorNodeUrl();\n this.logger =\n logger ||\n new Logger({\n level: 'debug',\n module: 'MirrorNode',\n });\n this.isServerEnvironment = typeof window === 'undefined';\n }\n\n /**\n * Configures the retry mechanism for API requests.\n * @param config The retry configuration.\n */\n public configureRetry(config: RetryConfig): void {\n this.maxRetries = config.maxRetries ?? this.maxRetries;\n this.initialDelayMs = config.initialDelayMs ?? this.initialDelayMs;\n this.maxDelayMs = config.maxDelayMs ?? this.maxDelayMs;\n this.backoffFactor = config.backoffFactor ?? this.backoffFactor;\n this.logger.info(\n `Retry configuration updated: maxRetries=${this.maxRetries}, initialDelayMs=${this.initialDelayMs}, maxDelayMs=${this.maxDelayMs}, backoffFactor=${this.backoffFactor}`\n );\n }\n\n private getMirrorNodeUrl(): string {\n return this.network === 'mainnet'\n ? 'https://mainnet-public.mirrornode.hedera.com'\n : 'https://testnet.mirrornode.hedera.com';\n }\n\n getBaseUrl(): string {\n return this.baseUrl;\n }\n\n /**\n * Retrieves the public key for a given account ID from the mirror node.\n * @param accountId The ID of the account to retrieve the public key for.\n * @returns A promise that resolves to the public key for the given account.\n * @throws An error if the account ID is invalid or the public key cannot be retrieved.\n */\n async getPublicKey(accountId: string): Promise<PublicKey> {\n this.logger.info(`Getting public key for account ${accountId}`);\n\n const accountInfo = await this.requestAccount(accountId);\n\n try {\n if (!accountInfo || !accountInfo.key) {\n throw new Error(\n `Failed to retrieve public key for account ID: ${accountId}`\n );\n }\n\n return PublicKey.fromString(accountInfo.key.key);\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error fetching public key from Mirror Node: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n\n /**\n * Retrieves the memo for a given account ID from the mirror node.\n * @param accountId The ID of the account to retrieve the memo for.\n * @returns A promise that resolves to the memo for the given account.\n * @throws An error if the account ID is invalid or the memo cannot be retrieved.\n */\n async getAccountMemo(accountId: string): Promise<string | null> {\n this.logger.info(`Getting account memo for account ID: ${accountId}`);\n const accountInfoUrl = `${this.baseUrl}/api/v1/accounts/${accountId}`;\n\n try {\n const accountInfo = await this._requestWithRetry<AccountResponse>(\n accountInfoUrl\n );\n\n if (accountInfo?.memo) {\n return accountInfo.memo;\n }\n this.logger.warn(`No memo found for account ${accountId}`);\n return null;\n } catch (e: any) {\n const error = e as Error;\n this.logger.error(\n `Failed to get account memo for ${accountId} after retries: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Retrieves topic information for a given topic ID from the mirror node.\n * @param topicId The ID of the topic to retrieve information for.\n * @returns A promise that resolves to the topic information.\n * @throws An error if the topic ID is invalid or the information cannot be retrieved.\n */\n async getTopicInfo(topicId: string): Promise<TopicResponse> {\n try {\n const topicInfoUrl = `${this.baseUrl}/api/v1/topics/${topicId}`;\n this.logger.debug(`Fetching topic info from ${topicInfoUrl}`);\n const data = await this._requestWithRetry<TopicResponse>(topicInfoUrl);\n return data;\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error retrieving topic information for ${topicId} after retries: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n\n /**\n * Retrieves custom fees for a given topic ID from the mirror node.\n * @param topicId The ID of the topic to retrieve custom fees for.\n * @returns A promise that resolves to the custom fees for the given topic.\n * @throws An error if the topic ID is invalid or the custom fees cannot be retrieved.\n */\n async getTopicFees(topicId: string): Promise<CustomFees | null> {\n try {\n const topicInfo = await this.getTopicInfo(topicId);\n return topicInfo.custom_fees;\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error retrieving topic fees: ${error.message}`;\n this.logger.error(logMessage);\n return null;\n }\n }\n\n /**\n * Retrieves the current HBAR price from the mirror node.\n * @param date The date to retrieve the HBAR price for.\n * @returns A promise that resolves to the HBAR price for the given date.\n * @throws An error if the date is invalid or the price cannot be retrieved.\n */\n async getHBARPrice(date: Date): Promise<number | null> {\n try {\n const timestamp = Timestamp.fromDate(date).toString();\n const url = `https://mainnet-public.mirrornode.hedera.com/api/v1/network/exchangerate?timestamp=${timestamp}`;\n this.logger.debug(`Fetching HBAR price from ${url}`);\n\n const response = await this._fetchWithRetry<HBARPrice>(url);\n\n const usdPrice =\n Number(response?.current_rate?.cent_equivalent) /\n Number(response?.current_rate?.hbar_equivalent) /\n 100;\n\n return usdPrice;\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error retrieving HBAR price: ${error.message}`;\n this.logger.error(logMessage);\n return null;\n }\n }\n\n /**\n * Retrieves token information for a given token ID from the mirror node.\n * @param tokenId The ID of the token to retrieve information for.\n * @returns A promise that resolves to the token information.\n * @throws An error if the token ID is invalid or the information cannot be retrieved.\n */\n async getTokenInfo(tokenId: string): Promise<TokenInfoResponse | null> {\n this.logger.debug(`Fetching token info for ${tokenId}`);\n try {\n const tokenInfoUrl = `${this.baseUrl}/api/v1/tokens/${tokenId}`;\n const data = await this._requestWithRetry<TokenInfoResponse>(\n tokenInfoUrl\n );\n if (data) {\n this.logger.trace(`Token info found for ${tokenId}:`, data);\n return data;\n }\n this.logger.warn(`No token info found for ${tokenId}`);\n return null;\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error fetching token info for ${tokenId}: ${error.message}`;\n this.logger.error(logMessage);\n\n return null;\n }\n }\n\n /**\n * Retrieves messages for a given topic ID from the mirror node.\n * @param topicId The ID of the topic to retrieve messages for.\n * @returns A promise that resolves to the messages for the given topic.\n * @throws An error if the topic ID is invalid or the messages cannot be retrieved.\n */\n async getTopicMessages(topicId: string): Promise<HCSMessage[]> {\n this.logger.trace(`Querying messages for topic ${topicId}`);\n\n let nextUrl = `${this.baseUrl}/api/v1/topics/${topicId}/messages`;\n const messages: HCSMessage[] = [];\n\n while (nextUrl) {\n try {\n const data = await this._requestWithRetry<TopicMessagesResponse>(\n nextUrl\n );\n\n if (data.messages && data.messages.length > 0) {\n for (const message of data.messages) {\n try {\n if (!message.message) {\n continue;\n }\n\n let messageContent: string;\n try {\n if (this.isServerEnvironment) {\n messageContent = Buffer.from(\n message.message,\n 'base64'\n ).toString('utf-8');\n } else {\n messageContent = new TextDecoder().decode(\n Uint8Array.from(atob(message.message), (c) =>\n c.charCodeAt(0)\n )\n );\n }\n } catch (error) {\n const logMessage = `Error decoding message: ${error}`;\n this.logger.error(logMessage);\n continue;\n }\n\n let messageJson;\n try {\n messageJson = JSON.parse(messageContent);\n } catch (error) {\n const logMessage = `Invalid JSON message content: ${messageContent}`;\n this.logger.error(logMessage);\n continue;\n }\n\n messageJson.sequence_number = message.sequence_number;\n messages.push({\n ...messageJson,\n consensus_timestamp: message.consensus_timestamp,\n sequence_number: message.sequence_number,\n created: new Date(Number(message.consensus_timestamp) * 1000),\n });\n } catch (error: any) {\n const logMessage = `Error processing message: ${error.message}`;\n this.logger.error(logMessage);\n }\n }\n }\n\n nextUrl = data.links?.next ? `${this.baseUrl}${data.links.next}` : '';\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error querying topic messages for topic ${topicId} (URL: ${nextUrl}) after retries: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n\n return messages;\n }\n\n /**\n * Requests account information for a given account ID from the mirror node.\n * @param accountId The ID of the account to retrieve information for.\n * @returns A promise that resolves to the account information.\n * @throws An error if the account ID is invalid or the information cannot be retrieved.\n */\n async requestAccount(accountId: string): Promise<AccountResponse> {\n try {\n const accountInfoUrl = `${this.baseUrl}/api/v1/accounts/${accountId}`;\n this.logger.debug(`Requesting account info from ${accountInfoUrl}`);\n const data = await this._requestWithRetry<AccountResponse>(\n accountInfoUrl\n );\n if (!data) {\n throw new Error(\n `No data received from mirror node for account: ${accountId}`\n );\n }\n return data;\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Failed to fetch account ${accountId} after retries: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n\n /**\n * Checks if a user has access to a given key list.\n * @param keyBytes The key list to check access for.\n * @param userPublicKey The public key of the user to check access for.\n * @returns A promise that resolves to true if the user has access, false otherwise.\n */\n async checkKeyListAccess(\n keyBytes: Buffer,\n userPublicKey: PublicKey\n ): Promise<boolean> {\n try {\n const key = proto.Key.decode(keyBytes);\n return this.evaluateKeyAccess(key, userPublicKey);\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error decoding protobuf key: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n\n /**\n * Evaluates the access of a given key to a user's public key.\n * @param key The key to evaluate access for.\n * @param userPublicKey The public key of the user to evaluate access for.\n * @returns A promise that resolves to true if the key has access, false otherwise.\n */\n private async evaluateKeyAccess(\n key: proto.IKey,\n userPublicKey: PublicKey\n ): Promise<boolean> {\n if (key.ed25519) {\n return this.compareEd25519Key(key.ed25519, userPublicKey);\n }\n\n if (key.keyList) {\n return this.evaluateKeyList(key.keyList, userPublicKey);\n }\n\n if (key.thresholdKey && key.thresholdKey.keys) {\n return this.evaluateKeyList(key.thresholdKey.keys, userPublicKey);\n }\n\n return false;\n }\n\n /**\n * Evaluates the access of a given key list to a user's public key.\n * @param keyList The key list to evaluate access for.\n * @param userPublicKey The public key of the user to evaluate access for.\n * @returns A promise that resolves to true if the key list has access, false otherwise.\n */\n private async evaluateKeyList(\n keyList: proto.IKeyList,\n userPublicKey: PublicKey\n ): Promise<boolean> {\n const keys = keyList.keys || [];\n\n for (const listKey of keys) {\n if (!listKey) continue;\n\n if (listKey.ed25519) {\n if (this.compareEd25519Key(listKey.ed25519, userPublicKey)) {\n return true;\n }\n } else if (listKey.keyList || listKey.thresholdKey) {\n try {\n const nestedKeyBytes = proto.Key.encode({\n ...(listKey.keyList ? { keyList: listKey.keyList } : {}),\n ...(listKey.thresholdKey\n ? { thresholdKey: listKey.thresholdKey }\n : {}),\n }).finish();\n\n const hasNestedAccess = await this.checkKeyListAccess(\n Buffer.from(nestedKeyBytes),\n userPublicKey\n );\n\n if (hasNestedAccess) {\n return true;\n }\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error in nested key: ${error.message}`;\n this.logger.debug(logMessage);\n }\n }\n }\n\n return false;\n }\n\n /**\n * Compares an Ed25519 key with a user's public key.\n * @param keyData The Ed25519 key data to compare.\n * @param userPublicKey The public key of the user to compare with.\n * @returns A boolean indicating whether the key matches the user's public key.\n */\n private compareEd25519Key(\n keyData: Uint8Array,\n userPublicKey: PublicKey\n ): boolean {\n try {\n const decodedKey = PublicKey.fromBytes(Buffer.from(keyData));\n return decodedKey.toString() === userPublicKey.toString();\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error comparing Ed25519 key: ${error.message}`;\n this.logger.debug(logMessage);\n return false;\n }\n }\n\n /**\n * Retrieves information about a scheduled transaction\n * @param scheduleId The ID of the scheduled transaction\n * @returns A promise that resolves to the scheduled transaction information\n */\n async getScheduleInfo(scheduleId: string): Promise<ScheduleInfo | null> {\n try {\n this.logger.info(\n `Getting information for scheduled transaction ${scheduleId}`\n );\n\n const url = `${this.baseUrl}/api/v1/schedules/${scheduleId}`;\n const data = await this._requestWithRetry<ScheduleInfo>(url);\n\n if (data) {\n return data;\n }\n\n this.logger.warn(\n `No schedule info found for ${scheduleId} after retries.`\n );\n return null;\n } catch (error: any) {\n this.logger.error(\n `Error fetching schedule info for ${scheduleId} after retries: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Checks the status of a scheduled transaction\n * @param scheduleId The schedule ID to check\n * @returns Status of the scheduled transaction\n */\n public async getScheduledTransactionStatus(scheduleId: string): Promise<{\n executed: boolean;\n executedDate?: Date;\n deleted: boolean;\n }> {\n try {\n this.logger.info(\n `Checking status of scheduled transaction ${scheduleId}`\n );\n\n const scheduleInfo = await this.getScheduleInfo(scheduleId);\n\n if (!scheduleInfo) {\n throw new Error(`Schedule ${scheduleId} not found`);\n }\n\n return {\n executed: Boolean(scheduleInfo.executed_timestamp),\n executedDate: scheduleInfo.executed_timestamp\n ? new Date(Number(scheduleInfo.executed_timestamp) * 1000)\n : undefined,\n deleted: scheduleInfo.deleted || false,\n };\n } catch (error) {\n this.logger.error(\n `Error checking scheduled transaction status: ${error}`\n );\n throw error;\n }\n }\n\n /**\n * Retrieves details for a given transaction ID or hash from the mirror node.\n * @param transactionIdOrHash The ID or hash of the transaction.\n * @returns A promise that resolves to the transaction details.\n * @throws An error if the transaction ID/hash is invalid or details cannot be retrieved.\n */\n async getTransaction(\n transactionIdOrHash: string\n ): Promise<HederaTransaction | null> {\n this.logger.info(\n `Getting transaction details for ID/hash: ${transactionIdOrHash}`\n );\n const endpoint = transactionIdOrHash.includes('-')\n ? `transactions/${transactionIdOrHash}`\n : `transactions/${transactionIdOrHash}`;\n\n const transactionDetailsUrl = `${this.baseUrl}/api/v1/${endpoint}`;\n\n try {\n const response = await this._requestWithRetry<{\n transactions: HederaTransaction[];\n }>(transactionDetailsUrl);\n\n if (response?.transactions?.length > 0) {\n this.logger.trace(\n `Transaction details found for ${transactionIdOrHash}:`,\n response.transactions[0]\n );\n return response.transactions[0];\n }\n\n this.logger.warn(\n `No transaction details found for ${transactionIdOrHash} or unexpected response structure.`\n );\n return null;\n } catch (e: any) {\n const error = e as Error;\n this.logger.error(\n `Failed to get transaction details for ${transactionIdOrHash} after retries: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Private helper to make GET requests with retry logic using Axios.\n */\n private async _requestWithRetry<T>(\n url: string,\n axiosConfig?: AxiosRequestConfig\n ): Promise<T> {\n let attempt = 0;\n let delay = this.initialDelayMs;\n\n while (attempt < this.maxRetries) {\n try {\n const response = await axios.get<T>(url, axiosConfig);\n return response.data;\n } catch (error: any) {\n attempt++;\n const isLastAttempt = attempt >= this.maxRetries;\n const statusCode = error.response?.status;\n\n if (\n statusCode &&\n statusCode >= 400 &&\n statusCode < 500 &&\n statusCode !== 429\n ) {\n this.logger.error(\n `Client error for ${url} (status ${statusCode}): ${error.message}. Not retrying.`\n );\n throw error;\n }\n\n if (isLastAttempt) {\n this.logger.error(\n `Max retries (${this.maxRetries}) reached for ${url}. Last error: ${error.message}`\n );\n throw error;\n }\n\n this.logger.warn(\n `Attempt ${attempt}/${this.maxRetries} failed for ${url}: ${error.message}. Retrying in ${delay}ms...`\n );\n await new Promise((resolve) => setTimeout(resolve, delay));\n delay = Math.min(delay * this.backoffFactor, this.maxDelayMs);\n }\n }\n\n throw new Error(\n `Failed to fetch data from ${url} after ${this.maxRetries} attempts.`\n );\n }\n\n /**\n * Private helper to make fetch requests with retry logic.\n */\n private async _fetchWithRetry<T>(\n url: string,\n fetchOptions?: RequestInit\n ): Promise<T> {\n let attempt = 0;\n let delay = this.initialDelayMs;\n\n while (attempt < this.maxRetries) {\n try {\n const request = await fetch(url, fetchOptions);\n if (!request.ok) {\n if (\n request.status >= 400 &&\n request.status < 500 &&\n request.status !== 429\n ) {\n this.logger.error(\n `Client error for ${url} (status ${request.status}): ${request.statusText}. Not retrying.`\n );\n throw new Error(\n `Fetch failed with status ${request.status}: ${request.statusText} for URL: ${url}`\n );\n }\n throw new Error(\n `Fetch failed with status ${request.status}: ${request.statusText} for URL: ${url}`\n );\n }\n const response = (await request.json()) as T;\n return response;\n } catch (error: any) {\n attempt++;\n if (attempt >= this.maxRetries) {\n this.logger.error(\n `Max retries (${this.maxRetries}) reached for ${url}. Last error: ${error.message}`\n );\n throw error;\n }\n this.logger.warn(\n `Attempt ${attempt}/${this.maxRetries} failed for ${url}: ${error.message}. Retrying in ${delay}ms...`\n );\n await new Promise((resolve) => setTimeout(resolve, delay));\n delay = Math.min(delay * this.backoffFactor, this.maxDelayMs);\n }\n }\n throw new Error(\n `Failed to fetch data from ${url} after ${this.maxRetries} attempts.`\n );\n }\n\n /**\n * Retrieves the numerical balance (in HBAR) for a given account ID.\n * @param accountId The ID of the account.\n * @returns A promise that resolves to the HBAR balance or null if an error occurs.\n */\n async getAccountBalanceNumerical(accountId: string): Promise<number | null> {\n this.logger.info(`Getting numerical balance for account ${accountId}`);\n try {\n const accountInfo = await this.requestAccount(accountId);\n if (accountInfo && accountInfo.balance) {\n const hbarBalance = accountInfo.balance.balance / 100_000_000;\n return hbarBalance;\n }\n this.logger.warn(\n `Could not retrieve balance for account ${accountId} from account info.`\n );\n return null;\n } catch (error: any) {\n this.logger.error(\n `Error fetching numerical balance for account ${accountId}: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Retrieves messages for a given topic ID with optional filters.\n * @param topicId The ID of the topic.\n * @param sequenceNumber Filter by sequence number (e.g., \"gt:10\", \"lte:20\").\n * @param startTime Filter by consensus timestamp (e.g., \"gt:1629400000.000000000\").\n * @param endTime Filter by consensus timestamp (e.g., \"lt:1629500000.000000000\").\n * @param limit The maximum number of messages to return.\n * @returns A promise that resolves to an array of HCSMessages or null.\n */\n async getTopicMessagesByFilter(\n topicId: string,\n options?: {\n sequenceNumber?: string;\n startTime?: string;\n endTime?: string;\n limit?: number;\n order?: 'asc' | 'desc';\n }\n ): Promise<HCSMessage[] | null> {\n this.logger.trace(\n `Querying messages for topic ${topicId} with filters: ${JSON.stringify(\n options\n )}`\n );\n\n let nextUrl = `${this.baseUrl}/api/v1/topics/${topicId}/messages`;\n const params = new URLSearchParams();\n\n if (options?.limit) {\n params.append('limit', options.limit.toString());\n }\n if (options?.sequenceNumber) {\n params.append('sequencenumber', options.sequenceNumber);\n }\n if (options?.startTime) {\n params.append('timestamp', `gte:${options.startTime}`);\n }\n if (options?.endTime) {\n params.append('timestamp', `lt:${options.endTime}`);\n }\n if (options?.order) {\n params.append('order', options.order);\n }\n\n const queryString = params.toString();\n if (queryString) {\n nextUrl += `?${queryString}`;\n }\n\n const messages: HCSMessage[] = [];\n let pagesFetched = 0;\n const maxPages = 10;\n\n try {\n while (nextUrl && pagesFetched < maxPages) {\n pagesFetched++;\n const data = await this._requestWithRetry<TopicMessagesResponse>(\n nextUrl\n );\n\n if (data.messages && data.messages.length > 0) {\n for (const message of data.messages) {\n try {\n if (!message.message) {\n continue;\n }\n let messageContent: string;\n if (this.isServerEnvironment) {\n messageContent = Buffer.from(\n message.message,\n 'base64'\n ).toString('utf-8');\n } else {\n messageContent = new TextDecoder().decode(\n Uint8Array.from(atob(message.message), (c) => c.charCodeAt(0))\n );\n }\n let messageJson = {};\n try {\n messageJson = JSON.parse(messageContent);\n } catch (parseError) {\n this.logger.debug(\n `Message content is not valid JSON, using raw: ${messageContent}`\n );\n messageJson = { raw_content: messageContent };\n }\n\n const parsedContent = messageJson as any;\n\n const hcsMsg: HCSMessage = {\n ...parsedContent,\n consensus_timestamp: message.consensus_timestamp,\n sequence_number: message.sequence_number,\n payer_account_id: message.payer_account_id,\n topic_id: message.topic_id,\n running_hash: message.running_hash,\n running_hash_version: message.running_hash_version,\n chunk_info: message.chunk_info,\n created: new Date(\n Number(message.consensus_timestamp.split('.')[0]) * 1000 +\n Number(message.consensus_timestamp.split('.')[1] || 0) /\n 1_000_000\n ),\n payer: message.payer_account_id,\n };\n\n messages.push(hcsMsg);\n } catch (error: any) {\n this.logger.error(\n `Error processing individual message: ${error.message}`\n );\n }\n }\n }\n if (options?.limit && messages.length >= options.limit) break;\n nextUrl = data.links?.next ? `${this.baseUrl}${data.links.next}` : '';\n }\n return messages;\n } catch (e: any) {\n const error = e as Error;\n this.logger.error(\n `Error querying filtered topic messages for ${topicId}: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Retrieves token balances for a given account ID.\n * @param accountId The ID of the account.\n * @param limit The maximum number of tokens to return.\n * @returns A promise that resolves to an array of AccountTokenBalance or null.\n */\n async getAccountTokens(\n accountId: string,\n limit: number = 100\n ): Promise<AccountTokenBalance[] | null> {\n this.logger.info(`Getting tokens for account ${accountId}`);\n let allTokens: AccountTokenBalance[] = [];\n let url = `${this.baseUrl}/api/v1/accounts/${accountId}/tokens?limit=${limit}`;\n\n try {\n for (let i = 0; i < 10 && url; i++) {\n const response = await this._requestWithRetry<AccountTokensResponse>(\n url\n );\n if (response && response.tokens) {\n allTokens = allTokens.concat(response.tokens);\n }\n url = response.links?.next\n ? `${this.baseUrl}${response.links.next}`\n : '';\n if (!url || (limit && allTokens.length >= limit)) {\n if (limit && allTokens.length > limit) {\n allTokens = allTokens.slice(0, limit);\n }\n break;\n }\n }\n return allTokens;\n } catch (error: any) {\n this.logger.error(\n `Error fetching tokens for account ${accountId}: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Retrieves transaction details by consensus timestamp.\n * @param timestamp The consensus timestamp of the transaction (e.g., \"1629400000.000000000\").\n * @returns A promise that resolves to the transaction details or null.\n */\n async getTransactionByTimestamp(\n timestamp: string\n ): Promise<HederaTransaction | null> {\n this.logger.info(`Getting transaction by timestamp: ${timestamp}`);\n const url = `${this.baseUrl}/api/v1/transactions?timestamp=${timestamp}&limit=1`;\n\n try {\n const response = await this._requestWithRetry<{\n transactions: HederaTransaction[];\n }>(url);\n\n if (\n response &&\n response.transactions &&\n response.transactions.length > 0\n ) {\n const specificTransactionId = response.transactions[0].transaction_id;\n this.logger.debug(\n `Transaction found by timestamp, fetching full details for ID: ${specificTransactionId}`\n );\n return this.getTransaction(specificTransactionId);\n }\n this.logger.warn(`No transaction found for timestamp: ${timestamp}`);\n return null;\n } catch (error: any) {\n this.logger.error(\n `Error fetching transaction by timestamp ${timestamp}: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Retrieves NFTs for a given account ID, optionally filtered by token ID.\n * @param accountId The ID of the account.\n * @param tokenId Optional ID of the token to filter NFTs by.\n * @param limit The maximum number of NFTs to return per page (API has its own max).\n * @returns A promise that resolves to an array of NftDetail or null.\n */\n async getAccountNfts(\n accountId: string,\n tokenId?: string,\n limit: number = 100\n ): Promise<NftDetail[] | null> {\n this.logger.info(\n `Getting NFTs for account ${accountId}${\n tokenId ? ` for token ${tokenId}` : ''\n }`\n );\n let allNfts: NftDetail[] = [];\n let url = `${this.baseUrl}/api/v1/accounts/${accountId}/nfts?limit=${limit}`;\n if (tokenId) {\n url += `&token.id=${tokenId}`;\n }\n\n try {\n for (let i = 0; i < 10 && url; i++) {\n const response = await this._requestWithRetry<AccountNftsResponse>(url);\n if (response && response.nfts) {\n const nftsWithUri = response.nfts.map((nft) => {\n let tokenUri: string | undefined = undefined;\n if (nft.metadata) {\n try {\n if (this.isServerEnvironment) {\n tokenUri = Buffer.from(nft.metadata, 'base64').toString(\n 'utf-8'\n );\n } else {\n tokenUri = new TextDecoder().decode(\n Uint8Array.from(atob(nft.metadata), (c) => c.charCodeAt(0))\n );\n }\n } catch (e) {\n this.logger.warn(\n `Failed to decode metadata for NFT ${nft.token_id} SN ${\n nft.serial_number\n }: ${(e as Error).message}`\n );\n }\n }\n return { ...nft, token_uri: tokenUri };\n });\n allNfts = allNfts.concat(nftsWithUri);\n }\n url = response.links?.next\n ? `${this.baseUrl}${response.links.next}`\n : '';\n if (!url) break;\n }\n return allNfts;\n } catch (error: any) {\n this.logger.error(\n `Error fetching NFTs for account ${accountId}: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Validates NFT ownership by checking if a specific serial number of a token ID exists for an account.\n * @param accountId The ID of the account.\n * @param tokenId The ID of the NFT's token.\n * @param serialNumber The serial number of the NFT.\n * @returns A promise that resolves to the NftDetail if owned, or null otherwise.\n */\n async validateNFTOwnership(\n accountId: string,\n tokenId: string,\n serialNumber: number\n ): Promise<NftDetail | null> {\n this.logger.info(\n `Validating ownership of NFT ${tokenId} SN ${serialNumber} for account ${accountId}`\n );\n try {\n const nfts = await this.getAccountNfts(accountId, tokenId);\n if (nfts) {\n const foundNft = nfts.find(\n (nft) =>\n nft.token_id === tokenId && nft.serial_number === serialNumber\n );\n return foundNft || null;\n }\n return null;\n } catch (error: any) {\n this.logger.error(`Error validating NFT ownership: ${error.message}`);\n return null;\n }\n }\n\n /**\n * Performs a read-only query against a smart contract (eth_call like).\n * @param contractIdOrAddress The contract ID (e.g., \"0.0.123\") or EVM address (e.g., \"0x...\").\n * @param functionSelector The function selector and encoded parameters (e.g., \"0xabcdef12...\").\n * @param payerAccountId The account ID of the payer (not strictly payer for read-only, but often required as 'from').\n * @param estimate Whether this is an estimate call. Mirror node might not support this directly in /contracts/call for true estimation.\n * @param block Block parameter, e.g., \"latest\", \"pending\", or block number.\n * @param value The value in tinybars to send with the call (for payable view/pure functions, usually 0).\n * @returns A promise that resolves to the contract call query response or null.\n */\n async readSmartContractQuery(\n contractIdOrAddress: string,\n functionSelector: string,\n payerAccountId: string,\n options?: {\n estimate?: boolean;\n block?: string;\n value?: number;\n gas?: number;\n gasPrice?: number;\n }\n ): Promise<ContractCallQueryResponse | null> {\n this.logger.info(\n `Reading smart contract ${contractIdOrAddress} with selector ${functionSelector}`\n );\n const url = `${this.baseUrl}/api/v1/contracts/call`;\n\n const toAddress = contractIdOrAddress.startsWith('0x')\n ? contractIdOrAddress\n : `0x${AccountId.fromString(contractIdOrAddress).toSolidityAddress()}`;\n const fromAddress = payerAccountId.startsWith('0x')\n ? payerAccountId\n : `0x${AccountId.fromString(payerAccountId).toSolidityAddress()}`;\n\n const body: any = {\n block: options?.block || 'latest',\n data: functionSelector,\n estimate: options?.estimate || false,\n from: fromAddress,\n to: toAddress,\n gas: options?.gas,\n gasPrice: options?.gasPrice,\n value: options?.value || 0,\n };\n\n Object.keys(body).forEach((key) => {\n const K = key as keyof typeof body;\n if (body[K] === undefined) {\n delete body[K];\n }\n });\n\n try {\n const response = await this._fetchWithRetry<ContractCallQueryResponse>(\n url,\n {\n method: 'POST',\n body: JSON.stringify(body),\n headers: {\n 'Content-Type': 'application/json',\n },\n }\n );\n return response;\n } catch (error: any) {\n this.logger.error(\n `Error reading smart contract ${contractIdOrAddress}: ${error.message}`\n );\n return null;\n }\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"standards-sdk.es21.js","sources":["../../src/services/mirror-node.ts"],"sourcesContent":["import { PublicKey, Timestamp, AccountId } from '@hashgraph/sdk';\nimport axios, { AxiosRequestConfig } from 'axios';\nimport { Logger } from '../utils/logger';\nimport { HCSMessage } from '../hcs-10/base-client';\nimport { proto } from '@hashgraph/proto';\nimport {\n AccountResponse,\n CustomFees,\n HBARPrice,\n ScheduleInfo,\n TokenInfoResponse,\n TopicMessagesResponse,\n TopicResponse,\n Transaction as HederaTransaction,\n AccountTokenBalance,\n AccountTokensResponse,\n NftDetail,\n AccountNftsResponse,\n ContractCallQueryResponse,\n} from './types';\nimport { NetworkType } from '../utils/types';\n\n/**\n * Configuration for retry attempts.\n */\nexport interface RetryConfig {\n maxRetries?: number;\n initialDelayMs?: number;\n maxDelayMs?: number;\n backoffFactor?: number;\n}\n\nexport class HederaMirrorNode {\n private network: NetworkType;\n private baseUrl: string;\n private logger: Logger;\n private isServerEnvironment: boolean;\n\n private maxRetries: number = 3;\n private initialDelayMs: number = 1000;\n private maxDelayMs: number = 30000;\n private backoffFactor: number = 2;\n\n constructor(network: NetworkType, logger: Logger) {\n this.network = network;\n this.baseUrl = this.getMirrorNodeUrl();\n this.logger =\n logger ||\n new Logger({\n level: 'debug',\n module: 'MirrorNode',\n });\n this.isServerEnvironment = typeof window === 'undefined';\n }\n\n /**\n * Configures the retry mechanism for API requests.\n * @param config The retry configuration.\n */\n public configureRetry(config: RetryConfig): void {\n this.maxRetries = config.maxRetries ?? this.maxRetries;\n this.initialDelayMs = config.initialDelayMs ?? this.initialDelayMs;\n this.maxDelayMs = config.maxDelayMs ?? this.maxDelayMs;\n this.backoffFactor = config.backoffFactor ?? this.backoffFactor;\n this.logger.info(\n `Retry configuration updated: maxRetries=${this.maxRetries}, initialDelayMs=${this.initialDelayMs}, maxDelayMs=${this.maxDelayMs}, backoffFactor=${this.backoffFactor}`\n );\n }\n\n private getMirrorNodeUrl(): string {\n return this.network === 'mainnet'\n ? 'https://mainnet-public.mirrornode.hedera.com'\n : 'https://testnet.mirrornode.hedera.com';\n }\n\n getBaseUrl(): string {\n return this.baseUrl;\n }\n\n /**\n * Retrieves the public key for a given account ID from the mirror node.\n * @param accountId The ID of the account to retrieve the public key for.\n * @returns A promise that resolves to the public key for the given account.\n * @throws An error if the account ID is invalid or the public key cannot be retrieved.\n */\n async getPublicKey(accountId: string): Promise<PublicKey> {\n this.logger.info(`Getting public key for account ${accountId}`);\n\n const accountInfo = await this.requestAccount(accountId);\n\n try {\n if (!accountInfo || !accountInfo.key) {\n throw new Error(\n `Failed to retrieve public key for account ID: ${accountId}`\n );\n }\n\n return PublicKey.fromString(accountInfo.key.key);\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error fetching public key from Mirror Node: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n\n /**\n * Retrieves the memo for a given account ID from the mirror node.\n * @param accountId The ID of the account to retrieve the memo for.\n * @returns A promise that resolves to the memo for the given account.\n * @throws An error if the account ID is invalid or the memo cannot be retrieved.\n */\n async getAccountMemo(accountId: string): Promise<string | null> {\n this.logger.info(`Getting account memo for account ID: ${accountId}`);\n const accountInfoUrl = `${this.baseUrl}/api/v1/accounts/${accountId}`;\n\n try {\n const accountInfo = await this._requestWithRetry<AccountResponse>(\n accountInfoUrl\n );\n\n if (accountInfo?.memo) {\n return accountInfo.memo;\n }\n this.logger.warn(`No memo found for account ${accountId}`);\n return null;\n } catch (e: any) {\n const error = e as Error;\n this.logger.error(\n `Failed to get account memo for ${accountId} after retries: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Retrieves topic information for a given topic ID from the mirror node.\n * @param topicId The ID of the topic to retrieve information for.\n * @returns A promise that resolves to the topic information.\n * @throws An error if the topic ID is invalid or the information cannot be retrieved.\n */\n async getTopicInfo(topicId: string): Promise<TopicResponse> {\n try {\n const topicInfoUrl = `${this.baseUrl}/api/v1/topics/${topicId}`;\n this.logger.debug(`Fetching topic info from ${topicInfoUrl}`);\n const data = await this._requestWithRetry<TopicResponse>(topicInfoUrl);\n return data;\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error retrieving topic information for ${topicId} after retries: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n\n /**\n * Retrieves custom fees for a given topic ID from the mirror node.\n * @param topicId The ID of the topic to retrieve custom fees for.\n * @returns A promise that resolves to the custom fees for the given topic.\n * @throws An error if the topic ID is invalid or the custom fees cannot be retrieved.\n */\n async getTopicFees(topicId: string): Promise<CustomFees | null> {\n try {\n const topicInfo = await this.getTopicInfo(topicId);\n return topicInfo.custom_fees;\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error retrieving topic fees: ${error.message}`;\n this.logger.error(logMessage);\n return null;\n }\n }\n\n /**\n * Retrieves the current HBAR price from the mirror node.\n * @param date The date to retrieve the HBAR price for.\n * @returns A promise that resolves to the HBAR price for the given date.\n * @throws An error if the date is invalid or the price cannot be retrieved.\n */\n async getHBARPrice(date: Date): Promise<number | null> {\n try {\n const timestamp = Timestamp.fromDate(date).toString();\n const url = `https://mainnet-public.mirrornode.hedera.com/api/v1/network/exchangerate?timestamp=${timestamp}`;\n this.logger.debug(`Fetching HBAR price from ${url}`);\n\n const response = await this._fetchWithRetry<HBARPrice>(url);\n\n const usdPrice =\n Number(response?.current_rate?.cent_equivalent) /\n Number(response?.current_rate?.hbar_equivalent) /\n 100;\n\n return usdPrice;\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error retrieving HBAR price: ${error.message}`;\n this.logger.error(logMessage);\n return null;\n }\n }\n\n /**\n * Retrieves token information for a given token ID from the mirror node.\n * @param tokenId The ID of the token to retrieve information for.\n * @returns A promise that resolves to the token information.\n * @throws An error if the token ID is invalid or the information cannot be retrieved.\n */\n async getTokenInfo(tokenId: string): Promise<TokenInfoResponse | null> {\n this.logger.debug(`Fetching token info for ${tokenId}`);\n try {\n const tokenInfoUrl = `${this.baseUrl}/api/v1/tokens/${tokenId}`;\n const data = await this._requestWithRetry<TokenInfoResponse>(\n tokenInfoUrl\n );\n if (data) {\n this.logger.trace(`Token info found for ${tokenId}:`, data);\n return data;\n }\n this.logger.warn(`No token info found for ${tokenId}`);\n return null;\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error fetching token info for ${tokenId}: ${error.message}`;\n this.logger.error(logMessage);\n\n return null;\n }\n }\n\n /**\n * Retrieves messages for a given topic ID from the mirror node.\n * @param topicId The ID of the topic to retrieve messages for.\n * @returns A promise that resolves to the messages for the given topic.\n * @throws An error if the topic ID is invalid or the messages cannot be retrieved.\n */\n async getTopicMessages(topicId: string): Promise<HCSMessage[]> {\n this.logger.trace(`Querying messages for topic ${topicId}`);\n\n let nextUrl = `${this.baseUrl}/api/v1/topics/${topicId}/messages`;\n const messages: HCSMessage[] = [];\n\n while (nextUrl) {\n try {\n const data = await this._requestWithRetry<TopicMessagesResponse>(\n nextUrl\n );\n\n if (data.messages && data.messages.length > 0) {\n for (const message of data.messages) {\n try {\n if (!message.message) {\n continue;\n }\n\n let messageContent: string;\n try {\n if (this.isServerEnvironment) {\n messageContent = Buffer.from(\n message.message,\n 'base64'\n ).toString('utf-8');\n } else {\n messageContent = new TextDecoder().decode(\n Uint8Array.from(atob(message.message), (c) =>\n c.charCodeAt(0)\n )\n );\n }\n } catch (error) {\n const logMessage = `Error decoding message: ${error}`;\n this.logger.error(logMessage);\n continue;\n }\n\n let messageJson;\n try {\n messageJson = JSON.parse(messageContent);\n } catch (error) {\n const logMessage = `Invalid JSON message content: ${messageContent}`;\n this.logger.error(logMessage);\n continue;\n }\n\n messageJson.sequence_number = message.sequence_number;\n messages.push({\n ...messageJson,\n consensus_timestamp: message.consensus_timestamp,\n sequence_number: message.sequence_number,\n created: new Date(Number(message.consensus_timestamp) * 1000),\n });\n } catch (error: any) {\n const logMessage = `Error processing message: ${error.message}`;\n this.logger.error(logMessage);\n }\n }\n }\n\n nextUrl = data.links?.next ? `${this.baseUrl}${data.links.next}` : '';\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error querying topic messages for topic ${topicId} (URL: ${nextUrl}) after retries: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n\n return messages;\n }\n\n /**\n * Requests account information for a given account ID from the mirror node.\n * @param accountId The ID of the account to retrieve information for.\n * @returns A promise that resolves to the account information.\n * @throws An error if the account ID is invalid or the information cannot be retrieved.\n */\n async requestAccount(accountId: string): Promise<AccountResponse> {\n try {\n const accountInfoUrl = `${this.baseUrl}/api/v1/accounts/${accountId}`;\n this.logger.debug(`Requesting account info from ${accountInfoUrl}`);\n const data = await this._requestWithRetry<AccountResponse>(\n accountInfoUrl\n );\n if (!data) {\n throw new Error(\n `No data received from mirror node for account: ${accountId}`\n );\n }\n return data;\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Failed to fetch account ${accountId} after retries: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n\n /**\n * Checks if a user has access to a given key list.\n * @param keyBytes The key list to check access for.\n * @param userPublicKey The public key of the user to check access for.\n * @returns A promise that resolves to true if the user has access, false otherwise.\n */\n async checkKeyListAccess(\n keyBytes: Buffer,\n userPublicKey: PublicKey\n ): Promise<boolean> {\n try {\n const key = proto.Key.decode(keyBytes);\n return this.evaluateKeyAccess(key, userPublicKey);\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error decoding protobuf key: ${error.message}`;\n this.logger.error(logMessage);\n throw new Error(logMessage);\n }\n }\n\n /**\n * Evaluates the access of a given key to a user's public key.\n * @param key The key to evaluate access for.\n * @param userPublicKey The public key of the user to evaluate access for.\n * @returns A promise that resolves to true if the key has access, false otherwise.\n */\n private async evaluateKeyAccess(\n key: proto.IKey,\n userPublicKey: PublicKey\n ): Promise<boolean> {\n if (key.ed25519) {\n return this.compareEd25519Key(key.ed25519, userPublicKey);\n }\n\n if (key.keyList) {\n return this.evaluateKeyList(key.keyList, userPublicKey);\n }\n\n if (key.thresholdKey && key.thresholdKey.keys) {\n return this.evaluateKeyList(key.thresholdKey.keys, userPublicKey);\n }\n\n return false;\n }\n\n /**\n * Evaluates the access of a given key list to a user's public key.\n * @param keyList The key list to evaluate access for.\n * @param userPublicKey The public key of the user to evaluate access for.\n * @returns A promise that resolves to true if the key list has access, false otherwise.\n */\n private async evaluateKeyList(\n keyList: proto.IKeyList,\n userPublicKey: PublicKey\n ): Promise<boolean> {\n const keys = keyList.keys || [];\n\n for (const listKey of keys) {\n if (!listKey) continue;\n\n if (listKey.ed25519) {\n if (this.compareEd25519Key(listKey.ed25519, userPublicKey)) {\n return true;\n }\n } else if (listKey.keyList || listKey.thresholdKey) {\n try {\n const nestedKeyBytes = proto.Key.encode({\n ...(listKey.keyList ? { keyList: listKey.keyList } : {}),\n ...(listKey.thresholdKey\n ? { thresholdKey: listKey.thresholdKey }\n : {}),\n }).finish();\n\n const hasNestedAccess = await this.checkKeyListAccess(\n Buffer.from(nestedKeyBytes),\n userPublicKey\n );\n\n if (hasNestedAccess) {\n return true;\n }\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error in nested key: ${error.message}`;\n this.logger.debug(logMessage);\n }\n }\n }\n\n return false;\n }\n\n /**\n * Compares an Ed25519 key with a user's public key.\n * @param keyData The Ed25519 key data to compare.\n * @param userPublicKey The public key of the user to compare with.\n * @returns A boolean indicating whether the key matches the user's public key.\n */\n private compareEd25519Key(\n keyData: Uint8Array,\n userPublicKey: PublicKey\n ): boolean {\n try {\n const decodedKey = PublicKey.fromBytes(Buffer.from(keyData));\n return decodedKey.toString() === userPublicKey.toString();\n } catch (e: any) {\n const error = e as Error;\n const logMessage = `Error comparing Ed25519 key: ${error.message}`;\n this.logger.debug(logMessage);\n return false;\n }\n }\n\n /**\n * Retrieves information about a scheduled transaction\n * @param scheduleId The ID of the scheduled transaction\n * @returns A promise that resolves to the scheduled transaction information\n */\n async getScheduleInfo(scheduleId: string): Promise<ScheduleInfo | null> {\n try {\n this.logger.info(\n `Getting information for scheduled transaction ${scheduleId}`\n );\n\n const url = `${this.baseUrl}/api/v1/schedules/${scheduleId}`;\n const data = await this._requestWithRetry<ScheduleInfo>(url);\n\n if (data) {\n return data;\n }\n\n this.logger.warn(\n `No schedule info found for ${scheduleId} after retries.`\n );\n return null;\n } catch (error: any) {\n this.logger.error(\n `Error fetching schedule info for ${scheduleId} after retries: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Checks the status of a scheduled transaction\n * @param scheduleId The schedule ID to check\n * @returns Status of the scheduled transaction\n */\n public async getScheduledTransactionStatus(scheduleId: string): Promise<{\n executed: boolean;\n executedDate?: Date;\n deleted: boolean;\n }> {\n try {\n this.logger.info(\n `Checking status of scheduled transaction ${scheduleId}`\n );\n\n const scheduleInfo = await this.getScheduleInfo(scheduleId);\n\n if (!scheduleInfo) {\n throw new Error(`Schedule ${scheduleId} not found`);\n }\n\n return {\n executed: Boolean(scheduleInfo.executed_timestamp),\n executedDate: scheduleInfo.executed_timestamp\n ? new Date(Number(scheduleInfo.executed_timestamp) * 1000)\n : undefined,\n deleted: scheduleInfo.deleted || false,\n };\n } catch (error) {\n this.logger.error(\n `Error checking scheduled transaction status: ${error}`\n );\n throw error;\n }\n }\n\n /**\n * Retrieves details for a given transaction ID or hash from the mirror node.\n * @param transactionIdOrHash The ID or hash of the transaction.\n * @returns A promise that resolves to the transaction details.\n * @throws An error if the transaction ID/hash is invalid or details cannot be retrieved.\n */\n async getTransaction(\n transactionIdOrHash: string\n ): Promise<HederaTransaction | null> {\n this.logger.info(\n `Getting transaction details for ID/hash: ${transactionIdOrHash}`\n );\n const endpoint = transactionIdOrHash.includes('-')\n ? `transactions/${transactionIdOrHash}`\n : `transactions/${transactionIdOrHash}`;\n\n const transactionDetailsUrl = `${this.baseUrl}/api/v1/${endpoint}`;\n\n try {\n const response = await this._requestWithRetry<{\n transactions: HederaTransaction[];\n }>(transactionDetailsUrl);\n\n if (response?.transactions?.length > 0) {\n this.logger.trace(\n `Transaction details found for ${transactionIdOrHash}:`,\n response.transactions[0]\n );\n return response.transactions[0];\n }\n\n this.logger.warn(\n `No transaction details found for ${transactionIdOrHash} or unexpected response structure.`\n );\n return null;\n } catch (e: any) {\n const error = e as Error;\n this.logger.error(\n `Failed to get transaction details for ${transactionIdOrHash} after retries: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Private helper to make GET requests with retry logic using Axios.\n */\n private async _requestWithRetry<T>(\n url: string,\n axiosConfig?: AxiosRequestConfig\n ): Promise<T> {\n let attempt = 0;\n let delay = this.initialDelayMs;\n\n while (attempt < this.maxRetries) {\n try {\n const response = await axios.get<T>(url, axiosConfig);\n return response.data;\n } catch (error: any) {\n attempt++;\n const isLastAttempt = attempt >= this.maxRetries;\n const statusCode = error.response?.status;\n\n if (\n statusCode &&\n statusCode >= 400 &&\n statusCode < 500 &&\n statusCode !== 429\n ) {\n this.logger.error(\n `Client error for ${url} (status ${statusCode}): ${error.message}. Not retrying.`\n );\n throw error;\n }\n\n if (isLastAttempt) {\n this.logger.error(\n `Max retries (${this.maxRetries}) reached for ${url}. Last error: ${error.message}`\n );\n throw error;\n }\n\n this.logger.warn(\n `Attempt ${attempt}/${this.maxRetries} failed for ${url}: ${error.message}. Retrying in ${delay}ms...`\n );\n await new Promise((resolve) => setTimeout(resolve, delay));\n delay = Math.min(delay * this.backoffFactor, this.maxDelayMs);\n }\n }\n\n throw new Error(\n `Failed to fetch data from ${url} after ${this.maxRetries} attempts.`\n );\n }\n\n /**\n * Private helper to make fetch requests with retry logic.\n */\n private async _fetchWithRetry<T>(\n url: string,\n fetchOptions?: RequestInit\n ): Promise<T> {\n let attempt = 0;\n let delay = this.initialDelayMs;\n\n while (attempt < this.maxRetries) {\n try {\n const request = await fetch(url, fetchOptions);\n if (!request.ok) {\n if (\n request.status >= 400 &&\n request.status < 500 &&\n request.status !== 429\n ) {\n this.logger.error(\n `Client error for ${url} (status ${request.status}): ${request.statusText}. Not retrying.`\n );\n throw new Error(\n `Fetch failed with status ${request.status}: ${request.statusText} for URL: ${url}`\n );\n }\n throw new Error(\n `Fetch failed with status ${request.status}: ${request.statusText} for URL: ${url}`\n );\n }\n const response = (await request.json()) as T;\n return response;\n } catch (error: any) {\n attempt++;\n if (attempt >= this.maxRetries) {\n this.logger.error(\n `Max retries (${this.maxRetries}) reached for ${url}. Last error: ${error.message}`\n );\n throw error;\n }\n this.logger.warn(\n `Attempt ${attempt}/${this.maxRetries} failed for ${url}: ${error.message}. Retrying in ${delay}ms...`\n );\n await new Promise((resolve) => setTimeout(resolve, delay));\n delay = Math.min(delay * this.backoffFactor, this.maxDelayMs);\n }\n }\n throw new Error(\n `Failed to fetch data from ${url} after ${this.maxRetries} attempts.`\n );\n }\n\n /**\n * Retrieves the numerical balance (in HBAR) for a given account ID.\n * @param accountId The ID of the account.\n * @returns A promise that resolves to the HBAR balance or null if an error occurs.\n */\n async getAccountBalanceNumerical(accountId: string): Promise<number | null> {\n this.logger.info(`Getting numerical balance for account ${accountId}`);\n try {\n const accountInfo = await this.requestAccount(accountId);\n if (accountInfo && accountInfo.balance) {\n const hbarBalance = accountInfo.balance.balance / 100_000_000;\n return hbarBalance;\n }\n this.logger.warn(\n `Could not retrieve balance for account ${accountId} from account info.`\n );\n return null;\n } catch (error: any) {\n this.logger.error(\n `Error fetching numerical balance for account ${accountId}: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Retrieves messages for a given topic ID with optional filters.\n * @param topicId The ID of the topic.\n * @param sequenceNumber Filter by sequence number (e.g., \"gt:10\", \"lte:20\").\n * @param startTime Filter by consensus timestamp (e.g., \"gt:1629400000.000000000\").\n * @param endTime Filter by consensus timestamp (e.g., \"lt:1629500000.000000000\").\n * @param limit The maximum number of messages to return.\n * @returns A promise that resolves to an array of HCSMessages or null.\n */\n async getTopicMessagesByFilter(\n topicId: string,\n options?: {\n sequenceNumber?: string;\n startTime?: string;\n endTime?: string;\n limit?: number;\n order?: 'asc' | 'desc';\n }\n ): Promise<HCSMessage[] | null> {\n this.logger.trace(\n `Querying messages for topic ${topicId} with filters: ${JSON.stringify(\n options\n )}`\n );\n\n let nextUrl = `${this.baseUrl}/api/v1/topics/${topicId}/messages`;\n const params = new URLSearchParams();\n\n if (options?.limit) {\n params.append('limit', options.limit.toString());\n }\n if (options?.sequenceNumber) {\n params.append('sequencenumber', options.sequenceNumber);\n }\n if (options?.startTime) {\n params.append('timestamp', `gte:${options.startTime}`);\n }\n if (options?.endTime) {\n params.append('timestamp', `lt:${options.endTime}`);\n }\n if (options?.order) {\n params.append('order', options.order);\n }\n\n const queryString = params.toString();\n if (queryString) {\n nextUrl += `?${queryString}`;\n }\n\n const messages: HCSMessage[] = [];\n let pagesFetched = 0;\n const maxPages = 10;\n\n try {\n while (nextUrl && pagesFetched < maxPages) {\n pagesFetched++;\n const data = await this._requestWithRetry<TopicMessagesResponse>(\n nextUrl\n );\n\n if (data.messages && data.messages.length > 0) {\n for (const message of data.messages) {\n try {\n if (!message.message) {\n continue;\n }\n let messageContent: string;\n if (this.isServerEnvironment) {\n messageContent = Buffer.from(\n message.message,\n 'base64'\n ).toString('utf-8');\n } else {\n messageContent = new TextDecoder().decode(\n Uint8Array.from(atob(message.message), (c) => c.charCodeAt(0))\n );\n }\n let messageJson = {};\n try {\n messageJson = JSON.parse(messageContent);\n } catch (parseError) {\n this.logger.debug(\n `Message content is not valid JSON, using raw: ${messageContent}`\n );\n messageJson = { raw_content: messageContent };\n }\n\n const parsedContent = messageJson as any;\n\n const hcsMsg: HCSMessage = {\n ...parsedContent,\n consensus_timestamp: message.consensus_timestamp,\n sequence_number: message.sequence_number,\n payer_account_id: message.payer_account_id,\n topic_id: message.topic_id,\n running_hash: message.running_hash,\n running_hash_version: message.running_hash_version,\n chunk_info: message.chunk_info,\n created: new Date(\n Number(message.consensus_timestamp.split('.')[0]) * 1000 +\n Number(message.consensus_timestamp.split('.')[1] || 0) /\n 1_000_000\n ),\n payer: message.payer_account_id,\n };\n\n messages.push(hcsMsg);\n } catch (error: any) {\n this.logger.error(\n `Error processing individual message: ${error.message}`\n );\n }\n }\n }\n if (options?.limit && messages.length >= options.limit) break;\n nextUrl = data.links?.next ? `${this.baseUrl}${data.links.next}` : '';\n }\n return messages;\n } catch (e: any) {\n const error = e as Error;\n this.logger.error(\n `Error querying filtered topic messages for ${topicId}: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Retrieves token balances for a given account ID.\n * @param accountId The ID of the account.\n * @param limit The maximum number of tokens to return.\n * @returns A promise that resolves to an array of AccountTokenBalance or null.\n */\n async getAccountTokens(\n accountId: string,\n limit: number = 100\n ): Promise<AccountTokenBalance[] | null> {\n this.logger.info(`Getting tokens for account ${accountId}`);\n let allTokens: AccountTokenBalance[] = [];\n let url = `${this.baseUrl}/api/v1/accounts/${accountId}/tokens?limit=${limit}`;\n\n try {\n for (let i = 0; i < 10 && url; i++) {\n const response = await this._requestWithRetry<AccountTokensResponse>(\n url\n );\n if (response && response.tokens) {\n allTokens = allTokens.concat(response.tokens);\n }\n url = response.links?.next\n ? `${this.baseUrl}${response.links.next}`\n : '';\n if (!url || (limit && allTokens.length >= limit)) {\n if (limit && allTokens.length > limit) {\n allTokens = allTokens.slice(0, limit);\n }\n break;\n }\n }\n return allTokens;\n } catch (error: any) {\n this.logger.error(\n `Error fetching tokens for account ${accountId}: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Retrieves transaction details by consensus timestamp.\n * @param timestamp The consensus timestamp of the transaction (e.g., \"1629400000.000000000\").\n * @returns A promise that resolves to the transaction details or null.\n */\n async getTransactionByTimestamp(\n timestamp: string\n ): Promise<HederaTransaction[]> {\n this.logger.info(`Getting transaction by timestamp: ${timestamp}`);\n const url = `${this.baseUrl}/api/v1/transactions?timestamp=${timestamp}&limit=1`;\n\n try {\n const response = await this._requestWithRetry<{\n transactions: HederaTransaction[];\n }>(url);\n\n return response.transactions;\n } catch (error: unknown) {\n this.logger.error(\n `Error fetching transaction by timestamp ${timestamp}: ${error}`\n );\n return [];\n }\n }\n\n /**\n * Retrieves NFTs for a given account ID, optionally filtered by token ID.\n * @param accountId The ID of the account.\n * @param tokenId Optional ID of the token to filter NFTs by.\n * @param limit The maximum number of NFTs to return per page (API has its own max).\n * @returns A promise that resolves to an array of NftDetail or null.\n */\n async getAccountNfts(\n accountId: string,\n tokenId?: string,\n limit: number = 100\n ): Promise<NftDetail[] | null> {\n this.logger.info(\n `Getting NFTs for account ${accountId}${\n tokenId ? ` for token ${tokenId}` : ''\n }`\n );\n let allNfts: NftDetail[] = [];\n let url = `${this.baseUrl}/api/v1/accounts/${accountId}/nfts?limit=${limit}`;\n if (tokenId) {\n url += `&token.id=${tokenId}`;\n }\n\n try {\n for (let i = 0; i < 10 && url; i++) {\n const response = await this._requestWithRetry<AccountNftsResponse>(url);\n if (response && response.nfts) {\n const nftsWithUri = response.nfts.map((nft) => {\n let tokenUri: string | undefined = undefined;\n if (nft.metadata) {\n try {\n if (this.isServerEnvironment) {\n tokenUri = Buffer.from(nft.metadata, 'base64').toString(\n 'utf-8'\n );\n } else {\n tokenUri = new TextDecoder().decode(\n Uint8Array.from(atob(nft.metadata), (c) => c.charCodeAt(0))\n );\n }\n } catch (e) {\n this.logger.warn(\n `Failed to decode metadata for NFT ${nft.token_id} SN ${\n nft.serial_number\n }: ${(e as Error).message}`\n );\n }\n }\n return { ...nft, token_uri: tokenUri };\n });\n allNfts = allNfts.concat(nftsWithUri);\n }\n url = response.links?.next\n ? `${this.baseUrl}${response.links.next}`\n : '';\n if (!url) break;\n }\n return allNfts;\n } catch (error: any) {\n this.logger.error(\n `Error fetching NFTs for account ${accountId}: ${error.message}`\n );\n return null;\n }\n }\n\n /**\n * Validates NFT ownership by checking if a specific serial number of a token ID exists for an account.\n * @param accountId The ID of the account.\n * @param tokenId The ID of the NFT's token.\n * @param serialNumber The serial number of the NFT.\n * @returns A promise that resolves to the NftDetail if owned, or null otherwise.\n */\n async validateNFTOwnership(\n accountId: string,\n tokenId: string,\n serialNumber: number\n ): Promise<NftDetail | null> {\n this.logger.info(\n `Validating ownership of NFT ${tokenId} SN ${serialNumber} for account ${accountId}`\n );\n try {\n const nfts = await this.getAccountNfts(accountId, tokenId);\n if (nfts) {\n const foundNft = nfts.find(\n (nft) =>\n nft.token_id === tokenId && nft.serial_number === serialNumber\n );\n return foundNft || null;\n }\n return null;\n } catch (error: any) {\n this.logger.error(`Error validating NFT ownership: ${error.message}`);\n return null;\n }\n }\n\n /**\n * Performs a read-only query against a smart contract (eth_call like).\n * @param contractIdOrAddress The contract ID (e.g., \"0.0.123\") or EVM address (e.g., \"0x...\").\n * @param functionSelector The function selector and encoded parameters (e.g., \"0xabcdef12...\").\n * @param payerAccountId The account ID of the payer (not strictly payer for read-only, but often required as 'from').\n * @param estimate Whether this is an estimate call. Mirror node might not support this directly in /contracts/call for true estimation.\n * @param block Block parameter, e.g., \"latest\", \"pending\", or block number.\n * @param value The value in tinybars to send with the call (for payable view/pure functions, usually 0).\n * @returns A promise that resolves to the contract call query response or null.\n */\n async readSmartContractQuery(\n contractIdOrAddress: string,\n functionSelector: string,\n payerAccountId: string,\n options?: {\n estimate?: boolean;\n block?: string;\n value?: number;\n gas?: number;\n gasPrice?: number;\n }\n ): Promise<ContractCallQueryResponse | null> {\n this.logger.info(\n `Reading smart contract ${contractIdOrAddress} with selector ${functionSelector}`\n );\n const url = `${this.baseUrl}/api/v1/contracts/call`;\n\n const toAddress = contractIdOrAddress.startsWith('0x')\n ? contractIdOrAddress\n : `0x${AccountId.fromString(contractIdOrAddress).toSolidityAddress()}`;\n const fromAddress = payerAccountId.startsWith('0x')\n ? payerAccountId\n : `0x${AccountId.fromString(payerAccountId).toSolidityAddress()}`;\n\n const body: any = {\n block: options?.block || 'latest',\n data: functionSelector,\n estimate: options?.estimate || false,\n from: fromAddress,\n to: toAddress,\n gas: options?.gas,\n gasPrice: options?.gasPrice,\n value: options?.value || 0,\n };\n\n Object.keys(body).forEach((key) => {\n const K = key as keyof typeof body;\n if (body[K] === undefined) {\n delete body[K];\n }\n });\n\n try {\n const response = await this._fetchWithRetry<ContractCallQueryResponse>(\n url,\n {\n method: 'POST',\n body: JSON.stringify(body),\n headers: {\n 'Content-Type': 'application/json',\n },\n }\n );\n return response;\n } catch (error: any) {\n this.logger.error(\n `Error reading smart contract ${contractIdOrAddress}: ${error.message}`\n );\n return null;\n }\n }\n}\n"],"names":[],"mappings":"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"}
@@ -10,16 +10,16 @@ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot
10
10
  var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
11
11
  var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
12
12
  var _errors, _events, _functions, _abiCoder, _Interface_instances, getFunction_fn, getEvent_fn;
13
- import { keccak256 } from "./standards-sdk.es54.js";
14
- import { AbiCoder } from "./standards-sdk.es36.js";
15
- import { Result } from "./standards-sdk.es37.js";
16
- import { Fragment, ConstructorFragment, FunctionFragment, EventFragment, ErrorFragment, ParamType } from "./standards-sdk.es47.js";
13
+ import { keccak256 } from "./standards-sdk.es37.js";
14
+ import { AbiCoder } from "./standards-sdk.es40.js";
15
+ import { Result } from "./standards-sdk.es41.js";
16
+ import { Fragment, ConstructorFragment, FunctionFragment, EventFragment, ErrorFragment, ParamType } from "./standards-sdk.es51.js";
17
17
  import { Typed } from "./standards-sdk.es55.js";
18
- import { defineProperties } from "./standards-sdk.es51.js";
19
- import { assertArgument, assert } from "./standards-sdk.es48.js";
20
- import { isHexString, dataSlice, concat, getBytesCopy, hexlify, getBytes, zeroPadBytes, zeroPadValue } from "./standards-sdk.es49.js";
21
- import { id } from "./standards-sdk.es52.js";
22
- import { getBigInt, toBeHex } from "./standards-sdk.es53.js";
18
+ import { defineProperties } from "./standards-sdk.es52.js";
19
+ import { assertArgument, assert } from "./standards-sdk.es38.js";
20
+ import { isHexString, dataSlice, concat, getBytesCopy, hexlify, getBytes, zeroPadBytes, zeroPadValue } from "./standards-sdk.es39.js";
21
+ import { id } from "./standards-sdk.es53.js";
22
+ import { getBigInt, toBeHex } from "./standards-sdk.es54.js";
23
23
  class LogDescription {
24
24
  /**
25
25
  * @_ignore:
@@ -1,4 +1,4 @@
1
- import { __require as requireMimeTypes } from "./standards-sdk.es58.js";
1
+ import { __require as requireMimeTypes } from "./standards-sdk.es59.js";
2
2
  var mimeTypesExports = requireMimeTypes();
3
3
  export {
4
4
  mimeTypesExports as m
@@ -5287,7 +5287,7 @@ class FileTypeParser {
5287
5287
  }
5288
5288
  }
5289
5289
  async toDetectionStream(readableStream, options = {}) {
5290
- const { default: stream } = await import("./standards-sdk.es69.js").then((n) => n.i);
5290
+ const { default: stream } = await import("./standards-sdk.es58.js").then((n) => n.i);
5291
5291
  const { sampleSize = minimumBytes } = options;
5292
5292
  return new Promise((resolve, reject) => {
5293
5293
  readableStream.on("error", reject);
@@ -1,12 +1,39 @@
1
- import toInteger from "./standards-sdk.es71.js";
2
- import addMilliseconds from "./standards-sdk.es70.js";
3
- import requiredArgs from "./standards-sdk.es73.js";
4
- function addSeconds(dirtyDate, dirtyAmount) {
5
- requiredArgs(2, arguments);
6
- var amount = toInteger(dirtyAmount);
7
- return addMilliseconds(dirtyDate, amount * 1e3);
8
- }
1
+ import axios from "./standards-sdk.es30.js";
2
+ const {
3
+ Axios,
4
+ AxiosError,
5
+ CanceledError,
6
+ isCancel,
7
+ CancelToken,
8
+ VERSION,
9
+ all,
10
+ Cancel,
11
+ isAxiosError,
12
+ spread,
13
+ toFormData,
14
+ AxiosHeaders,
15
+ HttpStatusCode,
16
+ formToJSON,
17
+ getAdapter,
18
+ mergeConfig
19
+ } = axios;
9
20
  export {
10
- addSeconds as default
21
+ Axios,
22
+ AxiosError,
23
+ AxiosHeaders,
24
+ Cancel,
25
+ CancelToken,
26
+ CanceledError,
27
+ HttpStatusCode,
28
+ VERSION,
29
+ all,
30
+ axios as default,
31
+ formToJSON,
32
+ getAdapter,
33
+ isAxiosError,
34
+ isCancel,
35
+ mergeConfig,
36
+ spread,
37
+ toFormData
11
38
  };
12
39
  //# sourceMappingURL=standards-sdk.es29.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es29.js","sources":["../../node_modules/date-fns/esm/addSeconds/index.js"],"sourcesContent":["import toInteger from \"../_lib/toInteger/index.js\";\nimport addMilliseconds from \"../addMilliseconds/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name addSeconds\n * @category Second Helpers\n * @summary Add the specified number of seconds to the given date.\n *\n * @description\n * Add the specified number of seconds to the given date.\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of seconds to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} the new date with the seconds added\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Add 30 seconds to 10 July 2014 12:45:00:\n * const result = addSeconds(new Date(2014, 6, 10, 12, 45, 0), 30)\n * //=> Thu Jul 10 2014 12:45:30\n */\nexport default function addSeconds(dirtyDate, dirtyAmount) {\n requiredArgs(2, arguments);\n var amount = toInteger(dirtyAmount);\n return addMilliseconds(dirtyDate, amount * 1000);\n}"],"names":[],"mappings":";;;AAqBe,SAAS,WAAW,WAAW,aAAa;AACzD,eAAa,GAAG,SAAS;AACzB,MAAI,SAAS,UAAU,WAAW;AAClC,SAAO,gBAAgB,WAAW,SAAS,GAAI;AACjD;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"standards-sdk.es29.js","sources":["../../node_modules/axios/index.js"],"sourcesContent":["import axios from './lib/axios.js';\n\n// This module is intended to unwrap Axios default export as named.\n// Keep top-level export same with static properties\n// so that it can keep same with es module or cjs\nconst {\n Axios,\n AxiosError,\n CanceledError,\n isCancel,\n CancelToken,\n VERSION,\n all,\n Cancel,\n isAxiosError,\n spread,\n toFormData,\n AxiosHeaders,\n HttpStatusCode,\n formToJSON,\n getAdapter,\n mergeConfig\n} = axios;\n\nexport {\n axios as default,\n Axios,\n AxiosError,\n CanceledError,\n isCancel,\n CancelToken,\n VERSION,\n all,\n Cancel,\n isAxiosError,\n spread,\n toFormData,\n AxiosHeaders,\n HttpStatusCode,\n formToJSON,\n getAdapter,\n mergeConfig\n}\n"],"names":[],"mappings":";AAKK,MAAC;AAAA,EACJ;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,IAAI;","x_google_ignoreList":[0]}