@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.
- package/CHANGELOG.md +6 -0
- package/dist/common/feature-config.d.ts.map +1 -1
- package/dist/index2.cjs +6 -6
- package/dist/index2.js +762 -754
- package/package.json +7 -8
- package/src/__tests__/AssetNamespace.spec.ts +0 -234
- package/src/__tests__/helpers/createTestConfig.ts +0 -90
- package/src/__tests__/integration/automint-fee.integration.test.ts +0 -74
- package/src/__tests__/integration/btc-deposit.integration.test.ts +0 -109
- package/src/__tests__/integration/btc-stake-and-deploy.integration.test.ts +0 -96
- package/src/__tests__/integration/btc-stake.integration.test.ts +0 -466
- package/src/__tests__/integration/evm-actions.integration.test.ts +0 -932
- package/src/__tests__/integration/evm-deploy.integration.test.ts +0 -122
- package/src/__tests__/integration/evm-redeem.integration.test.ts +0 -157
- package/src/__tests__/integration/faq-patterns.integration.test.ts +0 -465
- package/src/__tests__/integration/getLBTCMintingFee.integration.test.ts +0 -195
- package/src/__tests__/real-wallet/btc/btc-stake.real.test.ts +0 -70
- package/src/__tests__/real-wallet/evm/evm-stake.real.test.ts +0 -47
- package/src/__tests__/real-wallet/evm/evm-unstake.real.test.ts +0 -49
- package/src/__tests__/real-wallet/non-evm/solana-unstake.real.test.ts +0 -19
- package/src/__tests__/real-wallet/non-evm/starknet-unstake.real.test.ts +0 -19
- package/src/__tests__/real-wallet/non-evm/sui-unstake.real.test.ts +0 -19
- package/src/__tests__/services/ApiService.test.ts +0 -62
- package/src/__tests__/services/BtcService.test.ts +0 -30
- package/src/__tests__/services/EvmService.test.ts +0 -39
- package/src/__tests__/setup.ts +0 -16
- package/src/__tests__/test-utils/eip1193-adapter.ts +0 -48
- package/src/__tests__/test-utils/evm-wallet.ts +0 -38
- package/src/__tests__/test-utils/solana-wallet.ts +0 -22
- package/src/__tests__/test-utils/starknet-wallet.ts +0 -9
- package/src/__tests__/test-utils/sui-wallet.ts +0 -14
- package/src/__tests__/test-utils/test-constraints.ts +0 -110
- package/src/__tests__/unit/btc/BtcDeposit.test.ts +0 -253
- package/src/__tests__/unit/btc/BtcDepositAndDeploy.test.ts +0 -174
- package/src/__tests__/unit/btc/BtcDepositConfig.test.ts +0 -143
- package/src/__tests__/unit/btc/BtcDepositStatusTransition.test.ts +0 -221
- package/src/__tests__/unit/btc/BtcStakeAndDeploy.test.ts +0 -194
- package/src/__tests__/unit/btc/ExistingSignatureHandling.test.ts +0 -301
- package/src/__tests__/unit/btc/StakeAndBakeRatioConversion.test.ts +0 -200
- package/src/__tests__/unit/btc/StakeAndBakeSignatureRestore.test.ts +0 -216
- package/src/__tests__/unit/btc/TokenParameterConsistency.test.ts +0 -184
- package/src/__tests__/unit/btc/btc-deposit-token.test.ts +0 -191
- package/src/__tests__/unit/catalog/AssetCatalog.test.ts +0 -293
- package/src/__tests__/unit/config/ChainConfig.test.ts +0 -47
- package/src/__tests__/unit/config/FeeAuthConfig.test.ts +0 -76
- package/src/__tests__/unit/contract-functions/getLBTCMintingFee.test.ts +0 -128
- package/src/__tests__/unit/core/chain-parsing.test.ts +0 -257
- package/src/__tests__/unit/defi/AvailableProtocols.test.ts +0 -100
- package/src/__tests__/unit/defi/DefiRegistry.test.ts +0 -25
- package/src/__tests__/unit/evm/EvmDeploy.test.ts +0 -224
- package/src/__tests__/unit/evm/EvmRedeem.test.ts +0 -207
- package/src/__tests__/unit/evm/EvmRedeemFeeAuth.test.ts +0 -93
- package/src/__tests__/unit/evm/EvmStake.test.ts +0 -207
- package/src/__tests__/unit/evm/EvmStakeFeeAuth.test.ts +0 -193
- package/src/__tests__/unit/evm/EvmUnstakeAllowance.test.ts +0 -69
- package/src/__tests__/unit/evm/EvmUnstakeConfig.test.ts +0 -203
- package/src/__tests__/unit/fee-signature-expiration.test.ts +0 -76
- package/src/__tests__/unit/modules/CapabilityRegistry.test.ts +0 -55
- package/src/__tests__/unit/shared/BaseAction.test.ts +0 -122
- package/src/__tests__/unit/shared/BaseBtcAction.test.ts +0 -114
- package/src/__tests__/unit/solana/SolanaUnstake.test.ts +0 -314
- package/src/__tests__/unit/starknet/StarknetUnstake.test.ts +0 -318
- package/src/__tests__/unit/sui/SuiUnstake.test.ts +0 -310
- package/src/__tests__/unit/utils/satoshi.test.ts +0 -27
- package/src/__tests__/unit/validation/address-validation.test.ts +0 -350
- package/src/api-functions/generateDepositBtcAddress/generateDepositBtcAddress.stories.tsx +0 -71
- package/src/api-functions/generateDepositBtcAddress/generateDepositBtcAddress.ts +0 -235
- package/src/api-functions/generateDepositBtcAddress/index.ts +0 -1
- package/src/api-functions/get-badges-by-address/get-badges-by-address.ts +0 -13
- package/src/api-functions/get-badges-by-address/index.ts +0 -1
- package/src/api-functions/getDepositAddressReferrer/getDepositAddressReferrer.ts +0 -38
- package/src/api-functions/getDepositAddressReferrer/index.ts +0 -1
- package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.stories.tsx +0 -59
- package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.test.ts +0 -265
- package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.ts +0 -167
- package/src/api-functions/getDepositBtcAddress/getDepositBtcAddresses.stories.tsx +0 -58
- package/src/api-functions/getDepositBtcAddress/index.ts +0 -1
- package/src/api-functions/getDepositBtcAddress/make-request.ts +0 -59
- package/src/api-functions/getDepositBtcAddress/types.ts +0 -106
- package/src/api-functions/getDepositsByAddress/getDepositsByAddress.stories.tsx +0 -51
- package/src/api-functions/getDepositsByAddress/getDepositsByAddress.ts +0 -502
- package/src/api-functions/getDepositsByAddress/index.ts +0 -1
- package/src/api-functions/getLBTCExchangeRate/get-exchange-ratio.stories.tsx +0 -48
- package/src/api-functions/getLBTCExchangeRate/get-exchange-ratio.ts +0 -59
- package/src/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.stories.tsx +0 -55
- package/src/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.ts +0 -75
- package/src/api-functions/getLBTCExchangeRate/index.ts +0 -2
- package/src/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.stories.tsx +0 -59
- package/src/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.ts +0 -116
- package/src/api-functions/getNetworkFeeSignature/index.ts +0 -1
- package/src/api-functions/getPointsByAddress/getPointsByAddress.stories.tsx +0 -51
- package/src/api-functions/getPointsByAddress/getPointsByAddress.ts +0 -304
- package/src/api-functions/getPointsByAddress/index.ts +0 -1
- package/src/api-functions/getUnstakesByAddress/getUnstakesByAddress.stories.tsx +0 -51
- package/src/api-functions/getUnstakesByAddress/getUnstakesByAddress.ts +0 -368
- package/src/api-functions/getUnstakesByAddress/index.ts +0 -1
- package/src/api-functions/getUserStakeAndBakeSignature/getUserStakeAndBakeSignature.stories.tsx +0 -70
- package/src/api-functions/getUserStakeAndBakeSignature/getUserStakeAndBakeSignature.ts +0 -91
- package/src/api-functions/getUserStakeAndBakeSignature/index.ts +0 -1
- package/src/api-functions/index.ts +0 -11
- package/src/api-functions/setReferral/index.ts +0 -1
- package/src/api-functions/setReferral/setReferral.ts +0 -67
- package/src/api-functions/storeNetworkFeeSignature/index.ts +0 -1
- package/src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.stories.tsx +0 -57
- package/src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.ts +0 -75
- package/src/api-functions/storeStakeAndBakeSignature/index.ts +0 -1
- package/src/api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature.stories.tsx +0 -57
- package/src/api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature.ts +0 -61
- package/src/bridge/abi/CCIP_BRIDGE_ADAPTER_ABI.json +0 -704
- package/src/bridge/abi/CCIP_ROUTER_ABI.json +0 -702
- package/src/bridge/abi/OFT_BRIDGE_ADAPTER_ABI.json +0 -912
- package/src/bridge/index.ts +0 -16
- package/src/bridge/lib/bridge.stories.tsx +0 -90
- package/src/bridge/lib/bridge.ts +0 -115
- package/src/bridge/lib/ccip-bridge.stories.tsx +0 -91
- package/src/bridge/lib/ccip-bridge.ts +0 -214
- package/src/bridge/lib/ccip-config.ts +0 -54
- package/src/bridge/lib/config.ts +0 -384
- package/src/bridge/lib/oft-bridge.stories.tsx +0 -90
- package/src/bridge/lib/oft-bridge.ts +0 -217
- package/src/chains/btc/BtcActions.ts +0 -192
- package/src/chains/btc/actions/deposit/BtcDeposit.ts +0 -388
- package/src/chains/btc/actions/deposit/config/evm.ts +0 -197
- package/src/chains/btc/actions/deposit/config/index.ts +0 -53
- package/src/chains/btc/actions/deposit/config/types.ts +0 -108
- package/src/chains/btc/actions/deposit/factory.ts +0 -53
- package/src/chains/btc/actions/deposit/index.ts +0 -23
- package/src/chains/btc/actions/deposit/types.ts +0 -120
- package/src/chains/btc/actions/depositAndDeploy/BtcDepositAndDeploy.ts +0 -366
- package/src/chains/btc/actions/depositAndDeploy/config/evm.ts +0 -105
- package/src/chains/btc/actions/depositAndDeploy/config/index.ts +0 -111
- package/src/chains/btc/actions/depositAndDeploy/config/types.ts +0 -67
- package/src/chains/btc/actions/depositAndDeploy/factory.ts +0 -38
- package/src/chains/btc/actions/depositAndDeploy/index.ts +0 -24
- package/src/chains/btc/actions/depositAndDeploy/types.ts +0 -120
- package/src/chains/btc/actions/index.ts +0 -14
- package/src/chains/btc/actions/shared/BaseBtcAction.ts +0 -495
- package/src/chains/btc/actions/shared/index.ts +0 -28
- package/src/chains/btc/actions/shared/tokenUtils.ts +0 -68
- package/src/chains/btc/actions/shared/validation.ts +0 -180
- package/src/chains/btc/actions/stake/BtcStake.ts +0 -433
- package/src/chains/btc/actions/stake/__tests__/BtcStake.test.ts +0 -247
- package/src/chains/btc/actions/stake/config/evm.ts +0 -183
- package/src/chains/btc/actions/stake/config/index.ts +0 -122
- package/src/chains/btc/actions/stake/config/solana.ts +0 -96
- package/src/chains/btc/actions/stake/config/starknet.ts +0 -66
- package/src/chains/btc/actions/stake/config/sui.ts +0 -61
- package/src/chains/btc/actions/stake/config/types.ts +0 -165
- package/src/chains/btc/actions/stake/factory.ts +0 -53
- package/src/chains/btc/actions/stake/index.ts +0 -22
- package/src/chains/btc/actions/stake/types.ts +0 -175
- package/src/chains/btc/actions/stakeAndDeploy/BtcStakeAndDeploy.ts +0 -415
- package/src/chains/btc/actions/stakeAndDeploy/config/evm.ts +0 -135
- package/src/chains/btc/actions/stakeAndDeploy/config/index.ts +0 -119
- package/src/chains/btc/actions/stakeAndDeploy/config/types.ts +0 -93
- package/src/chains/btc/actions/stakeAndDeploy/factory.ts +0 -54
- package/src/chains/btc/actions/stakeAndDeploy/index.ts +0 -26
- package/src/chains/btc/actions/stakeAndDeploy/types.ts +0 -118
- package/src/chains/btc/client/getCurrentBlockHeight.ts +0 -28
- package/src/chains/btc/client/mempool/error.ts +0 -24
- package/src/chains/btc/client/mempool/mempool.ts +0 -23
- package/src/chains/btc/index.ts +0 -71
- package/src/chains/evm/EvmActions.ts +0 -185
- package/src/chains/evm/actions/deploy/EvmDeploy.ts +0 -256
- package/src/chains/evm/actions/deploy/config/evm.ts +0 -80
- package/src/chains/evm/actions/deploy/config/index.ts +0 -8
- package/src/chains/evm/actions/deploy/config/types.ts +0 -43
- package/src/chains/evm/actions/deploy/factory.ts +0 -44
- package/src/chains/evm/actions/deploy/index.ts +0 -17
- package/src/chains/evm/actions/deploy/types.ts +0 -74
- package/src/chains/evm/actions/deposit/EvmDeposit.ts +0 -159
- package/src/chains/evm/actions/deposit/config/evm.ts +0 -100
- package/src/chains/evm/actions/deposit/config/index.ts +0 -8
- package/src/chains/evm/actions/deposit/config/types.ts +0 -39
- package/src/chains/evm/actions/deposit/factory.ts +0 -44
- package/src/chains/evm/actions/deposit/index.ts +0 -17
- package/src/chains/evm/actions/deposit/types.ts +0 -87
- package/src/chains/evm/actions/index.ts +0 -67
- package/src/chains/evm/actions/redeem/EvmRedeem.ts +0 -263
- package/src/chains/evm/actions/redeem/config/evm.ts +0 -85
- package/src/chains/evm/actions/redeem/config/index.ts +0 -8
- package/src/chains/evm/actions/redeem/config/types.ts +0 -39
- package/src/chains/evm/actions/redeem/factory.ts +0 -43
- package/src/chains/evm/actions/redeem/index.ts +0 -17
- package/src/chains/evm/actions/redeem/types.ts +0 -93
- package/src/chains/evm/actions/stake/EvmStake.ts +0 -339
- package/src/chains/evm/actions/stake/config/evm.ts +0 -89
- package/src/chains/evm/actions/stake/config/index.ts +0 -8
- package/src/chains/evm/actions/stake/config/types.ts +0 -89
- package/src/chains/evm/actions/stake/factory.ts +0 -52
- package/src/chains/evm/actions/stake/index.ts +0 -30
- package/src/chains/evm/actions/stake/types.ts +0 -104
- package/src/chains/evm/actions/unstake/EvmUnstake.ts +0 -258
- package/src/chains/evm/actions/unstake/config/evm.ts +0 -123
- package/src/chains/evm/actions/unstake/config/index.ts +0 -13
- package/src/chains/evm/actions/unstake/config/types.ts +0 -37
- package/src/chains/evm/actions/unstake/factory.ts +0 -44
- package/src/chains/evm/actions/unstake/index.ts +0 -22
- package/src/chains/evm/actions/unstake/types.ts +0 -87
- package/src/chains/evm/index.ts +0 -16
- package/src/chains/evm/shared/feeAuth.ts +0 -198
- package/src/chains/evm/shared/index.ts +0 -7
- package/src/chains/solana/SolanaActions.ts +0 -85
- package/src/chains/solana/actions/index.ts +0 -7
- package/src/chains/solana/actions/unstake/SolanaUnstake.ts +0 -151
- package/src/chains/solana/actions/unstake/config/btc.ts +0 -47
- package/src/chains/solana/actions/unstake/config/index.ts +0 -8
- package/src/chains/solana/actions/unstake/config/solana.ts +0 -47
- package/src/chains/solana/actions/unstake/config/types.ts +0 -35
- package/src/chains/solana/actions/unstake/factory.ts +0 -34
- package/src/chains/solana/actions/unstake/index.ts +0 -14
- package/src/chains/solana/actions/unstake/types.ts +0 -58
- package/src/chains/solana/index.ts +0 -8
- package/src/chains/starknet/StarknetActions.ts +0 -85
- package/src/chains/starknet/actions/index.ts +0 -7
- package/src/chains/starknet/actions/unstake/StarknetUnstake.ts +0 -128
- package/src/chains/starknet/actions/unstake/config/btc.ts +0 -43
- package/src/chains/starknet/actions/unstake/config/index.ts +0 -8
- package/src/chains/starknet/actions/unstake/config/starknet.ts +0 -43
- package/src/chains/starknet/actions/unstake/config/types.ts +0 -27
- package/src/chains/starknet/actions/unstake/factory.ts +0 -32
- package/src/chains/starknet/actions/unstake/index.ts +0 -14
- package/src/chains/starknet/actions/unstake/types.ts +0 -57
- package/src/chains/starknet/index.ts +0 -8
- package/src/chains/sui/SuiActions.ts +0 -82
- package/src/chains/sui/actions/index.ts +0 -7
- package/src/chains/sui/actions/unstake/SuiUnstake.ts +0 -146
- package/src/chains/sui/actions/unstake/config/btc.ts +0 -43
- package/src/chains/sui/actions/unstake/config/index.ts +0 -8
- package/src/chains/sui/actions/unstake/config/sui.ts +0 -43
- package/src/chains/sui/actions/unstake/config/types.ts +0 -27
- package/src/chains/sui/actions/unstake/factory.ts +0 -32
- package/src/chains/sui/actions/unstake/index.ts +0 -14
- package/src/chains/sui/actions/unstake/types.ts +0 -57
- package/src/chains/sui/index.ts +0 -8
- package/src/client/ApiNamespace.ts +0 -302
- package/src/client/AssetNamespace.ts +0 -112
- package/src/client/LombardSDK.ts +0 -212
- package/src/client/PartnerConfiguration.ts +0 -50
- package/src/client/createConfig.ts +0 -90
- package/src/client/createLombardSDK.ts +0 -130
- package/src/clients/evm-signer-adapter.ts +0 -313
- package/src/clients/public-client.ts +0 -49
- package/src/clients/rpc-url-config.ts +0 -64
- package/src/clients/wallet-client.ts +0 -34
- package/src/common/api-config.ts +0 -48
- package/src/common/blockchain-identifier.ts +0 -217
- package/src/common/chains.stories.tsx +0 -68
- package/src/common/chains.ts +0 -449
- package/src/common/constants.ts +0 -1
- package/src/common/contract-info.ts +0 -9
- package/src/common/feature-config.ts +0 -79
- package/src/common/fee-requirements.ts +0 -34
- package/src/common/parameters.ts +0 -89
- package/src/config/defaults.ts +0 -49
- package/src/config/index.ts +0 -12
- package/src/config/providers.ts +0 -81
- package/src/config/types.ts +0 -216
- package/src/config/validation.ts +0 -69
- package/src/contract-functions/approveLBTC/approveLBTC.stories.tsx +0 -79
- package/src/contract-functions/approveLBTC/approveLBTC.ts +0 -66
- package/src/contract-functions/approveLBTC/index.ts +0 -1
- package/src/contract-functions/approveToken/approveToken.ts +0 -126
- package/src/contract-functions/approveToken/index.ts +0 -1
- package/src/contract-functions/claimLBTC/claimLBTC.stories.tsx +0 -82
- package/src/contract-functions/claimLBTC/claimLBTC.ts +0 -159
- package/src/contract-functions/claimLBTC/index.ts +0 -1
- package/src/contract-functions/claimUnstakeRedeem/claimUnstakeRedeem.ts +0 -95
- package/src/contract-functions/claimUnstakeRedeem/index.ts +0 -1
- package/src/contract-functions/deposit/depositToken.stories.tsx +0 -83
- package/src/contract-functions/deposit/depositToken.ts +0 -214
- package/src/contract-functions/deposit/index.ts +0 -1
- package/src/contract-functions/getBasculeDepositStatus/decodeBasculeDepositStatus.ts +0 -170
- package/src/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.stories.tsx +0 -62
- package/src/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.ts +0 -211
- package/src/contract-functions/getBasculeDepositStatus/index.ts +0 -2
- package/src/contract-functions/getLBTCMintingFee/getLBTCMintingFee.stories.tsx +0 -61
- package/src/contract-functions/getLBTCMintingFee/getLBTCMintingFee.ts +0 -193
- package/src/contract-functions/getLBTCMintingFee/index.ts +0 -1
- package/src/contract-functions/getLBTCTotalSupply/getLBTCTotalSupply.stories.tsx +0 -51
- package/src/contract-functions/getLBTCTotalSupply/getLBTCTotalSupply.ts +0 -40
- package/src/contract-functions/getLBTCTotalSupply/index.ts +0 -1
- package/src/contract-functions/getPermitNonce/getPermitNonce.stories.tsx +0 -56
- package/src/contract-functions/getPermitNonce/getPermitNonce.ts +0 -50
- package/src/contract-functions/getPermitNonce/index.ts +0 -1
- package/src/contract-functions/getShareValue/getShareValue.stories.tsx +0 -58
- package/src/contract-functions/getShareValue/getShareValue.ts +0 -59
- package/src/contract-functions/getShareValue/index.ts +0 -1
- package/src/contract-functions/getSharesByAddress/getSharesByAddress.stories.tsx +0 -65
- package/src/contract-functions/getSharesByAddress/getSharesByAddress.ts +0 -86
- package/src/contract-functions/getSharesByAddress/index.ts +0 -4
- package/src/contract-functions/getStakeAndBakeFee/__tests__/getStakeAndBakeFee.test.ts +0 -167
- package/src/contract-functions/getStakeAndBakeFee/getStakeAndBakeFee.stories.tsx +0 -180
- package/src/contract-functions/getStakeAndBakeFee/getStakeAndBakeFee.tsx +0 -101
- package/src/contract-functions/getStakeAndBakeFee/index.ts +0 -1
- package/src/contract-functions/index.ts +0 -21
- package/src/contract-functions/signLbtcDestionationAddr/index.ts +0 -1
- package/src/contract-functions/signLbtcDestionationAddr/signLbtcDestinationAddr.ts +0 -32
- package/src/contract-functions/signLbtcDestionationAddr/signLbtcDestionationAddr.stories.tsx +0 -64
- package/src/contract-functions/signNetworkFee/getTypedData.ts +0 -41
- package/src/contract-functions/signNetworkFee/index.ts +0 -1
- package/src/contract-functions/signNetworkFee/signNetworkFee.stories.tsx +0 -94
- package/src/contract-functions/signNetworkFee/signNetworkFee.ts +0 -106
- package/src/contract-functions/signStakeAndBake/__tests__/signStakeAndBake.test.ts +0 -888
- package/src/contract-functions/signStakeAndBake/handleApprove.ts +0 -81
- package/src/contract-functions/signStakeAndBake/handlePermit.ts +0 -28
- package/src/contract-functions/signStakeAndBake/index.ts +0 -2
- package/src/contract-functions/signStakeAndBake/signStakeAndBake.stories.tsx +0 -202
- package/src/contract-functions/signStakeAndBake/signStakeAndBake.ts +0 -160
- package/src/contract-functions/signStakeAndBake/typed-data-builder.ts +0 -137
- package/src/contract-functions/signStakeAndBake/utils.ts +0 -61
- package/src/contract-functions/signStakeAndBake/validation.ts +0 -124
- package/src/contract-functions/unstakeLBTC/index.ts +0 -1
- package/src/contract-functions/unstakeLBTC/unstakeLBTC.stories.tsx +0 -92
- package/src/contract-functions/unstakeLBTC/unstakeLBTC.ts +0 -396
- package/src/contracts/abis/index.ts +0 -29
- package/src/contracts/index.ts +0 -63
- package/src/contracts/types.ts +0 -143
- package/src/contracts/utils.ts +0 -288
- package/src/core/assets/catalog.ts +0 -343
- package/src/core/assets/index.ts +0 -40
- package/src/core/assets/types.ts +0 -142
- package/src/core/assets/utils.ts +0 -287
- package/src/core/chains/catalog.ts +0 -396
- package/src/core/chains/index.ts +0 -39
- package/src/core/chains/types.ts +0 -193
- package/src/core/chains/utils.ts +0 -245
- package/src/core/index.ts +0 -72
- package/src/core/types.ts +0 -126
- package/src/debug-api/btc-script-to-address.ts +0 -20
- package/src/debug-api/btc-tx-info.ts +0 -32
- package/src/debug-api/evm-by-btc-address.ts +0 -26
- package/src/debug-api/index.ts +0 -3
- package/src/defi/README.md +0 -517
- package/src/defi/defi-registry.stories.tsx +0 -527
- package/src/defi/defi-registry.ts +0 -295
- package/src/defi/index.ts +0 -17
- package/src/index.ts +0 -336
- package/src/metrics/get-additional-rewards.ts +0 -69
- package/src/metrics/get-lbtc-apy.ts +0 -74
- package/src/metrics/get-lbtc-stats.stories.tsx +0 -57
- package/src/metrics/get-lbtc-stats.ts +0 -59
- package/src/metrics/get-positions-summary.stories.tsx +0 -58
- package/src/metrics/get-positions-summary.ts +0 -132
- package/src/modules/CapabilityRegistry.ts +0 -125
- package/src/modules/apiModule.ts +0 -51
- package/src/modules/btcModule.ts +0 -43
- package/src/modules/evmModule.ts +0 -48
- package/src/modules/index.ts +0 -60
- package/src/referrals/ReferralsClient.ts +0 -34
- package/src/referrals/index.ts +0 -1
- package/src/services/ApiService.ts +0 -152
- package/src/services/BtcService.ts +0 -29
- package/src/services/EvmService.ts +0 -127
- package/src/services/index.ts +0 -43
- package/src/shared/__tests__/errors.test.ts +0 -185
- package/src/shared/__tests__/events.test.ts +0 -120
- package/src/shared/__tests__/types.test.ts +0 -155
- package/src/shared/actions/BaseAction.ts +0 -497
- package/src/shared/actions/__tests__/BaseAction.test.ts +0 -292
- package/src/shared/actions/index.ts +0 -9
- package/src/shared/constants/statusConstants.ts +0 -108
- package/src/shared/context/ContextBuilder.ts +0 -149
- package/src/shared/context/index.ts +0 -8
- package/src/shared/context/types.ts +0 -156
- package/src/shared/deposits/depositStatus.ts +0 -402
- package/src/shared/deposits/index.ts +0 -29
- package/src/shared/errors.ts +0 -405
- package/src/shared/events.ts +0 -260
- package/src/shared/evm/switchChain.ts +0 -109
- package/src/shared/index.ts +0 -54
- package/src/shared/monitoring/__tests__/createEventEmitter.test.ts +0 -150
- package/src/shared/monitoring/createEventEmitter.ts +0 -160
- package/src/shared/monitoring/createProgressEmitter.ts +0 -46
- package/src/shared/monitoring/depositMonitor.ts +0 -211
- package/src/shared/monitoring/index.ts +0 -25
- package/src/shared/validation/index.ts +0 -411
- package/src/stories/arg-types.ts +0 -38
- package/src/stories/components/Badge.tsx +0 -27
- package/src/stories/components/Button/Button.css +0 -10
- package/src/stories/components/Button/Button.tsx +0 -52
- package/src/stories/components/Button/index.ts +0 -1
- package/src/stories/components/Card.tsx +0 -18
- package/src/stories/components/CodeBlock/CodeBlock.tsx +0 -27
- package/src/stories/components/CodeBlock/CodeBlockStyles.css +0 -3
- package/src/stories/components/CodeBlock/index.ts +0 -1
- package/src/stories/components/ConnectButton/connect-button.tsx +0 -248
- package/src/stories/components/ConnectButton/index.ts +0 -1
- package/src/stories/components/JsonPreview.tsx +0 -84
- package/src/stories/components/Spinner/Spinner.tsx +0 -27
- package/src/stories/components/Spinner/index.ts +0 -1
- package/src/stories/components/StatsCard.tsx +0 -30
- package/src/stories/components/StatusIndicator.tsx +0 -37
- package/src/stories/components/TreeNode.tsx +0 -47
- package/src/stories/components/decorators/function-type.tsx +0 -63
- package/src/stories/components/decorators/index.ts +0 -2
- package/src/stories/components/decorators/wagmi-decorator.tsx +0 -92
- package/src/stories/components/error-block.tsx +0 -21
- package/src/stories/components/index.ts +0 -11
- package/src/stories/constants.ts +0 -3
- package/src/stories/hooks/useConnection.ts +0 -63
- package/src/stories/hooks/useQuery.ts +0 -57
- package/src/tokens/__tests__/token-addresses.test.ts +0 -551
- package/src/tokens/abi/ASSET_ROUTER_ABI.ts +0 -1966
- package/src/tokens/abi/BRIDGE_TOKEN_ADAPTER_ABI.ts +0 -1405
- package/src/tokens/abi/BTCK_ABI.ts +0 -1092
- package/src/tokens/abi/KATANA_BASCULE_ABI.ts +0 -653
- package/src/tokens/abi/LBTC_ABI.json +0 -1761
- package/src/tokens/abi/LBTC_ABI.ts +0 -1761
- package/src/tokens/abi/LBTC_BASCULE_ABI.json +0 -850
- package/src/tokens/abi/NATIVE_LBTC_ABI.ts +0 -1147
- package/src/tokens/abi/STLBTC_ABI.ts +0 -1062
- package/src/tokens/cross-chain-addresses.stories.tsx +0 -236
- package/src/tokens/denomination-utils.stories.tsx +0 -176
- package/src/tokens/getLbtcContractAddresses.stories.tsx +0 -158
- package/src/tokens/getTokenByAddress.stories.tsx +0 -172
- package/src/tokens/getTokenContractInfo.stories.tsx +0 -148
- package/src/tokens/getTokenInfo.stories.tsx +0 -133
- package/src/tokens/isUpgradedContract.stories.tsx +0 -124
- package/src/tokens/lbtc-addresses.ts +0 -18
- package/src/tokens/token-addresses.ts +0 -477
- package/src/tokens/tokens.ts +0 -249
- package/src/tokens/types.ts +0 -80
- package/src/utils/array.ts +0 -31
- package/src/utils/block.ts +0 -23
- package/src/utils/chain.ts +0 -152
- package/src/utils/consoleLogger.ts +0 -140
- package/src/utils/ensureNotSanctionedAddress.ts +0 -11
- package/src/utils/env.ts +0 -20
- package/src/utils/err.ts +0 -83
- package/src/utils/evmAccount.ts +0 -47
- package/src/utils/gas.ts +0 -36
- package/src/utils/hex.ts +0 -9
- package/src/utils/http.ts +0 -224
- package/src/utils/numbers.ts +0 -37
- package/src/utils/pagination.ts +0 -70
- package/src/utils/satoshi.ts +0 -41
- package/src/utils/time.ts +0 -12
- package/src/utils/transaction-executor.ts +0 -299
- package/src/vaults/abi/SILO_VAULT_SPENDER_ABI.json +0 -793
- package/src/vaults/abi/VEDA_VAULT_ABI.json +0 -452
- package/src/vaults/abi/VEDA_VAULT_ACCOUNTANT_ABI.json +0 -591
- package/src/vaults/abi/VEDA_VAULT_BASE_ASSET_ABI.json +0 -296
- package/src/vaults/abi/VEDA_VAULT_BORING_WITHDRAW_QUEUE_ABI.json +0 -502
- package/src/vaults/abi/VEDA_VAULT_LENS_ABI.json +0 -175
- package/src/vaults/abi/VEDA_VAULT_SPENDER_ABI.json +0 -408
- package/src/vaults/abi/VEDA_VAULT_TELLER_ABI.json +0 -700
- package/src/vaults/abi/index.ts +0 -4
- package/src/vaults/index.ts +0 -46
- package/src/vaults/lib/config.ts +0 -184
- package/src/vaults/lib/metrics/get-vault-apy.stories.tsx +0 -58
- package/src/vaults/lib/metrics/get-vault-apy.ts +0 -176
- package/src/vaults/lib/metrics/get-vault-points.stories.tsx +0 -60
- package/src/vaults/lib/metrics/get-vault-points.ts +0 -74
- package/src/vaults/lib/metrics/get-vault-tvl.stories.tsx +0 -58
- package/src/vaults/lib/metrics/get-vault-tvl.ts +0 -121
- package/src/vaults/lib/ops/cancel-withdraw.stories.tsx +0 -80
- package/src/vaults/lib/ops/deposit.stories.tsx +0 -82
- package/src/vaults/lib/ops/deposit.ts +0 -152
- package/src/vaults/lib/ops/get-vault-deposits.stories.tsx +0 -65
- package/src/vaults/lib/ops/get-vault-deposits.ts +0 -209
- package/src/vaults/lib/ops/get-vault-withdrawals.stories.tsx +0 -67
- package/src/vaults/lib/ops/get-vault-withdrawals.ts +0 -349
- package/src/vaults/lib/ops/withdraw.stories.tsx +0 -82
- package/src/vaults/lib/ops/withdraw.ts +0 -225
- package/src/version.ts +0 -56
- 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
|
-
|