@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,310 +0,0 @@
1
- /**
2
- * SuiUnstake Unit Tests
3
- *
4
- * Tests for the Sui LBTC unstaking action with mocked providers.
5
- */
6
-
7
- import { Env } from '@lombard.finance/sdk-common';
8
- import { beforeEach, describe, expect, it, vi } from 'vitest';
9
-
10
- import { SuiUnstake } from '../../../chains/sui/actions/unstake/SuiUnstake';
11
- import { PartnerConfiguration } from '../../../client/PartnerConfiguration';
12
- import { AssetId, Chain } from '../../../core';
13
- import { NonEvmUnstakeStatus } from '../../../shared/constants/statusConstants';
14
- import type { SuiCoreContext } from '../../../shared/context';
15
-
16
- // ═══════════════════════════════════════════════════════════════════════════
17
- // Mock Setup
18
- // ═══════════════════════════════════════════════════════════════════════════
19
-
20
- function createMockSuiService() {
21
- return {
22
- signLbtcDestination: vi.fn().mockResolvedValue({ signature: '0xmock' }),
23
- unstake: vi.fn().mockResolvedValue({ txHash: 'mock-sui-digest-abc123' }),
24
- };
25
- }
26
-
27
- function createMockContext(
28
- overrides: Partial<SuiCoreContext> = {},
29
- ): SuiCoreContext {
30
- return {
31
- env: Env.testnet,
32
- partner: new PartnerConfiguration({ partnerId: 'test-partner' }),
33
- getProvider: vi.fn().mockResolvedValue({}),
34
- sui: createMockSuiService(),
35
- ...overrides,
36
- };
37
- }
38
-
39
- // ═══════════════════════════════════════════════════════════════════════════
40
- // Tests
41
- // ═══════════════════════════════════════════════════════════════════════════
42
-
43
- describe('SuiUnstake', () => {
44
- let mockCtx: SuiCoreContext;
45
-
46
- const validParams = {
47
- assetIn: AssetId.LBTC,
48
- assetOut: AssetId.BTC,
49
- sourceChain: Chain.SUI_MAINNET,
50
- destChain: Chain.BITCOIN_MAINNET,
51
- };
52
-
53
- const validPrepareParams = {
54
- amount: '0.001',
55
- recipient: 'bc1qxy2kgdygjrsqtzq2n0yrf2493p83kkfjhx0wlh',
56
- };
57
-
58
- beforeEach(() => {
59
- mockCtx = createMockContext({ env: Env.prod });
60
- vi.clearAllMocks();
61
- });
62
-
63
- // ─────────────────────────────────────────────────────────────────────────
64
- // Initialization Tests
65
- // ─────────────────────────────────────────────────────────────────────────
66
-
67
- describe('initialization', () => {
68
- it('should initialize with IDLE status', () => {
69
- const unstake = new SuiUnstake(mockCtx, validParams);
70
- expect(unstake.status).toBe(NonEvmUnstakeStatus.IDLE);
71
- });
72
-
73
- it('should throw for unsupported source chain', () => {
74
- const invalidParams = {
75
- ...validParams,
76
- sourceChain: Chain.ETHEREUM, // Not a Sui chain
77
- };
78
-
79
- expect(() => new SuiUnstake(mockCtx, invalidParams)).toThrow();
80
- });
81
-
82
- it('should throw for unsupported env/chain combination', () => {
83
- // testnet env with mainnet chain
84
- const testnetCtx = createMockContext({ env: Env.testnet });
85
-
86
- expect(() => new SuiUnstake(testnetCtx, validParams)).toThrow();
87
- });
88
-
89
- it('should accept valid testnet configuration', () => {
90
- const testnetCtx = createMockContext({ env: Env.testnet });
91
- const testnetParams = {
92
- ...validParams,
93
- sourceChain: Chain.SUI_TESTNET,
94
- destChain: Chain.BITCOIN_SIGNET,
95
- };
96
-
97
- const unstake = new SuiUnstake(testnetCtx, testnetParams);
98
- expect(unstake.status).toBe(NonEvmUnstakeStatus.IDLE);
99
- });
100
- });
101
-
102
- // ─────────────────────────────────────────────────────────────────────────
103
- // Prepare Tests
104
- // ─────────────────────────────────────────────────────────────────────────
105
-
106
- describe('prepare', () => {
107
- it('should transition to READY status on valid prepare', async () => {
108
- const unstake = new SuiUnstake(mockCtx, validParams);
109
-
110
- await unstake.prepare(validPrepareParams);
111
-
112
- expect(unstake.status).toBe(NonEvmUnstakeStatus.READY);
113
- expect(unstake.amount).toBe('0.001');
114
- expect(unstake.recipient).toBe(validPrepareParams.recipient);
115
- });
116
-
117
- it('should validate BTC address format', async () => {
118
- const unstake = new SuiUnstake(mockCtx, validParams);
119
-
120
- await expect(
121
- unstake.prepare({
122
- amount: '0.001',
123
- recipient: 'invalid-btc-address',
124
- }),
125
- ).rejects.toThrow();
126
- });
127
-
128
- it('should validate amount is positive', async () => {
129
- const unstake = new SuiUnstake(mockCtx, validParams);
130
-
131
- await expect(
132
- unstake.prepare({
133
- amount: '0',
134
- recipient: validPrepareParams.recipient,
135
- }),
136
- ).rejects.toThrow();
137
- });
138
-
139
- it('should throw if called when not IDLE', async () => {
140
- const unstake = new SuiUnstake(mockCtx, validParams);
141
- await unstake.prepare(validPrepareParams);
142
-
143
- await expect(unstake.prepare(validPrepareParams)).rejects.toThrow(
144
- /prepare/,
145
- );
146
- });
147
- });
148
-
149
- // ─────────────────────────────────────────────────────────────────────────
150
- // Execute Tests
151
- // ─────────────────────────────────────────────────────────────────────────
152
-
153
- describe('execute', () => {
154
- it('should call sui service unstake method', async () => {
155
- const unstake = new SuiUnstake(mockCtx, validParams);
156
- await unstake.prepare(validPrepareParams);
157
-
158
- const result = await unstake.execute();
159
-
160
- expect(mockCtx.sui.unstake).toHaveBeenCalledWith({
161
- amount: validPrepareParams.amount,
162
- btcAddress: validPrepareParams.recipient,
163
- chainId: 'sui:mainnet',
164
- env: Env.prod,
165
- });
166
- expect(result.txHash).toBe('mock-sui-digest-abc123');
167
- });
168
-
169
- it('should transition to COMPLETED status', async () => {
170
- const unstake = new SuiUnstake(mockCtx, validParams);
171
- await unstake.prepare(validPrepareParams);
172
-
173
- await unstake.execute();
174
-
175
- expect(unstake.status).toBe(NonEvmUnstakeStatus.COMPLETED);
176
- });
177
-
178
- it('should throw if called when not READY', async () => {
179
- const unstake = new SuiUnstake(mockCtx, validParams);
180
-
181
- await expect(unstake.execute()).rejects.toThrow(/execute/);
182
- });
183
-
184
- it('should handle service errors', async () => {
185
- mockCtx.sui.unstake = vi
186
- .fn()
187
- .mockRejectedValue(new Error('Sui transaction failed'));
188
-
189
- const unstake = new SuiUnstake(mockCtx, validParams);
190
- await unstake.prepare(validPrepareParams);
191
-
192
- await expect(unstake.execute()).rejects.toThrow('Sui transaction failed');
193
- expect(unstake.isFailed).toBe(true);
194
- });
195
-
196
- it('should set txHash property on success', async () => {
197
- const unstake = new SuiUnstake(mockCtx, validParams);
198
- await unstake.prepare(validPrepareParams);
199
-
200
- await unstake.execute();
201
-
202
- expect(unstake.txHash).toBe('mock-sui-digest-abc123');
203
- });
204
- });
205
-
206
- // ─────────────────────────────────────────────────────────────────────────
207
- // Event Tests
208
- // ─────────────────────────────────────────────────────────────────────────
209
-
210
- describe('events', () => {
211
- it('should emit progress events during prepare', async () => {
212
- const unstake = new SuiUnstake(mockCtx, validParams);
213
- const progressHandler = vi.fn();
214
-
215
- unstake.on('progress', progressHandler);
216
- await unstake.prepare(validPrepareParams);
217
-
218
- expect(progressHandler).toHaveBeenCalled();
219
- });
220
-
221
- it('should emit completed event after execute', async () => {
222
- const unstake = new SuiUnstake(mockCtx, validParams);
223
- const completedHandler = vi.fn();
224
-
225
- unstake.on('completed', completedHandler);
226
- await unstake.prepare(validPrepareParams);
227
- await unstake.execute();
228
-
229
- expect(completedHandler).toHaveBeenCalled();
230
- });
231
-
232
- it('should emit error event on failure', async () => {
233
- mockCtx.sui.unstake = vi.fn().mockRejectedValue(new Error('Sui error'));
234
-
235
- const unstake = new SuiUnstake(mockCtx, validParams);
236
- const errorHandler = vi.fn();
237
-
238
- unstake.on('error', errorHandler);
239
- await unstake.prepare(validPrepareParams);
240
-
241
- await expect(unstake.execute()).rejects.toThrow();
242
- expect(errorHandler).toHaveBeenCalled();
243
- });
244
- });
245
-
246
- // ─────────────────────────────────────────────────────────────────────────
247
- // Chain ID Mapping Tests
248
- // ─────────────────────────────────────────────────────────────────────────
249
-
250
- describe('chain ID mapping', () => {
251
- it('should use sui:mainnet for mainnet chain', async () => {
252
- const unstake = new SuiUnstake(mockCtx, validParams);
253
- await unstake.prepare(validPrepareParams);
254
-
255
- await unstake.execute();
256
-
257
- expect(mockCtx.sui.unstake).toHaveBeenCalledWith(
258
- expect.objectContaining({ chainId: 'sui:mainnet' }),
259
- );
260
- });
261
-
262
- it('should use sui:testnet for testnet chain', async () => {
263
- const testnetCtx = createMockContext({ env: Env.testnet });
264
- const testnetParams = {
265
- ...validParams,
266
- sourceChain: Chain.SUI_TESTNET,
267
- destChain: Chain.BITCOIN_SIGNET,
268
- };
269
- const unstake = new SuiUnstake(testnetCtx, testnetParams);
270
- await unstake.prepare(validPrepareParams);
271
-
272
- await unstake.execute();
273
-
274
- expect(testnetCtx.sui.unstake).toHaveBeenCalledWith(
275
- expect.objectContaining({ chainId: 'sui:testnet' }),
276
- );
277
- });
278
- });
279
-
280
- // ─────────────────────────────────────────────────────────────────────────
281
- // Loading State Tests
282
- // ─────────────────────────────────────────────────────────────────────────
283
-
284
- describe('loading state', () => {
285
- it('should set isLoading during prepare', async () => {
286
- const unstake = new SuiUnstake(mockCtx, validParams);
287
- const loadingStates: boolean[] = [];
288
-
289
- unstake.on('loading', (isLoading) => loadingStates.push(isLoading));
290
- await unstake.prepare(validPrepareParams);
291
-
292
- expect(loadingStates).toContain(true);
293
- expect(unstake.isLoading).toBe(false);
294
- });
295
-
296
- it('should set isLoading during execute', async () => {
297
- const unstake = new SuiUnstake(mockCtx, validParams);
298
- await unstake.prepare(validPrepareParams);
299
-
300
- const loadingStates: boolean[] = [];
301
- unstake.on('loading', (isLoading) => loadingStates.push(isLoading));
302
-
303
- await unstake.execute();
304
-
305
- expect(loadingStates).toContain(true);
306
- expect(unstake.isLoading).toBe(false);
307
- });
308
- });
309
- });
310
-
@@ -1,27 +0,0 @@
1
- import BigNumber from 'bignumber.js';
2
- import { describe, expect,it } from 'vitest';
3
-
4
- import { fromSatoshi,toSatoshi, toSatoshiBigInt } from '../../../utils/satoshi';
5
-
6
- describe('Satoshi Conversions', () => {
7
- it('toSatoshi should convert BTC decimal to satoshis', () => {
8
- expect(toSatoshi('0.00001992').toString()).toBe('1992');
9
- expect(toSatoshi('1').toString()).toBe('100000000');
10
- expect(toSatoshi('0').toString()).toBe('0');
11
- });
12
-
13
- it('toSatoshiBigInt should return BigInt', () => {
14
- expect(toSatoshiBigInt('0.00000032')).toBe(32n);
15
- expect(toSatoshiBigInt('0.00001992')).toBe(1992n);
16
- });
17
-
18
- it('toSatoshi should handle BigNumber inputs', () => {
19
- expect(toSatoshi(new BigNumber('0.00001992')).toString()).toBe('1992');
20
- });
21
-
22
- it('fromSatoshi should convert satoshis to BTC decimal', () => {
23
- expect(fromSatoshi('1992').toFixed()).toBe('0.00001992');
24
- expect(fromSatoshi(100000000).toFixed()).toBe('1');
25
- });
26
- });
27
-
@@ -1,350 +0,0 @@
1
- /**
2
- * Address Validation Tests
3
- *
4
- * Tests for address validation schemas to ensure they properly reject
5
- * truncated, malformed, and invalid addresses.
6
- *
7
- * Related Issue: APP-1979
8
- * - Address validation was accepting truncated addresses
9
- * - User could paste valid address, delete last character, and still proceed
10
- *
11
- * @module __tests__/unit/validation/address-validation.test.ts
12
- */
13
-
14
- import { describe, expect, it } from 'vitest';
15
-
16
- import {
17
- bitcoinAddressSchema,
18
- evmAddressSchema,
19
- solanaAddressSchema,
20
- starknetAddressSchema,
21
- suiAddressSchema,
22
- } from '../../../shared/validation';
23
-
24
- describe('Address Validation Schemas', () => {
25
- // ═══════════════════════════════════════════════════════════════════════════
26
- // EVM Address Validation
27
- // ═══════════════════════════════════════════════════════════════════════════
28
-
29
- describe('evmAddressSchema', () => {
30
- const validAddresses = [
31
- '0x742d35Cc6634C0532925a3b844Bc9e7595f0bEb0',
32
- '0x659579F1460c38c3ce3288b47b074646cef855fc',
33
- '0x0000000000000000000000000000000000000000',
34
- '0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF',
35
- ];
36
-
37
- it.each(validAddresses)('should accept valid EVM address: %s', (address) => {
38
- const result = evmAddressSchema.safeParse(address);
39
- expect(result.success).toBe(true);
40
- });
41
-
42
- describe('should reject truncated addresses', () => {
43
- it('should reject address with last character removed', () => {
44
- const valid = '0x659579F1460c38c3ce3288b47b074646cef855fc';
45
- const truncated = valid.slice(0, -1); // Remove last 'c'
46
-
47
- const result = evmAddressSchema.safeParse(truncated);
48
- expect(result.success).toBe(false);
49
- expect(result.error?.issues[0]?.message).toContain('Invalid EVM address');
50
- });
51
-
52
- it('should reject address with first hex character removed', () => {
53
- const valid = '0x659579F1460c38c3ce3288b47b074646cef855fc';
54
- const truncated = '0x' + valid.slice(3); // Remove first hex char
55
-
56
- const result = evmAddressSchema.safeParse(truncated);
57
- expect(result.success).toBe(false);
58
- });
59
-
60
- it('should reject address with multiple characters removed', () => {
61
- const valid = '0x659579F1460c38c3ce3288b47b074646cef855fc';
62
- const truncated = valid.slice(0, -5); // Remove last 5 chars
63
-
64
- const result = evmAddressSchema.safeParse(truncated);
65
- expect(result.success).toBe(false);
66
- });
67
- });
68
-
69
- describe('should reject malformed addresses', () => {
70
- const invalidAddresses = [
71
- { address: '659579F1460c38c3ce3288b47b074646cef855fc', reason: 'missing 0x prefix' },
72
- { address: '0x659579F1460c38c3ce3288b47b074646cef855f', reason: 'only 39 hex chars' },
73
- { address: '0x659579F1460c38c3ce3288b47b074646cef855fcc', reason: '41 hex chars' },
74
- { address: '0x659579F1460c38c3ce3288b47b074646cef855fG', reason: 'invalid hex char G' },
75
- { address: '', reason: 'empty string' },
76
- { address: '0x', reason: 'only prefix' },
77
- ];
78
-
79
- it.each(invalidAddresses)(
80
- 'should reject $reason: $address',
81
- ({ address }) => {
82
- const result = evmAddressSchema.safeParse(address);
83
- expect(result.success).toBe(false);
84
- }
85
- );
86
- });
87
- });
88
-
89
- // ═══════════════════════════════════════════════════════════════════════════
90
- // Bitcoin Address Validation
91
- // ═══════════════════════════════════════════════════════════════════════════
92
-
93
- describe('bitcoinAddressSchema', () => {
94
- // Valid mainnet addresses
95
- const validMainnetAddresses = [
96
- // Legacy P2PKH
97
- '1BvBMSEYstWetqTFn5Au4m4GFg7xJaNVN2',
98
- // SegWit P2WPKH (bech32)
99
- 'bc1qar0srrr7xfkvy5l643lydnw9re59gtzzwf5mdq',
100
- // SegWit P2WSH (bech32)
101
- 'bc1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3qccfmv3',
102
- // Taproot (bech32m)
103
- 'bc1pxwww0ct9ue7e8tdnlmug5m2tamfn7q06sahstg39ys4c9f3340qqxrdu9k',
104
- ];
105
-
106
- // Valid testnet addresses
107
- const validTestnetAddresses = [
108
- // Testnet Legacy
109
- 'mipcBbFg9gMiCh81Kj8tqqdgoZub1ZJRfn',
110
- 'n3ZddxzLvAY9o7184TB4c6FJasAybsw4HZ',
111
- // Testnet SegWit
112
- 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx',
113
- // Testnet Taproot (version 1, bech32m)
114
- 'tb1pqqqqp399et2xygdj5xreqhjjvcmzhxw4aywxecjdzew6hylgvsesf3hn0c',
115
- ];
116
-
117
- it.each([...validMainnetAddresses, ...validTestnetAddresses])(
118
- 'should accept valid Bitcoin address: %s',
119
- (address) => {
120
- const result = bitcoinAddressSchema.safeParse(address);
121
- expect(result.success).toBe(true);
122
- }
123
- );
124
-
125
- describe('should reject truncated addresses (APP-1979 - FIXED)', () => {
126
- /**
127
- * FIX IMPLEMENTED: APP-1979
128
- *
129
- * The bitcoinAddressSchema now uses bitcoinjs-lib for proper validation:
130
- * - bech32/bech32m checksum verification for SegWit/Taproot addresses
131
- * - base58check checksum verification for legacy addresses
132
- *
133
- * Truncated addresses will now correctly fail validation.
134
- */
135
-
136
- it('should reject bech32 (Taproot) address with last character removed', () => {
137
- const valid = 'tb1pqqqqp399et2xygdj5xreqhjjvcmzhxw4aywxecjdzew6hylgvsesf3hn0c';
138
- const truncated = valid.slice(0, -1); // Remove last 'c'
139
-
140
- const result = bitcoinAddressSchema.safeParse(truncated);
141
- expect(result.success).toBe(false);
142
- expect(result.error?.issues[0]?.message).toBe('Invalid Bitcoin address format');
143
- });
144
-
145
- it('should reject bech32 (SegWit) address with last character removed', () => {
146
- const valid = 'bc1qar0srrr7xfkvy5l643lydnw9re59gtzzwf5mdq';
147
- const truncated = valid.slice(0, -1);
148
-
149
- const result = bitcoinAddressSchema.safeParse(truncated);
150
- expect(result.success).toBe(false);
151
- });
152
-
153
- it('should reject legacy address with last character removed', () => {
154
- const valid = '1BvBMSEYstWetqTFn5Au4m4GFg7xJaNVN2';
155
- const truncated = valid.slice(0, -1);
156
-
157
- const result = bitcoinAddressSchema.safeParse(truncated);
158
- expect(result.success).toBe(false);
159
- });
160
-
161
- it('should reject address with multiple characters removed', () => {
162
- const valid = 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx';
163
- const truncated = valid.slice(0, -6);
164
-
165
- const result = bitcoinAddressSchema.safeParse(truncated);
166
- expect(result.success).toBe(false);
167
- });
168
- });
169
-
170
- describe('should reject malformed addresses', () => {
171
- const invalidAddresses = [
172
- { address: '', reason: 'empty string' },
173
- { address: 'bc1', reason: 'too short' },
174
- { address: 'bc1invalid!address', reason: 'invalid characters' },
175
- { address: '0x659579F1460c38c3ce3288b47b074646cef855fc', reason: 'EVM address' },
176
- { address: 'bc1qar0srrr7xfkvy5l643lydnw9re59gtzzwf5mdqINVALID', reason: 'uppercase in bech32' },
177
- ];
178
-
179
- it.each(invalidAddresses)(
180
- 'should reject $reason: $address',
181
- ({ address }) => {
182
- const result = bitcoinAddressSchema.safeParse(address);
183
- expect(result.success).toBe(false);
184
- }
185
- );
186
- });
187
- });
188
-
189
- // ═══════════════════════════════════════════════════════════════════════════
190
- // Solana Address Validation
191
- // ═══════════════════════════════════════════════════════════════════════════
192
-
193
- describe('solanaAddressSchema', () => {
194
- const validAddresses = [
195
- 'DRpbCBMxVnDK7maPGv7USy4MjEBQdCgaBExK8rKJmVZk',
196
- '11111111111111111111111111111111',
197
- 'TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA',
198
- ];
199
-
200
- it.each(validAddresses)('should accept valid Solana address: %s', (address) => {
201
- const result = solanaAddressSchema.safeParse(address);
202
- expect(result.success).toBe(true);
203
- });
204
-
205
- /**
206
- * LIMITATION: Solana addresses don't have a checksum
207
- *
208
- * Unlike Bitcoin, Solana addresses are just raw base58-encoded 32-byte keys.
209
- * A truncated address that still decodes to 32 bytes will pass format validation.
210
- *
211
- * This is a known limitation of the Solana address format itself.
212
- * The best we can do is verify:
213
- * 1. Valid base58 characters
214
- * 2. Length between 32-44 chars
215
- * 3. Decodes to exactly 32 bytes
216
- *
217
- * Some truncations will change the decoded length, failing validation.
218
- * Others won't - this is unavoidable without a checksum.
219
- */
220
- it('should reject addresses that decode to wrong byte length', () => {
221
- // Removing 2+ chars from a 44-char address usually changes decoded length
222
- const valid = 'DRpbCBMxVnDK7maPGv7USy4MjEBQdCgaBExK8rKJmVZk';
223
- const truncated = valid.slice(0, -2);
224
-
225
- const result = solanaAddressSchema.safeParse(truncated);
226
- expect(result.success).toBe(false);
227
- });
228
-
229
- it('should reject addresses shorter than 32 chars', () => {
230
- const tooShort = 'DRpbCBMxVnDK7maPGv7USy4MjEBQdC';
231
-
232
- const result = solanaAddressSchema.safeParse(tooShort);
233
- expect(result.success).toBe(false);
234
- });
235
-
236
- it('documents: single-char truncation may still decode to 32 bytes (no checksum)', () => {
237
- // This documents a limitation of Solana addresses - no checksum means
238
- // some truncations still produce valid-looking addresses
239
- const valid = 'DRpbCBMxVnDK7maPGv7USy4MjEBQdCgaBExK8rKJmVZk';
240
- const truncated = valid.slice(0, -1);
241
-
242
- const result = solanaAddressSchema.safeParse(truncated);
243
- // This may pass or fail depending on the specific truncation
244
- // We document rather than assert specific behavior
245
- expect(typeof result.success).toBe('boolean');
246
- });
247
-
248
- it('should reject address with invalid characters', () => {
249
- // Base58 doesn't include 0, O, I, l
250
- const invalid = 'DRpbCBMxVnDK7maPGv7USy4MjEBQdCgaBExK8rKJmVZ0';
251
-
252
- const result = solanaAddressSchema.safeParse(invalid);
253
- expect(result.success).toBe(false);
254
- });
255
- });
256
-
257
- // ═══════════════════════════════════════════════════════════════════════════
258
- // Sui Address Validation
259
- // ═══════════════════════════════════════════════════════════════════════════
260
-
261
- describe('suiAddressSchema', () => {
262
- const validAddresses = [
263
- '0x02a212de6a9dfa3a69e22387acfbafbb1a9e591bd9d636e7895dcfc8de05f331',
264
- '0x0000000000000000000000000000000000000000000000000000000000000000',
265
- '0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff',
266
- ];
267
-
268
- it.each(validAddresses)('should accept valid Sui address: %s', (address) => {
269
- const result = suiAddressSchema.safeParse(address);
270
- expect(result.success).toBe(true);
271
- });
272
-
273
- it('should reject truncated address', () => {
274
- const valid = '0x02a212de6a9dfa3a69e22387acfbafbb1a9e591bd9d636e7895dcfc8de05f331';
275
- const truncated = valid.slice(0, -1);
276
-
277
- const result = suiAddressSchema.safeParse(truncated);
278
- expect(result.success).toBe(false);
279
- });
280
-
281
- it('should reject address with only 40 hex chars (EVM length)', () => {
282
- const evmLength = '0x02a212de6a9dfa3a69e22387acfbafbb1a9e591b';
283
-
284
- const result = suiAddressSchema.safeParse(evmLength);
285
- expect(result.success).toBe(false);
286
- });
287
- });
288
-
289
- // ═══════════════════════════════════════════════════════════════════════════
290
- // Starknet Address Validation
291
- // ═══════════════════════════════════════════════════════════════════════════
292
-
293
- describe('starknetAddressSchema', () => {
294
- const validAddresses = [
295
- '0x049d36570d4e46f48e99674bd3fcc84644ddd6b96f7c741b1562b82f9e004dc7',
296
- '0x1',
297
- '0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff',
298
- ];
299
-
300
- it.each(validAddresses)('should accept valid Starknet address: %s', (address) => {
301
- const result = starknetAddressSchema.safeParse(address);
302
- expect(result.success).toBe(true);
303
- });
304
-
305
- it('should reject address without 0x prefix', () => {
306
- const invalid = '049d36570d4e46f48e99674bd3fcc84644ddd6b96f7c741b1562b82f9e004dc7';
307
-
308
- const result = starknetAddressSchema.safeParse(invalid);
309
- expect(result.success).toBe(false);
310
- });
311
-
312
- it('should reject empty hex part', () => {
313
- const invalid = '0x';
314
-
315
- const result = starknetAddressSchema.safeParse(invalid);
316
- expect(result.success).toBe(false);
317
- });
318
- });
319
-
320
- // ═══════════════════════════════════════════════════════════════════════════
321
- // Cross-chain Validation (prevent mixing)
322
- // ═══════════════════════════════════════════════════════════════════════════
323
-
324
- describe('Cross-chain address rejection', () => {
325
- const evmAddress = '0x659579F1460c38c3ce3288b47b074646cef855fc';
326
- const btcAddress = 'bc1qar0srrr7xfkvy5l643lydnw9re59gtzzwf5mdq';
327
- const solanaAddress = 'DRpbCBMxVnDK7maPGv7USy4MjEBQdCgaBExK8rKJmVZk';
328
-
329
- it('should reject Bitcoin address in EVM schema', () => {
330
- const result = evmAddressSchema.safeParse(btcAddress);
331
- expect(result.success).toBe(false);
332
- });
333
-
334
- it('should reject EVM address in Bitcoin schema', () => {
335
- const result = bitcoinAddressSchema.safeParse(evmAddress);
336
- expect(result.success).toBe(false);
337
- });
338
-
339
- it('should reject Solana address in EVM schema', () => {
340
- const result = evmAddressSchema.safeParse(solanaAddress);
341
- expect(result.success).toBe(false);
342
- });
343
-
344
- it('should reject EVM address in Solana schema', () => {
345
- const result = solanaAddressSchema.safeParse(evmAddress);
346
- expect(result.success).toBe(false);
347
- });
348
- });
349
- });
350
-