@ercworldio/blockchain-shared 1.0.0-dev.10

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 (680) hide show
  1. package/README.md +1 -0
  2. package/build/chains/ChainDefinition.d.ts +2 -0
  3. package/build/chains/ChainDefinition.d.ts.map +1 -0
  4. package/build/chains/ChainDefinition.js +84 -0
  5. package/build/chains/Provider.d.ts +20 -0
  6. package/build/chains/Provider.d.ts.map +1 -0
  7. package/build/chains/Provider.js +85 -0
  8. package/build/chains/RPC.d.ts +34 -0
  9. package/build/chains/RPC.d.ts.map +1 -0
  10. package/build/chains/RPC.js +147 -0
  11. package/build/chains/chain_to_ticker.json +28 -0
  12. package/build/chains/chains.json +513 -0
  13. package/build/chains/chains_stg-bu.json +513 -0
  14. package/build/chains/chains_v2.json +494 -0
  15. package/build/chains/escrow-contracts/10143.json +8 -0
  16. package/build/chains/escrow-contracts/97.json +8 -0
  17. package/build/chains/event_listener_config_escrows.json +699 -0
  18. package/build/chains/networks_dev.json +669 -0
  19. package/build/chains/networks_prod-bu.json +568 -0
  20. package/build/chains/networks_prod-dz.json +510 -0
  21. package/build/chains/networks_prod.json +553 -0
  22. package/build/chains/networks_stg-bu.json +568 -0
  23. package/build/chains/networks_stg-dz.json +451 -0
  24. package/build/chains/networks_stg.json +541 -0
  25. package/build/chains/networks_stg_drizzle.json +130 -0
  26. package/build/chains/rpcs.d.ts +30 -0
  27. package/build/chains/rpcs.d.ts.map +1 -0
  28. package/build/chains/rpcs.js +138 -0
  29. package/build/constants.d.ts +34 -0
  30. package/build/constants.d.ts.map +1 -0
  31. package/build/constants.js +40 -0
  32. package/build/contracts/Escrow.d.ts +162 -0
  33. package/build/contracts/Escrow.d.ts.map +1 -0
  34. package/build/contracts/Escrow.js +359 -0
  35. package/build/contracts/EscrowErrors.d.ts +75 -0
  36. package/build/contracts/EscrowErrors.d.ts.map +1 -0
  37. package/build/contracts/EscrowErrors.js +47 -0
  38. package/build/contracts/artifacts/ERC20Mock.json +344 -0
  39. package/build/contracts/artifacts/Erc20.json +344 -0
  40. package/build/contracts/artifacts/ErrorAbi.json +1847 -0
  41. package/build/contracts/artifacts/Escrow.json +1545 -0
  42. package/build/contracts/contract-events/AccessControlEvents.d.ts +51 -0
  43. package/build/contracts/contract-events/AccessControlEvents.d.ts.map +1 -0
  44. package/build/contracts/contract-events/AccessControlEvents.js +83 -0
  45. package/build/contracts/contract-events/CoverageInfo.d.ts +16 -0
  46. package/build/contracts/contract-events/CoverageInfo.d.ts.map +1 -0
  47. package/build/contracts/contract-events/CoverageInfo.js +135 -0
  48. package/build/contracts/contract-events/Erc20Events.d.ts +23 -0
  49. package/build/contracts/contract-events/Erc20Events.d.ts.map +1 -0
  50. package/build/contracts/contract-events/Erc20Events.js +52 -0
  51. package/build/contracts/contract-events/EscrowEvents.d.ts +64 -0
  52. package/build/contracts/contract-events/EscrowEvents.d.ts.map +1 -0
  53. package/build/contracts/contract-events/EscrowEvents.js +142 -0
  54. package/build/contracts/contract-events/types/AccessControlEvents.d.ts +9 -0
  55. package/build/contracts/contract-events/types/AccessControlEvents.d.ts.map +1 -0
  56. package/build/contracts/contract-events/types/AccessControlEvents.js +2 -0
  57. package/build/contracts/contract-events/types/events.d.ts +24 -0
  58. package/build/contracts/contract-events/types/events.d.ts.map +1 -0
  59. package/build/contracts/contract-events/types/events.js +2 -0
  60. package/build/contracts/deployment/avalanche/contracts.json +37 -0
  61. package/build/contracts/deployment/bitlayer/contracts.json +50 -0
  62. package/build/contracts/deployment/bsc/contracts.json +62 -0
  63. package/build/contracts/deployment/config.d.ts +4 -0
  64. package/build/contracts/deployment/config.d.ts.map +1 -0
  65. package/build/contracts/deployment/config.js +19 -0
  66. package/build/contracts/deployment/fantom/contracts.json +61 -0
  67. package/build/contracts/deployment/mumbai/contracts.json +43 -0
  68. package/build/contracts/deployment/polygon/contracts.json +43 -0
  69. package/build/contracts/deployment/sepolia/contracts.json +62 -0
  70. package/build/contracts/typechain-types/@openzeppelin/contracts/access/AccessControl.d.ts +160 -0
  71. package/build/contracts/typechain-types/@openzeppelin/contracts/access/AccessControl.d.ts.map +1 -0
  72. package/build/contracts/typechain-types/@openzeppelin/contracts/access/AccessControl.js +2 -0
  73. package/build/contracts/typechain-types/@openzeppelin/contracts/access/IAccessControl.d.ts +148 -0
  74. package/build/contracts/typechain-types/@openzeppelin/contracts/access/IAccessControl.d.ts.map +1 -0
  75. package/build/contracts/typechain-types/@openzeppelin/contracts/access/IAccessControl.js +2 -0
  76. package/build/contracts/typechain-types/@openzeppelin/contracts/access/Ownable.d.ts +55 -0
  77. package/build/contracts/typechain-types/@openzeppelin/contracts/access/Ownable.d.ts.map +1 -0
  78. package/build/contracts/typechain-types/@openzeppelin/contracts/access/Ownable.js +2 -0
  79. package/build/contracts/typechain-types/@openzeppelin/contracts/access/index.d.ts +4 -0
  80. package/build/contracts/typechain-types/@openzeppelin/contracts/access/index.d.ts.map +1 -0
  81. package/build/contracts/typechain-types/@openzeppelin/contracts/access/index.js +2 -0
  82. package/build/contracts/typechain-types/@openzeppelin/contracts/index.d.ts +9 -0
  83. package/build/contracts/typechain-types/@openzeppelin/contracts/index.d.ts.map +1 -0
  84. package/build/contracts/typechain-types/@openzeppelin/contracts/index.js +2 -0
  85. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/IERC5267.d.ts +79 -0
  86. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/IERC5267.d.ts.map +1 -0
  87. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/IERC5267.js +2 -0
  88. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC1155Errors.d.ts +21 -0
  89. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC1155Errors.d.ts.map +1 -0
  90. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC1155Errors.js +2 -0
  91. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC20Errors.d.ts +21 -0
  92. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC20Errors.d.ts.map +1 -0
  93. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC20Errors.js +2 -0
  94. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC721Errors.d.ts +21 -0
  95. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC721Errors.d.ts.map +1 -0
  96. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC721Errors.js +2 -0
  97. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/index.d.ts +4 -0
  98. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/index.d.ts.map +1 -0
  99. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/index.js +2 -0
  100. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/index.d.ts +4 -0
  101. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/index.d.ts.map +1 -0
  102. package/build/contracts/typechain-types/@openzeppelin/contracts/interfaces/index.js +2 -0
  103. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/ERC20.d.ts +142 -0
  104. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/ERC20.d.ts.map +1 -0
  105. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/ERC20.js +2 -0
  106. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/IERC20.d.ts +130 -0
  107. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/IERC20.d.ts.map +1 -0
  108. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/IERC20.js +2 -0
  109. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.d.ts +142 -0
  110. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.d.ts.map +1 -0
  111. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.js +2 -0
  112. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/extensions/index.d.ts +2 -0
  113. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/extensions/index.d.ts.map +1 -0
  114. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/extensions/index.js +2 -0
  115. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/index.d.ts +5 -0
  116. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/index.d.ts.map +1 -0
  117. package/build/contracts/typechain-types/@openzeppelin/contracts/token/ERC20/index.js +2 -0
  118. package/build/contracts/typechain-types/@openzeppelin/contracts/token/index.d.ts +3 -0
  119. package/build/contracts/typechain-types/@openzeppelin/contracts/token/index.d.ts.map +1 -0
  120. package/build/contracts/typechain-types/@openzeppelin/contracts/token/index.js +2 -0
  121. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/ShortStrings.d.ts +21 -0
  122. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/ShortStrings.d.ts.map +1 -0
  123. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/ShortStrings.js +2 -0
  124. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/Strings.d.ts +21 -0
  125. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/Strings.d.ts.map +1 -0
  126. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/Strings.js +2 -0
  127. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/cryptography/EIP712.d.ts +79 -0
  128. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/cryptography/EIP712.d.ts.map +1 -0
  129. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/cryptography/EIP712.js +2 -0
  130. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/cryptography/index.d.ts +2 -0
  131. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/cryptography/index.d.ts.map +1 -0
  132. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/cryptography/index.js +2 -0
  133. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/index.d.ts +9 -0
  134. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/index.d.ts.map +1 -0
  135. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/index.js +2 -0
  136. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/introspection/ERC165.d.ts +30 -0
  137. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/introspection/ERC165.d.ts.map +1 -0
  138. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/introspection/ERC165.js +2 -0
  139. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/introspection/IERC165.d.ts +30 -0
  140. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/introspection/IERC165.d.ts.map +1 -0
  141. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/introspection/IERC165.js +2 -0
  142. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/introspection/index.d.ts +3 -0
  143. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/introspection/index.d.ts.map +1 -0
  144. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/introspection/index.js +2 -0
  145. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/math/SafeCast.d.ts +21 -0
  146. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/math/SafeCast.d.ts.map +1 -0
  147. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/math/SafeCast.js +2 -0
  148. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/math/index.d.ts +2 -0
  149. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/math/index.d.ts.map +1 -0
  150. package/build/contracts/typechain-types/@openzeppelin/contracts/utils/math/index.js +2 -0
  151. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/index.d.ts +3 -0
  152. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/index.d.ts.map +1 -0
  153. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/index.js +2 -0
  154. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/proxy/index.d.ts +3 -0
  155. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/proxy/index.d.ts.map +1 -0
  156. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/proxy/index.js +2 -0
  157. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.d.ts +37 -0
  158. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.d.ts.map +1 -0
  159. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.js +2 -0
  160. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/proxy/utils/index.d.ts +2 -0
  161. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/proxy/utils/index.d.ts.map +1 -0
  162. package/build/contracts/typechain-types/@openzeppelin/contracts-upgradeable/proxy/utils/index.js +2 -0
  163. package/build/contracts/typechain-types/@openzeppelin/index.d.ts +5 -0
  164. package/build/contracts/typechain-types/@openzeppelin/index.d.ts.map +1 -0
  165. package/build/contracts/typechain-types/@openzeppelin/index.js +2 -0
  166. package/build/contracts/typechain-types/common.d.ts +51 -0
  167. package/build/contracts/typechain-types/common.d.ts.map +1 -0
  168. package/build/contracts/typechain-types/common.js +2 -0
  169. package/build/contracts/typechain-types/contracts/escrow/Escrow.d.ts +856 -0
  170. package/build/contracts/typechain-types/contracts/escrow/Escrow.d.ts.map +1 -0
  171. package/build/contracts/typechain-types/contracts/escrow/Escrow.js +2 -0
  172. package/build/contracts/typechain-types/contracts/escrow/EscrowAccessControl.d.ts +218 -0
  173. package/build/contracts/typechain-types/contracts/escrow/EscrowAccessControl.d.ts.map +1 -0
  174. package/build/contracts/typechain-types/contracts/escrow/EscrowAccessControl.js +2 -0
  175. package/build/contracts/typechain-types/contracts/escrow/EscrowErrors.d.ts +21 -0
  176. package/build/contracts/typechain-types/contracts/escrow/EscrowErrors.d.ts.map +1 -0
  177. package/build/contracts/typechain-types/contracts/escrow/EscrowErrors.js +2 -0
  178. package/build/contracts/typechain-types/contracts/escrow/EscrowSignature.d.ts +120 -0
  179. package/build/contracts/typechain-types/contracts/escrow/EscrowSignature.d.ts.map +1 -0
  180. package/build/contracts/typechain-types/contracts/escrow/EscrowSignature.js +2 -0
  181. package/build/contracts/typechain-types/contracts/escrow/TokensWhitelist.d.ts +82 -0
  182. package/build/contracts/typechain-types/contracts/escrow/TokensWhitelist.d.ts.map +1 -0
  183. package/build/contracts/typechain-types/contracts/escrow/TokensWhitelist.js +2 -0
  184. package/build/contracts/typechain-types/contracts/escrow/index.d.ts +6 -0
  185. package/build/contracts/typechain-types/contracts/escrow/index.d.ts.map +1 -0
  186. package/build/contracts/typechain-types/contracts/escrow/index.js +2 -0
  187. package/build/contracts/typechain-types/contracts/index.d.ts +5 -0
  188. package/build/contracts/typechain-types/contracts/index.d.ts.map +1 -0
  189. package/build/contracts/typechain-types/contracts/index.js +2 -0
  190. package/build/contracts/typechain-types/contracts/mock/erc20/ERC20Mock.d.ts +146 -0
  191. package/build/contracts/typechain-types/contracts/mock/erc20/ERC20Mock.d.ts.map +1 -0
  192. package/build/contracts/typechain-types/contracts/mock/erc20/ERC20Mock.js +2 -0
  193. package/build/contracts/typechain-types/contracts/mock/erc20/index.d.ts +2 -0
  194. package/build/contracts/typechain-types/contracts/mock/erc20/index.d.ts.map +1 -0
  195. package/build/contracts/typechain-types/contracts/mock/erc20/index.js +2 -0
  196. package/build/contracts/typechain-types/contracts/mock/index.d.ts +3 -0
  197. package/build/contracts/typechain-types/contracts/mock/index.d.ts.map +1 -0
  198. package/build/contracts/typechain-types/contracts/mock/index.js +2 -0
  199. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/AccessControl__factory.d.ts +182 -0
  200. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/AccessControl__factory.d.ts.map +1 -0
  201. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/AccessControl__factory.js +244 -0
  202. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/IAccessControl__factory.d.ts +158 -0
  203. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/IAccessControl__factory.d.ts.map +1 -0
  204. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/IAccessControl__factory.js +212 -0
  205. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/Ownable__factory.d.ts +65 -0
  206. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/Ownable__factory.d.ts.map +1 -0
  207. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/Ownable__factory.js +93 -0
  208. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/index.d.ts +4 -0
  209. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/index.d.ts.map +1 -0
  210. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/access/index.js +12 -0
  211. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/index.d.ts +5 -0
  212. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/index.d.ts.map +1 -0
  213. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/index.js +43 -0
  214. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/IERC5267__factory.d.ts +47 -0
  215. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/IERC5267__factory.d.ts.map +1 -0
  216. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/IERC5267__factory.js +68 -0
  217. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC1155Errors__factory.d.ts +84 -0
  218. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC1155Errors__factory.d.ts.map +1 -0
  219. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC1155Errors__factory.js +121 -0
  220. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC20Errors__factory.d.ts +72 -0
  221. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC20Errors__factory.d.ts.map +1 -0
  222. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC20Errors__factory.js +105 -0
  223. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC721Errors__factory.d.ts +84 -0
  224. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC721Errors__factory.d.ts.map +1 -0
  225. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/IERC721Errors__factory.js +122 -0
  226. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/index.d.ts +4 -0
  227. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/index.d.ts.map +1 -0
  228. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/draft-IERC6093.sol/index.js +12 -0
  229. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/index.d.ts +3 -0
  230. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/index.d.ts.map +1 -0
  231. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/interfaces/index.js +42 -0
  232. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/ERC20__factory.d.ts +242 -0
  233. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/ERC20__factory.d.ts.map +1 -0
  234. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/ERC20__factory.js +327 -0
  235. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/IERC20__factory.d.ts +148 -0
  236. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/IERC20__factory.d.ts.map +1 -0
  237. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/IERC20__factory.js +202 -0
  238. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata__factory.d.ts +178 -0
  239. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata__factory.d.ts.map +1 -0
  240. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata__factory.js +241 -0
  241. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/extensions/index.d.ts +2 -0
  242. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/extensions/index.d.ts.map +1 -0
  243. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/extensions/index.js +8 -0
  244. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/index.d.ts +4 -0
  245. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/index.d.ts.map +1 -0
  246. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/ERC20/index.js +44 -0
  247. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/index.d.ts +2 -0
  248. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/index.d.ts.map +1 -0
  249. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/token/index.js +40 -0
  250. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/ShortStrings__factory.d.ts +35 -0
  251. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/ShortStrings__factory.d.ts.map +1 -0
  252. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/ShortStrings__factory.js +55 -0
  253. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/Strings__factory.d.ts +43 -0
  254. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/Strings__factory.d.ts.map +1 -0
  255. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/Strings__factory.js +65 -0
  256. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/cryptography/EIP712__factory.d.ts +59 -0
  257. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/cryptography/EIP712__factory.d.ts.map +1 -0
  258. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/cryptography/EIP712__factory.js +84 -0
  259. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/cryptography/index.d.ts +2 -0
  260. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/cryptography/index.d.ts.map +1 -0
  261. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/cryptography/index.js +8 -0
  262. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/index.d.ts +6 -0
  263. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/index.d.ts.map +1 -0
  264. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/index.js +46 -0
  265. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/introspection/ERC165__factory.d.ts +22 -0
  266. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/introspection/ERC165__factory.d.ts.map +1 -0
  267. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/introspection/ERC165__factory.js +38 -0
  268. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/introspection/IERC165__factory.d.ts +22 -0
  269. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/introspection/IERC165__factory.d.ts.map +1 -0
  270. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/introspection/IERC165__factory.js +38 -0
  271. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/introspection/index.d.ts +3 -0
  272. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/introspection/index.d.ts.map +1 -0
  273. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/introspection/index.js +10 -0
  274. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/math/SafeCast__factory.d.ts +63 -0
  275. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/math/SafeCast__factory.d.ts.map +1 -0
  276. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/math/SafeCast__factory.js +93 -0
  277. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/math/index.d.ts +2 -0
  278. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/math/index.d.ts.map +1 -0
  279. package/build/contracts/typechain-types/factories/@openzeppelin/contracts/utils/math/index.js +8 -0
  280. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/index.d.ts +2 -0
  281. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/index.d.ts.map +1 -0
  282. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/index.js +40 -0
  283. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/proxy/index.d.ts +2 -0
  284. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/proxy/index.d.ts.map +1 -0
  285. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/proxy/index.js +40 -0
  286. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable__factory.d.ts +26 -0
  287. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable__factory.d.ts.map +1 -0
  288. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable__factory.js +42 -0
  289. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/proxy/utils/index.d.ts +2 -0
  290. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/proxy/utils/index.d.ts.map +1 -0
  291. package/build/contracts/typechain-types/factories/@openzeppelin/contracts-upgradeable/proxy/utils/index.js +8 -0
  292. package/build/contracts/typechain-types/factories/@openzeppelin/index.d.ts +3 -0
  293. package/build/contracts/typechain-types/factories/@openzeppelin/index.d.ts.map +1 -0
  294. package/build/contracts/typechain-types/factories/@openzeppelin/index.js +41 -0
  295. package/build/contracts/typechain-types/factories/contracts/escrow/EscrowAccessControl__factory.d.ts +415 -0
  296. package/build/contracts/typechain-types/factories/contracts/escrow/EscrowAccessControl__factory.d.ts.map +1 -0
  297. package/build/contracts/typechain-types/factories/contracts/escrow/EscrowAccessControl__factory.js +547 -0
  298. package/build/contracts/typechain-types/factories/contracts/escrow/EscrowErrors__factory.d.ts +151 -0
  299. package/build/contracts/typechain-types/factories/contracts/escrow/EscrowErrors__factory.d.ts.map +1 -0
  300. package/build/contracts/typechain-types/factories/contracts/escrow/EscrowErrors__factory.js +205 -0
  301. package/build/contracts/typechain-types/factories/contracts/escrow/EscrowSignature__factory.d.ts +151 -0
  302. package/build/contracts/typechain-types/factories/contracts/escrow/EscrowSignature__factory.d.ts.map +1 -0
  303. package/build/contracts/typechain-types/factories/contracts/escrow/EscrowSignature__factory.js +205 -0
  304. package/build/contracts/typechain-types/factories/contracts/escrow/Escrow__factory.d.ts +1217 -0
  305. package/build/contracts/typechain-types/factories/contracts/escrow/Escrow__factory.d.ts.map +1 -0
  306. package/build/contracts/typechain-types/factories/contracts/escrow/Escrow__factory.js +1582 -0
  307. package/build/contracts/typechain-types/factories/contracts/escrow/TokensWhitelist__factory.d.ts +99 -0
  308. package/build/contracts/typechain-types/factories/contracts/escrow/TokensWhitelist__factory.d.ts.map +1 -0
  309. package/build/contracts/typechain-types/factories/contracts/escrow/TokensWhitelist__factory.js +139 -0
  310. package/build/contracts/typechain-types/factories/contracts/escrow/index.d.ts +6 -0
  311. package/build/contracts/typechain-types/factories/contracts/escrow/index.d.ts.map +1 -0
  312. package/build/contracts/typechain-types/factories/contracts/escrow/index.js +16 -0
  313. package/build/contracts/typechain-types/factories/contracts/index.d.ts +3 -0
  314. package/build/contracts/typechain-types/factories/contracts/index.d.ts.map +1 -0
  315. package/build/contracts/typechain-types/factories/contracts/index.js +41 -0
  316. package/build/contracts/typechain-types/factories/contracts/mock/erc20/ERC20Mock__factory.d.ts +283 -0
  317. package/build/contracts/typechain-types/factories/contracts/mock/erc20/ERC20Mock__factory.d.ts.map +1 -0
  318. package/build/contracts/typechain-types/factories/contracts/mock/erc20/ERC20Mock__factory.js +381 -0
  319. package/build/contracts/typechain-types/factories/contracts/mock/erc20/index.d.ts +2 -0
  320. package/build/contracts/typechain-types/factories/contracts/mock/erc20/index.d.ts.map +1 -0
  321. package/build/contracts/typechain-types/factories/contracts/mock/erc20/index.js +8 -0
  322. package/build/contracts/typechain-types/factories/contracts/mock/index.d.ts +2 -0
  323. package/build/contracts/typechain-types/factories/contracts/mock/index.d.ts.map +1 -0
  324. package/build/contracts/typechain-types/factories/contracts/mock/index.js +40 -0
  325. package/build/contracts/typechain-types/factories/index.d.ts +3 -0
  326. package/build/contracts/typechain-types/factories/index.d.ts.map +1 -0
  327. package/build/contracts/typechain-types/factories/index.js +41 -0
  328. package/build/contracts/typechain-types/index.d.ts +52 -0
  329. package/build/contracts/typechain-types/index.d.ts.map +1 -0
  330. package/build/contracts/typechain-types/index.js +83 -0
  331. package/build/contracts/types/escrow.d.ts +42 -0
  332. package/build/contracts/types/escrow.d.ts.map +1 -0
  333. package/build/contracts/types/escrow.js +20 -0
  334. package/build/entities/Checkpoint.d.ts +11 -0
  335. package/build/entities/Checkpoint.d.ts.map +1 -0
  336. package/build/entities/Checkpoint.js +52 -0
  337. package/build/entities/ClaimHistory.d.ts +17 -0
  338. package/build/entities/ClaimHistory.d.ts.map +1 -0
  339. package/build/entities/ClaimHistory.js +73 -0
  340. package/build/entities/ClaimJob.d.ts +27 -0
  341. package/build/entities/ClaimJob.d.ts.map +1 -0
  342. package/build/entities/ClaimJob.js +113 -0
  343. package/build/entities/CryptoConfirmationLocks.d.ts +14 -0
  344. package/build/entities/CryptoConfirmationLocks.d.ts.map +1 -0
  345. package/build/entities/CryptoConfirmationLocks.js +65 -0
  346. package/build/entities/DepositAddress.d.ts +12 -0
  347. package/build/entities/DepositAddress.d.ts.map +1 -0
  348. package/build/entities/DepositAddress.js +56 -0
  349. package/build/entities/DepositWalletBalance.d.ts +16 -0
  350. package/build/entities/DepositWalletBalance.d.ts.map +1 -0
  351. package/build/entities/DepositWalletBalance.js +72 -0
  352. package/build/entities/SweepHistory.d.ts +16 -0
  353. package/build/entities/SweepHistory.d.ts.map +1 -0
  354. package/build/entities/SweepHistory.js +72 -0
  355. package/build/entities/SweepJob.d.ts +26 -0
  356. package/build/entities/SweepJob.d.ts.map +1 -0
  357. package/build/entities/SweepJob.js +116 -0
  358. package/build/entities/WalletIndex.d.ts +8 -0
  359. package/build/entities/WalletIndex.d.ts.map +1 -0
  360. package/build/entities/WalletIndex.js +40 -0
  361. package/build/errors/AdminErrors.d.ts +25 -0
  362. package/build/errors/AdminErrors.d.ts.map +1 -0
  363. package/build/errors/AdminErrors.js +45 -0
  364. package/build/errors/AlchemyErrors.d.ts +34 -0
  365. package/build/errors/AlchemyErrors.d.ts.map +1 -0
  366. package/build/errors/AlchemyErrors.js +79 -0
  367. package/build/errors/BalanceErrors.d.ts +23 -0
  368. package/build/errors/BalanceErrors.d.ts.map +1 -0
  369. package/build/errors/BalanceErrors.js +45 -0
  370. package/build/errors/DatabaseErrors.d.ts +25 -0
  371. package/build/errors/DatabaseErrors.d.ts.map +1 -0
  372. package/build/errors/DatabaseErrors.js +49 -0
  373. package/build/errors/TransactionsErrors.d.ts +37 -0
  374. package/build/errors/TransactionsErrors.d.ts.map +1 -0
  375. package/build/errors/TransactionsErrors.js +95 -0
  376. package/build/errors/VoltageErrors.d.ts +29 -0
  377. package/build/errors/VoltageErrors.d.ts.map +1 -0
  378. package/build/errors/VoltageErrors.js +69 -0
  379. package/build/errors/WalletErrors.d.ts +26 -0
  380. package/build/errors/WalletErrors.d.ts.map +1 -0
  381. package/build/errors/WalletErrors.js +55 -0
  382. package/build/errors/errors.d.ts +74 -0
  383. package/build/errors/errors.d.ts.map +1 -0
  384. package/build/errors/errors.js +117 -0
  385. package/build/errors/index.d.ts +81 -0
  386. package/build/errors/index.d.ts.map +1 -0
  387. package/build/errors/index.js +78 -0
  388. package/build/index.d.ts +95 -0
  389. package/build/index.d.ts.map +1 -0
  390. package/build/index.js +208 -0
  391. package/build/interfaces/config.d.ts +87 -0
  392. package/build/interfaces/config.d.ts.map +1 -0
  393. package/build/interfaces/config.js +7 -0
  394. package/build/interfaces/database.d.ts +29 -0
  395. package/build/interfaces/database.d.ts.map +1 -0
  396. package/build/interfaces/database.js +2 -0
  397. package/build/interfaces.d.ts +311 -0
  398. package/build/interfaces.d.ts.map +1 -0
  399. package/build/interfaces.js +12 -0
  400. package/build/services/AccountingService.d.ts +34 -0
  401. package/build/services/AccountingService.d.ts.map +1 -0
  402. package/build/services/AccountingService.js +239 -0
  403. package/build/services/AlchemyService.d.ts +47 -0
  404. package/build/services/AlchemyService.d.ts.map +1 -0
  405. package/build/services/AlchemyService.js +239 -0
  406. package/build/services/AlchemyWebhookSignature.d.ts +16 -0
  407. package/build/services/AlchemyWebhookSignature.d.ts.map +1 -0
  408. package/build/services/AlchemyWebhookSignature.js +119 -0
  409. package/build/services/AlchemyWebhooks.d.ts +87 -0
  410. package/build/services/AlchemyWebhooks.d.ts.map +1 -0
  411. package/build/services/AlchemyWebhooks.js +406 -0
  412. package/build/services/AsyncTTLCache.d.ts +12 -0
  413. package/build/services/AsyncTTLCache.d.ts.map +1 -0
  414. package/build/services/AsyncTTLCache.js +67 -0
  415. package/build/services/AzureEventHubHandler.d.ts +32 -0
  416. package/build/services/AzureEventHubHandler.d.ts.map +1 -0
  417. package/build/services/AzureEventHubHandler.js +139 -0
  418. package/build/services/BalanceService.d.ts +39 -0
  419. package/build/services/BalanceService.d.ts.map +1 -0
  420. package/build/services/BalanceService.js +482 -0
  421. package/build/services/ChainManager.d.ts +86 -0
  422. package/build/services/ChainManager.d.ts.map +1 -0
  423. package/build/services/ChainManager.js +442 -0
  424. package/build/services/ClaimHistoryService.d.ts +40 -0
  425. package/build/services/ClaimHistoryService.d.ts.map +1 -0
  426. package/build/services/ClaimHistoryService.js +121 -0
  427. package/build/services/ClaimJobService.d.ts +46 -0
  428. package/build/services/ClaimJobService.d.ts.map +1 -0
  429. package/build/services/ClaimJobService.js +407 -0
  430. package/build/services/CryptoConfirmationLocksService.d.ts +13 -0
  431. package/build/services/CryptoConfirmationLocksService.d.ts.map +1 -0
  432. package/build/services/CryptoConfirmationLocksService.js +46 -0
  433. package/build/services/CryptoKeysManager.d.ts +16 -0
  434. package/build/services/CryptoKeysManager.d.ts.map +1 -0
  435. package/build/services/CryptoKeysManager.js +136 -0
  436. package/build/services/DepositAddressService.d.ts +42 -0
  437. package/build/services/DepositAddressService.d.ts.map +1 -0
  438. package/build/services/DepositAddressService.js +275 -0
  439. package/build/services/ElasticSearch.d.ts +19 -0
  440. package/build/services/ElasticSearch.d.ts.map +1 -0
  441. package/build/services/ElasticSearch.js +104 -0
  442. package/build/services/EventsHandler.d.ts +11 -0
  443. package/build/services/EventsHandler.d.ts.map +1 -0
  444. package/build/services/EventsHandler.js +39 -0
  445. package/build/services/EventsService.d.ts +44 -0
  446. package/build/services/EventsService.d.ts.map +1 -0
  447. package/build/services/EventsService.js +234 -0
  448. package/build/services/InvoiceQueue.d.ts +56 -0
  449. package/build/services/InvoiceQueue.d.ts.map +1 -0
  450. package/build/services/InvoiceQueue.js +297 -0
  451. package/build/services/KeyVaultService.d.ts +14 -0
  452. package/build/services/KeyVaultService.d.ts.map +1 -0
  453. package/build/services/KeyVaultService.js +65 -0
  454. package/build/services/PriceCache.d.ts +19 -0
  455. package/build/services/PriceCache.d.ts.map +1 -0
  456. package/build/services/PriceCache.js +125 -0
  457. package/build/services/ProviderManager.d.ts +41 -0
  458. package/build/services/ProviderManager.d.ts.map +1 -0
  459. package/build/services/ProviderManager.js +111 -0
  460. package/build/services/QuicknodeWebhookSignature.d.ts +14 -0
  461. package/build/services/QuicknodeWebhookSignature.d.ts.map +1 -0
  462. package/build/services/QuicknodeWebhookSignature.js +119 -0
  463. package/build/services/Redis.d.ts +52 -0
  464. package/build/services/Redis.d.ts.map +1 -0
  465. package/build/services/Redis.js +364 -0
  466. package/build/services/RedisListQueue.d.ts +15 -0
  467. package/build/services/RedisListQueue.d.ts.map +1 -0
  468. package/build/services/RedisListQueue.js +87 -0
  469. package/build/services/RedisPubSub.d.ts +41 -0
  470. package/build/services/RedisPubSub.d.ts.map +1 -0
  471. package/build/services/RedisPubSub.js +254 -0
  472. package/build/services/RedisQueue.d.ts +18 -0
  473. package/build/services/RedisQueue.d.ts.map +1 -0
  474. package/build/services/RedisQueue.js +82 -0
  475. package/build/services/StorageService.d.ts +12 -0
  476. package/build/services/StorageService.d.ts.map +1 -0
  477. package/build/services/StorageService.js +92 -0
  478. package/build/services/SweepHistoryService.d.ts +15 -0
  479. package/build/services/SweepHistoryService.d.ts.map +1 -0
  480. package/build/services/SweepHistoryService.js +52 -0
  481. package/build/services/SweepJobService.d.ts +53 -0
  482. package/build/services/SweepJobService.d.ts.map +1 -0
  483. package/build/services/SweepJobService.js +725 -0
  484. package/build/services/TimerManager.d.ts +44 -0
  485. package/build/services/TimerManager.d.ts.map +1 -0
  486. package/build/services/TimerManager.js +239 -0
  487. package/build/services/WalletIndexService.d.ts +11 -0
  488. package/build/services/WalletIndexService.d.ts.map +1 -0
  489. package/build/services/WalletIndexService.js +73 -0
  490. package/build/services/WalletManager.d.ts +42 -0
  491. package/build/services/WalletManager.d.ts.map +1 -0
  492. package/build/services/WalletManager.js +359 -0
  493. package/build/services/WithdrawalManager.d.ts +51 -0
  494. package/build/services/WithdrawalManager.d.ts.map +1 -0
  495. package/build/services/WithdrawalManager.js +372 -0
  496. package/build/services/Worker.d.ts +25 -0
  497. package/build/services/Worker.d.ts.map +1 -0
  498. package/build/services/Worker.js +115 -0
  499. package/build/services/solana/escrow/SolanaEscrowAdmin.d.ts +102 -0
  500. package/build/services/solana/escrow/SolanaEscrowAdmin.d.ts.map +1 -0
  501. package/build/services/solana/escrow/SolanaEscrowAdmin.js +209 -0
  502. package/build/services/solana/escrow/SolanaEscrowInteraction.d.ts +50 -0
  503. package/build/services/solana/escrow/SolanaEscrowInteraction.d.ts.map +1 -0
  504. package/build/services/solana/escrow/SolanaEscrowInteraction.js +235 -0
  505. package/build/services/solana/escrow/idl/escrow.json +2941 -0
  506. package/build/services/solana/escrow/index.d.ts +5 -0
  507. package/build/services/solana/escrow/index.d.ts.map +1 -0
  508. package/build/services/solana/escrow/index.js +20 -0
  509. package/build/services/solana/escrow/services/Errors.d.ts +19 -0
  510. package/build/services/solana/escrow/services/Errors.d.ts.map +1 -0
  511. package/build/services/solana/escrow/services/Errors.js +29 -0
  512. package/build/services/solana/escrow/services/EscrowAdminUtility.d.ts +122 -0
  513. package/build/services/solana/escrow/services/EscrowAdminUtility.d.ts.map +1 -0
  514. package/build/services/solana/escrow/services/EscrowAdminUtility.js +665 -0
  515. package/build/services/solana/escrow/services/EscrowService.d.ts +15 -0
  516. package/build/services/solana/escrow/services/EscrowService.d.ts.map +1 -0
  517. package/build/services/solana/escrow/services/EscrowService.js +155 -0
  518. package/build/services/solana/escrow/services/EscrowUtility.d.ts +58 -0
  519. package/build/services/solana/escrow/services/EscrowUtility.d.ts.map +1 -0
  520. package/build/services/solana/escrow/services/EscrowUtility.js +318 -0
  521. package/build/services/solana/escrow/services/TokenAccountService.d.ts +10 -0
  522. package/build/services/solana/escrow/services/TokenAccountService.d.ts.map +1 -0
  523. package/build/services/solana/escrow/services/TokenAccountService.js +145 -0
  524. package/build/services/solana/escrow/services/TransactionsService.d.ts +12 -0
  525. package/build/services/solana/escrow/services/TransactionsService.d.ts.map +1 -0
  526. package/build/services/solana/escrow/services/TransactionsService.js +44 -0
  527. package/build/services/solana/escrow/services/index.d.ts +7 -0
  528. package/build/services/solana/escrow/services/index.d.ts.map +1 -0
  529. package/build/services/solana/escrow/services/index.js +22 -0
  530. package/build/services/solana/escrow/types/custom.d.ts +14 -0
  531. package/build/services/solana/escrow/types/custom.d.ts.map +1 -0
  532. package/build/services/solana/escrow/types/custom.js +2 -0
  533. package/build/services/solana/escrow/types/escrow.d.ts +2948 -0
  534. package/build/services/solana/escrow/types/escrow.d.ts.map +1 -0
  535. package/build/services/solana/escrow/types/escrow.js +2 -0
  536. package/build/services/solana/escrow/types/index.d.ts +3 -0
  537. package/build/services/solana/escrow/types/index.d.ts.map +1 -0
  538. package/build/services/solana/escrow/types/index.js +18 -0
  539. package/build/services/solana/escrow/types/types.d.ts +19 -0
  540. package/build/services/solana/escrow/types/types.d.ts.map +1 -0
  541. package/build/services/solana/escrow/types/types.js +2 -0
  542. package/build/services/solana/index.d.ts +2 -0
  543. package/build/services/solana/index.d.ts.map +1 -0
  544. package/build/services/solana/index.js +17 -0
  545. package/build/services/tron/index.d.ts +5 -0
  546. package/build/services/tron/index.d.ts.map +1 -0
  547. package/build/services/tron/index.js +21 -0
  548. package/build/services/tron/services/BitQueryQueue.d.ts +13 -0
  549. package/build/services/tron/services/BitQueryQueue.d.ts.map +1 -0
  550. package/build/services/tron/services/BitQueryQueue.js +22 -0
  551. package/build/services/tron/services/BitQuerySubscription.d.ts +5 -0
  552. package/build/services/tron/services/BitQuerySubscription.d.ts.map +1 -0
  553. package/build/services/tron/services/BitQuerySubscription.js +7 -0
  554. package/build/services/tron/services/Escrow.d.ts +1 -0
  555. package/build/services/tron/services/Escrow.d.ts.map +1 -0
  556. package/build/services/tron/services/Escrow.js +1 -0
  557. package/build/services/tron/services/Transactions.d.ts +33 -0
  558. package/build/services/tron/services/Transactions.d.ts.map +1 -0
  559. package/build/services/tron/services/Transactions.js +164 -0
  560. package/build/services/tron/services/TronCustodialWallet.d.ts +17 -0
  561. package/build/services/tron/services/TronCustodialWallet.d.ts.map +1 -0
  562. package/build/services/tron/services/TronCustodialWallet.js +46 -0
  563. package/build/services/tron/services/TronFundingWallet.d.ts +30 -0
  564. package/build/services/tron/services/TronFundingWallet.d.ts.map +1 -0
  565. package/build/services/tron/services/TronFundingWallet.js +57 -0
  566. package/build/services/tron/services/TronHelper.d.ts +11 -0
  567. package/build/services/tron/services/TronHelper.d.ts.map +1 -0
  568. package/build/services/tron/services/TronHelper.js +29 -0
  569. package/build/services/tron/services/TronHotWallet.d.ts +29 -0
  570. package/build/services/tron/services/TronHotWallet.d.ts.map +1 -0
  571. package/build/services/tron/services/TronHotWallet.js +168 -0
  572. package/build/services/tron/services/TronSigner.d.ts +12 -0
  573. package/build/services/tron/services/TronSigner.d.ts.map +1 -0
  574. package/build/services/tron/services/TronSigner.js +51 -0
  575. package/build/services/tron/services/TronWallet.d.ts +32 -0
  576. package/build/services/tron/services/TronWallet.d.ts.map +1 -0
  577. package/build/services/tron/services/TronWallet.js +110 -0
  578. package/build/services/tron/types/bitquery.d.ts +26 -0
  579. package/build/services/tron/types/bitquery.d.ts.map +1 -0
  580. package/build/services/tron/types/bitquery.js +3 -0
  581. package/build/services/tron/types/index.d.ts +3 -0
  582. package/build/services/tron/types/index.d.ts.map +1 -0
  583. package/build/services/tron/types/index.js +18 -0
  584. package/build/services/tron/types/transactions.d.ts +36 -0
  585. package/build/services/tron/types/transactions.d.ts.map +1 -0
  586. package/build/services/tron/types/transactions.js +3 -0
  587. package/build/services/tron/types/tron_helper.d.ts +25 -0
  588. package/build/services/tron/types/tron_helper.d.ts.map +1 -0
  589. package/build/services/tron/types/tron_helper.js +3 -0
  590. package/build/services/types/RedisPubSub.d.ts +11 -0
  591. package/build/services/types/RedisPubSub.d.ts.map +1 -0
  592. package/build/services/types/RedisPubSub.js +15 -0
  593. package/build/services/types/accounting_service.d.ts +7 -0
  594. package/build/services/types/accounting_service.d.ts.map +1 -0
  595. package/build/services/types/accounting_service.js +2 -0
  596. package/build/services/types/alchemy.d.ts +243 -0
  597. package/build/services/types/alchemy.d.ts.map +1 -0
  598. package/build/services/types/alchemy.js +3 -0
  599. package/build/services/types/azure_event_hub_handler.d.ts +18 -0
  600. package/build/services/types/azure_event_hub_handler.d.ts.map +1 -0
  601. package/build/services/types/azure_event_hub_handler.js +20 -0
  602. package/build/services/types/balance_service.d.ts +10 -0
  603. package/build/services/types/balance_service.d.ts.map +1 -0
  604. package/build/services/types/balance_service.js +2 -0
  605. package/build/services/types/chain_manager.d.ts +49 -0
  606. package/build/services/types/chain_manager.d.ts.map +1 -0
  607. package/build/services/types/chain_manager.js +2 -0
  608. package/build/services/types/claim.d.ts +42 -0
  609. package/build/services/types/claim.d.ts.map +1 -0
  610. package/build/services/types/claim.js +2 -0
  611. package/build/services/types/claim_job_service.d.ts +54 -0
  612. package/build/services/types/claim_job_service.d.ts.map +1 -0
  613. package/build/services/types/claim_job_service.js +2 -0
  614. package/build/services/types/crypto_confirmation_locks_service.d.ts +6 -0
  615. package/build/services/types/crypto_confirmation_locks_service.d.ts.map +1 -0
  616. package/build/services/types/crypto_confirmation_locks_service.js +2 -0
  617. package/build/services/types/events_service.d.ts +57 -0
  618. package/build/services/types/events_service.d.ts.map +1 -0
  619. package/build/services/types/events_service.js +2 -0
  620. package/build/services/types/index.d.ts +16 -0
  621. package/build/services/types/index.d.ts.map +1 -0
  622. package/build/services/types/index.js +31 -0
  623. package/build/services/types/lightning.d.ts +129 -0
  624. package/build/services/types/lightning.d.ts.map +1 -0
  625. package/build/services/types/lightning.js +2 -0
  626. package/build/services/types/quicknode.d.ts +7 -0
  627. package/build/services/types/quicknode.d.ts.map +1 -0
  628. package/build/services/types/quicknode.js +2 -0
  629. package/build/services/types/sweep_job_service.d.ts +9 -0
  630. package/build/services/types/sweep_job_service.d.ts.map +1 -0
  631. package/build/services/types/sweep_job_service.js +3 -0
  632. package/build/services/types/timer_manager.d.ts +6 -0
  633. package/build/services/types/timer_manager.d.ts.map +1 -0
  634. package/build/services/types/timer_manager.js +2 -0
  635. package/build/services/types/wallet_manager.d.ts +36 -0
  636. package/build/services/types/wallet_manager.d.ts.map +1 -0
  637. package/build/services/types/wallet_manager.js +2 -0
  638. package/build/services/types/withdrawal.d.ts +48 -0
  639. package/build/services/types/withdrawal.d.ts.map +1 -0
  640. package/build/services/types/withdrawal.js +50 -0
  641. package/build/services/types/withdrawal_manager.d.ts +14 -0
  642. package/build/services/types/withdrawal_manager.d.ts.map +1 -0
  643. package/build/services/types/withdrawal_manager.js +2 -0
  644. package/build/services/utils/alchemy.d.ts +6 -0
  645. package/build/services/utils/alchemy.d.ts.map +1 -0
  646. package/build/services/utils/alchemy.js +155 -0
  647. package/build/services/utils/graphql.d.ts +2 -0
  648. package/build/services/utils/graphql.d.ts.map +1 -0
  649. package/build/services/utils/graphql.js +46 -0
  650. package/build/utils/AsyncRateLimiter.d.ts +23 -0
  651. package/build/utils/AsyncRateLimiter.d.ts.map +1 -0
  652. package/build/utils/AsyncRateLimiter.js +87 -0
  653. package/build/utils/AsyncTTLCache.d.ts +12 -0
  654. package/build/utils/AsyncTTLCache.d.ts.map +1 -0
  655. package/build/utils/AsyncTTLCache.js +69 -0
  656. package/build/utils/Logger.d.ts +67 -0
  657. package/build/utils/Logger.d.ts.map +1 -0
  658. package/build/utils/Logger.js +171 -0
  659. package/build/utils/MemoryMonitor.d.ts +12 -0
  660. package/build/utils/MemoryMonitor.d.ts.map +1 -0
  661. package/build/utils/MemoryMonitor.js +59 -0
  662. package/build/utils/Parsing.d.ts +13 -0
  663. package/build/utils/Parsing.d.ts.map +1 -0
  664. package/build/utils/Parsing.js +84 -0
  665. package/build/utils/RpcLimiter.d.ts +10 -0
  666. package/build/utils/RpcLimiter.d.ts.map +1 -0
  667. package/build/utils/RpcLimiter.js +28 -0
  668. package/build/utils/Utility.d.ts +23 -0
  669. package/build/utils/Utility.d.ts.map +1 -0
  670. package/build/utils/Utility.js +211 -0
  671. package/build/utils/Wallets.d.ts +4 -0
  672. package/build/utils/Wallets.d.ts.map +1 -0
  673. package/build/utils/Wallets.js +68 -0
  674. package/build/utils/custodial.d.ts +32 -0
  675. package/build/utils/custodial.d.ts.map +1 -0
  676. package/build/utils/custodial.js +291 -0
  677. package/build/utils/solana.d.ts +151 -0
  678. package/build/utils/solana.d.ts.map +1 -0
  679. package/build/utils/solana.js +674 -0
  680. package/package.json +107 -0
@@ -0,0 +1,23 @@
1
+ import { BlockchainType } from "../interfaces";
2
+ import { IConfig } from "../interfaces/config";
3
+ export declare const sleep: (delay: number) => Promise<void>;
4
+ export declare const convertOffsetInDaysToDate: (offsetInDays: number) => Date;
5
+ export declare const getAmountInEther: (chainId: string, tokenAddress: string, amount: bigint, config: IConfig) => number;
6
+ export declare const getAmountInWei: (chainId: string, tokenAddress: string, amount: number, config: IConfig, decimals?: number) => bigint;
7
+ export declare const getAmountInLamports: (tokenAddress: string, amount: number, chainId: string, decimals: number) => Promise<bigint>;
8
+ export declare const lamportsToDecimal: (tokenAddress: string, amount: bigint, chainId: string, decimals: number) => Promise<number>;
9
+ export declare const _lamportsToDecimal: (amount: bigint, decimals: number) => number;
10
+ export declare const _decimalsToLamport: (amount: number, decimals: number) => bigint;
11
+ export declare const fromDecimal: (blockchain: BlockchainType, chainId: string, tokenAddress: string, amount: number, config: IConfig) => bigint;
12
+ export declare const toDecimal: (blockchain: BlockchainType, chainId: string, tokenAddress: string, amount: bigint, config: IConfig, owner?: string) => string;
13
+ export declare const convertHexString: (hexString: string, format: "decimal" | "ascii" | "raw") => string;
14
+ export declare function retryWithExponentialBackoff<T>(operation: () => Promise<T>, maxAttempts?: number, initialDelayMs?: number, maxDelayMs?: number): Promise<T>;
15
+ export declare function parseBoolean(value: any): boolean;
16
+ export declare const get_expiry_time: (duration_s: number) => {
17
+ expires_at_timestamp_s: number;
18
+ expires_at: Date;
19
+ created_at_timestamp_s: number;
20
+ created_at: Date;
21
+ duration_s: number;
22
+ };
23
+ //# sourceMappingURL=Utility.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Utility.d.ts","sourceRoot":"","sources":["../../src/utils/Utility.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAI/C,eAAO,MAAM,KAAK,GAAU,OAAO,MAAM,KAAG,OAAO,CAAC,IAAI,CAEvD,CAAA;AAED,eAAO,MAAM,yBAAyB,GAAI,cAAc,MAAM,KAAG,IAKhE,CAAA;AAED,eAAO,MAAM,gBAAgB,GAAI,SAAS,MAAM,EAAE,cAAc,MAAM,EAAE,QAAQ,MAAM,EAAE,QAAQ,OAAO,WAsBtG,CAAA;AAGD,eAAO,MAAM,cAAc,GAAI,SAAS,MAAM,EAAE,cAAc,MAAM,EAAE,QAAQ,MAAM,EAAE,QAAQ,OAAO,EAAE,WAAW,MAAM,WAoBvH,CAAA;AAED,eAAO,MAAM,mBAAmB,GAAU,cAAc,MAAM,EAAE,QAAQ,MAAM,EAAE,SAAS,MAAM,EAAE,UAAU,MAAM,oBAYhH,CAAA;AAED,eAAO,MAAM,iBAAiB,GAAU,cAAc,MAAM,EAAE,QAAQ,MAAM,EAAE,SAAS,MAAM,EAAE,UAAU,MAAM,oBAY9G,CAAA;AAED,eAAO,MAAM,kBAAkB,GAAI,QAAQ,MAAM,EAAE,UAAU,MAAM,WAElE,CAAA;AAED,eAAO,MAAM,kBAAkB,GAAI,QAAQ,MAAM,EAAE,UAAU,MAAM,WAElE,CAAA;AAED,eAAO,MAAM,WAAW,GAAI,YAAY,cAAc,EAAE,SAAS,MAAM,EAAE,cAAc,MAAM,EAAE,QAAQ,MAAM,EAAE,QAAQ,OAAO,WAM7H,CAAA;AAED,eAAO,MAAM,SAAS,GAAI,YAAY,cAAc,EAAE,SAAS,MAAM,EAAE,cAAc,MAAM,EAAE,QAAQ,MAAM,EAAE,QAAQ,OAAO,EAAE,QAAQ,MAAM,WAM3I,CAAA;AAED,eAAO,MAAM,gBAAgB,GAAI,WAAW,MAAM,EAAE,QAAQ,SAAS,GAAG,OAAO,GAAG,KAAK,WAiBtF,CAAA;AAiBD,wBAAsB,2BAA2B,CAAC,CAAC,EAC/C,SAAS,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EAC3B,WAAW,GAAE,MAAU,EACvB,cAAc,GAAE,MAAa,EAC7B,UAAU,GAAE,MAAc,GAC3B,OAAO,CAAC,CAAC,CAAC,CAsCZ;AAGD,wBAAgB,YAAY,CAAC,KAAK,EAAE,GAAG,GAAG,OAAO,CAKhD;AAED,eAAO,MAAM,eAAe,GAAI,YAAY,MAAM;;;;;;CAcjD,CAAA"}
@@ -0,0 +1,211 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.get_expiry_time = exports.convertHexString = exports.toDecimal = exports.fromDecimal = exports._decimalsToLamport = exports._lamportsToDecimal = exports.lamportsToDecimal = exports.getAmountInLamports = exports.getAmountInWei = exports.getAmountInEther = exports.convertOffsetInDaysToDate = exports.sleep = void 0;
16
+ exports.retryWithExponentialBackoff = retryWithExponentialBackoff;
17
+ exports.parseBoolean = parseBoolean;
18
+ const ethers_1 = require("ethers");
19
+ const ErrorAbi_json_1 = __importDefault(require("../contracts/artifacts/ErrorAbi.json"));
20
+ const web3_js_1 = require("@solana/web3.js");
21
+ const ChainManager_1 = __importDefault(require("../services/ChainManager"));
22
+ const solana_1 = require("./solana");
23
+ const Wallets_1 = require("./Wallets");
24
+ const sleep = (delay) => __awaiter(void 0, void 0, void 0, function* () {
25
+ return new Promise(resolve => setTimeout(resolve, delay));
26
+ });
27
+ exports.sleep = sleep;
28
+ const convertOffsetInDaysToDate = (offsetInDays) => {
29
+ const now = new Date().getTime();
30
+ const destinationTimeUnix = now - (offsetInDays * 60 * 1000);
31
+ const destinationTimeDate = new Date(destinationTimeUnix);
32
+ return destinationTimeDate;
33
+ };
34
+ exports.convertOffsetInDaysToDate = convertOffsetInDaysToDate;
35
+ const getAmountInEther = (chainId, tokenAddress, amount, config) => {
36
+ try {
37
+ let etherAmount = 0;
38
+ // Handle native token conversion
39
+ if (tokenAddress === ethers_1.ethers.ZeroAddress) {
40
+ etherAmount = Number(ethers_1.ethers.formatEther(amount));
41
+ }
42
+ else { // Handle erc20 token conversion
43
+ const paymentTokens = ChainManager_1.default.getInstance(config).getPaymentTokensForChain(parseInt(chainId));
44
+ const targetToken = paymentTokens === null || paymentTokens === void 0 ? void 0 : paymentTokens.find((t) => (0, Wallets_1.normalizeAddress)(t.address, "evm") === (0, Wallets_1.normalizeAddress)(tokenAddress, "evm"));
45
+ if (!targetToken) {
46
+ throw new Error(`Failed to find target payment token for ${chainId}`);
47
+ }
48
+ etherAmount = Number(ethers_1.ethers.formatUnits(amount, targetToken.decimals));
49
+ }
50
+ return etherAmount;
51
+ }
52
+ catch (error) {
53
+ throw error;
54
+ }
55
+ };
56
+ exports.getAmountInEther = getAmountInEther;
57
+ const getAmountInWei = (chainId, tokenAddress, amount, config, decimals) => {
58
+ let weiAmount = ethers_1.ethers.toBigInt(0);
59
+ // Handle native token conversion
60
+ if (tokenAddress === ethers_1.ethers.ZeroAddress) {
61
+ weiAmount = ethers_1.ethers.parseEther(amount.toString());
62
+ }
63
+ else { // Handle erc20 token conversion
64
+ if (decimals)
65
+ return ethers_1.ethers.parseUnits(amount.toString(), decimals);
66
+ const paymentTokens = ChainManager_1.default.getInstance(config).getPaymentTokensForChain(parseInt(chainId));
67
+ const targetToken = paymentTokens === null || paymentTokens === void 0 ? void 0 : paymentTokens.find((t) => (0, Wallets_1.normalizeAddress)(t.address, "evm") === (0, Wallets_1.normalizeAddress)(tokenAddress, "evm"));
68
+ if (!targetToken) {
69
+ throw new Error(`Failed to find target payment token for ${chainId}`);
70
+ }
71
+ weiAmount = ethers_1.ethers.parseUnits(amount.toString(), targetToken.decimals);
72
+ }
73
+ return weiAmount;
74
+ };
75
+ exports.getAmountInWei = getAmountInWei;
76
+ const getAmountInLamports = (tokenAddress, amount, chainId, decimals) => __awaiter(void 0, void 0, void 0, function* () {
77
+ if (tokenAddress === solana_1.solana_program_address) {
78
+ return BigInt(amount * web3_js_1.LAMPORTS_PER_SOL);
79
+ }
80
+ else {
81
+ // const { decimals, spl_balance_decimals, spl_balance_lamports, sol_balance_lamports } = await get_token_account_info(chainId, tokenAddress, owner);
82
+ // if (!decimals) throw new Error("Decimals is required.");
83
+ // return ethers.parseUnits(amount.toString(), decimals);
84
+ // return _decimalsToLamport(amount, decimals);
85
+ return ethers_1.ethers.parseUnits(amount.toString(), decimals);
86
+ }
87
+ });
88
+ exports.getAmountInLamports = getAmountInLamports;
89
+ const lamportsToDecimal = (tokenAddress, amount, chainId, decimals) => __awaiter(void 0, void 0, void 0, function* () {
90
+ if (tokenAddress === solana_1.solana_program_address) {
91
+ return (Number(amount) / web3_js_1.LAMPORTS_PER_SOL);
92
+ }
93
+ else {
94
+ // const { decimals, spl_balance_decimals, spl_balance_lamports, sol_balance_lamports } = await get_token_account_info(chainId, tokenAddress, owner);
95
+ // if (!decimals) throw new Error("Decimals is required.");
96
+ // return Number(ethers.formatUnits(amount, decimals));
97
+ // return _lamportsToDecimal(amount, deicm);
98
+ return Number(ethers_1.ethers.formatUnits(amount, decimals));
99
+ }
100
+ });
101
+ exports.lamportsToDecimal = lamportsToDecimal;
102
+ const _lamportsToDecimal = (amount, decimals) => {
103
+ return Number(ethers_1.ethers.formatUnits(amount, decimals));
104
+ };
105
+ exports._lamportsToDecimal = _lamportsToDecimal;
106
+ const _decimalsToLamport = (amount, decimals) => {
107
+ return ethers_1.ethers.parseUnits(amount.toString(), decimals);
108
+ };
109
+ exports._decimalsToLamport = _decimalsToLamport;
110
+ const fromDecimal = (blockchain, chainId, tokenAddress, amount, config) => {
111
+ const chain_manager = ChainManager_1.default.getInstance(config);
112
+ const target_token = chain_manager.get_payment_token_for_chain(blockchain, chainId, tokenAddress);
113
+ if (!target_token)
114
+ throw new Error(`Payment token not found.`);
115
+ return ethers_1.ethers.parseUnits(amount.toString(), target_token.decimals);
116
+ };
117
+ exports.fromDecimal = fromDecimal;
118
+ const toDecimal = (blockchain, chainId, tokenAddress, amount, config, owner) => {
119
+ const chain_manager = ChainManager_1.default.getInstance(config);
120
+ const target_token = chain_manager.get_payment_token_for_chain(blockchain, chainId, tokenAddress);
121
+ if (!target_token)
122
+ throw new Error(`Payment token not found.`);
123
+ return ethers_1.ethers.formatUnits(amount, target_token.decimals);
124
+ };
125
+ exports.toDecimal = toDecimal;
126
+ const convertHexString = (hexString, format) => {
127
+ const cleanHex = hexString.startsWith('0x') ? hexString.slice(2) : hexString;
128
+ switch (format) {
129
+ case 'decimal':
130
+ return parseInt(cleanHex, 16).toString();
131
+ case 'ascii':
132
+ let result = '';
133
+ for (let i = 0; i < cleanHex.length; i += 2) {
134
+ result += String.fromCharCode(parseInt(cleanHex.substr(i, 2), 16));
135
+ }
136
+ return result;
137
+ case 'raw':
138
+ return cleanHex;
139
+ default:
140
+ return hexString;
141
+ }
142
+ };
143
+ exports.convertHexString = convertHexString;
144
+ function decodeRevertData(hexData) {
145
+ for (const abi of [ErrorAbi_json_1.default]) {
146
+ try {
147
+ const iface = new ethers_1.Interface(abi);
148
+ const err = iface.parseError(hexData);
149
+ if (!err) {
150
+ continue;
151
+ }
152
+ return { name: err.name, args: err.args, signature: err.signature };
153
+ }
154
+ catch (_a) { }
155
+ }
156
+ return null;
157
+ }
158
+ function retryWithExponentialBackoff(operation_1) {
159
+ return __awaiter(this, arguments, void 0, function* (operation, maxAttempts = 5, initialDelayMs = 1000, maxDelayMs = 32000) {
160
+ var _a, _b, _c, _d, _e, _f;
161
+ let attempt = 1;
162
+ let delay = initialDelayMs;
163
+ while (attempt <= maxAttempts) {
164
+ try {
165
+ return yield operation();
166
+ }
167
+ catch (error) {
168
+ const data = (_f = (_c = (_a = error === null || error === void 0 ? void 0 : error.data) !== null && _a !== void 0 ? _a : (_b = error === null || error === void 0 ? void 0 : error.error) === null || _b === void 0 ? void 0 : _b.data) !== null && _c !== void 0 ? _c : (_e = (_d = error === null || error === void 0 ? void 0 : error.info) === null || _d === void 0 ? void 0 : _d.error) === null || _e === void 0 ? void 0 : _e.data) !== null && _f !== void 0 ? _f : '';
169
+ const decoded = data ? decodeRevertData(data) : null;
170
+ console.log('Decoded:', decoded);
171
+ console.log(`Operation failed, attempt ${attempt} of ${maxAttempts}. Retrying in ${delay}ms...`);
172
+ console.log(`Error:`, error);
173
+ if (decoded) {
174
+ if (attempt === maxAttempts) {
175
+ throw new Error((decoded === null || decoded === void 0 ? void 0 : decoded.name) ? decoded.name : error.message); // Rethrow the error on the last attempt
176
+ }
177
+ throw { message: decoded.name, data: decoded.args };
178
+ }
179
+ if (attempt === maxAttempts) {
180
+ throw error;
181
+ }
182
+ yield new Promise(resolve => setTimeout(resolve, delay));
183
+ // Exponential backoff with jitter
184
+ delay = Math.min(delay * 2 * (0.5 + Math.random()), maxDelayMs);
185
+ attempt++;
186
+ }
187
+ }
188
+ throw new Error('Should never reach here due to maxAttempts check');
189
+ });
190
+ }
191
+ function parseBoolean(value) {
192
+ if (typeof value === "string") {
193
+ return value.toLowerCase() === "true" || value === "1";
194
+ }
195
+ return Boolean(value);
196
+ }
197
+ const get_expiry_time = (duration_s) => {
198
+ const duration = duration_s;
199
+ const now = new Date();
200
+ const now_s = Math.floor(now.getTime() / 1000);
201
+ const expires_at_s = (now_s + duration);
202
+ const expires_at = new Date((now_s + duration) * 1000);
203
+ return {
204
+ expires_at_timestamp_s: expires_at_s,
205
+ expires_at: expires_at,
206
+ created_at_timestamp_s: now_s,
207
+ created_at: now,
208
+ duration_s: duration_s
209
+ };
210
+ };
211
+ exports.get_expiry_time = get_expiry_time;
@@ -0,0 +1,4 @@
1
+ import { IConfig } from "../interfaces/config";
2
+ export declare const monitor: (config: IConfig) => Promise<never>;
3
+ export declare const normalizeAddress: (address: string, blockchain: string) => string;
4
+ //# sourceMappingURL=Wallets.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Wallets.d.ts","sourceRoot":"","sources":["../../src/utils/Wallets.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAK/C,eAAO,MAAM,OAAO,GAAU,QAAQ,OAAO,mBAS5C,CAAA;AAGD,eAAO,MAAM,gBAAgB,GAAI,SAAS,MAAM,EAAE,YAAY,MAAM,KAAG,MA+BtE,CAAA"}
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.normalizeAddress = exports.monitor = void 0;
16
+ const ethers_1 = require("ethers");
17
+ // import { config } from "../config/config";
18
+ const ProviderManager_1 = __importDefault(require("../services/ProviderManager"));
19
+ const Utility_1 = require("./Utility");
20
+ const web3_js_1 = require("@solana/web3.js");
21
+ const TransactionsErrors_1 = __importDefault(require("../errors/TransactionsErrors"));
22
+ const constants_1 = require("../constants");
23
+ const tronweb_1 = require("tronweb");
24
+ // Unused
25
+ const monitor = (config) => __awaiter(void 0, void 0, void 0, function* () {
26
+ while (true) {
27
+ const provider = ProviderManager_1.default.getInstance(config).getNewProvider("97").provider;
28
+ const blockNumber = yield provider.getBlockNumber();
29
+ const block = yield provider.getBlock(blockNumber, true);
30
+ const prefetched = block === null || block === void 0 ? void 0 : block.getPrefetchedTransaction(block === null || block === void 0 ? void 0 : block.transactions[0]);
31
+ yield (0, Utility_1.sleep)(1000);
32
+ }
33
+ });
34
+ exports.monitor = monitor;
35
+ const normalizeAddress = (address, blockchain) => {
36
+ const error_manager = new TransactionsErrors_1.default();
37
+ if (blockchain === constants_1.BLOCKCHAINS.SOLANA || blockchain.includes('solana')) {
38
+ try {
39
+ const pubKey = new web3_js_1.PublicKey(address);
40
+ return pubKey.toBase58();
41
+ }
42
+ catch (error) {
43
+ throw new Error(error_manager.InvalidAddress());
44
+ }
45
+ }
46
+ else if (blockchain === constants_1.BLOCKCHAINS.TRON) {
47
+ if (address === ethers_1.ethers.ZeroAddress.slice(2) || address === ethers_1.ethers.ZeroAddress || address === 'TRX' || address === 'trx') {
48
+ return address;
49
+ }
50
+ if (tronweb_1.TronWeb.isAddress(address)) {
51
+ return address;
52
+ }
53
+ else
54
+ throw new Error(error_manager.InvalidAddress());
55
+ }
56
+ else if (blockchain === constants_1.BLOCKCHAINS.EVM) {
57
+ // EVM chains
58
+ try {
59
+ return ethers_1.ethers.getAddress(address);
60
+ }
61
+ catch (error) {
62
+ const error_manager = new TransactionsErrors_1.default();
63
+ throw new Error(error_manager.InvalidAddress());
64
+ }
65
+ }
66
+ throw new Error(`Blockchain is not supported: ${blockchain}`);
67
+ };
68
+ exports.normalizeAddress = normalizeAddress;
@@ -0,0 +1,32 @@
1
+ import { ethers } from "ethers";
2
+ import { ApprovalResult, BlockchainType, Candidate, ChainId } from "../interfaces";
3
+ import { IConfig } from "../interfaces/config";
4
+ import { IDatabasePool } from "../interfaces/database";
5
+ export type TransactionType = "native" | "approve" | "transferFrom";
6
+ export interface EvmTransferResult {
7
+ status: boolean;
8
+ failed: Candidate[];
9
+ success: ApprovalResult[];
10
+ }
11
+ export interface EstimateEscrowBatchWithdrawPayload {
12
+ amount_in_tokens: bigint;
13
+ token: string;
14
+ receiver: string;
15
+ requestId: number;
16
+ }
17
+ export declare const needs_approval_and_funding: (blockchain: BlockchainType, chainId: ChainId, token: string, parentIndex: number, childIndex: number, spender: string, dbPool: IDatabasePool, config: IConfig) => Promise<{
18
+ status: boolean;
19
+ needs_approval: boolean;
20
+ needs_funding: boolean;
21
+ }>;
22
+ export declare const approve_if_not_approved: (blockchain: BlockchainType, chainId: ChainId, parentIndex: number, childIndex: number, spender: string, token: string, dbPool: IDatabasePool, config: IConfig) => Promise<{
23
+ status: boolean;
24
+ balance: bigint;
25
+ }>;
26
+ export declare const getWalletBalance: (blockchain: BlockchainType, chainId: ChainId, address: string, token: string, dbPool: IDatabasePool, config: IConfig) => Promise<{
27
+ balance: bigint;
28
+ decimals: bigint;
29
+ }>;
30
+ export declare const estimate_escrow_method_call_cost: (chain_id: ChainId, payloads: EstimateEscrowBatchWithdrawPayload[], dbPool: IDatabasePool, config: IConfig) => Promise<bigint>;
31
+ export declare const estimateGas: (provider: ethers.Provider, tokenAddress: string, spenderAddress: string | null, amount: bigint, fromAddress: string, chainId: number, transactionType: TransactionType, isMockTransfer?: boolean) => Promise<bigint>;
32
+ //# sourceMappingURL=custodial.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"custodial.d.ts","sourceRoot":"","sources":["../../src/utils/custodial.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyC,MAAM,EAAwC,MAAM,QAAQ,CAAC;AAC7G,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAYnF,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAMvD,MAAM,MAAM,eAAe,GAAG,QAAQ,GAAG,SAAS,GAAG,cAAc,CAAC;AACpE,MAAM,WAAW,iBAAiB;IAC9B,MAAM,EAAE,OAAO,CAAC;IAChB,MAAM,EAAE,SAAS,EAAE,CAAC;IACpB,OAAO,EAAE,cAAc,EAAE,CAAC;CAC7B;AAED,MAAM,WAAW,kCAAkC;IAC/C,gBAAgB,EAAE,MAAM,CAAC;IACzB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;CACrB;AAED,eAAO,MAAM,0BAA0B,GAAU,YAAY,cAAc,EAAE,SAAS,OAAO,EAAE,OAAO,MAAM,EAAE,aAAa,MAAM,EAAE,YAAY,MAAM,EAAE,SAAS,MAAM,EAAE,QAAQ,aAAa,EAAE,QAAQ,OAAO;;;;EAkC7M,CAAA;AAED,eAAO,MAAM,uBAAuB,GAAU,YAAY,cAAc,EAAE,SAAS,OAAO,EAAE,aAAa,MAAM,EAAE,YAAY,MAAM,EAAE,SAAS,MAAM,EAAE,OAAO,MAAM,EAAE,QAAQ,aAAa,EAAE,QAAQ,OAAO;;;EAkC1M,CAAA;AAGD,eAAO,MAAM,gBAAgB,GAAU,YAAY,cAAc,EAAE,SAAS,OAAO,EAAE,SAAS,MAAM,EAAE,OAAO,MAAM,EAAE,QAAQ,aAAa,EAAE,QAAQ,OAAO;;;EA0F1J,CAAA;AAED,eAAO,MAAM,gCAAgC,GAAU,UAAU,OAAO,EAAE,UAAU,kCAAkC,EAAE,EAAE,QAAQ,aAAa,EAAE,QAAQ,OAAO,oBA2C/J,CAAA;AAED,eAAO,MAAM,WAAW,GACpB,UAAU,MAAM,CAAC,QAAQ,EACzB,cAAc,MAAM,EACpB,gBAAgB,MAAM,GAAG,IAAI,EAC7B,QAAQ,MAAM,EACd,aAAa,MAAM,EACnB,SAAS,MAAM,EACf,iBAAiB,eAAe,EAChC,wBAAsB,oBA8DzB,CAAA"}
@@ -0,0 +1,291 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.estimateGas = exports.estimate_escrow_method_call_cost = exports.getWalletBalance = exports.approve_if_not_approved = exports.needs_approval_and_funding = void 0;
16
+ const ethers_1 = require("ethers");
17
+ const ERC20Mock_json_1 = __importDefault(require("../contracts/artifacts/ERC20Mock.json"));
18
+ const Escrow_json_1 = __importDefault(require("../contracts/artifacts/Escrow.json"));
19
+ const WalletManager_1 = __importDefault(require("../services/WalletManager"));
20
+ const ProviderManager_1 = __importDefault(require("../services/ProviderManager"));
21
+ const Utility_1 = require("./Utility");
22
+ const solana_1 = require("./solana");
23
+ const web3_js_1 = require("@solana/web3.js");
24
+ const spl_token_1 = require("@solana/spl-token");
25
+ const TransactionsErrors_1 = __importDefault(require("../errors/TransactionsErrors"));
26
+ const ChainManager_1 = __importDefault(require("../services/ChainManager"));
27
+ const TronHelper_1 = __importDefault(require("../services/tron/services/TronHelper"));
28
+ const needs_approval_and_funding = (blockchain, chainId, token, parentIndex, childIndex, spender, dbPool, config) => __awaiter(void 0, void 0, void 0, function* () {
29
+ const walletManager = WalletManager_1.default.getInstance(config, dbPool);
30
+ const wallet = walletManager.deriveWallet(parentIndex, childIndex, blockchain);
31
+ try {
32
+ const providerManager = ProviderManager_1.default.getInstance(config);
33
+ const provider = providerManager.getNewProvider(chainId).provider;
34
+ let signer = wallet.wallet.connect(provider);
35
+ let tokenContract = new ethers_1.Contract(token, ERC20Mock_json_1.default, signer);
36
+ const balance = yield tokenContract.balanceOf(signer.address);
37
+ if (balance === BigInt(0))
38
+ return { status: true, needs_approval: false, needs_funding: false };
39
+ const fundsManager = walletManager.getEscrowFundsManagerWallet("evm");
40
+ let fundsManagerSigner = fundsManager.connect(provider);
41
+ tokenContract = tokenContract.connect(fundsManagerSigner);
42
+ // Request approval only if the token is not already approved for spending by escrow contract
43
+ const allowance = yield tokenContract.allowance(wallet.address, spender);
44
+ if (allowance === BigInt(0)) {
45
+ const ethers_balance = yield provider.getBalance(signer.address);
46
+ const gas_estimate = yield (0, exports.estimateGas)(provider, token, spender, ethers_1.ethers.MaxUint256, wallet.address, parseInt(chainId), "approve");
47
+ if (gas_estimate > ethers_balance) {
48
+ return { status: true, needs_approval: true, needs_funding: true };
49
+ }
50
+ return { status: true, needs_approval: true, needs_funding: false };
51
+ }
52
+ return { status: true, needs_approval: false, needs_funding: false };
53
+ }
54
+ catch (error) {
55
+ throw error;
56
+ }
57
+ });
58
+ exports.needs_approval_and_funding = needs_approval_and_funding;
59
+ const approve_if_not_approved = (blockchain, chainId, parentIndex, childIndex, spender, token, dbPool, config) => __awaiter(void 0, void 0, void 0, function* () {
60
+ const walletManager = WalletManager_1.default.getInstance(config, dbPool);
61
+ const wallet = walletManager.deriveWallet(parentIndex, childIndex, blockchain);
62
+ try {
63
+ const providerManager = ProviderManager_1.default.getInstance(config);
64
+ const provider = providerManager.getNewProvider(chainId).provider;
65
+ let signer = wallet.wallet.connect(provider);
66
+ let tokenContract = new ethers_1.Contract(token, ERC20Mock_json_1.default, signer);
67
+ const balance = yield tokenContract.balanceOf(signer.address);
68
+ if (balance === BigInt(0))
69
+ return { status: true, balance: balance };
70
+ const fundsManager = walletManager.getEscrowFundsManagerWallet("evm");
71
+ let fundsManagerSigner = fundsManager.connect(provider);
72
+ tokenContract = tokenContract.connect(fundsManagerSigner);
73
+ // Request approval only if the token is not already approved for spending by escrow contract
74
+ const allowance = yield tokenContract.allowance(wallet.address, spender);
75
+ tokenContract = tokenContract.connect(signer);
76
+ if (allowance === BigInt(0)) {
77
+ const ethers_balance = yield provider.getBalance(signer.address);
78
+ // const gas_estimate = await retryWithExponentialBackoff(() => estimateApprovalGas(provider, token, spender, balance, signer.address, parseInt(chainId)));
79
+ const gas_estimate = yield (0, exports.estimateGas)(provider, token, spender, ethers_1.ethers.MaxUint256, wallet.address, parseInt(chainId), "approve");
80
+ if (gas_estimate > ethers_balance) {
81
+ // await walletManager.fund_wallets_evm(blockchain, chainId, signer.address, "native");
82
+ }
83
+ const approveTx = yield tokenContract.approve(spender, ethers_1.ethers.MaxUint256);
84
+ yield approveTx.wait();
85
+ }
86
+ return { status: true, balance: balance };
87
+ }
88
+ catch (error) {
89
+ throw error;
90
+ }
91
+ });
92
+ exports.approve_if_not_approved = approve_if_not_approved;
93
+ // TODO get payment token from cache
94
+ const getWalletBalance = (blockchain, chainId, address, token, dbPool, config) => __awaiter(void 0, void 0, void 0, function* () {
95
+ var _a;
96
+ switch (blockchain) {
97
+ case ("evm"):
98
+ const providerManager = ProviderManager_1.default.getInstance(config);
99
+ const provider = providerManager.getNewProvider(chainId).provider;
100
+ if (token === ethers_1.ethers.ZeroAddress) {
101
+ const balance = yield (0, Utility_1.retryWithExponentialBackoff)(() => provider.getBalance(address));
102
+ return { balance, decimals: BigInt(18) };
103
+ }
104
+ else {
105
+ const contract = new ethers_1.ethers.Contract(token, ERC20Mock_json_1.default, provider);
106
+ let balance = yield (0, Utility_1.retryWithExponentialBackoff)(() => contract.balanceOf(address));
107
+ let decimals = yield (0, Utility_1.retryWithExponentialBackoff)(() => contract.decimals());
108
+ return { balance: BigInt(balance), decimals: BigInt(decimals) };
109
+ }
110
+ case ("solana"):
111
+ const ownerPk = new web3_js_1.PublicKey(address);
112
+ const connection = (0, solana_1.getSolanaConnection)(chainId, config);
113
+ // Handle sol native transfers
114
+ if (token === solana_1.solana_program_address) {
115
+ // const lamports = await connection.getBalance(ownerPk);
116
+ const lamports = yield (0, Utility_1.retryWithExponentialBackoff)(() => connection.getBalance(ownerPk));
117
+ return { balance: BigInt(lamports), decimals: BigInt(9) };
118
+ }
119
+ // Handle SPL token balances
120
+ try {
121
+ const mintPk = new web3_js_1.PublicKey(token);
122
+ const mintadd = mintPk.toString();
123
+ // const mint = await getMint(connection, mintPk);
124
+ const parsedTokenAccounts = yield (0, Utility_1.retryWithExponentialBackoff)(() => connection.getParsedTokenAccountsByOwner(ownerPk, { programId: spl_token_1.TOKEN_PROGRAM_ID }));
125
+ const targetAccount = parsedTokenAccounts.value.find(a => new web3_js_1.PublicKey(a.account.data.parsed.info.mint).toString() === mintPk.toString());
126
+ if (!targetAccount)
127
+ throw new Error("Token account not found");
128
+ const tokenInfo = yield connection.getAccountInfo(targetAccount.pubkey);
129
+ // const parsedInfo = await connection.getParsedAccountInfo(targetAccount.pubkey);
130
+ const sol_balance = tokenInfo === null || tokenInfo === void 0 ? void 0 : tokenInfo.lamports;
131
+ const balance = targetAccount.account.data.parsed.info.tokenAmount.amount;
132
+ const decimals = targetAccount.account.data.parsed.info.tokenAmount.decimals;
133
+ return { balance: BigInt(balance), decimals: BigInt(decimals) };
134
+ }
135
+ catch (error) {
136
+ return { balance: BigInt(0), decimals: BigInt(0) };
137
+ }
138
+ case "tron":
139
+ const network = ChainManager_1.default.getInstance(config).getChainConfigForChainIdSync(parseInt(chainId));
140
+ if (!network)
141
+ throw new Error(`Tron network config is not setup`);
142
+ // const api_url = (network.rpcMetadata as TronRpcMetadata).tronGridApi;
143
+ // const tronNode = chainId === '3448148188' ? "https://nile.trongrid.io/" : "https://api.trongrid.io";
144
+ // const tronWeb = new TronWeb({ fullHost: api_url });
145
+ const tronWeb = new TronHelper_1.default().get_tron_provider(chainId, config);
146
+ tronWeb.setAddress(address);
147
+ // Native TRX
148
+ if (token === "TRX" || token === "0x0" || token === ethers_1.ethers.ZeroAddress || token === ethers_1.ethers.ZeroAddress.slice(2)) {
149
+ try {
150
+ const account = yield (0, Utility_1.retryWithExponentialBackoff)(() => tronWeb.trx.getAccount(address));
151
+ const balance = BigInt((_a = account.balance) !== null && _a !== void 0 ? _a : 0); // balance in SUN. 1 TRX -> 1e6 SUN
152
+ return { balance, decimals: BigInt(6) }; // TRX has 6 decimals
153
+ }
154
+ catch (err) {
155
+ console.error("Tron TRX balance error:", err);
156
+ return { balance: BigInt(0), decimals: BigInt(6) };
157
+ }
158
+ }
159
+ // TRC20 token
160
+ try {
161
+ const contract = yield tronWeb.contract().at(token);
162
+ const balance = yield (0, Utility_1.retryWithExponentialBackoff)(() => contract.methods.balanceOf(address).call());
163
+ const decimals = yield (0, Utility_1.retryWithExponentialBackoff)(() => contract.methods.decimals().call());
164
+ return { balance: BigInt(balance), decimals: BigInt(decimals) };
165
+ }
166
+ catch (err) {
167
+ console.error("Tron TRC20 balance error:", err);
168
+ return { balance: BigInt(0), decimals: BigInt(0) };
169
+ }
170
+ default:
171
+ return { balance: BigInt(0), decimals: BigInt(0) };
172
+ }
173
+ });
174
+ exports.getWalletBalance = getWalletBalance;
175
+ const estimate_escrow_method_call_cost = (chain_id, payloads, dbPool, config) => __awaiter(void 0, void 0, void 0, function* () {
176
+ const errors = new TransactionsErrors_1.default();
177
+ if (payloads.length === 0)
178
+ throw new Error(errors.EmptyPayload("estimating Escrow withdrawal cost"));
179
+ const chain_manager = ChainManager_1.default.getInstance(config);
180
+ const escrow_config = chain_manager.getEscrowContractForChain(parseInt(chain_id));
181
+ const provider = ProviderManager_1.default.getInstance(config).getNewProvider(chain_id).provider;
182
+ const Escrow = new ethers_1.ethers.Contract(escrow_config.addresses[0], Escrow_json_1.default, provider);
183
+ const batch_payloads = payloads.map(p => {
184
+ return {
185
+ amount: p.amount_in_tokens,
186
+ requestId: p.requestId,
187
+ tokenAddress: p.token,
188
+ receiverAddress: p.receiver
189
+ };
190
+ });
191
+ const data = Escrow.interface.encodeFunctionData('batch_withdraw', [
192
+ batch_payloads
193
+ ]);
194
+ const funds_wallet = WalletManager_1.default.getInstance(config, dbPool).getEscrowFundsManagerWallet("evm");
195
+ // Create transaction request for gas estimation
196
+ const txDetails = {
197
+ to: Escrow.target,
198
+ data: data,
199
+ from: funds_wallet.address,
200
+ chainId: chain_id.toString(),
201
+ value: 0
202
+ };
203
+ console.log(`BATCh WITHDRAW DAT: `, { batch_payloads, data, txDetails });
204
+ // Estimate gas units and get current gas price
205
+ const [gasUnits, gasPrice] = yield Promise.all([
206
+ (0, Utility_1.retryWithExponentialBackoff)(() => __awaiter(void 0, void 0, void 0, function* () { return yield provider.estimateGas(txDetails); })),
207
+ (0, Utility_1.retryWithExponentialBackoff)(() => __awaiter(void 0, void 0, void 0, function* () { return yield provider.getFeeData(); }))
208
+ ]);
209
+ // Calculate total gas cost in native token
210
+ const totalFee = gasPrice.maxFeePerGas ? gasUnits * gasPrice.maxFeePerGas : gasUnits * (gasPrice.gasPrice || BigInt(0));
211
+ return totalFee;
212
+ });
213
+ exports.estimate_escrow_method_call_cost = estimate_escrow_method_call_cost;
214
+ const estimateGas = (provider_1, tokenAddress_1, spenderAddress_1, amount_1, fromAddress_1, chainId_1, transactionType_1, ...args_1) => __awaiter(void 0, [provider_1, tokenAddress_1, spenderAddress_1, amount_1, fromAddress_1, chainId_1, transactionType_1, ...args_1], void 0, function* (provider, tokenAddress, spenderAddress, amount, fromAddress, chainId, transactionType, isMockTransfer = false) {
215
+ let data = undefined;
216
+ let value = BigInt(0);
217
+ switch (transactionType) {
218
+ case "approve":
219
+ {
220
+ if (!spenderAddress)
221
+ throw new Error("Spender address required.");
222
+ // Create contract interface
223
+ const tokenContract = new ethers_1.ethers.Contract(tokenAddress, ERC20Mock_json_1.default, provider);
224
+ data = tokenContract.interface.encodeFunctionData('approve', [
225
+ spenderAddress,
226
+ amount
227
+ ]);
228
+ }
229
+ break;
230
+ case ("transferFrom"):
231
+ {
232
+ if (!spenderAddress)
233
+ throw new Error("Spender address required.");
234
+ // Create contract interface
235
+ const tokenContract = new ethers_1.ethers.Contract(tokenAddress, ERC20Mock_json_1.default, provider);
236
+ if (isMockTransfer) {
237
+ data = tokenContract.interface.encodeFunctionData("transfer", [
238
+ spenderAddress,
239
+ amount
240
+ ]);
241
+ }
242
+ else {
243
+ data = tokenContract.interface.encodeFunctionData("transferFrom", [
244
+ fromAddress,
245
+ spenderAddress,
246
+ amount
247
+ ]);
248
+ }
249
+ }
250
+ break;
251
+ case "native":
252
+ value = amount;
253
+ break;
254
+ }
255
+ // Create transaction request for gas estimation
256
+ const txDetails = {
257
+ to: transactionType == 'native' ? undefined : tokenAddress,
258
+ data: data,
259
+ from: fromAddress,
260
+ chainId: chainId.toString(),
261
+ value: value
262
+ };
263
+ // Estimate gas units and get current gas price
264
+ const [gasUnits, gasPrice] = yield Promise.all([
265
+ (0, Utility_1.retryWithExponentialBackoff)(() => __awaiter(void 0, void 0, void 0, function* () { return yield provider.estimateGas(txDetails); })),
266
+ (0, Utility_1.retryWithExponentialBackoff)(() => __awaiter(void 0, void 0, void 0, function* () { return yield provider.getFeeData(); }))
267
+ ]);
268
+ // Calculate total gas cost in native token
269
+ const totalFee = gasPrice.maxFeePerGas ? gasUnits * gasPrice.maxFeePerGas : gasUnits * (gasPrice.gasPrice || BigInt(0));
270
+ return totalFee;
271
+ });
272
+ exports.estimateGas = estimateGas;
273
+ const estimateApprovalGas = (provider, tokenAddress, spenderAddress, amount, fromAddress, chainId) => __awaiter(void 0, void 0, void 0, function* () {
274
+ // Create contract interface
275
+ const tokenContract = new ethers_1.ethers.Contract(tokenAddress, ERC20Mock_json_1.default, provider);
276
+ // Encode the approve function call
277
+ const approveData = tokenContract.interface.encodeFunctionData('approve', [
278
+ spenderAddress,
279
+ amount
280
+ ]);
281
+ // Create transaction request for gas estimation
282
+ const txDetails = {
283
+ to: tokenAddress,
284
+ data: approveData,
285
+ from: fromAddress,
286
+ chainId: chainId
287
+ };
288
+ // Estimate gas
289
+ const gasEstimate = yield provider.estimateGas(txDetails);
290
+ return gasEstimate;
291
+ });