@lombard.finance/sdk 4.0.0 → 4.1.0

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 (467) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/dist/common/feature-config.d.ts.map +1 -1
  3. package/dist/index2.cjs +6 -6
  4. package/dist/index2.js +762 -754
  5. package/package.json +7 -8
  6. package/src/__tests__/AssetNamespace.spec.ts +0 -234
  7. package/src/__tests__/helpers/createTestConfig.ts +0 -90
  8. package/src/__tests__/integration/automint-fee.integration.test.ts +0 -74
  9. package/src/__tests__/integration/btc-deposit.integration.test.ts +0 -109
  10. package/src/__tests__/integration/btc-stake-and-deploy.integration.test.ts +0 -96
  11. package/src/__tests__/integration/btc-stake.integration.test.ts +0 -466
  12. package/src/__tests__/integration/evm-actions.integration.test.ts +0 -932
  13. package/src/__tests__/integration/evm-deploy.integration.test.ts +0 -122
  14. package/src/__tests__/integration/evm-redeem.integration.test.ts +0 -157
  15. package/src/__tests__/integration/faq-patterns.integration.test.ts +0 -465
  16. package/src/__tests__/integration/getLBTCMintingFee.integration.test.ts +0 -195
  17. package/src/__tests__/real-wallet/btc/btc-stake.real.test.ts +0 -70
  18. package/src/__tests__/real-wallet/evm/evm-stake.real.test.ts +0 -47
  19. package/src/__tests__/real-wallet/evm/evm-unstake.real.test.ts +0 -49
  20. package/src/__tests__/real-wallet/non-evm/solana-unstake.real.test.ts +0 -19
  21. package/src/__tests__/real-wallet/non-evm/starknet-unstake.real.test.ts +0 -19
  22. package/src/__tests__/real-wallet/non-evm/sui-unstake.real.test.ts +0 -19
  23. package/src/__tests__/services/ApiService.test.ts +0 -62
  24. package/src/__tests__/services/BtcService.test.ts +0 -30
  25. package/src/__tests__/services/EvmService.test.ts +0 -39
  26. package/src/__tests__/setup.ts +0 -16
  27. package/src/__tests__/test-utils/eip1193-adapter.ts +0 -48
  28. package/src/__tests__/test-utils/evm-wallet.ts +0 -38
  29. package/src/__tests__/test-utils/solana-wallet.ts +0 -22
  30. package/src/__tests__/test-utils/starknet-wallet.ts +0 -9
  31. package/src/__tests__/test-utils/sui-wallet.ts +0 -14
  32. package/src/__tests__/test-utils/test-constraints.ts +0 -110
  33. package/src/__tests__/unit/btc/BtcDeposit.test.ts +0 -253
  34. package/src/__tests__/unit/btc/BtcDepositAndDeploy.test.ts +0 -174
  35. package/src/__tests__/unit/btc/BtcDepositConfig.test.ts +0 -143
  36. package/src/__tests__/unit/btc/BtcDepositStatusTransition.test.ts +0 -221
  37. package/src/__tests__/unit/btc/BtcStakeAndDeploy.test.ts +0 -194
  38. package/src/__tests__/unit/btc/ExistingSignatureHandling.test.ts +0 -301
  39. package/src/__tests__/unit/btc/StakeAndBakeRatioConversion.test.ts +0 -200
  40. package/src/__tests__/unit/btc/StakeAndBakeSignatureRestore.test.ts +0 -216
  41. package/src/__tests__/unit/btc/TokenParameterConsistency.test.ts +0 -184
  42. package/src/__tests__/unit/btc/btc-deposit-token.test.ts +0 -191
  43. package/src/__tests__/unit/catalog/AssetCatalog.test.ts +0 -293
  44. package/src/__tests__/unit/config/ChainConfig.test.ts +0 -47
  45. package/src/__tests__/unit/config/FeeAuthConfig.test.ts +0 -76
  46. package/src/__tests__/unit/contract-functions/getLBTCMintingFee.test.ts +0 -128
  47. package/src/__tests__/unit/core/chain-parsing.test.ts +0 -257
  48. package/src/__tests__/unit/defi/AvailableProtocols.test.ts +0 -100
  49. package/src/__tests__/unit/defi/DefiRegistry.test.ts +0 -25
  50. package/src/__tests__/unit/evm/EvmDeploy.test.ts +0 -224
  51. package/src/__tests__/unit/evm/EvmRedeem.test.ts +0 -207
  52. package/src/__tests__/unit/evm/EvmRedeemFeeAuth.test.ts +0 -93
  53. package/src/__tests__/unit/evm/EvmStake.test.ts +0 -207
  54. package/src/__tests__/unit/evm/EvmStakeFeeAuth.test.ts +0 -193
  55. package/src/__tests__/unit/evm/EvmUnstakeAllowance.test.ts +0 -69
  56. package/src/__tests__/unit/evm/EvmUnstakeConfig.test.ts +0 -203
  57. package/src/__tests__/unit/fee-signature-expiration.test.ts +0 -76
  58. package/src/__tests__/unit/modules/CapabilityRegistry.test.ts +0 -55
  59. package/src/__tests__/unit/shared/BaseAction.test.ts +0 -122
  60. package/src/__tests__/unit/shared/BaseBtcAction.test.ts +0 -114
  61. package/src/__tests__/unit/solana/SolanaUnstake.test.ts +0 -314
  62. package/src/__tests__/unit/starknet/StarknetUnstake.test.ts +0 -318
  63. package/src/__tests__/unit/sui/SuiUnstake.test.ts +0 -310
  64. package/src/__tests__/unit/utils/satoshi.test.ts +0 -27
  65. package/src/__tests__/unit/validation/address-validation.test.ts +0 -350
  66. package/src/api-functions/generateDepositBtcAddress/generateDepositBtcAddress.stories.tsx +0 -71
  67. package/src/api-functions/generateDepositBtcAddress/generateDepositBtcAddress.ts +0 -235
  68. package/src/api-functions/generateDepositBtcAddress/index.ts +0 -1
  69. package/src/api-functions/get-badges-by-address/get-badges-by-address.ts +0 -13
  70. package/src/api-functions/get-badges-by-address/index.ts +0 -1
  71. package/src/api-functions/getDepositAddressReferrer/getDepositAddressReferrer.ts +0 -38
  72. package/src/api-functions/getDepositAddressReferrer/index.ts +0 -1
  73. package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.stories.tsx +0 -59
  74. package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.test.ts +0 -265
  75. package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.ts +0 -167
  76. package/src/api-functions/getDepositBtcAddress/getDepositBtcAddresses.stories.tsx +0 -58
  77. package/src/api-functions/getDepositBtcAddress/index.ts +0 -1
  78. package/src/api-functions/getDepositBtcAddress/make-request.ts +0 -59
  79. package/src/api-functions/getDepositBtcAddress/types.ts +0 -106
  80. package/src/api-functions/getDepositsByAddress/getDepositsByAddress.stories.tsx +0 -51
  81. package/src/api-functions/getDepositsByAddress/getDepositsByAddress.ts +0 -502
  82. package/src/api-functions/getDepositsByAddress/index.ts +0 -1
  83. package/src/api-functions/getLBTCExchangeRate/get-exchange-ratio.stories.tsx +0 -48
  84. package/src/api-functions/getLBTCExchangeRate/get-exchange-ratio.ts +0 -59
  85. package/src/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.stories.tsx +0 -55
  86. package/src/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.ts +0 -75
  87. package/src/api-functions/getLBTCExchangeRate/index.ts +0 -2
  88. package/src/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.stories.tsx +0 -59
  89. package/src/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.ts +0 -116
  90. package/src/api-functions/getNetworkFeeSignature/index.ts +0 -1
  91. package/src/api-functions/getPointsByAddress/getPointsByAddress.stories.tsx +0 -51
  92. package/src/api-functions/getPointsByAddress/getPointsByAddress.ts +0 -304
  93. package/src/api-functions/getPointsByAddress/index.ts +0 -1
  94. package/src/api-functions/getUnstakesByAddress/getUnstakesByAddress.stories.tsx +0 -51
  95. package/src/api-functions/getUnstakesByAddress/getUnstakesByAddress.ts +0 -368
  96. package/src/api-functions/getUnstakesByAddress/index.ts +0 -1
  97. package/src/api-functions/getUserStakeAndBakeSignature/getUserStakeAndBakeSignature.stories.tsx +0 -70
  98. package/src/api-functions/getUserStakeAndBakeSignature/getUserStakeAndBakeSignature.ts +0 -91
  99. package/src/api-functions/getUserStakeAndBakeSignature/index.ts +0 -1
  100. package/src/api-functions/index.ts +0 -11
  101. package/src/api-functions/setReferral/index.ts +0 -1
  102. package/src/api-functions/setReferral/setReferral.ts +0 -67
  103. package/src/api-functions/storeNetworkFeeSignature/index.ts +0 -1
  104. package/src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.stories.tsx +0 -57
  105. package/src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.ts +0 -75
  106. package/src/api-functions/storeStakeAndBakeSignature/index.ts +0 -1
  107. package/src/api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature.stories.tsx +0 -57
  108. package/src/api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature.ts +0 -61
  109. package/src/bridge/abi/CCIP_BRIDGE_ADAPTER_ABI.json +0 -704
  110. package/src/bridge/abi/CCIP_ROUTER_ABI.json +0 -702
  111. package/src/bridge/abi/OFT_BRIDGE_ADAPTER_ABI.json +0 -912
  112. package/src/bridge/index.ts +0 -16
  113. package/src/bridge/lib/bridge.stories.tsx +0 -90
  114. package/src/bridge/lib/bridge.ts +0 -115
  115. package/src/bridge/lib/ccip-bridge.stories.tsx +0 -91
  116. package/src/bridge/lib/ccip-bridge.ts +0 -214
  117. package/src/bridge/lib/ccip-config.ts +0 -54
  118. package/src/bridge/lib/config.ts +0 -384
  119. package/src/bridge/lib/oft-bridge.stories.tsx +0 -90
  120. package/src/bridge/lib/oft-bridge.ts +0 -217
  121. package/src/chains/btc/BtcActions.ts +0 -192
  122. package/src/chains/btc/actions/deposit/BtcDeposit.ts +0 -388
  123. package/src/chains/btc/actions/deposit/config/evm.ts +0 -197
  124. package/src/chains/btc/actions/deposit/config/index.ts +0 -53
  125. package/src/chains/btc/actions/deposit/config/types.ts +0 -108
  126. package/src/chains/btc/actions/deposit/factory.ts +0 -53
  127. package/src/chains/btc/actions/deposit/index.ts +0 -23
  128. package/src/chains/btc/actions/deposit/types.ts +0 -120
  129. package/src/chains/btc/actions/depositAndDeploy/BtcDepositAndDeploy.ts +0 -366
  130. package/src/chains/btc/actions/depositAndDeploy/config/evm.ts +0 -105
  131. package/src/chains/btc/actions/depositAndDeploy/config/index.ts +0 -111
  132. package/src/chains/btc/actions/depositAndDeploy/config/types.ts +0 -67
  133. package/src/chains/btc/actions/depositAndDeploy/factory.ts +0 -38
  134. package/src/chains/btc/actions/depositAndDeploy/index.ts +0 -24
  135. package/src/chains/btc/actions/depositAndDeploy/types.ts +0 -120
  136. package/src/chains/btc/actions/index.ts +0 -14
  137. package/src/chains/btc/actions/shared/BaseBtcAction.ts +0 -495
  138. package/src/chains/btc/actions/shared/index.ts +0 -28
  139. package/src/chains/btc/actions/shared/tokenUtils.ts +0 -68
  140. package/src/chains/btc/actions/shared/validation.ts +0 -180
  141. package/src/chains/btc/actions/stake/BtcStake.ts +0 -433
  142. package/src/chains/btc/actions/stake/__tests__/BtcStake.test.ts +0 -247
  143. package/src/chains/btc/actions/stake/config/evm.ts +0 -183
  144. package/src/chains/btc/actions/stake/config/index.ts +0 -122
  145. package/src/chains/btc/actions/stake/config/solana.ts +0 -96
  146. package/src/chains/btc/actions/stake/config/starknet.ts +0 -66
  147. package/src/chains/btc/actions/stake/config/sui.ts +0 -61
  148. package/src/chains/btc/actions/stake/config/types.ts +0 -165
  149. package/src/chains/btc/actions/stake/factory.ts +0 -53
  150. package/src/chains/btc/actions/stake/index.ts +0 -22
  151. package/src/chains/btc/actions/stake/types.ts +0 -175
  152. package/src/chains/btc/actions/stakeAndDeploy/BtcStakeAndDeploy.ts +0 -415
  153. package/src/chains/btc/actions/stakeAndDeploy/config/evm.ts +0 -135
  154. package/src/chains/btc/actions/stakeAndDeploy/config/index.ts +0 -119
  155. package/src/chains/btc/actions/stakeAndDeploy/config/types.ts +0 -93
  156. package/src/chains/btc/actions/stakeAndDeploy/factory.ts +0 -54
  157. package/src/chains/btc/actions/stakeAndDeploy/index.ts +0 -26
  158. package/src/chains/btc/actions/stakeAndDeploy/types.ts +0 -118
  159. package/src/chains/btc/client/getCurrentBlockHeight.ts +0 -28
  160. package/src/chains/btc/client/mempool/error.ts +0 -24
  161. package/src/chains/btc/client/mempool/mempool.ts +0 -23
  162. package/src/chains/btc/index.ts +0 -71
  163. package/src/chains/evm/EvmActions.ts +0 -185
  164. package/src/chains/evm/actions/deploy/EvmDeploy.ts +0 -256
  165. package/src/chains/evm/actions/deploy/config/evm.ts +0 -80
  166. package/src/chains/evm/actions/deploy/config/index.ts +0 -8
  167. package/src/chains/evm/actions/deploy/config/types.ts +0 -43
  168. package/src/chains/evm/actions/deploy/factory.ts +0 -44
  169. package/src/chains/evm/actions/deploy/index.ts +0 -17
  170. package/src/chains/evm/actions/deploy/types.ts +0 -74
  171. package/src/chains/evm/actions/deposit/EvmDeposit.ts +0 -159
  172. package/src/chains/evm/actions/deposit/config/evm.ts +0 -100
  173. package/src/chains/evm/actions/deposit/config/index.ts +0 -8
  174. package/src/chains/evm/actions/deposit/config/types.ts +0 -39
  175. package/src/chains/evm/actions/deposit/factory.ts +0 -44
  176. package/src/chains/evm/actions/deposit/index.ts +0 -17
  177. package/src/chains/evm/actions/deposit/types.ts +0 -87
  178. package/src/chains/evm/actions/index.ts +0 -67
  179. package/src/chains/evm/actions/redeem/EvmRedeem.ts +0 -263
  180. package/src/chains/evm/actions/redeem/config/evm.ts +0 -85
  181. package/src/chains/evm/actions/redeem/config/index.ts +0 -8
  182. package/src/chains/evm/actions/redeem/config/types.ts +0 -39
  183. package/src/chains/evm/actions/redeem/factory.ts +0 -43
  184. package/src/chains/evm/actions/redeem/index.ts +0 -17
  185. package/src/chains/evm/actions/redeem/types.ts +0 -93
  186. package/src/chains/evm/actions/stake/EvmStake.ts +0 -339
  187. package/src/chains/evm/actions/stake/config/evm.ts +0 -89
  188. package/src/chains/evm/actions/stake/config/index.ts +0 -8
  189. package/src/chains/evm/actions/stake/config/types.ts +0 -89
  190. package/src/chains/evm/actions/stake/factory.ts +0 -52
  191. package/src/chains/evm/actions/stake/index.ts +0 -30
  192. package/src/chains/evm/actions/stake/types.ts +0 -104
  193. package/src/chains/evm/actions/unstake/EvmUnstake.ts +0 -258
  194. package/src/chains/evm/actions/unstake/config/evm.ts +0 -123
  195. package/src/chains/evm/actions/unstake/config/index.ts +0 -13
  196. package/src/chains/evm/actions/unstake/config/types.ts +0 -37
  197. package/src/chains/evm/actions/unstake/factory.ts +0 -44
  198. package/src/chains/evm/actions/unstake/index.ts +0 -22
  199. package/src/chains/evm/actions/unstake/types.ts +0 -87
  200. package/src/chains/evm/index.ts +0 -16
  201. package/src/chains/evm/shared/feeAuth.ts +0 -198
  202. package/src/chains/evm/shared/index.ts +0 -7
  203. package/src/chains/solana/SolanaActions.ts +0 -85
  204. package/src/chains/solana/actions/index.ts +0 -7
  205. package/src/chains/solana/actions/unstake/SolanaUnstake.ts +0 -151
  206. package/src/chains/solana/actions/unstake/config/btc.ts +0 -47
  207. package/src/chains/solana/actions/unstake/config/index.ts +0 -8
  208. package/src/chains/solana/actions/unstake/config/solana.ts +0 -47
  209. package/src/chains/solana/actions/unstake/config/types.ts +0 -35
  210. package/src/chains/solana/actions/unstake/factory.ts +0 -34
  211. package/src/chains/solana/actions/unstake/index.ts +0 -14
  212. package/src/chains/solana/actions/unstake/types.ts +0 -58
  213. package/src/chains/solana/index.ts +0 -8
  214. package/src/chains/starknet/StarknetActions.ts +0 -85
  215. package/src/chains/starknet/actions/index.ts +0 -7
  216. package/src/chains/starknet/actions/unstake/StarknetUnstake.ts +0 -128
  217. package/src/chains/starknet/actions/unstake/config/btc.ts +0 -43
  218. package/src/chains/starknet/actions/unstake/config/index.ts +0 -8
  219. package/src/chains/starknet/actions/unstake/config/starknet.ts +0 -43
  220. package/src/chains/starknet/actions/unstake/config/types.ts +0 -27
  221. package/src/chains/starknet/actions/unstake/factory.ts +0 -32
  222. package/src/chains/starknet/actions/unstake/index.ts +0 -14
  223. package/src/chains/starknet/actions/unstake/types.ts +0 -57
  224. package/src/chains/starknet/index.ts +0 -8
  225. package/src/chains/sui/SuiActions.ts +0 -82
  226. package/src/chains/sui/actions/index.ts +0 -7
  227. package/src/chains/sui/actions/unstake/SuiUnstake.ts +0 -146
  228. package/src/chains/sui/actions/unstake/config/btc.ts +0 -43
  229. package/src/chains/sui/actions/unstake/config/index.ts +0 -8
  230. package/src/chains/sui/actions/unstake/config/sui.ts +0 -43
  231. package/src/chains/sui/actions/unstake/config/types.ts +0 -27
  232. package/src/chains/sui/actions/unstake/factory.ts +0 -32
  233. package/src/chains/sui/actions/unstake/index.ts +0 -14
  234. package/src/chains/sui/actions/unstake/types.ts +0 -57
  235. package/src/chains/sui/index.ts +0 -8
  236. package/src/client/ApiNamespace.ts +0 -302
  237. package/src/client/AssetNamespace.ts +0 -112
  238. package/src/client/LombardSDK.ts +0 -212
  239. package/src/client/PartnerConfiguration.ts +0 -50
  240. package/src/client/createConfig.ts +0 -90
  241. package/src/client/createLombardSDK.ts +0 -130
  242. package/src/clients/evm-signer-adapter.ts +0 -313
  243. package/src/clients/public-client.ts +0 -49
  244. package/src/clients/rpc-url-config.ts +0 -64
  245. package/src/clients/wallet-client.ts +0 -34
  246. package/src/common/api-config.ts +0 -48
  247. package/src/common/blockchain-identifier.ts +0 -217
  248. package/src/common/chains.stories.tsx +0 -68
  249. package/src/common/chains.ts +0 -449
  250. package/src/common/constants.ts +0 -1
  251. package/src/common/contract-info.ts +0 -9
  252. package/src/common/feature-config.ts +0 -79
  253. package/src/common/fee-requirements.ts +0 -34
  254. package/src/common/parameters.ts +0 -89
  255. package/src/config/defaults.ts +0 -49
  256. package/src/config/index.ts +0 -12
  257. package/src/config/providers.ts +0 -81
  258. package/src/config/types.ts +0 -216
  259. package/src/config/validation.ts +0 -69
  260. package/src/contract-functions/approveLBTC/approveLBTC.stories.tsx +0 -79
  261. package/src/contract-functions/approveLBTC/approveLBTC.ts +0 -66
  262. package/src/contract-functions/approveLBTC/index.ts +0 -1
  263. package/src/contract-functions/approveToken/approveToken.ts +0 -126
  264. package/src/contract-functions/approveToken/index.ts +0 -1
  265. package/src/contract-functions/claimLBTC/claimLBTC.stories.tsx +0 -82
  266. package/src/contract-functions/claimLBTC/claimLBTC.ts +0 -159
  267. package/src/contract-functions/claimLBTC/index.ts +0 -1
  268. package/src/contract-functions/claimUnstakeRedeem/claimUnstakeRedeem.ts +0 -95
  269. package/src/contract-functions/claimUnstakeRedeem/index.ts +0 -1
  270. package/src/contract-functions/deposit/depositToken.stories.tsx +0 -83
  271. package/src/contract-functions/deposit/depositToken.ts +0 -214
  272. package/src/contract-functions/deposit/index.ts +0 -1
  273. package/src/contract-functions/getBasculeDepositStatus/decodeBasculeDepositStatus.ts +0 -170
  274. package/src/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.stories.tsx +0 -62
  275. package/src/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.ts +0 -211
  276. package/src/contract-functions/getBasculeDepositStatus/index.ts +0 -2
  277. package/src/contract-functions/getLBTCMintingFee/getLBTCMintingFee.stories.tsx +0 -61
  278. package/src/contract-functions/getLBTCMintingFee/getLBTCMintingFee.ts +0 -193
  279. package/src/contract-functions/getLBTCMintingFee/index.ts +0 -1
  280. package/src/contract-functions/getLBTCTotalSupply/getLBTCTotalSupply.stories.tsx +0 -51
  281. package/src/contract-functions/getLBTCTotalSupply/getLBTCTotalSupply.ts +0 -40
  282. package/src/contract-functions/getLBTCTotalSupply/index.ts +0 -1
  283. package/src/contract-functions/getPermitNonce/getPermitNonce.stories.tsx +0 -56
  284. package/src/contract-functions/getPermitNonce/getPermitNonce.ts +0 -50
  285. package/src/contract-functions/getPermitNonce/index.ts +0 -1
  286. package/src/contract-functions/getShareValue/getShareValue.stories.tsx +0 -58
  287. package/src/contract-functions/getShareValue/getShareValue.ts +0 -59
  288. package/src/contract-functions/getShareValue/index.ts +0 -1
  289. package/src/contract-functions/getSharesByAddress/getSharesByAddress.stories.tsx +0 -65
  290. package/src/contract-functions/getSharesByAddress/getSharesByAddress.ts +0 -86
  291. package/src/contract-functions/getSharesByAddress/index.ts +0 -4
  292. package/src/contract-functions/getStakeAndBakeFee/__tests__/getStakeAndBakeFee.test.ts +0 -167
  293. package/src/contract-functions/getStakeAndBakeFee/getStakeAndBakeFee.stories.tsx +0 -180
  294. package/src/contract-functions/getStakeAndBakeFee/getStakeAndBakeFee.tsx +0 -101
  295. package/src/contract-functions/getStakeAndBakeFee/index.ts +0 -1
  296. package/src/contract-functions/index.ts +0 -21
  297. package/src/contract-functions/signLbtcDestionationAddr/index.ts +0 -1
  298. package/src/contract-functions/signLbtcDestionationAddr/signLbtcDestinationAddr.ts +0 -32
  299. package/src/contract-functions/signLbtcDestionationAddr/signLbtcDestionationAddr.stories.tsx +0 -64
  300. package/src/contract-functions/signNetworkFee/getTypedData.ts +0 -41
  301. package/src/contract-functions/signNetworkFee/index.ts +0 -1
  302. package/src/contract-functions/signNetworkFee/signNetworkFee.stories.tsx +0 -94
  303. package/src/contract-functions/signNetworkFee/signNetworkFee.ts +0 -106
  304. package/src/contract-functions/signStakeAndBake/__tests__/signStakeAndBake.test.ts +0 -888
  305. package/src/contract-functions/signStakeAndBake/handleApprove.ts +0 -81
  306. package/src/contract-functions/signStakeAndBake/handlePermit.ts +0 -28
  307. package/src/contract-functions/signStakeAndBake/index.ts +0 -2
  308. package/src/contract-functions/signStakeAndBake/signStakeAndBake.stories.tsx +0 -202
  309. package/src/contract-functions/signStakeAndBake/signStakeAndBake.ts +0 -160
  310. package/src/contract-functions/signStakeAndBake/typed-data-builder.ts +0 -137
  311. package/src/contract-functions/signStakeAndBake/utils.ts +0 -61
  312. package/src/contract-functions/signStakeAndBake/validation.ts +0 -124
  313. package/src/contract-functions/unstakeLBTC/index.ts +0 -1
  314. package/src/contract-functions/unstakeLBTC/unstakeLBTC.stories.tsx +0 -92
  315. package/src/contract-functions/unstakeLBTC/unstakeLBTC.ts +0 -396
  316. package/src/contracts/abis/index.ts +0 -29
  317. package/src/contracts/index.ts +0 -63
  318. package/src/contracts/types.ts +0 -143
  319. package/src/contracts/utils.ts +0 -288
  320. package/src/core/assets/catalog.ts +0 -343
  321. package/src/core/assets/index.ts +0 -40
  322. package/src/core/assets/types.ts +0 -142
  323. package/src/core/assets/utils.ts +0 -287
  324. package/src/core/chains/catalog.ts +0 -396
  325. package/src/core/chains/index.ts +0 -39
  326. package/src/core/chains/types.ts +0 -193
  327. package/src/core/chains/utils.ts +0 -245
  328. package/src/core/index.ts +0 -72
  329. package/src/core/types.ts +0 -126
  330. package/src/debug-api/btc-script-to-address.ts +0 -20
  331. package/src/debug-api/btc-tx-info.ts +0 -32
  332. package/src/debug-api/evm-by-btc-address.ts +0 -26
  333. package/src/debug-api/index.ts +0 -3
  334. package/src/defi/README.md +0 -517
  335. package/src/defi/defi-registry.stories.tsx +0 -527
  336. package/src/defi/defi-registry.ts +0 -295
  337. package/src/defi/index.ts +0 -17
  338. package/src/index.ts +0 -336
  339. package/src/metrics/get-additional-rewards.ts +0 -69
  340. package/src/metrics/get-lbtc-apy.ts +0 -74
  341. package/src/metrics/get-lbtc-stats.stories.tsx +0 -57
  342. package/src/metrics/get-lbtc-stats.ts +0 -59
  343. package/src/metrics/get-positions-summary.stories.tsx +0 -58
  344. package/src/metrics/get-positions-summary.ts +0 -132
  345. package/src/modules/CapabilityRegistry.ts +0 -125
  346. package/src/modules/apiModule.ts +0 -51
  347. package/src/modules/btcModule.ts +0 -43
  348. package/src/modules/evmModule.ts +0 -48
  349. package/src/modules/index.ts +0 -60
  350. package/src/referrals/ReferralsClient.ts +0 -34
  351. package/src/referrals/index.ts +0 -1
  352. package/src/services/ApiService.ts +0 -152
  353. package/src/services/BtcService.ts +0 -29
  354. package/src/services/EvmService.ts +0 -127
  355. package/src/services/index.ts +0 -43
  356. package/src/shared/__tests__/errors.test.ts +0 -185
  357. package/src/shared/__tests__/events.test.ts +0 -120
  358. package/src/shared/__tests__/types.test.ts +0 -155
  359. package/src/shared/actions/BaseAction.ts +0 -497
  360. package/src/shared/actions/__tests__/BaseAction.test.ts +0 -292
  361. package/src/shared/actions/index.ts +0 -9
  362. package/src/shared/constants/statusConstants.ts +0 -108
  363. package/src/shared/context/ContextBuilder.ts +0 -149
  364. package/src/shared/context/index.ts +0 -8
  365. package/src/shared/context/types.ts +0 -156
  366. package/src/shared/deposits/depositStatus.ts +0 -402
  367. package/src/shared/deposits/index.ts +0 -29
  368. package/src/shared/errors.ts +0 -405
  369. package/src/shared/events.ts +0 -260
  370. package/src/shared/evm/switchChain.ts +0 -109
  371. package/src/shared/index.ts +0 -54
  372. package/src/shared/monitoring/__tests__/createEventEmitter.test.ts +0 -150
  373. package/src/shared/monitoring/createEventEmitter.ts +0 -160
  374. package/src/shared/monitoring/createProgressEmitter.ts +0 -46
  375. package/src/shared/monitoring/depositMonitor.ts +0 -211
  376. package/src/shared/monitoring/index.ts +0 -25
  377. package/src/shared/validation/index.ts +0 -411
  378. package/src/stories/arg-types.ts +0 -38
  379. package/src/stories/components/Badge.tsx +0 -27
  380. package/src/stories/components/Button/Button.css +0 -10
  381. package/src/stories/components/Button/Button.tsx +0 -52
  382. package/src/stories/components/Button/index.ts +0 -1
  383. package/src/stories/components/Card.tsx +0 -18
  384. package/src/stories/components/CodeBlock/CodeBlock.tsx +0 -27
  385. package/src/stories/components/CodeBlock/CodeBlockStyles.css +0 -3
  386. package/src/stories/components/CodeBlock/index.ts +0 -1
  387. package/src/stories/components/ConnectButton/connect-button.tsx +0 -248
  388. package/src/stories/components/ConnectButton/index.ts +0 -1
  389. package/src/stories/components/JsonPreview.tsx +0 -84
  390. package/src/stories/components/Spinner/Spinner.tsx +0 -27
  391. package/src/stories/components/Spinner/index.ts +0 -1
  392. package/src/stories/components/StatsCard.tsx +0 -30
  393. package/src/stories/components/StatusIndicator.tsx +0 -37
  394. package/src/stories/components/TreeNode.tsx +0 -47
  395. package/src/stories/components/decorators/function-type.tsx +0 -63
  396. package/src/stories/components/decorators/index.ts +0 -2
  397. package/src/stories/components/decorators/wagmi-decorator.tsx +0 -92
  398. package/src/stories/components/error-block.tsx +0 -21
  399. package/src/stories/components/index.ts +0 -11
  400. package/src/stories/constants.ts +0 -3
  401. package/src/stories/hooks/useConnection.ts +0 -63
  402. package/src/stories/hooks/useQuery.ts +0 -57
  403. package/src/tokens/__tests__/token-addresses.test.ts +0 -551
  404. package/src/tokens/abi/ASSET_ROUTER_ABI.ts +0 -1966
  405. package/src/tokens/abi/BRIDGE_TOKEN_ADAPTER_ABI.ts +0 -1405
  406. package/src/tokens/abi/BTCK_ABI.ts +0 -1092
  407. package/src/tokens/abi/KATANA_BASCULE_ABI.ts +0 -653
  408. package/src/tokens/abi/LBTC_ABI.json +0 -1761
  409. package/src/tokens/abi/LBTC_ABI.ts +0 -1761
  410. package/src/tokens/abi/LBTC_BASCULE_ABI.json +0 -850
  411. package/src/tokens/abi/NATIVE_LBTC_ABI.ts +0 -1147
  412. package/src/tokens/abi/STLBTC_ABI.ts +0 -1062
  413. package/src/tokens/cross-chain-addresses.stories.tsx +0 -236
  414. package/src/tokens/denomination-utils.stories.tsx +0 -176
  415. package/src/tokens/getLbtcContractAddresses.stories.tsx +0 -158
  416. package/src/tokens/getTokenByAddress.stories.tsx +0 -172
  417. package/src/tokens/getTokenContractInfo.stories.tsx +0 -148
  418. package/src/tokens/getTokenInfo.stories.tsx +0 -133
  419. package/src/tokens/isUpgradedContract.stories.tsx +0 -124
  420. package/src/tokens/lbtc-addresses.ts +0 -18
  421. package/src/tokens/token-addresses.ts +0 -477
  422. package/src/tokens/tokens.ts +0 -249
  423. package/src/tokens/types.ts +0 -80
  424. package/src/utils/array.ts +0 -31
  425. package/src/utils/block.ts +0 -23
  426. package/src/utils/chain.ts +0 -152
  427. package/src/utils/consoleLogger.ts +0 -140
  428. package/src/utils/ensureNotSanctionedAddress.ts +0 -11
  429. package/src/utils/env.ts +0 -20
  430. package/src/utils/err.ts +0 -83
  431. package/src/utils/evmAccount.ts +0 -47
  432. package/src/utils/gas.ts +0 -36
  433. package/src/utils/hex.ts +0 -9
  434. package/src/utils/http.ts +0 -224
  435. package/src/utils/numbers.ts +0 -37
  436. package/src/utils/pagination.ts +0 -70
  437. package/src/utils/satoshi.ts +0 -41
  438. package/src/utils/time.ts +0 -12
  439. package/src/utils/transaction-executor.ts +0 -299
  440. package/src/vaults/abi/SILO_VAULT_SPENDER_ABI.json +0 -793
  441. package/src/vaults/abi/VEDA_VAULT_ABI.json +0 -452
  442. package/src/vaults/abi/VEDA_VAULT_ACCOUNTANT_ABI.json +0 -591
  443. package/src/vaults/abi/VEDA_VAULT_BASE_ASSET_ABI.json +0 -296
  444. package/src/vaults/abi/VEDA_VAULT_BORING_WITHDRAW_QUEUE_ABI.json +0 -502
  445. package/src/vaults/abi/VEDA_VAULT_LENS_ABI.json +0 -175
  446. package/src/vaults/abi/VEDA_VAULT_SPENDER_ABI.json +0 -408
  447. package/src/vaults/abi/VEDA_VAULT_TELLER_ABI.json +0 -700
  448. package/src/vaults/abi/index.ts +0 -4
  449. package/src/vaults/index.ts +0 -46
  450. package/src/vaults/lib/config.ts +0 -184
  451. package/src/vaults/lib/metrics/get-vault-apy.stories.tsx +0 -58
  452. package/src/vaults/lib/metrics/get-vault-apy.ts +0 -176
  453. package/src/vaults/lib/metrics/get-vault-points.stories.tsx +0 -60
  454. package/src/vaults/lib/metrics/get-vault-points.ts +0 -74
  455. package/src/vaults/lib/metrics/get-vault-tvl.stories.tsx +0 -58
  456. package/src/vaults/lib/metrics/get-vault-tvl.ts +0 -121
  457. package/src/vaults/lib/ops/cancel-withdraw.stories.tsx +0 -80
  458. package/src/vaults/lib/ops/deposit.stories.tsx +0 -82
  459. package/src/vaults/lib/ops/deposit.ts +0 -152
  460. package/src/vaults/lib/ops/get-vault-deposits.stories.tsx +0 -65
  461. package/src/vaults/lib/ops/get-vault-deposits.ts +0 -209
  462. package/src/vaults/lib/ops/get-vault-withdrawals.stories.tsx +0 -67
  463. package/src/vaults/lib/ops/get-vault-withdrawals.ts +0 -349
  464. package/src/vaults/lib/ops/withdraw.stories.tsx +0 -82
  465. package/src/vaults/lib/ops/withdraw.ts +0 -225
  466. package/src/version.ts +0 -56
  467. 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
-