@atomiqlabs/chain-evm 1.0.0-dev.75 → 1.0.0-dev.77

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 (185) hide show
  1. package/LICENSE +201 -201
  2. package/dist/chains/botanix/BotanixChainType.d.ts +13 -13
  3. package/dist/chains/botanix/BotanixChainType.js +2 -2
  4. package/dist/chains/botanix/BotanixInitializer.d.ts +30 -30
  5. package/dist/chains/botanix/BotanixInitializer.js +122 -122
  6. package/dist/chains/citrea/CitreaBtcRelay.d.ts +21 -21
  7. package/dist/chains/citrea/CitreaBtcRelay.js +43 -43
  8. package/dist/chains/citrea/CitreaChainType.d.ts +13 -13
  9. package/dist/chains/citrea/CitreaChainType.js +2 -2
  10. package/dist/chains/citrea/CitreaFees.d.ts +29 -29
  11. package/dist/chains/citrea/CitreaFees.js +67 -67
  12. package/dist/chains/citrea/CitreaInitializer.d.ts +30 -30
  13. package/dist/chains/citrea/CitreaInitializer.js +129 -129
  14. package/dist/chains/citrea/CitreaSpvVaultContract.d.ts +15 -15
  15. package/dist/chains/citrea/CitreaSpvVaultContract.js +74 -74
  16. package/dist/chains/citrea/CitreaSwapContract.d.ts +22 -22
  17. package/dist/chains/citrea/CitreaSwapContract.js +96 -96
  18. package/dist/chains/citrea/CitreaTokens.d.ts +9 -9
  19. package/dist/chains/citrea/CitreaTokens.js +20 -20
  20. package/dist/evm/btcrelay/BtcRelayAbi.d.ts +198 -198
  21. package/dist/evm/btcrelay/BtcRelayAbi.js +261 -261
  22. package/dist/evm/btcrelay/BtcRelayTypechain.d.ts +172 -172
  23. package/dist/evm/btcrelay/BtcRelayTypechain.js +2 -2
  24. package/dist/evm/btcrelay/EVMBtcRelay.d.ts +197 -197
  25. package/dist/evm/btcrelay/EVMBtcRelay.js +435 -435
  26. package/dist/evm/btcrelay/headers/EVMBtcHeader.d.ts +33 -33
  27. package/dist/evm/btcrelay/headers/EVMBtcHeader.js +84 -84
  28. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.d.ts +56 -56
  29. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.js +123 -123
  30. package/dist/evm/chain/EVMChainInterface.d.ts +51 -51
  31. package/dist/evm/chain/EVMChainInterface.js +89 -89
  32. package/dist/evm/chain/EVMModule.d.ts +9 -9
  33. package/dist/evm/chain/EVMModule.js +13 -13
  34. package/dist/evm/chain/modules/ERC20Abi.d.ts +168 -168
  35. package/dist/evm/chain/modules/ERC20Abi.js +225 -225
  36. package/dist/evm/chain/modules/EVMAddresses.d.ts +10 -10
  37. package/dist/evm/chain/modules/EVMAddresses.js +30 -30
  38. package/dist/evm/chain/modules/EVMBlocks.d.ts +20 -20
  39. package/dist/evm/chain/modules/EVMBlocks.js +64 -64
  40. package/dist/evm/chain/modules/EVMEvents.d.ts +36 -36
  41. package/dist/evm/chain/modules/EVMEvents.js +122 -122
  42. package/dist/evm/chain/modules/EVMFees.d.ts +36 -36
  43. package/dist/evm/chain/modules/EVMFees.js +74 -74
  44. package/dist/evm/chain/modules/EVMSignatures.d.ts +29 -29
  45. package/dist/evm/chain/modules/EVMSignatures.js +68 -68
  46. package/dist/evm/chain/modules/EVMTokens.d.ts +70 -70
  47. package/dist/evm/chain/modules/EVMTokens.js +142 -142
  48. package/dist/evm/chain/modules/EVMTransactions.d.ts +94 -94
  49. package/dist/evm/chain/modules/EVMTransactions.js +286 -286
  50. package/dist/evm/contract/EVMContractBase.d.ts +22 -22
  51. package/dist/evm/contract/EVMContractBase.js +34 -34
  52. package/dist/evm/contract/EVMContractModule.d.ts +8 -8
  53. package/dist/evm/contract/EVMContractModule.js +11 -11
  54. package/dist/evm/contract/modules/EVMContractEvents.d.ts +42 -42
  55. package/dist/evm/contract/modules/EVMContractEvents.js +75 -75
  56. package/dist/evm/events/EVMChainEvents.d.ts +22 -22
  57. package/dist/evm/events/EVMChainEvents.js +69 -69
  58. package/dist/evm/events/EVMChainEventsBrowser.d.ts +102 -102
  59. package/dist/evm/events/EVMChainEventsBrowser.js +413 -404
  60. package/dist/evm/providers/JsonRpcProviderWithRetries.d.ts +15 -15
  61. package/dist/evm/providers/JsonRpcProviderWithRetries.js +19 -19
  62. package/dist/evm/providers/ReconnectingWebSocketProvider.d.ts +22 -22
  63. package/dist/evm/providers/ReconnectingWebSocketProvider.js +87 -87
  64. package/dist/evm/providers/SocketProvider.d.ts +111 -111
  65. package/dist/evm/providers/SocketProvider.js +334 -334
  66. package/dist/evm/providers/WebSocketProviderWithRetries.d.ts +17 -17
  67. package/dist/evm/providers/WebSocketProviderWithRetries.js +19 -19
  68. package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +79 -79
  69. package/dist/evm/spv_swap/EVMSpvVaultContract.js +482 -482
  70. package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +39 -39
  71. package/dist/evm/spv_swap/EVMSpvVaultData.js +0 -180
  72. package/dist/evm/spv_swap/EVMSpvWithdrawalData.d.ts +19 -19
  73. package/dist/evm/spv_swap/EVMSpvWithdrawalData.js +55 -55
  74. package/dist/evm/spv_swap/SpvVaultContractAbi.d.ts +91 -91
  75. package/dist/evm/spv_swap/SpvVaultContractAbi.js +849 -849
  76. package/dist/evm/spv_swap/SpvVaultContractTypechain.d.ts +450 -450
  77. package/dist/evm/spv_swap/SpvVaultContractTypechain.js +2 -2
  78. package/dist/evm/swaps/EVMSwapContract.d.ts +193 -193
  79. package/dist/evm/swaps/EVMSwapContract.js +378 -378
  80. package/dist/evm/swaps/EVMSwapData.d.ts +66 -66
  81. package/dist/evm/swaps/EVMSwapData.js +260 -260
  82. package/dist/evm/swaps/EVMSwapModule.d.ts +9 -9
  83. package/dist/evm/swaps/EVMSwapModule.js +11 -11
  84. package/dist/evm/swaps/EscrowManagerAbi.d.ts +120 -120
  85. package/dist/evm/swaps/EscrowManagerAbi.js +985 -985
  86. package/dist/evm/swaps/EscrowManagerTypechain.d.ts +475 -475
  87. package/dist/evm/swaps/EscrowManagerTypechain.js +2 -2
  88. package/dist/evm/swaps/handlers/IHandler.d.ts +13 -13
  89. package/dist/evm/swaps/handlers/IHandler.js +2 -2
  90. package/dist/evm/swaps/handlers/claim/ClaimHandlers.d.ts +10 -10
  91. package/dist/evm/swaps/handlers/claim/ClaimHandlers.js +13 -13
  92. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.d.ts +20 -20
  93. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.js +39 -39
  94. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.d.ts +24 -24
  95. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.js +59 -59
  96. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.d.ts +25 -25
  97. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.js +51 -51
  98. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.d.ts +21 -21
  99. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.js +28 -28
  100. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.d.ts +48 -48
  101. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.js +63 -63
  102. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.d.ts +17 -17
  103. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.js +28 -28
  104. package/dist/evm/swaps/modules/EVMLpVault.d.ts +69 -69
  105. package/dist/evm/swaps/modules/EVMLpVault.js +134 -134
  106. package/dist/evm/swaps/modules/EVMSwapClaim.d.ts +54 -54
  107. package/dist/evm/swaps/modules/EVMSwapClaim.js +137 -137
  108. package/dist/evm/swaps/modules/EVMSwapInit.d.ts +88 -88
  109. package/dist/evm/swaps/modules/EVMSwapInit.js +274 -274
  110. package/dist/evm/swaps/modules/EVMSwapRefund.d.ts +62 -62
  111. package/dist/evm/swaps/modules/EVMSwapRefund.js +167 -167
  112. package/dist/evm/typechain/common.d.ts +50 -50
  113. package/dist/evm/typechain/common.js +2 -2
  114. package/dist/evm/wallet/EVMBrowserSigner.d.ts +5 -5
  115. package/dist/evm/wallet/EVMBrowserSigner.js +11 -11
  116. package/dist/evm/wallet/EVMPersistentSigner.d.ts +29 -29
  117. package/dist/evm/wallet/EVMPersistentSigner.js +222 -222
  118. package/dist/evm/wallet/EVMSigner.d.ts +11 -11
  119. package/dist/evm/wallet/EVMSigner.js +24 -24
  120. package/dist/index.d.ts +44 -44
  121. package/dist/index.js +60 -60
  122. package/dist/utils/Utils.d.ts +17 -17
  123. package/dist/utils/Utils.js +81 -81
  124. package/package.json +39 -39
  125. package/src/chains/botanix/BotanixChainType.ts +28 -28
  126. package/src/chains/botanix/BotanixInitializer.ts +171 -171
  127. package/src/chains/citrea/CitreaBtcRelay.ts +57 -57
  128. package/src/chains/citrea/CitreaChainType.ts +28 -28
  129. package/src/chains/citrea/CitreaFees.ts +77 -77
  130. package/src/chains/citrea/CitreaInitializer.ts +178 -178
  131. package/src/chains/citrea/CitreaSpvVaultContract.ts +75 -75
  132. package/src/chains/citrea/CitreaSwapContract.ts +102 -102
  133. package/src/chains/citrea/CitreaTokens.ts +21 -21
  134. package/src/evm/btcrelay/BtcRelayAbi.ts +258 -258
  135. package/src/evm/btcrelay/BtcRelayTypechain.ts +371 -371
  136. package/src/evm/btcrelay/EVMBtcRelay.ts +537 -537
  137. package/src/evm/btcrelay/headers/EVMBtcHeader.ts +109 -109
  138. package/src/evm/btcrelay/headers/EVMBtcStoredHeader.ts +152 -152
  139. package/src/evm/chain/EVMChainInterface.ts +155 -155
  140. package/src/evm/chain/EVMModule.ts +21 -21
  141. package/src/evm/chain/modules/ERC20Abi.ts +222 -222
  142. package/src/evm/chain/modules/EVMAddresses.ts +28 -28
  143. package/src/evm/chain/modules/EVMBlocks.ts +75 -75
  144. package/src/evm/chain/modules/EVMEvents.ts +139 -139
  145. package/src/evm/chain/modules/EVMFees.ts +104 -104
  146. package/src/evm/chain/modules/EVMSignatures.ts +76 -76
  147. package/src/evm/chain/modules/EVMTokens.ts +155 -155
  148. package/src/evm/chain/modules/EVMTransactions.ts +325 -325
  149. package/src/evm/contract/EVMContractBase.ts +63 -63
  150. package/src/evm/contract/EVMContractModule.ts +16 -16
  151. package/src/evm/contract/modules/EVMContractEvents.ts +102 -102
  152. package/src/evm/events/EVMChainEvents.ts +82 -82
  153. package/src/evm/events/EVMChainEventsBrowser.ts +534 -525
  154. package/src/evm/providers/JsonRpcProviderWithRetries.ts +24 -24
  155. package/src/evm/providers/ReconnectingWebSocketProvider.ts +101 -101
  156. package/src/evm/providers/SocketProvider.ts +368 -368
  157. package/src/evm/providers/WebSocketProviderWithRetries.ts +27 -27
  158. package/src/evm/spv_swap/EVMSpvVaultContract.ts +615 -615
  159. package/src/evm/spv_swap/EVMSpvVaultData.ts +224 -224
  160. package/src/evm/spv_swap/EVMSpvWithdrawalData.ts +70 -70
  161. package/src/evm/spv_swap/SpvVaultContractAbi.ts +846 -846
  162. package/src/evm/spv_swap/SpvVaultContractTypechain.ts +685 -685
  163. package/src/evm/swaps/EVMSwapContract.ts +600 -600
  164. package/src/evm/swaps/EVMSwapData.ts +378 -378
  165. package/src/evm/swaps/EVMSwapModule.ts +16 -16
  166. package/src/evm/swaps/EscrowManagerAbi.ts +982 -982
  167. package/src/evm/swaps/EscrowManagerTypechain.ts +723 -723
  168. package/src/evm/swaps/handlers/IHandler.ts +17 -17
  169. package/src/evm/swaps/handlers/claim/ClaimHandlers.ts +20 -20
  170. package/src/evm/swaps/handlers/claim/HashlockClaimHandler.ts +46 -46
  171. package/src/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.ts +82 -82
  172. package/src/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.ts +76 -76
  173. package/src/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.ts +46 -46
  174. package/src/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.ts +115 -115
  175. package/src/evm/swaps/handlers/refund/TimelockRefundHandler.ts +37 -37
  176. package/src/evm/swaps/modules/EVMLpVault.ts +154 -154
  177. package/src/evm/swaps/modules/EVMSwapClaim.ts +172 -172
  178. package/src/evm/swaps/modules/EVMSwapInit.ts +328 -328
  179. package/src/evm/swaps/modules/EVMSwapRefund.ts +229 -229
  180. package/src/evm/typechain/common.ts +131 -131
  181. package/src/evm/wallet/EVMBrowserSigner.ts +11 -11
  182. package/src/evm/wallet/EVMPersistentSigner.ts +298 -298
  183. package/src/evm/wallet/EVMSigner.ts +31 -31
  184. package/src/index.ts +53 -53
  185. package/src/utils/Utils.ts +92 -92
@@ -1,122 +1,122 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BotanixInitializer = exports.initializeBotanix = exports.BotanixAssets = void 0;
4
- const base_1 = require("@atomiqlabs/base");
5
- const ethers_1 = require("ethers");
6
- const EVMChainInterface_1 = require("../../evm/chain/EVMChainInterface");
7
- const EVMFees_1 = require("../../evm/chain/modules/EVMFees");
8
- const EVMBtcRelay_1 = require("../../evm/btcrelay/EVMBtcRelay");
9
- const EVMSwapContract_1 = require("../../evm/swaps/EVMSwapContract");
10
- const EVMSpvVaultContract_1 = require("../../evm/spv_swap/EVMSpvVaultContract");
11
- const EVMChainEventsBrowser_1 = require("../../evm/events/EVMChainEventsBrowser");
12
- const EVMSwapData_1 = require("../../evm/swaps/EVMSwapData");
13
- const EVMSpvVaultData_1 = require("../../evm/spv_swap/EVMSpvVaultData");
14
- const EVMSpvWithdrawalData_1 = require("../../evm/spv_swap/EVMSpvWithdrawalData");
15
- const BotanixChainIds = {
16
- MAINNET: null,
17
- TESTNET: 3636
18
- };
19
- const BotanixContractAddresses = {
20
- MAINNET: {
21
- executionContract: "",
22
- swapContract: "",
23
- btcRelayContract: "",
24
- btcRelayDeploymentHeight: 0,
25
- spvVaultContract: "",
26
- spvVaultDeploymentHeight: 0,
27
- handlerContracts: {
28
- refund: {
29
- timelock: ""
30
- },
31
- claim: {
32
- [base_1.ChainSwapType.HTLC]: "",
33
- [base_1.ChainSwapType.CHAIN_TXID]: "",
34
- [base_1.ChainSwapType.CHAIN]: "",
35
- [base_1.ChainSwapType.CHAIN_NONCED]: ""
36
- }
37
- }
38
- },
39
- TESTNET: {
40
- executionContract: "0xBbf7755b674dD107d59F0650D1A3fA9C60bf6Fe6",
41
- swapContract: "0xf61D1da542111216337FeEA5586022130D468842",
42
- btcRelayContract: "0xba7E78011909e3501027FBc226a04DCC837a555D",
43
- btcRelayDeploymentHeight: 3462466,
44
- spvVaultContract: "0x1120e1Eb3049148AeBEe497331774BfE1f6c174D",
45
- spvVaultDeploymentHeight: 3425257,
46
- handlerContracts: {
47
- refund: {
48
- timelock: "0xEf227Caf24681FcEDa5fC26777B81964D404e239"
49
- },
50
- claim: {
51
- [base_1.ChainSwapType.HTLC]: "0xBe8C784b03F0c6d54aC35a4D41bd6CF2EDb6e012",
52
- [base_1.ChainSwapType.CHAIN_TXID]: "0x65faec5DC334bf2005eC2DFcf012da87a832f1F0",
53
- [base_1.ChainSwapType.CHAIN]: "0x4699450973c21d6Fe09e36A8A475EaE4D78a3137",
54
- [base_1.ChainSwapType.CHAIN_NONCED]: "0xfd0FbA128244f502678251b07dEa0fb4EcE959F3"
55
- }
56
- }
57
- }
58
- };
59
- exports.BotanixAssets = {
60
- BBTC: {
61
- address: "0x0000000000000000000000000000000000000000",
62
- decimals: 18,
63
- displayDecimals: 8
64
- }
65
- };
66
- function initializeBotanix(options, bitcoinRpc, network) {
67
- if (options.chainType == null) {
68
- switch (network) {
69
- case base_1.BitcoinNetwork.MAINNET:
70
- options.chainType = "MAINNET";
71
- break;
72
- case base_1.BitcoinNetwork.TESTNET:
73
- options.chainType = "TESTNET";
74
- break;
75
- }
76
- }
77
- const defaultContractAddresses = BotanixContractAddresses[options.chainType];
78
- const chainId = BotanixChainIds[options.chainType];
79
- const provider = typeof (options.rpcUrl) === "string" ?
80
- (options.rpcUrl.startsWith("ws")
81
- ? new ethers_1.WebSocketProvider(options.rpcUrl, { name: "Botanix", chainId })
82
- : new ethers_1.JsonRpcProvider(options.rpcUrl, { name: "Botanix", chainId })) :
83
- options.rpcUrl;
84
- const Fees = options.fees ?? new EVMFees_1.EVMFees(provider, 2n * 1000000000n, 1000000n);
85
- const chainInterface = new EVMChainInterface_1.EVMChainInterface("BOTANIX", chainId, provider, {
86
- safeBlockTag: "finalized",
87
- maxLogsBlockRange: options.maxLogsBlockRange ?? 500
88
- }, options.retryPolicy, Fees);
89
- const btcRelay = new EVMBtcRelay_1.EVMBtcRelay(chainInterface, bitcoinRpc, network, options.btcRelayContract ?? defaultContractAddresses.btcRelayContract, options.btcRelayDeploymentHeight ?? defaultContractAddresses.btcRelayDeploymentHeight);
90
- const swapContract = new EVMSwapContract_1.EVMSwapContract(chainInterface, btcRelay, options.swapContract ?? defaultContractAddresses.swapContract, {
91
- refund: {
92
- ...defaultContractAddresses.handlerContracts.refund,
93
- ...options?.handlerContracts?.refund
94
- },
95
- claim: {
96
- ...defaultContractAddresses.handlerContracts.claim,
97
- ...options?.handlerContracts?.claim
98
- }
99
- });
100
- const spvVaultContract = new EVMSpvVaultContract_1.EVMSpvVaultContract(chainInterface, btcRelay, bitcoinRpc, options.spvVaultContract ?? defaultContractAddresses.spvVaultContract, options.spvVaultDeploymentHeight ?? defaultContractAddresses.spvVaultDeploymentHeight);
101
- const chainEvents = new EVMChainEventsBrowser_1.EVMChainEventsBrowser(chainInterface, swapContract, spvVaultContract);
102
- return {
103
- chainId: "BOTANIX",
104
- btcRelay,
105
- chainInterface,
106
- swapContract,
107
- chainEvents,
108
- swapDataConstructor: EVMSwapData_1.EVMSwapData,
109
- spvVaultContract,
110
- spvVaultDataConstructor: EVMSpvVaultData_1.EVMSpvVaultData,
111
- spvVaultWithdrawalDataConstructor: EVMSpvWithdrawalData_1.EVMSpvWithdrawalData
112
- };
113
- }
114
- exports.initializeBotanix = initializeBotanix;
115
- ;
116
- exports.BotanixInitializer = {
117
- chainId: "BOTANIX",
118
- chainType: null,
119
- initializer: initializeBotanix,
120
- tokens: exports.BotanixAssets,
121
- options: null
122
- };
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BotanixInitializer = exports.initializeBotanix = exports.BotanixAssets = void 0;
4
+ const base_1 = require("@atomiqlabs/base");
5
+ const ethers_1 = require("ethers");
6
+ const EVMChainInterface_1 = require("../../evm/chain/EVMChainInterface");
7
+ const EVMFees_1 = require("../../evm/chain/modules/EVMFees");
8
+ const EVMBtcRelay_1 = require("../../evm/btcrelay/EVMBtcRelay");
9
+ const EVMSwapContract_1 = require("../../evm/swaps/EVMSwapContract");
10
+ const EVMSpvVaultContract_1 = require("../../evm/spv_swap/EVMSpvVaultContract");
11
+ const EVMChainEventsBrowser_1 = require("../../evm/events/EVMChainEventsBrowser");
12
+ const EVMSwapData_1 = require("../../evm/swaps/EVMSwapData");
13
+ const EVMSpvVaultData_1 = require("../../evm/spv_swap/EVMSpvVaultData");
14
+ const EVMSpvWithdrawalData_1 = require("../../evm/spv_swap/EVMSpvWithdrawalData");
15
+ const BotanixChainIds = {
16
+ MAINNET: null,
17
+ TESTNET: 3636
18
+ };
19
+ const BotanixContractAddresses = {
20
+ MAINNET: {
21
+ executionContract: "",
22
+ swapContract: "",
23
+ btcRelayContract: "",
24
+ btcRelayDeploymentHeight: 0,
25
+ spvVaultContract: "",
26
+ spvVaultDeploymentHeight: 0,
27
+ handlerContracts: {
28
+ refund: {
29
+ timelock: ""
30
+ },
31
+ claim: {
32
+ [base_1.ChainSwapType.HTLC]: "",
33
+ [base_1.ChainSwapType.CHAIN_TXID]: "",
34
+ [base_1.ChainSwapType.CHAIN]: "",
35
+ [base_1.ChainSwapType.CHAIN_NONCED]: ""
36
+ }
37
+ }
38
+ },
39
+ TESTNET: {
40
+ executionContract: "0xBbf7755b674dD107d59F0650D1A3fA9C60bf6Fe6",
41
+ swapContract: "0xf61D1da542111216337FeEA5586022130D468842",
42
+ btcRelayContract: "0xba7E78011909e3501027FBc226a04DCC837a555D",
43
+ btcRelayDeploymentHeight: 3462466,
44
+ spvVaultContract: "0x1120e1Eb3049148AeBEe497331774BfE1f6c174D",
45
+ spvVaultDeploymentHeight: 3425257,
46
+ handlerContracts: {
47
+ refund: {
48
+ timelock: "0xEf227Caf24681FcEDa5fC26777B81964D404e239"
49
+ },
50
+ claim: {
51
+ [base_1.ChainSwapType.HTLC]: "0xBe8C784b03F0c6d54aC35a4D41bd6CF2EDb6e012",
52
+ [base_1.ChainSwapType.CHAIN_TXID]: "0x65faec5DC334bf2005eC2DFcf012da87a832f1F0",
53
+ [base_1.ChainSwapType.CHAIN]: "0x4699450973c21d6Fe09e36A8A475EaE4D78a3137",
54
+ [base_1.ChainSwapType.CHAIN_NONCED]: "0xfd0FbA128244f502678251b07dEa0fb4EcE959F3"
55
+ }
56
+ }
57
+ }
58
+ };
59
+ exports.BotanixAssets = {
60
+ BBTC: {
61
+ address: "0x0000000000000000000000000000000000000000",
62
+ decimals: 18,
63
+ displayDecimals: 8
64
+ }
65
+ };
66
+ function initializeBotanix(options, bitcoinRpc, network) {
67
+ if (options.chainType == null) {
68
+ switch (network) {
69
+ case base_1.BitcoinNetwork.MAINNET:
70
+ options.chainType = "MAINNET";
71
+ break;
72
+ case base_1.BitcoinNetwork.TESTNET:
73
+ options.chainType = "TESTNET";
74
+ break;
75
+ }
76
+ }
77
+ const defaultContractAddresses = BotanixContractAddresses[options.chainType];
78
+ const chainId = BotanixChainIds[options.chainType];
79
+ const provider = typeof (options.rpcUrl) === "string" ?
80
+ (options.rpcUrl.startsWith("ws")
81
+ ? new ethers_1.WebSocketProvider(options.rpcUrl, { name: "Botanix", chainId })
82
+ : new ethers_1.JsonRpcProvider(options.rpcUrl, { name: "Botanix", chainId })) :
83
+ options.rpcUrl;
84
+ const Fees = options.fees ?? new EVMFees_1.EVMFees(provider, 2n * 1000000000n, 1000000n);
85
+ const chainInterface = new EVMChainInterface_1.EVMChainInterface("BOTANIX", chainId, provider, {
86
+ safeBlockTag: "finalized",
87
+ maxLogsBlockRange: options.maxLogsBlockRange ?? 500
88
+ }, options.retryPolicy, Fees);
89
+ const btcRelay = new EVMBtcRelay_1.EVMBtcRelay(chainInterface, bitcoinRpc, network, options.btcRelayContract ?? defaultContractAddresses.btcRelayContract, options.btcRelayDeploymentHeight ?? defaultContractAddresses.btcRelayDeploymentHeight);
90
+ const swapContract = new EVMSwapContract_1.EVMSwapContract(chainInterface, btcRelay, options.swapContract ?? defaultContractAddresses.swapContract, {
91
+ refund: {
92
+ ...defaultContractAddresses.handlerContracts.refund,
93
+ ...options?.handlerContracts?.refund
94
+ },
95
+ claim: {
96
+ ...defaultContractAddresses.handlerContracts.claim,
97
+ ...options?.handlerContracts?.claim
98
+ }
99
+ });
100
+ const spvVaultContract = new EVMSpvVaultContract_1.EVMSpvVaultContract(chainInterface, btcRelay, bitcoinRpc, options.spvVaultContract ?? defaultContractAddresses.spvVaultContract, options.spvVaultDeploymentHeight ?? defaultContractAddresses.spvVaultDeploymentHeight);
101
+ const chainEvents = new EVMChainEventsBrowser_1.EVMChainEventsBrowser(chainInterface, swapContract, spvVaultContract);
102
+ return {
103
+ chainId: "BOTANIX",
104
+ btcRelay,
105
+ chainInterface,
106
+ swapContract,
107
+ chainEvents,
108
+ swapDataConstructor: EVMSwapData_1.EVMSwapData,
109
+ spvVaultContract,
110
+ spvVaultDataConstructor: EVMSpvVaultData_1.EVMSpvVaultData,
111
+ spvVaultWithdrawalDataConstructor: EVMSpvWithdrawalData_1.EVMSpvWithdrawalData
112
+ };
113
+ }
114
+ exports.initializeBotanix = initializeBotanix;
115
+ ;
116
+ exports.BotanixInitializer = {
117
+ chainId: "BOTANIX",
118
+ chainType: null,
119
+ initializer: initializeBotanix,
120
+ tokens: exports.BotanixAssets,
121
+ options: null
122
+ };
@@ -1,21 +1,21 @@
1
- import { EVMBtcRelay } from "../../evm/btcrelay/EVMBtcRelay";
2
- import { BtcBlock } from "@atomiqlabs/base";
3
- export declare class CitreaBtcRelay<B extends BtcBlock> extends EVMBtcRelay<B> {
4
- static StateDiffSize: {
5
- STATE_DIFF_PER_BLOCKHEADER: number;
6
- STATE_DIFF_BASE: number;
7
- };
8
- /**
9
- * Estimate required synchronization fee (worst case) to synchronize btc relay to the required blockheight
10
- *
11
- * @param requiredBlockheight
12
- * @param feeRate
13
- */
14
- estimateSynchronizeFee(requiredBlockheight: number, feeRate?: string): Promise<bigint>;
15
- /**
16
- * Returns fee required (in native token) to synchronize a single block to btc relay
17
- *
18
- * @param feeRate
19
- */
20
- getFeePerBlock(feeRate?: string): Promise<bigint>;
21
- }
1
+ import { EVMBtcRelay } from "../../evm/btcrelay/EVMBtcRelay";
2
+ import { BtcBlock } from "@atomiqlabs/base";
3
+ export declare class CitreaBtcRelay<B extends BtcBlock> extends EVMBtcRelay<B> {
4
+ static StateDiffSize: {
5
+ STATE_DIFF_PER_BLOCKHEADER: number;
6
+ STATE_DIFF_BASE: number;
7
+ };
8
+ /**
9
+ * Estimate required synchronization fee (worst case) to synchronize btc relay to the required blockheight
10
+ *
11
+ * @param requiredBlockheight
12
+ * @param feeRate
13
+ */
14
+ estimateSynchronizeFee(requiredBlockheight: number, feeRate?: string): Promise<bigint>;
15
+ /**
16
+ * Returns fee required (in native token) to synchronize a single block to btc relay
17
+ *
18
+ * @param feeRate
19
+ */
20
+ getFeePerBlock(feeRate?: string): Promise<bigint>;
21
+ }
@@ -1,43 +1,43 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CitreaBtcRelay = void 0;
4
- const EVMBtcRelay_1 = require("../../evm/btcrelay/EVMBtcRelay");
5
- const Utils_1 = require("../../utils/Utils");
6
- const CitreaFees_1 = require("./CitreaFees");
7
- const logger = (0, Utils_1.getLogger)("CitreaBtcRelay: ");
8
- class CitreaBtcRelay extends EVMBtcRelay_1.EVMBtcRelay {
9
- /**
10
- * Estimate required synchronization fee (worst case) to synchronize btc relay to the required blockheight
11
- *
12
- * @param requiredBlockheight
13
- * @param feeRate
14
- */
15
- async estimateSynchronizeFee(requiredBlockheight, feeRate) {
16
- feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
17
- const tipData = await this.getTipData();
18
- const currBlockheight = tipData.blockheight;
19
- const blockheightDelta = requiredBlockheight - currBlockheight;
20
- if (blockheightDelta <= 0)
21
- return 0n;
22
- const numTxs = Math.ceil(blockheightDelta / this.maxHeadersPerTx);
23
- const synchronizationFee = (BigInt(blockheightDelta) * await this.getFeePerBlock(feeRate))
24
- + CitreaFees_1.CitreaFees.getGasFee(EVMBtcRelay_1.EVMBtcRelay.GasCosts.GAS_BASE_MAIN * numTxs, feeRate, CitreaBtcRelay.StateDiffSize.STATE_DIFF_BASE * numTxs);
25
- logger.debug("estimateSynchronizeFee(): required blockheight: " + requiredBlockheight +
26
- " blockheight delta: " + blockheightDelta + " fee: " + synchronizationFee.toString(10));
27
- return synchronizationFee;
28
- }
29
- /**
30
- * Returns fee required (in native token) to synchronize a single block to btc relay
31
- *
32
- * @param feeRate
33
- */
34
- async getFeePerBlock(feeRate) {
35
- feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
36
- return CitreaFees_1.CitreaFees.getGasFee(EVMBtcRelay_1.EVMBtcRelay.GasCosts.GAS_PER_BLOCKHEADER, feeRate, CitreaBtcRelay.StateDiffSize.STATE_DIFF_PER_BLOCKHEADER);
37
- }
38
- }
39
- exports.CitreaBtcRelay = CitreaBtcRelay;
40
- CitreaBtcRelay.StateDiffSize = {
41
- STATE_DIFF_PER_BLOCKHEADER: 22,
42
- STATE_DIFF_BASE: 30
43
- };
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CitreaBtcRelay = void 0;
4
+ const EVMBtcRelay_1 = require("../../evm/btcrelay/EVMBtcRelay");
5
+ const Utils_1 = require("../../utils/Utils");
6
+ const CitreaFees_1 = require("./CitreaFees");
7
+ const logger = (0, Utils_1.getLogger)("CitreaBtcRelay: ");
8
+ class CitreaBtcRelay extends EVMBtcRelay_1.EVMBtcRelay {
9
+ /**
10
+ * Estimate required synchronization fee (worst case) to synchronize btc relay to the required blockheight
11
+ *
12
+ * @param requiredBlockheight
13
+ * @param feeRate
14
+ */
15
+ async estimateSynchronizeFee(requiredBlockheight, feeRate) {
16
+ feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
17
+ const tipData = await this.getTipData();
18
+ const currBlockheight = tipData.blockheight;
19
+ const blockheightDelta = requiredBlockheight - currBlockheight;
20
+ if (blockheightDelta <= 0)
21
+ return 0n;
22
+ const numTxs = Math.ceil(blockheightDelta / this.maxHeadersPerTx);
23
+ const synchronizationFee = (BigInt(blockheightDelta) * await this.getFeePerBlock(feeRate))
24
+ + CitreaFees_1.CitreaFees.getGasFee(EVMBtcRelay_1.EVMBtcRelay.GasCosts.GAS_BASE_MAIN * numTxs, feeRate, CitreaBtcRelay.StateDiffSize.STATE_DIFF_BASE * numTxs);
25
+ logger.debug("estimateSynchronizeFee(): required blockheight: " + requiredBlockheight +
26
+ " blockheight delta: " + blockheightDelta + " fee: " + synchronizationFee.toString(10));
27
+ return synchronizationFee;
28
+ }
29
+ /**
30
+ * Returns fee required (in native token) to synchronize a single block to btc relay
31
+ *
32
+ * @param feeRate
33
+ */
34
+ async getFeePerBlock(feeRate) {
35
+ feeRate ?? (feeRate = await this.Chain.Fees.getFeeRate());
36
+ return CitreaFees_1.CitreaFees.getGasFee(EVMBtcRelay_1.EVMBtcRelay.GasCosts.GAS_PER_BLOCKHEADER, feeRate, CitreaBtcRelay.StateDiffSize.STATE_DIFF_PER_BLOCKHEADER);
37
+ }
38
+ }
39
+ exports.CitreaBtcRelay = CitreaBtcRelay;
40
+ CitreaBtcRelay.StateDiffSize = {
41
+ STATE_DIFF_PER_BLOCKHEADER: 22,
42
+ STATE_DIFF_BASE: 30
43
+ };
@@ -1,13 +1,13 @@
1
- import { ChainType } from "@atomiqlabs/base";
2
- import { EVMPreFetchVerification } from "../../evm/swaps/modules/EVMSwapInit";
3
- import { EVMTx } from "../../evm/chain/modules/EVMTransactions";
4
- import { EVMSigner } from "../../evm/wallet/EVMSigner";
5
- import { EVMSwapData } from "../../evm/swaps/EVMSwapData";
6
- import { EVMChainInterface } from "../../evm/chain/EVMChainInterface";
7
- import { EVMChainEventsBrowser } from "../../evm/events/EVMChainEventsBrowser";
8
- import { EVMSpvVaultData } from "../../evm/spv_swap/EVMSpvVaultData";
9
- import { EVMSpvWithdrawalData } from "../../evm/spv_swap/EVMSpvWithdrawalData";
10
- import { CitreaSwapContract } from "./CitreaSwapContract";
11
- import { CitreaBtcRelay } from "./CitreaBtcRelay";
12
- import { CitreaSpvVaultContract } from "./CitreaSpvVaultContract";
13
- export type CitreaChainType = ChainType<"CITREA", never, EVMPreFetchVerification, EVMTx, EVMSigner, EVMSwapData, CitreaSwapContract, EVMChainInterface<"CITREA", 5115>, EVMChainEventsBrowser, CitreaBtcRelay<any>, EVMSpvVaultData, EVMSpvWithdrawalData, CitreaSpvVaultContract>;
1
+ import { ChainType } from "@atomiqlabs/base";
2
+ import { EVMPreFetchVerification } from "../../evm/swaps/modules/EVMSwapInit";
3
+ import { EVMTx } from "../../evm/chain/modules/EVMTransactions";
4
+ import { EVMSigner } from "../../evm/wallet/EVMSigner";
5
+ import { EVMSwapData } from "../../evm/swaps/EVMSwapData";
6
+ import { EVMChainInterface } from "../../evm/chain/EVMChainInterface";
7
+ import { EVMChainEventsBrowser } from "../../evm/events/EVMChainEventsBrowser";
8
+ import { EVMSpvVaultData } from "../../evm/spv_swap/EVMSpvVaultData";
9
+ import { EVMSpvWithdrawalData } from "../../evm/spv_swap/EVMSpvWithdrawalData";
10
+ import { CitreaSwapContract } from "./CitreaSwapContract";
11
+ import { CitreaBtcRelay } from "./CitreaBtcRelay";
12
+ import { CitreaSpvVaultContract } from "./CitreaSpvVaultContract";
13
+ export type CitreaChainType = ChainType<"CITREA", never, EVMPreFetchVerification, EVMTx, EVMSigner, EVMSwapData, CitreaSwapContract, EVMChainInterface<"CITREA", 5115>, EVMChainEventsBrowser, CitreaBtcRelay<any>, EVMSpvVaultData, EVMSpvWithdrawalData, CitreaSpvVaultContract>;
@@ -1,2 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,29 +1,29 @@
1
- import { EVMFees } from "../../evm/chain/modules/EVMFees";
2
- export declare class CitreaFees extends EVMFees {
3
- static readonly StateDiffSize: {
4
- APPROVE_DIFF_SIZE: number;
5
- };
6
- protected readonly logger: import("../../utils/Utils").LoggerType;
7
- private _blockFeeCache;
8
- /**
9
- * Gets evm fee rate
10
- *
11
- * @private
12
- * @returns {Promise<bigint>} L1 gas price denominated in Wei
13
- */
14
- private __getFeeRate;
15
- /**
16
- * Gets the gas price with caching, format: <gas price in Wei>;<transaction version: v1/v3>
17
- *
18
- * @private
19
- */
20
- getFeeRate(): Promise<string>;
21
- /**
22
- * Calculates the total gas fee paid for a given gas limit and state diff size at a given fee rate
23
- *
24
- * @param gas
25
- * @param stateDiffSize
26
- * @param feeRate
27
- */
28
- static getGasFee(gas: number, feeRate: string, stateDiffSize?: number): bigint;
29
- }
1
+ import { EVMFees } from "../../evm/chain/modules/EVMFees";
2
+ export declare class CitreaFees extends EVMFees {
3
+ static readonly StateDiffSize: {
4
+ APPROVE_DIFF_SIZE: number;
5
+ };
6
+ protected readonly logger: import("../../utils/Utils").LoggerType;
7
+ private _blockFeeCache;
8
+ /**
9
+ * Gets evm fee rate
10
+ *
11
+ * @private
12
+ * @returns {Promise<bigint>} L1 gas price denominated in Wei
13
+ */
14
+ private __getFeeRate;
15
+ /**
16
+ * Gets the gas price with caching, format: <gas price in Wei>;<transaction version: v1/v3>
17
+ *
18
+ * @private
19
+ */
20
+ getFeeRate(): Promise<string>;
21
+ /**
22
+ * Calculates the total gas fee paid for a given gas limit and state diff size at a given fee rate
23
+ *
24
+ * @param gas
25
+ * @param stateDiffSize
26
+ * @param feeRate
27
+ */
28
+ static getGasFee(gas: number, feeRate: string, stateDiffSize?: number): bigint;
29
+ }
@@ -1,67 +1,67 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CitreaFees = void 0;
4
- const EVMFees_1 = require("../../evm/chain/modules/EVMFees");
5
- const Utils_1 = require("../../utils/Utils");
6
- class CitreaFees extends EVMFees_1.EVMFees {
7
- constructor() {
8
- super(...arguments);
9
- this.logger = (0, Utils_1.getLogger)("CitreaFees: ");
10
- this._blockFeeCache = null;
11
- }
12
- /**
13
- * Gets evm fee rate
14
- *
15
- * @private
16
- * @returns {Promise<bigint>} L1 gas price denominated in Wei
17
- */
18
- async __getFeeRate() {
19
- const res = await this.provider.send("eth_getBlockByNumber", ["latest", false]);
20
- const l1Fee = BigInt(res.l1FeeRate);
21
- const baseFee = BigInt(res.baseFeePerGas) * this.feeMultiplierPPM / 1000000n;
22
- this.logger.debug("__getFeeRate(): Base fee rate: " + baseFee.toString(10) + ", l1 fee rate: " + l1Fee.toString(10));
23
- return { baseFee, l1Fee };
24
- }
25
- /**
26
- * Gets the gas price with caching, format: <gas price in Wei>;<transaction version: v1/v3>
27
- *
28
- * @private
29
- */
30
- async getFeeRate() {
31
- if (this._blockFeeCache == null || Date.now() - this._blockFeeCache.timestamp > this.MAX_FEE_AGE) {
32
- let obj = {
33
- timestamp: Date.now(),
34
- feeRate: null
35
- };
36
- obj.feeRate = this.__getFeeRate().catch(e => {
37
- if (this._blockFeeCache === obj)
38
- this._blockFeeCache = null;
39
- throw e;
40
- });
41
- this._blockFeeCache = obj;
42
- }
43
- let { baseFee, l1Fee } = await this._blockFeeCache.feeRate;
44
- if (baseFee > this.maxFeeRatePerGas)
45
- baseFee = this.maxFeeRatePerGas;
46
- const fee = baseFee.toString(10) + "," + this.priorityFee.toString(10) + "," + l1Fee.toString(10);
47
- this.logger.debug("getFeeRate(): calculated fee: " + fee);
48
- return fee;
49
- }
50
- /**
51
- * Calculates the total gas fee paid for a given gas limit and state diff size at a given fee rate
52
- *
53
- * @param gas
54
- * @param stateDiffSize
55
- * @param feeRate
56
- */
57
- static getGasFee(gas, feeRate, stateDiffSize = 0) {
58
- if (feeRate == null)
59
- return 0n;
60
- const [maxFee, priorityFee, l1StateDiffFee] = feeRate.split(",");
61
- return (BigInt(gas) * BigInt(maxFee)) + (BigInt(stateDiffSize) * BigInt(l1StateDiffFee ?? 0n));
62
- }
63
- }
64
- exports.CitreaFees = CitreaFees;
65
- CitreaFees.StateDiffSize = {
66
- APPROVE_DIFF_SIZE: 40,
67
- };
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CitreaFees = void 0;
4
+ const EVMFees_1 = require("../../evm/chain/modules/EVMFees");
5
+ const Utils_1 = require("../../utils/Utils");
6
+ class CitreaFees extends EVMFees_1.EVMFees {
7
+ constructor() {
8
+ super(...arguments);
9
+ this.logger = (0, Utils_1.getLogger)("CitreaFees: ");
10
+ this._blockFeeCache = null;
11
+ }
12
+ /**
13
+ * Gets evm fee rate
14
+ *
15
+ * @private
16
+ * @returns {Promise<bigint>} L1 gas price denominated in Wei
17
+ */
18
+ async __getFeeRate() {
19
+ const res = await this.provider.send("eth_getBlockByNumber", ["latest", false]);
20
+ const l1Fee = BigInt(res.l1FeeRate);
21
+ const baseFee = BigInt(res.baseFeePerGas) * this.feeMultiplierPPM / 1000000n;
22
+ this.logger.debug("__getFeeRate(): Base fee rate: " + baseFee.toString(10) + ", l1 fee rate: " + l1Fee.toString(10));
23
+ return { baseFee, l1Fee };
24
+ }
25
+ /**
26
+ * Gets the gas price with caching, format: <gas price in Wei>;<transaction version: v1/v3>
27
+ *
28
+ * @private
29
+ */
30
+ async getFeeRate() {
31
+ if (this._blockFeeCache == null || Date.now() - this._blockFeeCache.timestamp > this.MAX_FEE_AGE) {
32
+ let obj = {
33
+ timestamp: Date.now(),
34
+ feeRate: null
35
+ };
36
+ obj.feeRate = this.__getFeeRate().catch(e => {
37
+ if (this._blockFeeCache === obj)
38
+ this._blockFeeCache = null;
39
+ throw e;
40
+ });
41
+ this._blockFeeCache = obj;
42
+ }
43
+ let { baseFee, l1Fee } = await this._blockFeeCache.feeRate;
44
+ if (baseFee > this.maxFeeRatePerGas)
45
+ baseFee = this.maxFeeRatePerGas;
46
+ const fee = baseFee.toString(10) + "," + this.priorityFee.toString(10) + "," + l1Fee.toString(10);
47
+ this.logger.debug("getFeeRate(): calculated fee: " + fee);
48
+ return fee;
49
+ }
50
+ /**
51
+ * Calculates the total gas fee paid for a given gas limit and state diff size at a given fee rate
52
+ *
53
+ * @param gas
54
+ * @param stateDiffSize
55
+ * @param feeRate
56
+ */
57
+ static getGasFee(gas, feeRate, stateDiffSize = 0) {
58
+ if (feeRate == null)
59
+ return 0n;
60
+ const [maxFee, priorityFee, l1StateDiffFee] = feeRate.split(",");
61
+ return (BigInt(gas) * BigInt(maxFee)) + (BigInt(stateDiffSize) * BigInt(l1StateDiffFee ?? 0n));
62
+ }
63
+ }
64
+ exports.CitreaFees = CitreaFees;
65
+ CitreaFees.StateDiffSize = {
66
+ APPROVE_DIFF_SIZE: 40,
67
+ };