@lombard.finance/sdk 4.0.0 → 4.1.2

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 (474) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/bridge/lib/ccip-config.d.ts.map +1 -1
  3. package/dist/bridge/lib/config.d.ts +3 -3
  4. package/dist/bridge/lib/config.d.ts.map +1 -1
  5. package/dist/common/chains.d.ts +2 -2
  6. package/dist/common/chains.d.ts.map +1 -1
  7. package/dist/common/feature-config.d.ts.map +1 -1
  8. package/dist/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.d.ts.map +1 -1
  9. package/dist/index2.cjs +6 -6
  10. package/dist/index2.js +792 -759
  11. package/dist/vaults/lib/config.d.ts +1 -1
  12. package/package.json +7 -8
  13. package/src/__tests__/AssetNamespace.spec.ts +0 -234
  14. package/src/__tests__/helpers/createTestConfig.ts +0 -90
  15. package/src/__tests__/integration/automint-fee.integration.test.ts +0 -74
  16. package/src/__tests__/integration/btc-deposit.integration.test.ts +0 -109
  17. package/src/__tests__/integration/btc-stake-and-deploy.integration.test.ts +0 -96
  18. package/src/__tests__/integration/btc-stake.integration.test.ts +0 -466
  19. package/src/__tests__/integration/evm-actions.integration.test.ts +0 -932
  20. package/src/__tests__/integration/evm-deploy.integration.test.ts +0 -122
  21. package/src/__tests__/integration/evm-redeem.integration.test.ts +0 -157
  22. package/src/__tests__/integration/faq-patterns.integration.test.ts +0 -465
  23. package/src/__tests__/integration/getLBTCMintingFee.integration.test.ts +0 -195
  24. package/src/__tests__/real-wallet/btc/btc-stake.real.test.ts +0 -70
  25. package/src/__tests__/real-wallet/evm/evm-stake.real.test.ts +0 -47
  26. package/src/__tests__/real-wallet/evm/evm-unstake.real.test.ts +0 -49
  27. package/src/__tests__/real-wallet/non-evm/solana-unstake.real.test.ts +0 -19
  28. package/src/__tests__/real-wallet/non-evm/starknet-unstake.real.test.ts +0 -19
  29. package/src/__tests__/real-wallet/non-evm/sui-unstake.real.test.ts +0 -19
  30. package/src/__tests__/services/ApiService.test.ts +0 -62
  31. package/src/__tests__/services/BtcService.test.ts +0 -30
  32. package/src/__tests__/services/EvmService.test.ts +0 -39
  33. package/src/__tests__/setup.ts +0 -16
  34. package/src/__tests__/test-utils/eip1193-adapter.ts +0 -48
  35. package/src/__tests__/test-utils/evm-wallet.ts +0 -38
  36. package/src/__tests__/test-utils/solana-wallet.ts +0 -22
  37. package/src/__tests__/test-utils/starknet-wallet.ts +0 -9
  38. package/src/__tests__/test-utils/sui-wallet.ts +0 -14
  39. package/src/__tests__/test-utils/test-constraints.ts +0 -110
  40. package/src/__tests__/unit/btc/BtcDeposit.test.ts +0 -253
  41. package/src/__tests__/unit/btc/BtcDepositAndDeploy.test.ts +0 -174
  42. package/src/__tests__/unit/btc/BtcDepositConfig.test.ts +0 -143
  43. package/src/__tests__/unit/btc/BtcDepositStatusTransition.test.ts +0 -221
  44. package/src/__tests__/unit/btc/BtcStakeAndDeploy.test.ts +0 -194
  45. package/src/__tests__/unit/btc/ExistingSignatureHandling.test.ts +0 -301
  46. package/src/__tests__/unit/btc/StakeAndBakeRatioConversion.test.ts +0 -200
  47. package/src/__tests__/unit/btc/StakeAndBakeSignatureRestore.test.ts +0 -216
  48. package/src/__tests__/unit/btc/TokenParameterConsistency.test.ts +0 -184
  49. package/src/__tests__/unit/btc/btc-deposit-token.test.ts +0 -191
  50. package/src/__tests__/unit/catalog/AssetCatalog.test.ts +0 -293
  51. package/src/__tests__/unit/config/ChainConfig.test.ts +0 -47
  52. package/src/__tests__/unit/config/FeeAuthConfig.test.ts +0 -76
  53. package/src/__tests__/unit/contract-functions/getLBTCMintingFee.test.ts +0 -128
  54. package/src/__tests__/unit/core/chain-parsing.test.ts +0 -257
  55. package/src/__tests__/unit/defi/AvailableProtocols.test.ts +0 -100
  56. package/src/__tests__/unit/defi/DefiRegistry.test.ts +0 -25
  57. package/src/__tests__/unit/evm/EvmDeploy.test.ts +0 -224
  58. package/src/__tests__/unit/evm/EvmRedeem.test.ts +0 -207
  59. package/src/__tests__/unit/evm/EvmRedeemFeeAuth.test.ts +0 -93
  60. package/src/__tests__/unit/evm/EvmStake.test.ts +0 -207
  61. package/src/__tests__/unit/evm/EvmStakeFeeAuth.test.ts +0 -193
  62. package/src/__tests__/unit/evm/EvmUnstakeAllowance.test.ts +0 -69
  63. package/src/__tests__/unit/evm/EvmUnstakeConfig.test.ts +0 -203
  64. package/src/__tests__/unit/fee-signature-expiration.test.ts +0 -76
  65. package/src/__tests__/unit/modules/CapabilityRegistry.test.ts +0 -55
  66. package/src/__tests__/unit/shared/BaseAction.test.ts +0 -122
  67. package/src/__tests__/unit/shared/BaseBtcAction.test.ts +0 -114
  68. package/src/__tests__/unit/solana/SolanaUnstake.test.ts +0 -314
  69. package/src/__tests__/unit/starknet/StarknetUnstake.test.ts +0 -318
  70. package/src/__tests__/unit/sui/SuiUnstake.test.ts +0 -310
  71. package/src/__tests__/unit/utils/satoshi.test.ts +0 -27
  72. package/src/__tests__/unit/validation/address-validation.test.ts +0 -350
  73. package/src/api-functions/generateDepositBtcAddress/generateDepositBtcAddress.stories.tsx +0 -71
  74. package/src/api-functions/generateDepositBtcAddress/generateDepositBtcAddress.ts +0 -235
  75. package/src/api-functions/generateDepositBtcAddress/index.ts +0 -1
  76. package/src/api-functions/get-badges-by-address/get-badges-by-address.ts +0 -13
  77. package/src/api-functions/get-badges-by-address/index.ts +0 -1
  78. package/src/api-functions/getDepositAddressReferrer/getDepositAddressReferrer.ts +0 -38
  79. package/src/api-functions/getDepositAddressReferrer/index.ts +0 -1
  80. package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.stories.tsx +0 -59
  81. package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.test.ts +0 -265
  82. package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.ts +0 -167
  83. package/src/api-functions/getDepositBtcAddress/getDepositBtcAddresses.stories.tsx +0 -58
  84. package/src/api-functions/getDepositBtcAddress/index.ts +0 -1
  85. package/src/api-functions/getDepositBtcAddress/make-request.ts +0 -59
  86. package/src/api-functions/getDepositBtcAddress/types.ts +0 -106
  87. package/src/api-functions/getDepositsByAddress/getDepositsByAddress.stories.tsx +0 -51
  88. package/src/api-functions/getDepositsByAddress/getDepositsByAddress.ts +0 -502
  89. package/src/api-functions/getDepositsByAddress/index.ts +0 -1
  90. package/src/api-functions/getLBTCExchangeRate/get-exchange-ratio.stories.tsx +0 -48
  91. package/src/api-functions/getLBTCExchangeRate/get-exchange-ratio.ts +0 -59
  92. package/src/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.stories.tsx +0 -55
  93. package/src/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.ts +0 -75
  94. package/src/api-functions/getLBTCExchangeRate/index.ts +0 -2
  95. package/src/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.stories.tsx +0 -59
  96. package/src/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.ts +0 -116
  97. package/src/api-functions/getNetworkFeeSignature/index.ts +0 -1
  98. package/src/api-functions/getPointsByAddress/getPointsByAddress.stories.tsx +0 -51
  99. package/src/api-functions/getPointsByAddress/getPointsByAddress.ts +0 -304
  100. package/src/api-functions/getPointsByAddress/index.ts +0 -1
  101. package/src/api-functions/getUnstakesByAddress/getUnstakesByAddress.stories.tsx +0 -51
  102. package/src/api-functions/getUnstakesByAddress/getUnstakesByAddress.ts +0 -368
  103. package/src/api-functions/getUnstakesByAddress/index.ts +0 -1
  104. package/src/api-functions/getUserStakeAndBakeSignature/getUserStakeAndBakeSignature.stories.tsx +0 -70
  105. package/src/api-functions/getUserStakeAndBakeSignature/getUserStakeAndBakeSignature.ts +0 -91
  106. package/src/api-functions/getUserStakeAndBakeSignature/index.ts +0 -1
  107. package/src/api-functions/index.ts +0 -11
  108. package/src/api-functions/setReferral/index.ts +0 -1
  109. package/src/api-functions/setReferral/setReferral.ts +0 -67
  110. package/src/api-functions/storeNetworkFeeSignature/index.ts +0 -1
  111. package/src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.stories.tsx +0 -57
  112. package/src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.ts +0 -75
  113. package/src/api-functions/storeStakeAndBakeSignature/index.ts +0 -1
  114. package/src/api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature.stories.tsx +0 -57
  115. package/src/api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature.ts +0 -61
  116. package/src/bridge/abi/CCIP_BRIDGE_ADAPTER_ABI.json +0 -704
  117. package/src/bridge/abi/CCIP_ROUTER_ABI.json +0 -702
  118. package/src/bridge/abi/OFT_BRIDGE_ADAPTER_ABI.json +0 -912
  119. package/src/bridge/index.ts +0 -16
  120. package/src/bridge/lib/bridge.stories.tsx +0 -90
  121. package/src/bridge/lib/bridge.ts +0 -115
  122. package/src/bridge/lib/ccip-bridge.stories.tsx +0 -91
  123. package/src/bridge/lib/ccip-bridge.ts +0 -214
  124. package/src/bridge/lib/ccip-config.ts +0 -54
  125. package/src/bridge/lib/config.ts +0 -384
  126. package/src/bridge/lib/oft-bridge.stories.tsx +0 -90
  127. package/src/bridge/lib/oft-bridge.ts +0 -217
  128. package/src/chains/btc/BtcActions.ts +0 -192
  129. package/src/chains/btc/actions/deposit/BtcDeposit.ts +0 -388
  130. package/src/chains/btc/actions/deposit/config/evm.ts +0 -197
  131. package/src/chains/btc/actions/deposit/config/index.ts +0 -53
  132. package/src/chains/btc/actions/deposit/config/types.ts +0 -108
  133. package/src/chains/btc/actions/deposit/factory.ts +0 -53
  134. package/src/chains/btc/actions/deposit/index.ts +0 -23
  135. package/src/chains/btc/actions/deposit/types.ts +0 -120
  136. package/src/chains/btc/actions/depositAndDeploy/BtcDepositAndDeploy.ts +0 -366
  137. package/src/chains/btc/actions/depositAndDeploy/config/evm.ts +0 -105
  138. package/src/chains/btc/actions/depositAndDeploy/config/index.ts +0 -111
  139. package/src/chains/btc/actions/depositAndDeploy/config/types.ts +0 -67
  140. package/src/chains/btc/actions/depositAndDeploy/factory.ts +0 -38
  141. package/src/chains/btc/actions/depositAndDeploy/index.ts +0 -24
  142. package/src/chains/btc/actions/depositAndDeploy/types.ts +0 -120
  143. package/src/chains/btc/actions/index.ts +0 -14
  144. package/src/chains/btc/actions/shared/BaseBtcAction.ts +0 -495
  145. package/src/chains/btc/actions/shared/index.ts +0 -28
  146. package/src/chains/btc/actions/shared/tokenUtils.ts +0 -68
  147. package/src/chains/btc/actions/shared/validation.ts +0 -180
  148. package/src/chains/btc/actions/stake/BtcStake.ts +0 -433
  149. package/src/chains/btc/actions/stake/__tests__/BtcStake.test.ts +0 -247
  150. package/src/chains/btc/actions/stake/config/evm.ts +0 -183
  151. package/src/chains/btc/actions/stake/config/index.ts +0 -122
  152. package/src/chains/btc/actions/stake/config/solana.ts +0 -96
  153. package/src/chains/btc/actions/stake/config/starknet.ts +0 -66
  154. package/src/chains/btc/actions/stake/config/sui.ts +0 -61
  155. package/src/chains/btc/actions/stake/config/types.ts +0 -165
  156. package/src/chains/btc/actions/stake/factory.ts +0 -53
  157. package/src/chains/btc/actions/stake/index.ts +0 -22
  158. package/src/chains/btc/actions/stake/types.ts +0 -175
  159. package/src/chains/btc/actions/stakeAndDeploy/BtcStakeAndDeploy.ts +0 -415
  160. package/src/chains/btc/actions/stakeAndDeploy/config/evm.ts +0 -135
  161. package/src/chains/btc/actions/stakeAndDeploy/config/index.ts +0 -119
  162. package/src/chains/btc/actions/stakeAndDeploy/config/types.ts +0 -93
  163. package/src/chains/btc/actions/stakeAndDeploy/factory.ts +0 -54
  164. package/src/chains/btc/actions/stakeAndDeploy/index.ts +0 -26
  165. package/src/chains/btc/actions/stakeAndDeploy/types.ts +0 -118
  166. package/src/chains/btc/client/getCurrentBlockHeight.ts +0 -28
  167. package/src/chains/btc/client/mempool/error.ts +0 -24
  168. package/src/chains/btc/client/mempool/mempool.ts +0 -23
  169. package/src/chains/btc/index.ts +0 -71
  170. package/src/chains/evm/EvmActions.ts +0 -185
  171. package/src/chains/evm/actions/deploy/EvmDeploy.ts +0 -256
  172. package/src/chains/evm/actions/deploy/config/evm.ts +0 -80
  173. package/src/chains/evm/actions/deploy/config/index.ts +0 -8
  174. package/src/chains/evm/actions/deploy/config/types.ts +0 -43
  175. package/src/chains/evm/actions/deploy/factory.ts +0 -44
  176. package/src/chains/evm/actions/deploy/index.ts +0 -17
  177. package/src/chains/evm/actions/deploy/types.ts +0 -74
  178. package/src/chains/evm/actions/deposit/EvmDeposit.ts +0 -159
  179. package/src/chains/evm/actions/deposit/config/evm.ts +0 -100
  180. package/src/chains/evm/actions/deposit/config/index.ts +0 -8
  181. package/src/chains/evm/actions/deposit/config/types.ts +0 -39
  182. package/src/chains/evm/actions/deposit/factory.ts +0 -44
  183. package/src/chains/evm/actions/deposit/index.ts +0 -17
  184. package/src/chains/evm/actions/deposit/types.ts +0 -87
  185. package/src/chains/evm/actions/index.ts +0 -67
  186. package/src/chains/evm/actions/redeem/EvmRedeem.ts +0 -263
  187. package/src/chains/evm/actions/redeem/config/evm.ts +0 -85
  188. package/src/chains/evm/actions/redeem/config/index.ts +0 -8
  189. package/src/chains/evm/actions/redeem/config/types.ts +0 -39
  190. package/src/chains/evm/actions/redeem/factory.ts +0 -43
  191. package/src/chains/evm/actions/redeem/index.ts +0 -17
  192. package/src/chains/evm/actions/redeem/types.ts +0 -93
  193. package/src/chains/evm/actions/stake/EvmStake.ts +0 -339
  194. package/src/chains/evm/actions/stake/config/evm.ts +0 -89
  195. package/src/chains/evm/actions/stake/config/index.ts +0 -8
  196. package/src/chains/evm/actions/stake/config/types.ts +0 -89
  197. package/src/chains/evm/actions/stake/factory.ts +0 -52
  198. package/src/chains/evm/actions/stake/index.ts +0 -30
  199. package/src/chains/evm/actions/stake/types.ts +0 -104
  200. package/src/chains/evm/actions/unstake/EvmUnstake.ts +0 -258
  201. package/src/chains/evm/actions/unstake/config/evm.ts +0 -123
  202. package/src/chains/evm/actions/unstake/config/index.ts +0 -13
  203. package/src/chains/evm/actions/unstake/config/types.ts +0 -37
  204. package/src/chains/evm/actions/unstake/factory.ts +0 -44
  205. package/src/chains/evm/actions/unstake/index.ts +0 -22
  206. package/src/chains/evm/actions/unstake/types.ts +0 -87
  207. package/src/chains/evm/index.ts +0 -16
  208. package/src/chains/evm/shared/feeAuth.ts +0 -198
  209. package/src/chains/evm/shared/index.ts +0 -7
  210. package/src/chains/solana/SolanaActions.ts +0 -85
  211. package/src/chains/solana/actions/index.ts +0 -7
  212. package/src/chains/solana/actions/unstake/SolanaUnstake.ts +0 -151
  213. package/src/chains/solana/actions/unstake/config/btc.ts +0 -47
  214. package/src/chains/solana/actions/unstake/config/index.ts +0 -8
  215. package/src/chains/solana/actions/unstake/config/solana.ts +0 -47
  216. package/src/chains/solana/actions/unstake/config/types.ts +0 -35
  217. package/src/chains/solana/actions/unstake/factory.ts +0 -34
  218. package/src/chains/solana/actions/unstake/index.ts +0 -14
  219. package/src/chains/solana/actions/unstake/types.ts +0 -58
  220. package/src/chains/solana/index.ts +0 -8
  221. package/src/chains/starknet/StarknetActions.ts +0 -85
  222. package/src/chains/starknet/actions/index.ts +0 -7
  223. package/src/chains/starknet/actions/unstake/StarknetUnstake.ts +0 -128
  224. package/src/chains/starknet/actions/unstake/config/btc.ts +0 -43
  225. package/src/chains/starknet/actions/unstake/config/index.ts +0 -8
  226. package/src/chains/starknet/actions/unstake/config/starknet.ts +0 -43
  227. package/src/chains/starknet/actions/unstake/config/types.ts +0 -27
  228. package/src/chains/starknet/actions/unstake/factory.ts +0 -32
  229. package/src/chains/starknet/actions/unstake/index.ts +0 -14
  230. package/src/chains/starknet/actions/unstake/types.ts +0 -57
  231. package/src/chains/starknet/index.ts +0 -8
  232. package/src/chains/sui/SuiActions.ts +0 -82
  233. package/src/chains/sui/actions/index.ts +0 -7
  234. package/src/chains/sui/actions/unstake/SuiUnstake.ts +0 -146
  235. package/src/chains/sui/actions/unstake/config/btc.ts +0 -43
  236. package/src/chains/sui/actions/unstake/config/index.ts +0 -8
  237. package/src/chains/sui/actions/unstake/config/sui.ts +0 -43
  238. package/src/chains/sui/actions/unstake/config/types.ts +0 -27
  239. package/src/chains/sui/actions/unstake/factory.ts +0 -32
  240. package/src/chains/sui/actions/unstake/index.ts +0 -14
  241. package/src/chains/sui/actions/unstake/types.ts +0 -57
  242. package/src/chains/sui/index.ts +0 -8
  243. package/src/client/ApiNamespace.ts +0 -302
  244. package/src/client/AssetNamespace.ts +0 -112
  245. package/src/client/LombardSDK.ts +0 -212
  246. package/src/client/PartnerConfiguration.ts +0 -50
  247. package/src/client/createConfig.ts +0 -90
  248. package/src/client/createLombardSDK.ts +0 -130
  249. package/src/clients/evm-signer-adapter.ts +0 -313
  250. package/src/clients/public-client.ts +0 -49
  251. package/src/clients/rpc-url-config.ts +0 -64
  252. package/src/clients/wallet-client.ts +0 -34
  253. package/src/common/api-config.ts +0 -48
  254. package/src/common/blockchain-identifier.ts +0 -217
  255. package/src/common/chains.stories.tsx +0 -68
  256. package/src/common/chains.ts +0 -449
  257. package/src/common/constants.ts +0 -1
  258. package/src/common/contract-info.ts +0 -9
  259. package/src/common/feature-config.ts +0 -79
  260. package/src/common/fee-requirements.ts +0 -34
  261. package/src/common/parameters.ts +0 -89
  262. package/src/config/defaults.ts +0 -49
  263. package/src/config/index.ts +0 -12
  264. package/src/config/providers.ts +0 -81
  265. package/src/config/types.ts +0 -216
  266. package/src/config/validation.ts +0 -69
  267. package/src/contract-functions/approveLBTC/approveLBTC.stories.tsx +0 -79
  268. package/src/contract-functions/approveLBTC/approveLBTC.ts +0 -66
  269. package/src/contract-functions/approveLBTC/index.ts +0 -1
  270. package/src/contract-functions/approveToken/approveToken.ts +0 -126
  271. package/src/contract-functions/approveToken/index.ts +0 -1
  272. package/src/contract-functions/claimLBTC/claimLBTC.stories.tsx +0 -82
  273. package/src/contract-functions/claimLBTC/claimLBTC.ts +0 -159
  274. package/src/contract-functions/claimLBTC/index.ts +0 -1
  275. package/src/contract-functions/claimUnstakeRedeem/claimUnstakeRedeem.ts +0 -95
  276. package/src/contract-functions/claimUnstakeRedeem/index.ts +0 -1
  277. package/src/contract-functions/deposit/depositToken.stories.tsx +0 -83
  278. package/src/contract-functions/deposit/depositToken.ts +0 -214
  279. package/src/contract-functions/deposit/index.ts +0 -1
  280. package/src/contract-functions/getBasculeDepositStatus/decodeBasculeDepositStatus.ts +0 -170
  281. package/src/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.stories.tsx +0 -62
  282. package/src/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.ts +0 -211
  283. package/src/contract-functions/getBasculeDepositStatus/index.ts +0 -2
  284. package/src/contract-functions/getLBTCMintingFee/getLBTCMintingFee.stories.tsx +0 -61
  285. package/src/contract-functions/getLBTCMintingFee/getLBTCMintingFee.ts +0 -193
  286. package/src/contract-functions/getLBTCMintingFee/index.ts +0 -1
  287. package/src/contract-functions/getLBTCTotalSupply/getLBTCTotalSupply.stories.tsx +0 -51
  288. package/src/contract-functions/getLBTCTotalSupply/getLBTCTotalSupply.ts +0 -40
  289. package/src/contract-functions/getLBTCTotalSupply/index.ts +0 -1
  290. package/src/contract-functions/getPermitNonce/getPermitNonce.stories.tsx +0 -56
  291. package/src/contract-functions/getPermitNonce/getPermitNonce.ts +0 -50
  292. package/src/contract-functions/getPermitNonce/index.ts +0 -1
  293. package/src/contract-functions/getShareValue/getShareValue.stories.tsx +0 -58
  294. package/src/contract-functions/getShareValue/getShareValue.ts +0 -59
  295. package/src/contract-functions/getShareValue/index.ts +0 -1
  296. package/src/contract-functions/getSharesByAddress/getSharesByAddress.stories.tsx +0 -65
  297. package/src/contract-functions/getSharesByAddress/getSharesByAddress.ts +0 -86
  298. package/src/contract-functions/getSharesByAddress/index.ts +0 -4
  299. package/src/contract-functions/getStakeAndBakeFee/__tests__/getStakeAndBakeFee.test.ts +0 -167
  300. package/src/contract-functions/getStakeAndBakeFee/getStakeAndBakeFee.stories.tsx +0 -180
  301. package/src/contract-functions/getStakeAndBakeFee/getStakeAndBakeFee.tsx +0 -101
  302. package/src/contract-functions/getStakeAndBakeFee/index.ts +0 -1
  303. package/src/contract-functions/index.ts +0 -21
  304. package/src/contract-functions/signLbtcDestionationAddr/index.ts +0 -1
  305. package/src/contract-functions/signLbtcDestionationAddr/signLbtcDestinationAddr.ts +0 -32
  306. package/src/contract-functions/signLbtcDestionationAddr/signLbtcDestionationAddr.stories.tsx +0 -64
  307. package/src/contract-functions/signNetworkFee/getTypedData.ts +0 -41
  308. package/src/contract-functions/signNetworkFee/index.ts +0 -1
  309. package/src/contract-functions/signNetworkFee/signNetworkFee.stories.tsx +0 -94
  310. package/src/contract-functions/signNetworkFee/signNetworkFee.ts +0 -106
  311. package/src/contract-functions/signStakeAndBake/__tests__/signStakeAndBake.test.ts +0 -888
  312. package/src/contract-functions/signStakeAndBake/handleApprove.ts +0 -81
  313. package/src/contract-functions/signStakeAndBake/handlePermit.ts +0 -28
  314. package/src/contract-functions/signStakeAndBake/index.ts +0 -2
  315. package/src/contract-functions/signStakeAndBake/signStakeAndBake.stories.tsx +0 -202
  316. package/src/contract-functions/signStakeAndBake/signStakeAndBake.ts +0 -160
  317. package/src/contract-functions/signStakeAndBake/typed-data-builder.ts +0 -137
  318. package/src/contract-functions/signStakeAndBake/utils.ts +0 -61
  319. package/src/contract-functions/signStakeAndBake/validation.ts +0 -124
  320. package/src/contract-functions/unstakeLBTC/index.ts +0 -1
  321. package/src/contract-functions/unstakeLBTC/unstakeLBTC.stories.tsx +0 -92
  322. package/src/contract-functions/unstakeLBTC/unstakeLBTC.ts +0 -396
  323. package/src/contracts/abis/index.ts +0 -29
  324. package/src/contracts/index.ts +0 -63
  325. package/src/contracts/types.ts +0 -143
  326. package/src/contracts/utils.ts +0 -288
  327. package/src/core/assets/catalog.ts +0 -343
  328. package/src/core/assets/index.ts +0 -40
  329. package/src/core/assets/types.ts +0 -142
  330. package/src/core/assets/utils.ts +0 -287
  331. package/src/core/chains/catalog.ts +0 -396
  332. package/src/core/chains/index.ts +0 -39
  333. package/src/core/chains/types.ts +0 -193
  334. package/src/core/chains/utils.ts +0 -245
  335. package/src/core/index.ts +0 -72
  336. package/src/core/types.ts +0 -126
  337. package/src/debug-api/btc-script-to-address.ts +0 -20
  338. package/src/debug-api/btc-tx-info.ts +0 -32
  339. package/src/debug-api/evm-by-btc-address.ts +0 -26
  340. package/src/debug-api/index.ts +0 -3
  341. package/src/defi/README.md +0 -517
  342. package/src/defi/defi-registry.stories.tsx +0 -527
  343. package/src/defi/defi-registry.ts +0 -295
  344. package/src/defi/index.ts +0 -17
  345. package/src/index.ts +0 -336
  346. package/src/metrics/get-additional-rewards.ts +0 -69
  347. package/src/metrics/get-lbtc-apy.ts +0 -74
  348. package/src/metrics/get-lbtc-stats.stories.tsx +0 -57
  349. package/src/metrics/get-lbtc-stats.ts +0 -59
  350. package/src/metrics/get-positions-summary.stories.tsx +0 -58
  351. package/src/metrics/get-positions-summary.ts +0 -132
  352. package/src/modules/CapabilityRegistry.ts +0 -125
  353. package/src/modules/apiModule.ts +0 -51
  354. package/src/modules/btcModule.ts +0 -43
  355. package/src/modules/evmModule.ts +0 -48
  356. package/src/modules/index.ts +0 -60
  357. package/src/referrals/ReferralsClient.ts +0 -34
  358. package/src/referrals/index.ts +0 -1
  359. package/src/services/ApiService.ts +0 -152
  360. package/src/services/BtcService.ts +0 -29
  361. package/src/services/EvmService.ts +0 -127
  362. package/src/services/index.ts +0 -43
  363. package/src/shared/__tests__/errors.test.ts +0 -185
  364. package/src/shared/__tests__/events.test.ts +0 -120
  365. package/src/shared/__tests__/types.test.ts +0 -155
  366. package/src/shared/actions/BaseAction.ts +0 -497
  367. package/src/shared/actions/__tests__/BaseAction.test.ts +0 -292
  368. package/src/shared/actions/index.ts +0 -9
  369. package/src/shared/constants/statusConstants.ts +0 -108
  370. package/src/shared/context/ContextBuilder.ts +0 -149
  371. package/src/shared/context/index.ts +0 -8
  372. package/src/shared/context/types.ts +0 -156
  373. package/src/shared/deposits/depositStatus.ts +0 -402
  374. package/src/shared/deposits/index.ts +0 -29
  375. package/src/shared/errors.ts +0 -405
  376. package/src/shared/events.ts +0 -260
  377. package/src/shared/evm/switchChain.ts +0 -109
  378. package/src/shared/index.ts +0 -54
  379. package/src/shared/monitoring/__tests__/createEventEmitter.test.ts +0 -150
  380. package/src/shared/monitoring/createEventEmitter.ts +0 -160
  381. package/src/shared/monitoring/createProgressEmitter.ts +0 -46
  382. package/src/shared/monitoring/depositMonitor.ts +0 -211
  383. package/src/shared/monitoring/index.ts +0 -25
  384. package/src/shared/validation/index.ts +0 -411
  385. package/src/stories/arg-types.ts +0 -38
  386. package/src/stories/components/Badge.tsx +0 -27
  387. package/src/stories/components/Button/Button.css +0 -10
  388. package/src/stories/components/Button/Button.tsx +0 -52
  389. package/src/stories/components/Button/index.ts +0 -1
  390. package/src/stories/components/Card.tsx +0 -18
  391. package/src/stories/components/CodeBlock/CodeBlock.tsx +0 -27
  392. package/src/stories/components/CodeBlock/CodeBlockStyles.css +0 -3
  393. package/src/stories/components/CodeBlock/index.ts +0 -1
  394. package/src/stories/components/ConnectButton/connect-button.tsx +0 -248
  395. package/src/stories/components/ConnectButton/index.ts +0 -1
  396. package/src/stories/components/JsonPreview.tsx +0 -84
  397. package/src/stories/components/Spinner/Spinner.tsx +0 -27
  398. package/src/stories/components/Spinner/index.ts +0 -1
  399. package/src/stories/components/StatsCard.tsx +0 -30
  400. package/src/stories/components/StatusIndicator.tsx +0 -37
  401. package/src/stories/components/TreeNode.tsx +0 -47
  402. package/src/stories/components/decorators/function-type.tsx +0 -63
  403. package/src/stories/components/decorators/index.ts +0 -2
  404. package/src/stories/components/decorators/wagmi-decorator.tsx +0 -92
  405. package/src/stories/components/error-block.tsx +0 -21
  406. package/src/stories/components/index.ts +0 -11
  407. package/src/stories/constants.ts +0 -3
  408. package/src/stories/hooks/useConnection.ts +0 -63
  409. package/src/stories/hooks/useQuery.ts +0 -57
  410. package/src/tokens/__tests__/token-addresses.test.ts +0 -551
  411. package/src/tokens/abi/ASSET_ROUTER_ABI.ts +0 -1966
  412. package/src/tokens/abi/BRIDGE_TOKEN_ADAPTER_ABI.ts +0 -1405
  413. package/src/tokens/abi/BTCK_ABI.ts +0 -1092
  414. package/src/tokens/abi/KATANA_BASCULE_ABI.ts +0 -653
  415. package/src/tokens/abi/LBTC_ABI.json +0 -1761
  416. package/src/tokens/abi/LBTC_ABI.ts +0 -1761
  417. package/src/tokens/abi/LBTC_BASCULE_ABI.json +0 -850
  418. package/src/tokens/abi/NATIVE_LBTC_ABI.ts +0 -1147
  419. package/src/tokens/abi/STLBTC_ABI.ts +0 -1062
  420. package/src/tokens/cross-chain-addresses.stories.tsx +0 -236
  421. package/src/tokens/denomination-utils.stories.tsx +0 -176
  422. package/src/tokens/getLbtcContractAddresses.stories.tsx +0 -158
  423. package/src/tokens/getTokenByAddress.stories.tsx +0 -172
  424. package/src/tokens/getTokenContractInfo.stories.tsx +0 -148
  425. package/src/tokens/getTokenInfo.stories.tsx +0 -133
  426. package/src/tokens/isUpgradedContract.stories.tsx +0 -124
  427. package/src/tokens/lbtc-addresses.ts +0 -18
  428. package/src/tokens/token-addresses.ts +0 -477
  429. package/src/tokens/tokens.ts +0 -249
  430. package/src/tokens/types.ts +0 -80
  431. package/src/utils/array.ts +0 -31
  432. package/src/utils/block.ts +0 -23
  433. package/src/utils/chain.ts +0 -152
  434. package/src/utils/consoleLogger.ts +0 -140
  435. package/src/utils/ensureNotSanctionedAddress.ts +0 -11
  436. package/src/utils/env.ts +0 -20
  437. package/src/utils/err.ts +0 -83
  438. package/src/utils/evmAccount.ts +0 -47
  439. package/src/utils/gas.ts +0 -36
  440. package/src/utils/hex.ts +0 -9
  441. package/src/utils/http.ts +0 -224
  442. package/src/utils/numbers.ts +0 -37
  443. package/src/utils/pagination.ts +0 -70
  444. package/src/utils/satoshi.ts +0 -41
  445. package/src/utils/time.ts +0 -12
  446. package/src/utils/transaction-executor.ts +0 -299
  447. package/src/vaults/abi/SILO_VAULT_SPENDER_ABI.json +0 -793
  448. package/src/vaults/abi/VEDA_VAULT_ABI.json +0 -452
  449. package/src/vaults/abi/VEDA_VAULT_ACCOUNTANT_ABI.json +0 -591
  450. package/src/vaults/abi/VEDA_VAULT_BASE_ASSET_ABI.json +0 -296
  451. package/src/vaults/abi/VEDA_VAULT_BORING_WITHDRAW_QUEUE_ABI.json +0 -502
  452. package/src/vaults/abi/VEDA_VAULT_LENS_ABI.json +0 -175
  453. package/src/vaults/abi/VEDA_VAULT_SPENDER_ABI.json +0 -408
  454. package/src/vaults/abi/VEDA_VAULT_TELLER_ABI.json +0 -700
  455. package/src/vaults/abi/index.ts +0 -4
  456. package/src/vaults/index.ts +0 -46
  457. package/src/vaults/lib/config.ts +0 -184
  458. package/src/vaults/lib/metrics/get-vault-apy.stories.tsx +0 -58
  459. package/src/vaults/lib/metrics/get-vault-apy.ts +0 -176
  460. package/src/vaults/lib/metrics/get-vault-points.stories.tsx +0 -60
  461. package/src/vaults/lib/metrics/get-vault-points.ts +0 -74
  462. package/src/vaults/lib/metrics/get-vault-tvl.stories.tsx +0 -58
  463. package/src/vaults/lib/metrics/get-vault-tvl.ts +0 -121
  464. package/src/vaults/lib/ops/cancel-withdraw.stories.tsx +0 -80
  465. package/src/vaults/lib/ops/deposit.stories.tsx +0 -82
  466. package/src/vaults/lib/ops/deposit.ts +0 -152
  467. package/src/vaults/lib/ops/get-vault-deposits.stories.tsx +0 -65
  468. package/src/vaults/lib/ops/get-vault-deposits.ts +0 -209
  469. package/src/vaults/lib/ops/get-vault-withdrawals.stories.tsx +0 -67
  470. package/src/vaults/lib/ops/get-vault-withdrawals.ts +0 -349
  471. package/src/vaults/lib/ops/withdraw.stories.tsx +0 -82
  472. package/src/vaults/lib/ops/withdraw.ts +0 -225
  473. package/src/version.ts +0 -56
  474. package/src/vite-env.d.ts +0 -1
@@ -1,932 +0,0 @@
1
- /**
2
- * EVM Actions Integration Tests
3
- *
4
- * Tests for all EVM chain operations:
5
- * - EvmStake: BTC.b → LBTC
6
- * - EvmUnstake: LBTC → BTC or BTC.b
7
- * - EvmDeposit: Claim LBTC with proof
8
- * - EvmDeploy: LBTC/BTC.b → DeFi
9
- * - EvmRedeem: LBTC → BTC.b
10
- *
11
- * @see SDK_DEVELOPER_FAQ.md
12
- */
13
-
14
- import { Env } from '@lombard.finance/sdk-common';
15
- import BigNumber from 'bignumber.js';
16
- import type { EIP1193Provider } from 'viem';
17
- import { beforeEach, describe, expect, it, vi } from 'vitest';
18
-
19
- import { evmActions } from '../../chains/evm/EvmActions';
20
- import { depositToken } from '../../contract-functions/deposit';
21
- import { AssetId, Chain, DeployProtocol } from '../../core';
22
- import { EvmOperationStatus } from '../../shared/constants/statusConstants';
23
- import { Token } from '../../tokens/token-addresses';
24
- import { createTestConfig as createConfig } from '../helpers/createTestConfig';
25
-
26
- vi.mock('../../contract-functions/deposit', () => ({
27
- depositToken: vi.fn(),
28
- getAssetRouterAddress: vi.fn(async () => '0x0000000000000000000000000000000000000001'),
29
- }));
30
-
31
- // Mock clients for EvmDeploy allowance checks
32
- vi.mock('../../clients/public-client', () => ({
33
- makePublicClient: vi.fn(() => ({
34
- readContract: vi.fn().mockResolvedValue(BigInt('100000000000')), // High allowance
35
- simulateContract: vi.fn().mockResolvedValue({ request: {} }),
36
- })),
37
- }));
38
-
39
- vi.mock('../../clients/wallet-client', () => ({
40
- makeWalletClient: vi.fn(() => ({
41
- writeContract: vi.fn().mockResolvedValue('0xapprovetxhash'),
42
- })),
43
- }));
44
-
45
- // Mock token contract info to avoid real address lookups
46
- vi.mock('../../tokens/tokens', () => ({
47
- getTokenContractInfo: vi.fn().mockResolvedValue({
48
- address: '0x1234567890123456789012345678901234567890' as `0x${string}`,
49
- abi: [],
50
- }),
51
- getTokenInfo: vi.fn().mockResolvedValue({
52
- address: '0x1234567890123456789012345678901234567890' as `0x${string}`,
53
- abi: [
54
- {
55
- name: 'allowance',
56
- type: 'function',
57
- inputs: [{ type: 'address' }, { type: 'address' }],
58
- outputs: [{ type: 'uint256' }],
59
- },
60
- {
61
- name: 'approve',
62
- type: 'function',
63
- inputs: [{ type: 'address' }, { type: 'uint256' }],
64
- outputs: [{ type: 'bool' }],
65
- },
66
- ],
67
- decimals: 8,
68
- symbol: 'LBTC',
69
- }),
70
- toBaseDenomination: vi.fn((amount) => new BigNumber(amount).multipliedBy(1e8)),
71
- fromBaseDenomination: vi.fn((amount) => new BigNumber(amount).dividedBy(1e8)),
72
- }));
73
-
74
- vi.mock('../../contract-functions/approveToken', () => ({
75
- approveToken: vi.fn(async () => '0xapprovetxhash'),
76
- // Mock sufficient allowance so tests proceed past approval check
77
- getTokenAllowance: vi.fn(async () => new BigNumber('1000000')),
78
- }));
79
-
80
- // Mock fee authorization for EvmStake (subsidized chains don't require fee auth)
81
- vi.mock('../../chains/evm/shared/feeAuth', async (importOriginal) => {
82
- const original = await importOriginal<typeof import('../../chains/evm/shared/feeAuth')>();
83
- return {
84
- ...original,
85
- checkFeeAuthorization: vi.fn(async () => ({
86
- requiresAuth: false, // Avalanche is subsidized
87
- hasValidSignature: false,
88
- feeInSatoshis: null,
89
- feeFormatted: null,
90
- expirationDate: null,
91
- })),
92
- authorizeFee: vi.fn(async () => ({
93
- signature: '0xabc123' as `0x${string}`,
94
- typedData: '{}',
95
- })),
96
- };
97
- });
98
-
99
- // ═══════════════════════════════════════════════════════════════════════════
100
- // Mock Provider Setup
101
- // ═══════════════════════════════════════════════════════════════════════════
102
-
103
- function createMockEvmProvider(): EIP1193Provider {
104
- const mockProvider = {
105
- request: vi.fn(),
106
- on: vi.fn(),
107
- removeListener: vi.fn(),
108
- };
109
-
110
- mockProvider.request.mockImplementation(async ({ method }) => {
111
- switch (method) {
112
- case 'eth_requestAccounts':
113
- case 'eth_accounts':
114
- return ['0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0'];
115
- case 'eth_chainId':
116
- return '0xa869'; // Avalanche Fuji chain ID (43113 in hex)
117
- case 'wallet_switchEthereumChain':
118
- return null;
119
- case 'eth_signTypedData_v4':
120
- return '0x' + '00'.repeat(65);
121
- case 'eth_sendTransaction':
122
- return '0x' + 'ab'.repeat(32); // Mock tx hash
123
- case 'eth_getTransactionReceipt':
124
- return { status: '0x1', blockNumber: '0x100' };
125
- default:
126
- console.warn(`Unhandled provider method: ${method}`);
127
- return null;
128
- }
129
- });
130
-
131
- return mockProvider as unknown as EIP1193Provider;
132
- }
133
-
134
- // ═══════════════════════════════════════════════════════════════════════════
135
- // EVM Stake Tests (BTC.b → LBTC)
136
- // ═══════════════════════════════════════════════════════════════════════════
137
-
138
- describe('EVM Stake Action', () => {
139
- let mockProvider: EIP1193Provider;
140
-
141
- beforeEach(() => {
142
- mockProvider = createMockEvmProvider();
143
- vi.clearAllMocks();
144
- });
145
-
146
- describe('Lifecycle', () => {
147
- it('should start in IDLE status', () => {
148
- const config = createConfig({
149
- env: Env.testnet,
150
- providers: { evm: () => mockProvider },
151
- });
152
-
153
- const evm = evmActions(config);
154
- const stake = evm.stake({
155
- assetIn: AssetId.BTCb,
156
- assetOut: AssetId.LBTC,
157
- sourceChain: Chain.AVALANCHE_FUJI,
158
- destChain: Chain.AVALANCHE_FUJI,
159
- });
160
-
161
- expect(stake.status).toBe(EvmOperationStatus.IDLE);
162
- expect(stake.isLoading).toBe(false);
163
- expect(stake.isFailed).toBe(false);
164
- expect(stake.error).toBeNull();
165
- });
166
-
167
- it('should transition to READY after prepare (subsidized chain)', async () => {
168
- const config = createConfig({
169
- env: Env.testnet,
170
- providers: { evm: () => mockProvider },
171
- });
172
-
173
- const evm = evmActions(config);
174
- const stake = evm.stake({
175
- assetIn: AssetId.BTCb,
176
- assetOut: AssetId.LBTC,
177
- sourceChain: Chain.AVALANCHE_FUJI,
178
- destChain: Chain.AVALANCHE_FUJI,
179
- });
180
-
181
- await stake.prepare({ amount: '0.001' });
182
-
183
- // Avalanche is a subsidized chain, so goes directly to READY
184
- expect(stake.status).toBe(EvmOperationStatus.READY);
185
- expect(stake.amount).toBe('0.001');
186
- });
187
-
188
- it('should transition to READY after approve', async () => {
189
- const config = createConfig({
190
- env: Env.testnet,
191
- providers: { evm: () => mockProvider },
192
- });
193
-
194
- const evm = evmActions(config);
195
- const stake = evm.stake({
196
- assetIn: AssetId.BTCb,
197
- assetOut: AssetId.LBTC,
198
- sourceChain: Chain.AVALANCHE_FUJI,
199
- destChain: Chain.AVALANCHE_FUJI,
200
- });
201
-
202
- await stake.prepare({ amount: '0.001' });
203
-
204
- // Avalanche is a subsidized chain, so no fee auth needed
205
- expect(stake.status).toBe(EvmOperationStatus.READY);
206
- expect(stake.feeAuth.requiresAuth).toBe(false);
207
- });
208
-
209
- it('should emit status change events', async () => {
210
- const config = createConfig({
211
- env: Env.testnet,
212
- providers: { evm: () => mockProvider },
213
- });
214
-
215
- const evm = evmActions(config);
216
- const stake = evm.stake({
217
- assetIn: AssetId.BTCb,
218
- assetOut: AssetId.LBTC,
219
- sourceChain: Chain.AVALANCHE_FUJI,
220
- destChain: Chain.AVALANCHE_FUJI,
221
- });
222
-
223
- const statusChanges: string[] = [];
224
- stake.on('status-change', (status: unknown) => statusChanges.push(status as string));
225
-
226
- await stake.prepare({ amount: '0.001' });
227
-
228
- // On subsidized chains, goes directly to READY (no NEEDS_FEE_AUTHORIZATION step)
229
- expect(statusChanges).toContain(EvmOperationStatus.READY);
230
- });
231
- });
232
-
233
- describe('Validation', () => {
234
- it('should reject invalid amount', async () => {
235
- const config = createConfig({
236
- env: Env.testnet,
237
- providers: { evm: () => mockProvider },
238
- });
239
-
240
- const evm = evmActions(config);
241
- const stake = evm.stake({
242
- assetIn: AssetId.BTCb,
243
- assetOut: AssetId.LBTC,
244
- sourceChain: Chain.AVALANCHE_FUJI,
245
- destChain: Chain.AVALANCHE_FUJI,
246
- });
247
-
248
- await expect(stake.prepare({ amount: '' })).rejects.toThrow();
249
- });
250
-
251
- it('should reject negative amount', async () => {
252
- const config = createConfig({
253
- env: Env.testnet,
254
- providers: { evm: () => mockProvider },
255
- });
256
-
257
- const evm = evmActions(config);
258
- const stake = evm.stake({
259
- assetIn: AssetId.BTCb,
260
- assetOut: AssetId.LBTC,
261
- sourceChain: Chain.AVALANCHE_FUJI,
262
- destChain: Chain.AVALANCHE_FUJI,
263
- });
264
-
265
- await expect(stake.prepare({ amount: '-0.001' })).rejects.toThrow();
266
- });
267
- });
268
-
269
- describe('Execution', () => {
270
- it('should execute BTC.b → LBTC via asset router', async () => {
271
- const mockTxHash = '0x' + 'cd'.repeat(32);
272
- (depositToken as unknown as ReturnType<typeof vi.fn>).mockResolvedValue(
273
- mockTxHash,
274
- );
275
-
276
- const config = createConfig({
277
- env: Env.testnet,
278
- providers: { evm: () => mockProvider },
279
- });
280
-
281
- const evm = evmActions(config);
282
- const stake = evm.stake({
283
- assetIn: AssetId.BTCb,
284
- assetOut: AssetId.LBTC,
285
- sourceChain: Chain.AVALANCHE_FUJI,
286
- destChain: Chain.AVALANCHE_FUJI,
287
- });
288
-
289
- await stake.prepare({ amount: '0.01' });
290
- // Avalanche is subsidized, goes directly to READY
291
- const result = await stake.execute();
292
-
293
- expect(result.txHash).toBe(mockTxHash);
294
- expect(depositToken).toHaveBeenCalledWith(
295
- expect.objectContaining({
296
- amount: '0.01',
297
- tokenIn: Token.BTCb,
298
- tokenOut: Token.LBTC,
299
- }),
300
- );
301
- expect(stake.txHash).toBe(mockTxHash);
302
- expect(stake.status).toBe(EvmOperationStatus.COMPLETED);
303
- });
304
- });
305
- });
306
-
307
- // ═══════════════════════════════════════════════════════════════════════════
308
- // EVM Unstake Tests (LBTC → BTC or BTC.b)
309
- // ═══════════════════════════════════════════════════════════════════════════
310
-
311
- describe('EVM Unstake Action', () => {
312
- let mockProvider: EIP1193Provider;
313
-
314
- beforeEach(() => {
315
- mockProvider = createMockEvmProvider();
316
- vi.clearAllMocks();
317
- });
318
-
319
- describe('LBTC → BTC.b (same-chain)', () => {
320
- it('should start in IDLE status', () => {
321
- const config = createConfig({
322
- env: Env.testnet,
323
- providers: { evm: () => mockProvider },
324
- });
325
-
326
- const evm = evmActions(config);
327
- const unstake = evm.unstake({
328
- assetIn: AssetId.LBTC,
329
- assetOut: AssetId.BTCb,
330
- sourceChain: Chain.AVALANCHE_FUJI,
331
- destChain: Chain.AVALANCHE_FUJI,
332
- });
333
-
334
- expect(unstake.status).toBe(EvmOperationStatus.IDLE);
335
- });
336
-
337
- it('should transition to READY after prepare', async () => {
338
- const config = createConfig({
339
- env: Env.testnet,
340
- providers: { evm: () => mockProvider },
341
- });
342
-
343
- const evm = evmActions(config);
344
- const unstake = evm.unstake({
345
- assetIn: AssetId.LBTC,
346
- assetOut: AssetId.BTCb,
347
- sourceChain: Chain.AVALANCHE_FUJI,
348
- destChain: Chain.AVALANCHE_FUJI,
349
- });
350
-
351
- await unstake.prepare({
352
- amount: '0.001',
353
- recipient: '0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0',
354
- });
355
-
356
- expect(unstake.status).toBe(EvmOperationStatus.READY);
357
- expect(unstake.amount).toBe('0.001');
358
- });
359
- });
360
-
361
- describe('LBTC → BTC (cross-chain)', () => {
362
- it('should validate Bitcoin recipient address', async () => {
363
- const config = createConfig({
364
- env: Env.testnet,
365
- providers: { evm: () => mockProvider },
366
- });
367
-
368
- const evm = evmActions(config);
369
- const unstake = evm.unstake({
370
- assetIn: AssetId.LBTC,
371
- assetOut: AssetId.BTC,
372
- sourceChain: Chain.SEPOLIA,
373
- destChain: Chain.BITCOIN_SIGNET,
374
- });
375
-
376
- // Valid Bitcoin signet address
377
- await unstake.prepare({
378
- amount: '0.001',
379
- recipient: 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx',
380
- });
381
-
382
- expect(unstake.status).toBe(EvmOperationStatus.READY);
383
- });
384
-
385
- it('should reject invalid Bitcoin address', async () => {
386
- const config = createConfig({
387
- env: Env.testnet,
388
- providers: { evm: () => mockProvider },
389
- });
390
-
391
- const evm = evmActions(config);
392
- const unstake = evm.unstake({
393
- assetIn: AssetId.LBTC,
394
- assetOut: AssetId.BTC,
395
- sourceChain: Chain.SEPOLIA,
396
- destChain: Chain.BITCOIN_SIGNET,
397
- });
398
-
399
- await expect(
400
- unstake.prepare({
401
- amount: '0.001',
402
- recipient: 'invalid-address',
403
- }),
404
- ).rejects.toThrow();
405
- });
406
- });
407
- });
408
-
409
- // ═══════════════════════════════════════════════════════════════════════════
410
- // EVM Deploy Tests (LBTC → DeFi)
411
- // ═══════════════════════════════════════════════════════════════════════════
412
-
413
- describe('EVM Deploy Action', () => {
414
- let mockProvider: EIP1193Provider;
415
-
416
- beforeEach(() => {
417
- mockProvider = createMockEvmProvider();
418
- vi.clearAllMocks();
419
- });
420
-
421
- describe('Lifecycle', () => {
422
- it('should start in IDLE status', () => {
423
- const config = createConfig({
424
- env: Env.prod, // Veda only on prod
425
- providers: { evm: () => mockProvider },
426
- });
427
-
428
- const evm = evmActions(config);
429
- const deploy = evm.deploy({
430
- asset: AssetId.LBTC,
431
- sourceChain: Chain.ETHEREUM,
432
- protocol: DeployProtocol.Veda,
433
- recipient: '0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0',
434
- });
435
-
436
- expect(deploy.status).toBe(EvmOperationStatus.IDLE);
437
- });
438
-
439
- it('should transition to READY after prepare when allowance is sufficient', async () => {
440
- // Mock returns high allowance (BigInt('100000000000') = 1000 LBTC in base units)
441
- // So 0.01 LBTC should not need approval
442
- const config = createConfig({
443
- env: Env.prod,
444
- providers: { evm: () => mockProvider },
445
- });
446
-
447
- const evm = evmActions(config);
448
- const deploy = evm.deploy({
449
- asset: AssetId.LBTC,
450
- sourceChain: Chain.ETHEREUM,
451
- protocol: DeployProtocol.Veda,
452
- recipient: '0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0',
453
- });
454
-
455
- await deploy.prepare({
456
- amount: '0.01',
457
- protocol: DeployProtocol.Veda,
458
- });
459
-
460
- // With sufficient allowance, should skip to READY
461
- expect(deploy.status).toBe(EvmOperationStatus.READY);
462
- expect(deploy.amount).toBe('0.01');
463
- expect(deploy.protocol).toBe(DeployProtocol.Veda);
464
- expect(deploy.needsApproval).toBe(false);
465
- });
466
-
467
- it('should transition to NEEDS_APPROVAL when allowance is insufficient', async () => {
468
- // Override the mock to return low allowance
469
- const { makePublicClient } = await import('../../clients/public-client');
470
- vi.mocked(makePublicClient).mockReturnValueOnce({
471
- readContract: vi.fn().mockResolvedValue(BigInt('0')), // Zero allowance
472
- simulateContract: vi.fn().mockResolvedValue({ request: {} }),
473
- } as unknown as ReturnType<typeof makePublicClient>);
474
-
475
- const config = createConfig({
476
- env: Env.prod,
477
- providers: { evm: () => mockProvider },
478
- });
479
-
480
- const evm = evmActions(config);
481
- const deploy = evm.deploy({
482
- asset: AssetId.LBTC,
483
- sourceChain: Chain.ETHEREUM,
484
- protocol: DeployProtocol.Veda,
485
- recipient: '0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0',
486
- });
487
-
488
- await deploy.prepare({
489
- amount: '0.01',
490
- protocol: DeployProtocol.Veda,
491
- });
492
-
493
- expect(deploy.status).toBe(EvmOperationStatus.NEEDS_APPROVAL);
494
- expect(deploy.needsApproval).toBe(true);
495
- });
496
-
497
- it('should transition to READY after approve when allowance was insufficient', async () => {
498
- // Override mock to return low allowance for prepare
499
- const { makePublicClient } = await import('../../clients/public-client');
500
- vi.mocked(makePublicClient).mockReturnValueOnce({
501
- readContract: vi.fn().mockResolvedValue(BigInt('0')), // Zero allowance
502
- simulateContract: vi.fn().mockResolvedValue({ request: {} }),
503
- } as unknown as ReturnType<typeof makePublicClient>);
504
-
505
- const config = createConfig({
506
- env: Env.prod,
507
- providers: { evm: () => mockProvider },
508
- });
509
-
510
- const evm = evmActions(config);
511
- const deploy = evm.deploy({
512
- asset: AssetId.LBTC,
513
- sourceChain: Chain.ETHEREUM,
514
- protocol: DeployProtocol.Veda,
515
- recipient: '0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0',
516
- });
517
-
518
- await deploy.prepare({
519
- amount: '0.01',
520
- protocol: DeployProtocol.Veda,
521
- });
522
-
523
- expect(deploy.status).toBe(EvmOperationStatus.NEEDS_APPROVAL);
524
-
525
- await deploy.approve();
526
-
527
- expect(deploy.status).toBe(EvmOperationStatus.READY);
528
- expect(deploy.needsApproval).toBe(false);
529
- });
530
- });
531
-
532
- describe('Protocol Validation', () => {
533
- it('should reject unsupported protocol in testnet', async () => {
534
- const config = createConfig({
535
- env: Env.testnet, // Veda not on testnet
536
- providers: { evm: () => mockProvider },
537
- });
538
-
539
- const evm = evmActions(config);
540
- const deploy = evm.deploy({
541
- asset: AssetId.LBTC,
542
- sourceChain: Chain.SEPOLIA,
543
- protocol: DeployProtocol.Veda,
544
- recipient: '0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0',
545
- });
546
-
547
- await expect(
548
- deploy.prepare({
549
- amount: '0.01',
550
- protocol: DeployProtocol.Veda,
551
- }),
552
- ).rejects.toThrow(/not supported/i);
553
- });
554
- });
555
- });
556
-
557
- // ═══════════════════════════════════════════════════════════════════════════
558
- // EVM Redeem Tests (LBTC → BTC.b)
559
- // ═══════════════════════════════════════════════════════════════════════════
560
-
561
- describe('EVM Redeem Action', () => {
562
- let mockProvider: EIP1193Provider;
563
-
564
- beforeEach(() => {
565
- mockProvider = createMockEvmProvider();
566
- vi.clearAllMocks();
567
- });
568
-
569
- describe('Lifecycle', () => {
570
- it('should start in IDLE status', () => {
571
- const config = createConfig({
572
- env: Env.testnet,
573
- providers: { evm: () => mockProvider },
574
- });
575
-
576
- const evm = evmActions(config);
577
- const redeem = evm.redeem({
578
- assetIn: AssetId.BTCb,
579
- assetOut: AssetId.BTC,
580
- sourceChain: Chain.AVALANCHE_FUJI,
581
- destChain: Chain.BITCOIN_SIGNET,
582
- });
583
-
584
- expect(redeem.status).toBe(EvmOperationStatus.IDLE);
585
- });
586
-
587
- it('should transition directly to READY after prepare (no approval)', async () => {
588
- const config = createConfig({
589
- env: Env.testnet,
590
- providers: { evm: () => mockProvider },
591
- });
592
-
593
- const evm = evmActions(config);
594
- const redeem = evm.redeem({
595
- assetIn: AssetId.BTCb,
596
- assetOut: AssetId.BTC,
597
- sourceChain: Chain.AVALANCHE_FUJI,
598
- destChain: Chain.BITCOIN_SIGNET,
599
- });
600
-
601
- await redeem.prepare({
602
- amount: '0.001',
603
- // Valid testnet Bitcoin address from BIP-0173
604
- recipient: 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx',
605
- });
606
-
607
- // Redeem goes directly to READY (no approval needed)
608
- expect(redeem.status).toBe(EvmOperationStatus.READY);
609
- expect(redeem.needsApproval).toBe(false);
610
- });
611
-
612
- it('should emit progress events', async () => {
613
- const config = createConfig({
614
- env: Env.testnet,
615
- providers: { evm: () => mockProvider },
616
- });
617
-
618
- const evm = evmActions(config);
619
- const redeem = evm.redeem({
620
- assetIn: AssetId.BTCb,
621
- assetOut: AssetId.BTC,
622
- sourceChain: Chain.AVALANCHE_FUJI,
623
- destChain: Chain.BITCOIN_SIGNET,
624
- });
625
-
626
- interface ProgressEvent {
627
- status: string;
628
- steps?: Record<string, string>;
629
- }
630
-
631
- const progressEvents: ProgressEvent[] = [];
632
- redeem.on('progress', (progress: unknown) =>
633
- progressEvents.push(progress as ProgressEvent),
634
- );
635
-
636
- await redeem.prepare({
637
- amount: '0.001',
638
- // Valid testnet Bitcoin address from BIP-0173
639
- recipient: 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx',
640
- });
641
-
642
- expect(progressEvents.length).toBeGreaterThan(0);
643
- expect(progressEvents[progressEvents.length - 1].status).toBe(
644
- EvmOperationStatus.READY,
645
- );
646
- });
647
- });
648
-
649
- describe('Validation', () => {
650
- it('should reject invalid EVM address', async () => {
651
- const config = createConfig({
652
- env: Env.testnet,
653
- providers: { evm: () => mockProvider },
654
- });
655
-
656
- const evm = evmActions(config);
657
- const redeem = evm.redeem({
658
- assetIn: AssetId.BTCb,
659
- assetOut: AssetId.BTC,
660
- sourceChain: Chain.AVALANCHE_FUJI,
661
- destChain: Chain.BITCOIN_SIGNET,
662
- });
663
-
664
- await expect(
665
- redeem.prepare({
666
- amount: '0.001',
667
- recipient: 'not-an-address',
668
- }),
669
- ).rejects.toThrow();
670
- });
671
- });
672
- });
673
-
674
- // ═══════════════════════════════════════════════════════════════════════════
675
- // EVM Deposit Tests (Claim LBTC with proof)
676
- // ═══════════════════════════════════════════════════════════════════════════
677
-
678
- describe('EVM Deposit Action', () => {
679
- let mockProvider: EIP1193Provider;
680
-
681
- beforeEach(() => {
682
- mockProvider = createMockEvmProvider();
683
- vi.clearAllMocks();
684
- });
685
-
686
- describe('Lifecycle', () => {
687
- it('should start in IDLE status', () => {
688
- const config = createConfig({
689
- env: Env.testnet,
690
- providers: { evm: () => mockProvider },
691
- });
692
-
693
- const evm = evmActions(config);
694
- const deposit = evm.deposit({
695
- assetIn: AssetId.BTC,
696
- assetOut: AssetId.LBTC,
697
- sourceChain: Chain.BITCOIN_SIGNET,
698
- destChain: Chain.SEPOLIA,
699
- });
700
-
701
- expect(deposit.status).toBe('idle');
702
- });
703
-
704
- it('should transition to READY after prepare', async () => {
705
- const config = createConfig({
706
- env: Env.testnet,
707
- providers: { evm: () => mockProvider },
708
- });
709
-
710
- const evm = evmActions(config);
711
- const deposit = evm.deposit({
712
- assetIn: AssetId.BTC,
713
- assetOut: AssetId.LBTC,
714
- sourceChain: Chain.BITCOIN_SIGNET,
715
- destChain: Chain.SEPOLIA,
716
- });
717
-
718
- await deposit.prepare({
719
- amount: '0.001',
720
- recipient: '0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0',
721
- });
722
-
723
- expect(deposit.status).toBe('ready');
724
- });
725
-
726
- it('should require claim data before execute', async () => {
727
- const config = createConfig({
728
- env: Env.testnet,
729
- providers: { evm: () => mockProvider },
730
- });
731
-
732
- const evm = evmActions(config);
733
- const deposit = evm.deposit({
734
- assetIn: AssetId.BTC,
735
- assetOut: AssetId.LBTC,
736
- sourceChain: Chain.BITCOIN_SIGNET,
737
- destChain: Chain.SEPOLIA,
738
- });
739
-
740
- await deposit.prepare({
741
- amount: '0.001',
742
- recipient: '0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0',
743
- });
744
-
745
- // Should fail without claim data
746
- await expect(deposit.execute()).rejects.toThrow(/claimData/i);
747
- });
748
- });
749
-
750
- describe('Claim Data', () => {
751
- it('should accept claim data via setClaimData', async () => {
752
- const config = createConfig({
753
- env: Env.testnet,
754
- providers: { evm: () => mockProvider },
755
- });
756
-
757
- const evm = evmActions(config);
758
- const deposit = evm.deposit({
759
- assetIn: AssetId.BTC,
760
- assetOut: AssetId.LBTC,
761
- sourceChain: Chain.BITCOIN_SIGNET,
762
- destChain: Chain.SEPOLIA,
763
- });
764
-
765
- await deposit.prepare({
766
- amount: '0.001',
767
- recipient: '0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0',
768
- });
769
-
770
- // Set claim data
771
- deposit.setClaimData('0xdata...', '0xproofSignature...');
772
-
773
- // Now should have claim data (execute would work with proper mocks)
774
- expect(deposit.status).toBe('ready');
775
- });
776
- });
777
- });
778
-
779
- // ═══════════════════════════════════════════════════════════════════════════
780
- // Error Handling Tests (applies to all actions)
781
- // ═══════════════════════════════════════════════════════════════════════════
782
-
783
- describe('EVM Action Error Handling', () => {
784
- let mockProvider: EIP1193Provider;
785
-
786
- beforeEach(() => {
787
- mockProvider = createMockEvmProvider();
788
- vi.clearAllMocks();
789
- });
790
-
791
- it('should preserve status on error', async () => {
792
- const config = createConfig({
793
- env: Env.testnet,
794
- providers: { evm: () => mockProvider },
795
- });
796
-
797
- const evm = evmActions(config);
798
- const stake = evm.stake({
799
- assetIn: AssetId.BTCb,
800
- assetOut: AssetId.LBTC,
801
- sourceChain: Chain.AVALANCHE_FUJI,
802
- destChain: Chain.AVALANCHE_FUJI,
803
- });
804
-
805
- const initialStatus = stake.status;
806
-
807
- await expect(stake.prepare({ amount: '' })).rejects.toThrow();
808
-
809
- // Status should not change on error
810
- expect(stake.status).toBe(initialStatus);
811
- expect(stake.isFailed).toBe(true);
812
- expect(stake.error).not.toBeNull();
813
- });
814
-
815
- it('should allow retry after error', async () => {
816
- const config = createConfig({
817
- env: Env.testnet,
818
- providers: { evm: () => mockProvider },
819
- });
820
-
821
- const evm = evmActions(config);
822
- const stake = evm.stake({
823
- assetIn: AssetId.BTCb,
824
- assetOut: AssetId.LBTC,
825
- sourceChain: Chain.AVALANCHE_FUJI,
826
- destChain: Chain.AVALANCHE_FUJI,
827
- });
828
-
829
- // First attempt fails
830
- await expect(stake.prepare({ amount: '' })).rejects.toThrow();
831
- expect(stake.isFailed).toBe(true);
832
-
833
- // Retry with valid amount
834
- await stake.prepare({ amount: '0.001' });
835
-
836
- expect(stake.isFailed).toBe(false);
837
- expect(stake.error).toBeNull();
838
- // Avalanche is subsidized, goes directly to READY
839
- expect(stake.status).toBe(EvmOperationStatus.READY);
840
- });
841
-
842
- it('should emit error and failed events', async () => {
843
- const config = createConfig({
844
- env: Env.testnet,
845
- providers: { evm: () => mockProvider },
846
- });
847
-
848
- const evm = evmActions(config);
849
- const unstake = evm.unstake({
850
- assetIn: AssetId.LBTC,
851
- assetOut: AssetId.BTCb,
852
- sourceChain: Chain.AVALANCHE_FUJI,
853
- destChain: Chain.AVALANCHE_FUJI,
854
- });
855
-
856
- const errors: Error[] = [];
857
- const failedEvents: number[] = [];
858
-
859
- unstake.on('error', (error: unknown) => errors.push(error as Error));
860
- unstake.on('failed', () => failedEvents.push(1));
861
-
862
- await expect(
863
- unstake.prepare({
864
- amount: '',
865
- recipient: '0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0',
866
- }),
867
- ).rejects.toThrow();
868
-
869
- expect(errors.length).toBe(1);
870
- expect(failedEvents.length).toBe(1);
871
- });
872
- });
873
-
874
- // ═══════════════════════════════════════════════════════════════════════════
875
- // Loading State Tests (applies to all actions)
876
- // ═══════════════════════════════════════════════════════════════════════════
877
-
878
- describe('EVM Action Loading States', () => {
879
- let mockProvider: EIP1193Provider;
880
-
881
- beforeEach(() => {
882
- mockProvider = createMockEvmProvider();
883
- vi.clearAllMocks();
884
- });
885
-
886
- it('should emit loading events during operations', async () => {
887
- const config = createConfig({
888
- env: Env.testnet,
889
- providers: { evm: () => mockProvider },
890
- });
891
-
892
- const evm = evmActions(config);
893
- const stake = evm.stake({
894
- assetIn: AssetId.BTCb,
895
- assetOut: AssetId.LBTC,
896
- sourceChain: Chain.AVALANCHE_FUJI,
897
- destChain: Chain.AVALANCHE_FUJI,
898
- });
899
-
900
- const loadingStates: boolean[] = [];
901
- stake.on('loading', (isLoading: unknown) => loadingStates.push(isLoading as boolean));
902
-
903
- await stake.prepare({ amount: '0.001' });
904
-
905
- // Should have transitioned through loading states
906
- expect(loadingStates).toContain(true);
907
- expect(loadingStates[loadingStates.length - 1]).toBe(false);
908
- expect(stake.isLoading).toBe(false);
909
- });
910
-
911
- it('should return unsubscribe function from on()', () => {
912
- const config = createConfig({
913
- env: Env.testnet,
914
- providers: { evm: () => mockProvider },
915
- });
916
-
917
- const evm = evmActions(config);
918
- const stake = evm.stake({
919
- assetIn: AssetId.BTCb,
920
- assetOut: AssetId.LBTC,
921
- sourceChain: Chain.AVALANCHE_FUJI,
922
- destChain: Chain.AVALANCHE_FUJI,
923
- });
924
-
925
- const handler = vi.fn();
926
- const unsubscribe = stake.on('status-change', handler);
927
-
928
- expect(typeof unsubscribe).toBe('function');
929
- unsubscribe();
930
- });
931
- });
932
-