@lombard.finance/sdk 3.7.4 → 4.0.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 +46 -0
- package/README.md +102 -698
- package/dist/api-functions/getDepositAddressReferrer/getDepositAddressReferrer.d.ts +15 -0
- package/dist/api-functions/getDepositAddressReferrer/getDepositAddressReferrer.d.ts.map +1 -0
- package/dist/api-functions/getDepositAddressReferrer/index.d.ts +2 -0
- package/dist/api-functions/getDepositAddressReferrer/index.d.ts.map +1 -0
- package/dist/api-functions/getDepositBtcAddress/getDepositBtcAddress.d.ts +1 -1
- package/dist/api-functions/getDepositBtcAddress/getDepositBtcAddress.d.ts.map +1 -1
- package/dist/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.d.ts +3 -0
- package/dist/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.d.ts.map +1 -1
- package/dist/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.d.ts +8 -0
- package/dist/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.d.ts.map +1 -1
- package/dist/api-functions/setReferral/setReferral.d.ts +5 -1
- package/dist/api-functions/setReferral/setReferral.d.ts.map +1 -1
- package/dist/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.d.ts +5 -1
- package/dist/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.d.ts.map +1 -1
- package/dist/bridge/lib/config.d.ts +5 -5
- package/dist/chains/btc/BtcActions.d.ts +155 -0
- package/dist/chains/btc/BtcActions.d.ts.map +1 -0
- package/dist/chains/btc/actions/deposit/BtcDeposit.d.ts +83 -0
- package/dist/chains/btc/actions/deposit/BtcDeposit.d.ts.map +1 -0
- package/dist/chains/btc/actions/deposit/config/evm.d.ts +22 -0
- package/dist/chains/btc/actions/deposit/config/evm.d.ts.map +1 -0
- package/dist/chains/btc/actions/deposit/config/index.d.ts +27 -0
- package/dist/chains/btc/actions/deposit/config/index.d.ts.map +1 -0
- package/dist/chains/btc/actions/deposit/config/types.d.ts +90 -0
- package/dist/chains/btc/actions/deposit/config/types.d.ts.map +1 -0
- package/dist/chains/btc/actions/deposit/factory.d.ts +39 -0
- package/dist/chains/btc/actions/deposit/factory.d.ts.map +1 -0
- package/dist/chains/btc/actions/deposit/index.d.ts +11 -0
- package/dist/chains/btc/actions/deposit/index.d.ts.map +1 -0
- package/dist/chains/btc/actions/deposit/types.d.ts +94 -0
- package/dist/chains/btc/actions/deposit/types.d.ts.map +1 -0
- package/dist/chains/btc/actions/depositAndDeploy/BtcDepositAndDeploy.d.ts +69 -0
- package/dist/chains/btc/actions/depositAndDeploy/BtcDepositAndDeploy.d.ts.map +1 -0
- package/dist/chains/btc/actions/depositAndDeploy/config/evm.d.ts +19 -0
- package/dist/chains/btc/actions/depositAndDeploy/config/evm.d.ts.map +1 -0
- package/dist/chains/btc/actions/depositAndDeploy/config/index.d.ts +54 -0
- package/dist/chains/btc/actions/depositAndDeploy/config/index.d.ts.map +1 -0
- package/dist/chains/btc/actions/depositAndDeploy/config/types.d.ts +54 -0
- package/dist/chains/btc/actions/depositAndDeploy/config/types.d.ts.map +1 -0
- package/dist/chains/btc/actions/depositAndDeploy/factory.d.ts +32 -0
- package/dist/chains/btc/actions/depositAndDeploy/factory.d.ts.map +1 -0
- package/dist/chains/btc/actions/depositAndDeploy/index.d.ts +12 -0
- package/dist/chains/btc/actions/depositAndDeploy/index.d.ts.map +1 -0
- package/dist/chains/btc/actions/depositAndDeploy/types.d.ts +93 -0
- package/dist/chains/btc/actions/depositAndDeploy/types.d.ts.map +1 -0
- package/dist/chains/btc/actions/index.d.ts +9 -0
- package/dist/chains/btc/actions/index.d.ts.map +1 -0
- package/dist/chains/btc/actions/shared/BaseBtcAction.d.ts +201 -0
- package/dist/chains/btc/actions/shared/BaseBtcAction.d.ts.map +1 -0
- package/dist/chains/btc/actions/shared/index.d.ts +13 -0
- package/dist/chains/btc/actions/shared/index.d.ts.map +1 -0
- package/dist/chains/btc/actions/shared/tokenUtils.d.ts +54 -0
- package/dist/chains/btc/actions/shared/tokenUtils.d.ts.map +1 -0
- package/dist/chains/btc/actions/shared/validation.d.ts +90 -0
- package/dist/chains/btc/actions/shared/validation.d.ts.map +1 -0
- package/dist/chains/btc/actions/stake/BtcStake.d.ts +82 -0
- package/dist/chains/btc/actions/stake/BtcStake.d.ts.map +1 -0
- package/dist/chains/btc/actions/stake/config/evm.d.ts +20 -0
- package/dist/chains/btc/actions/stake/config/evm.d.ts.map +1 -0
- package/dist/chains/btc/actions/stake/config/index.d.ts +63 -0
- package/dist/chains/btc/actions/stake/config/index.d.ts.map +1 -0
- package/dist/chains/btc/actions/stake/config/solana.d.ts +20 -0
- package/dist/chains/btc/actions/stake/config/solana.d.ts.map +1 -0
- package/dist/chains/btc/actions/stake/config/starknet.d.ts +21 -0
- package/dist/chains/btc/actions/stake/config/starknet.d.ts.map +1 -0
- package/dist/chains/btc/actions/stake/config/sui.d.ts +20 -0
- package/dist/chains/btc/actions/stake/config/sui.d.ts.map +1 -0
- package/dist/chains/btc/actions/stake/config/types.d.ts +127 -0
- package/dist/chains/btc/actions/stake/config/types.d.ts.map +1 -0
- package/dist/chains/btc/actions/stake/factory.d.ts +39 -0
- package/dist/chains/btc/actions/stake/factory.d.ts.map +1 -0
- package/dist/chains/btc/actions/stake/index.d.ts +11 -0
- package/dist/chains/btc/actions/stake/index.d.ts.map +1 -0
- package/dist/chains/btc/actions/stake/types.d.ts +152 -0
- package/dist/chains/btc/actions/stake/types.d.ts.map +1 -0
- package/dist/chains/btc/actions/stakeAndDeploy/BtcStakeAndDeploy.d.ts +68 -0
- package/dist/chains/btc/actions/stakeAndDeploy/BtcStakeAndDeploy.d.ts.map +1 -0
- package/dist/chains/btc/actions/stakeAndDeploy/config/evm.d.ts +19 -0
- package/dist/chains/btc/actions/stakeAndDeploy/config/evm.d.ts.map +1 -0
- package/dist/chains/btc/actions/stakeAndDeploy/config/index.d.ts +54 -0
- package/dist/chains/btc/actions/stakeAndDeploy/config/index.d.ts.map +1 -0
- package/dist/chains/btc/actions/stakeAndDeploy/config/types.d.ts +74 -0
- package/dist/chains/btc/actions/stakeAndDeploy/config/types.d.ts.map +1 -0
- package/dist/chains/btc/actions/stakeAndDeploy/factory.d.ts +40 -0
- package/dist/chains/btc/actions/stakeAndDeploy/factory.d.ts.map +1 -0
- package/dist/chains/btc/actions/stakeAndDeploy/index.d.ts +11 -0
- package/dist/chains/btc/actions/stakeAndDeploy/index.d.ts.map +1 -0
- package/dist/chains/btc/actions/stakeAndDeploy/types.d.ts +91 -0
- package/dist/chains/btc/actions/stakeAndDeploy/types.d.ts.map +1 -0
- package/dist/chains/btc/client/getCurrentBlockHeight.d.ts +6 -0
- package/dist/chains/btc/client/getCurrentBlockHeight.d.ts.map +1 -0
- package/dist/chains/btc/client/mempool/error.d.ts +10 -0
- package/dist/chains/btc/client/mempool/error.d.ts.map +1 -0
- package/dist/chains/btc/client/mempool/mempool.d.ts +14 -0
- package/dist/chains/btc/client/mempool/mempool.d.ts.map +1 -0
- package/dist/chains/btc/index.d.ts +18 -0
- package/dist/chains/btc/index.d.ts.map +1 -0
- package/dist/chains/evm/EvmActions.d.ts +140 -0
- package/dist/chains/evm/EvmActions.d.ts.map +1 -0
- package/dist/chains/evm/actions/deploy/EvmDeploy.d.ts +40 -0
- package/dist/chains/evm/actions/deploy/EvmDeploy.d.ts.map +1 -0
- package/dist/chains/evm/actions/deploy/config/evm.d.ts +22 -0
- package/dist/chains/evm/actions/deploy/config/evm.d.ts.map +1 -0
- package/dist/chains/evm/actions/deploy/config/index.d.ts +8 -0
- package/dist/chains/evm/actions/deploy/config/index.d.ts.map +1 -0
- package/dist/chains/evm/actions/deploy/config/types.d.ts +32 -0
- package/dist/chains/evm/actions/deploy/config/types.d.ts.map +1 -0
- package/dist/chains/evm/actions/deploy/factory.d.ts +30 -0
- package/dist/chains/evm/actions/deploy/factory.d.ts.map +1 -0
- package/dist/chains/evm/actions/deploy/index.d.ts +11 -0
- package/dist/chains/evm/actions/deploy/index.d.ts.map +1 -0
- package/dist/chains/evm/actions/deploy/types.d.ts +62 -0
- package/dist/chains/evm/actions/deploy/types.d.ts.map +1 -0
- package/dist/chains/evm/actions/deposit/EvmDeposit.d.ts +38 -0
- package/dist/chains/evm/actions/deposit/EvmDeposit.d.ts.map +1 -0
- package/dist/chains/evm/actions/deposit/config/evm.d.ts +23 -0
- package/dist/chains/evm/actions/deposit/config/evm.d.ts.map +1 -0
- package/dist/chains/evm/actions/deposit/config/index.d.ts +8 -0
- package/dist/chains/evm/actions/deposit/config/index.d.ts.map +1 -0
- package/dist/chains/evm/actions/deposit/config/types.d.ts +34 -0
- package/dist/chains/evm/actions/deposit/config/types.d.ts.map +1 -0
- package/dist/chains/evm/actions/deposit/factory.d.ts +30 -0
- package/dist/chains/evm/actions/deposit/factory.d.ts.map +1 -0
- package/dist/chains/evm/actions/deposit/index.d.ts +11 -0
- package/dist/chains/evm/actions/deposit/index.d.ts.map +1 -0
- package/dist/chains/evm/actions/deposit/types.d.ts +78 -0
- package/dist/chains/evm/actions/deposit/types.d.ts.map +1 -0
- package/dist/chains/evm/actions/index.d.ts +13 -0
- package/dist/chains/evm/actions/index.d.ts.map +1 -0
- package/dist/chains/evm/actions/redeem/EvmRedeem.d.ts +57 -0
- package/dist/chains/evm/actions/redeem/EvmRedeem.d.ts.map +1 -0
- package/dist/chains/evm/actions/redeem/config/evm.d.ts +24 -0
- package/dist/chains/evm/actions/redeem/config/evm.d.ts.map +1 -0
- package/dist/chains/evm/actions/redeem/config/index.d.ts +8 -0
- package/dist/chains/evm/actions/redeem/config/index.d.ts.map +1 -0
- package/dist/chains/evm/actions/redeem/config/types.d.ts +34 -0
- package/dist/chains/evm/actions/redeem/config/types.d.ts.map +1 -0
- package/dist/chains/evm/actions/redeem/factory.d.ts +29 -0
- package/dist/chains/evm/actions/redeem/factory.d.ts.map +1 -0
- package/dist/chains/evm/actions/redeem/index.d.ts +11 -0
- package/dist/chains/evm/actions/redeem/index.d.ts.map +1 -0
- package/dist/chains/evm/actions/redeem/types.d.ts +81 -0
- package/dist/chains/evm/actions/redeem/types.d.ts.map +1 -0
- package/dist/chains/evm/actions/stake/EvmStake.d.ts +62 -0
- package/dist/chains/evm/actions/stake/EvmStake.d.ts.map +1 -0
- package/dist/chains/evm/actions/stake/config/evm.d.ts +28 -0
- package/dist/chains/evm/actions/stake/config/evm.d.ts.map +1 -0
- package/dist/chains/evm/actions/stake/config/index.d.ts +8 -0
- package/dist/chains/evm/actions/stake/config/index.d.ts.map +1 -0
- package/dist/chains/evm/actions/stake/config/types.d.ts +60 -0
- package/dist/chains/evm/actions/stake/config/types.d.ts.map +1 -0
- package/dist/chains/evm/actions/stake/factory.d.ts +38 -0
- package/dist/chains/evm/actions/stake/factory.d.ts.map +1 -0
- package/dist/chains/evm/actions/stake/index.d.ts +13 -0
- package/dist/chains/evm/actions/stake/index.d.ts.map +1 -0
- package/dist/chains/evm/actions/stake/types.d.ts +94 -0
- package/dist/chains/evm/actions/stake/types.d.ts.map +1 -0
- package/dist/chains/evm/actions/unstake/EvmUnstake.d.ts +54 -0
- package/dist/chains/evm/actions/unstake/EvmUnstake.d.ts.map +1 -0
- package/dist/chains/evm/actions/unstake/config/evm.d.ts +34 -0
- package/dist/chains/evm/actions/unstake/config/evm.d.ts.map +1 -0
- package/dist/chains/evm/actions/unstake/config/index.d.ts +8 -0
- package/dist/chains/evm/actions/unstake/config/index.d.ts.map +1 -0
- package/dist/chains/evm/actions/unstake/config/types.d.ts +32 -0
- package/dist/chains/evm/actions/unstake/config/types.d.ts.map +1 -0
- package/dist/chains/evm/actions/unstake/factory.d.ts +30 -0
- package/dist/chains/evm/actions/unstake/factory.d.ts.map +1 -0
- package/dist/chains/evm/actions/unstake/index.d.ts +11 -0
- package/dist/chains/evm/actions/unstake/index.d.ts.map +1 -0
- package/dist/chains/evm/actions/unstake/types.d.ts +75 -0
- package/dist/chains/evm/actions/unstake/types.d.ts.map +1 -0
- package/dist/chains/evm/index.d.ts +11 -0
- package/dist/chains/evm/index.d.ts.map +1 -0
- package/dist/chains/evm/shared/feeAuth.d.ts +88 -0
- package/dist/chains/evm/shared/feeAuth.d.ts.map +1 -0
- package/dist/chains/evm/shared/index.d.ts +7 -0
- package/dist/chains/evm/shared/index.d.ts.map +1 -0
- package/dist/chains/solana/SolanaActions.d.ts +42 -0
- package/dist/chains/solana/SolanaActions.d.ts.map +1 -0
- package/dist/chains/solana/actions/index.d.ts +7 -0
- package/dist/chains/solana/actions/index.d.ts.map +1 -0
- package/dist/chains/solana/actions/unstake/SolanaUnstake.d.ts +30 -0
- package/dist/chains/solana/actions/unstake/SolanaUnstake.d.ts.map +1 -0
- package/dist/chains/solana/actions/unstake/config/btc.d.ts +20 -0
- package/dist/chains/solana/actions/unstake/config/btc.d.ts.map +1 -0
- package/dist/chains/solana/actions/unstake/config/index.d.ts +8 -0
- package/dist/chains/solana/actions/unstake/config/index.d.ts.map +1 -0
- package/dist/chains/solana/actions/unstake/config/solana.d.ts +20 -0
- package/dist/chains/solana/actions/unstake/config/solana.d.ts.map +1 -0
- package/dist/chains/solana/actions/unstake/config/types.d.ts +30 -0
- package/dist/chains/solana/actions/unstake/config/types.d.ts.map +1 -0
- package/dist/chains/solana/actions/unstake/factory.d.ts +19 -0
- package/dist/chains/solana/actions/unstake/factory.d.ts.map +1 -0
- package/dist/chains/solana/actions/unstake/index.d.ts +9 -0
- package/dist/chains/solana/actions/unstake/index.d.ts.map +1 -0
- package/dist/chains/solana/actions/unstake/types.d.ts +49 -0
- package/dist/chains/solana/actions/unstake/types.d.ts.map +1 -0
- package/dist/chains/solana/index.d.ts +8 -0
- package/dist/chains/solana/index.d.ts.map +1 -0
- package/dist/chains/starknet/StarknetActions.d.ts +42 -0
- package/dist/chains/starknet/StarknetActions.d.ts.map +1 -0
- package/dist/chains/starknet/actions/index.d.ts +7 -0
- package/dist/chains/starknet/actions/index.d.ts.map +1 -0
- package/dist/chains/starknet/actions/unstake/StarknetUnstake.d.ts +30 -0
- package/dist/chains/starknet/actions/unstake/StarknetUnstake.d.ts.map +1 -0
- package/dist/chains/starknet/actions/unstake/config/btc.d.ts +18 -0
- package/dist/chains/starknet/actions/unstake/config/btc.d.ts.map +1 -0
- package/dist/chains/starknet/actions/unstake/config/index.d.ts +8 -0
- package/dist/chains/starknet/actions/unstake/config/index.d.ts.map +1 -0
- package/dist/chains/starknet/actions/unstake/config/starknet.d.ts +18 -0
- package/dist/chains/starknet/actions/unstake/config/starknet.d.ts.map +1 -0
- package/dist/chains/starknet/actions/unstake/config/types.d.ts +24 -0
- package/dist/chains/starknet/actions/unstake/config/types.d.ts.map +1 -0
- package/dist/chains/starknet/actions/unstake/factory.d.ts +17 -0
- package/dist/chains/starknet/actions/unstake/factory.d.ts.map +1 -0
- package/dist/chains/starknet/actions/unstake/index.d.ts +9 -0
- package/dist/chains/starknet/actions/unstake/index.d.ts.map +1 -0
- package/dist/chains/starknet/actions/unstake/types.d.ts +48 -0
- package/dist/chains/starknet/actions/unstake/types.d.ts.map +1 -0
- package/dist/chains/starknet/index.d.ts +8 -0
- package/dist/chains/starknet/index.d.ts.map +1 -0
- package/dist/chains/sui/SuiActions.d.ts +42 -0
- package/dist/chains/sui/SuiActions.d.ts.map +1 -0
- package/dist/chains/sui/actions/index.d.ts +7 -0
- package/dist/chains/sui/actions/index.d.ts.map +1 -0
- package/dist/chains/sui/actions/unstake/SuiUnstake.d.ts +30 -0
- package/dist/chains/sui/actions/unstake/SuiUnstake.d.ts.map +1 -0
- package/dist/chains/sui/actions/unstake/config/btc.d.ts +18 -0
- package/dist/chains/sui/actions/unstake/config/btc.d.ts.map +1 -0
- package/dist/chains/sui/actions/unstake/config/index.d.ts +8 -0
- package/dist/chains/sui/actions/unstake/config/index.d.ts.map +1 -0
- package/dist/chains/sui/actions/unstake/config/sui.d.ts +18 -0
- package/dist/chains/sui/actions/unstake/config/sui.d.ts.map +1 -0
- package/dist/chains/sui/actions/unstake/config/types.d.ts +24 -0
- package/dist/chains/sui/actions/unstake/config/types.d.ts.map +1 -0
- package/dist/chains/sui/actions/unstake/factory.d.ts +17 -0
- package/dist/chains/sui/actions/unstake/factory.d.ts.map +1 -0
- package/dist/chains/sui/actions/unstake/index.d.ts +9 -0
- package/dist/chains/sui/actions/unstake/index.d.ts.map +1 -0
- package/dist/chains/sui/actions/unstake/types.d.ts +48 -0
- package/dist/chains/sui/actions/unstake/types.d.ts.map +1 -0
- package/dist/chains/sui/index.d.ts +8 -0
- package/dist/chains/sui/index.d.ts.map +1 -0
- package/dist/client/ApiNamespace.d.ts +207 -0
- package/dist/client/ApiNamespace.d.ts.map +1 -0
- package/dist/client/AssetNamespace.d.ts +53 -0
- package/dist/client/AssetNamespace.d.ts.map +1 -0
- package/dist/client/LombardSDK.d.ts +122 -0
- package/dist/client/LombardSDK.d.ts.map +1 -0
- package/dist/client/PartnerConfiguration.d.ts +34 -0
- package/dist/client/PartnerConfiguration.d.ts.map +1 -0
- package/dist/client/createConfig.d.ts +30 -0
- package/dist/client/createConfig.d.ts.map +1 -0
- package/dist/client/createLombardSDK.d.ts +64 -0
- package/dist/client/createLombardSDK.d.ts.map +1 -0
- package/dist/clients/public-client.d.ts.map +1 -1
- package/dist/clients/rpc-url-config.d.ts.map +1 -1
- package/dist/common/api-config.d.ts +1 -2
- package/dist/common/api-config.d.ts.map +1 -1
- package/dist/common/chains.d.ts +745 -768
- package/dist/common/chains.d.ts.map +1 -1
- package/dist/common/feature-config.d.ts +44 -4
- package/dist/common/feature-config.d.ts.map +1 -1
- package/dist/common/fee-requirements.d.ts +27 -0
- package/dist/common/fee-requirements.d.ts.map +1 -0
- package/dist/config/defaults.d.ts +27 -0
- package/dist/config/defaults.d.ts.map +1 -0
- package/dist/config/index.d.ts +12 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/providers.d.ts +23 -0
- package/dist/config/providers.d.ts.map +1 -0
- package/dist/config/types.d.ts +162 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/validation.d.ts +21 -0
- package/dist/config/validation.d.ts.map +1 -0
- package/dist/contract-functions/signStakeAndBake/signStakeAndBake.d.ts +1 -1
- package/dist/contract-functions/signStakeAndBake/signStakeAndBake.d.ts.map +1 -1
- package/dist/contract-functions/signStakeAndBake/validation.d.ts +3 -3
- package/dist/contracts/abis/index.d.ts +18 -0
- package/dist/contracts/abis/index.d.ts.map +1 -0
- package/dist/contracts/index.d.ts +43 -0
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/contracts/types.d.ts +127 -0
- package/dist/contracts/types.d.ts.map +1 -0
- package/dist/contracts/utils.d.ts +106 -0
- package/dist/contracts/utils.d.ts.map +1 -0
- package/dist/core/assets/catalog.d.ts +11 -0
- package/dist/core/assets/catalog.d.ts.map +1 -0
- package/dist/core/assets/index.d.ts +12 -0
- package/dist/core/assets/index.d.ts.map +1 -0
- package/dist/core/assets/types.d.ts +93 -0
- package/dist/core/assets/types.d.ts.map +1 -0
- package/dist/core/assets/utils.d.ts +82 -0
- package/dist/core/assets/utils.d.ts.map +1 -0
- package/dist/core/chains/catalog.d.ts +14 -0
- package/dist/core/chains/catalog.d.ts.map +1 -0
- package/dist/core/chains/index.d.ts +13 -0
- package/dist/core/chains/index.d.ts.map +1 -0
- package/dist/core/chains/types.d.ts +106 -0
- package/dist/core/chains/types.d.ts.map +1 -0
- package/dist/core/chains/utils.d.ts +55 -0
- package/dist/core/chains/utils.d.ts.map +1 -0
- package/dist/core/index.d.ts +14 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/types.d.ts +86 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/defi/defi-registry.d.ts +63 -6
- package/dist/defi/defi-registry.d.ts.map +1 -1
- package/dist/defi/index.d.ts +2 -1
- package/dist/defi/index.d.ts.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +61 -14
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +268 -155
- package/dist/index2.cjs +66 -66
- package/dist/index2.js +19778 -14373
- package/dist/modules/CapabilityRegistry.d.ts +58 -0
- package/dist/modules/CapabilityRegistry.d.ts.map +1 -0
- package/dist/modules/apiModule.d.ts +33 -0
- package/dist/modules/apiModule.d.ts.map +1 -0
- package/dist/modules/btcModule.d.ts +28 -0
- package/dist/modules/btcModule.d.ts.map +1 -0
- package/dist/modules/evmModule.d.ts +29 -0
- package/dist/modules/evmModule.d.ts.map +1 -0
- package/dist/modules/index.d.ts +27 -0
- package/dist/modules/index.d.ts.map +1 -0
- package/dist/referrals/ReferralsClient.d.ts +24 -0
- package/dist/referrals/ReferralsClient.d.ts.map +1 -0
- package/dist/referrals/index.d.ts +2 -0
- package/dist/referrals/index.d.ts.map +1 -0
- package/dist/services/ApiService.d.ts +52 -0
- package/dist/services/ApiService.d.ts.map +1 -0
- package/dist/services/BtcService.d.ts +21 -0
- package/dist/services/BtcService.d.ts.map +1 -0
- package/dist/services/EvmService.d.ts +48 -0
- package/dist/services/EvmService.d.ts.map +1 -0
- package/dist/services/index.d.ts +21 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/shared/actions/BaseAction.d.ts +275 -0
- package/dist/shared/actions/BaseAction.d.ts.map +1 -0
- package/dist/shared/actions/index.d.ts +9 -0
- package/dist/shared/actions/index.d.ts.map +1 -0
- package/dist/shared/constants/statusConstants.d.ts +92 -0
- package/dist/shared/constants/statusConstants.d.ts.map +1 -0
- package/dist/shared/context/ContextBuilder.d.ts +46 -0
- package/dist/shared/context/ContextBuilder.d.ts.map +1 -0
- package/dist/shared/context/index.d.ts +8 -0
- package/dist/shared/context/index.d.ts.map +1 -0
- package/dist/shared/context/types.d.ts +122 -0
- package/dist/shared/context/types.d.ts.map +1 -0
- package/dist/shared/deposits/depositStatus.d.ts +138 -0
- package/dist/shared/deposits/depositStatus.d.ts.map +1 -0
- package/dist/shared/deposits/index.d.ts +10 -0
- package/dist/shared/deposits/index.d.ts.map +1 -0
- package/dist/shared/errors.d.ts +211 -0
- package/dist/shared/errors.d.ts.map +1 -0
- package/dist/shared/events.d.ts +209 -0
- package/dist/shared/events.d.ts.map +1 -0
- package/dist/shared/evm/switchChain.d.ts +35 -0
- package/dist/shared/evm/switchChain.d.ts.map +1 -0
- package/dist/shared/index.d.ts +12 -0
- package/dist/shared/index.d.ts.map +1 -0
- package/dist/shared/monitoring/createEventEmitter.d.ts +68 -0
- package/dist/shared/monitoring/createEventEmitter.d.ts.map +1 -0
- package/dist/shared/monitoring/createProgressEmitter.d.ts +18 -0
- package/dist/shared/monitoring/createProgressEmitter.d.ts.map +1 -0
- package/dist/shared/monitoring/depositMonitor.d.ts +107 -0
- package/dist/shared/monitoring/depositMonitor.d.ts.map +1 -0
- package/dist/shared/monitoring/index.d.ts +9 -0
- package/dist/shared/monitoring/index.d.ts.map +1 -0
- package/dist/shared/validation/index.d.ts +188 -0
- package/dist/shared/validation/index.d.ts.map +1 -0
- package/dist/stories/arg-types.d.ts.map +1 -1
- package/dist/stories/components/Badge.d.ts +13 -0
- package/dist/stories/components/Badge.d.ts.map +1 -0
- package/dist/stories/components/Button/Button.d.ts +2 -2
- package/dist/stories/components/Button/Button.d.ts.map +1 -1
- package/dist/stories/components/Card.d.ts +12 -0
- package/dist/stories/components/Card.d.ts.map +1 -0
- package/dist/stories/components/CodeBlock/CodeBlock.d.ts +1 -1
- package/dist/stories/components/CodeBlock/CodeBlock.d.ts.map +1 -1
- package/dist/stories/components/ConnectButton/connect-button.d.ts.map +1 -1
- package/dist/stories/components/JsonPreview.d.ts +23 -0
- package/dist/stories/components/JsonPreview.d.ts.map +1 -0
- package/dist/stories/components/StatsCard.d.ts +13 -0
- package/dist/stories/components/StatsCard.d.ts.map +1 -0
- package/dist/stories/components/StatusIndicator.d.ts +13 -0
- package/dist/stories/components/StatusIndicator.d.ts.map +1 -0
- package/dist/stories/components/TreeNode.d.ts +15 -0
- package/dist/stories/components/TreeNode.d.ts.map +1 -0
- package/dist/stories/components/decorators/wagmi-decorator.d.ts.map +1 -1
- package/dist/stories/components/index.d.ts +11 -0
- package/dist/stories/components/index.d.ts.map +1 -0
- package/dist/stories/hooks/useConnection.d.ts.map +1 -1
- package/dist/stories/hooks/useQuery.d.ts.map +1 -1
- package/dist/tokens/token-addresses.d.ts +18 -0
- package/dist/tokens/token-addresses.d.ts.map +1 -1
- package/dist/tokens/tokens.d.ts +12 -0
- package/dist/tokens/tokens.d.ts.map +1 -1
- package/dist/utils/chain.d.ts +107 -0
- package/dist/utils/chain.d.ts.map +1 -0
- package/dist/utils/consoleLogger.d.ts +71 -0
- package/dist/utils/consoleLogger.d.ts.map +1 -0
- package/dist/utils/ensureNotSanctionedAddress.d.ts +2 -0
- package/dist/utils/ensureNotSanctionedAddress.d.ts.map +1 -0
- package/dist/utils/evmAccount.d.ts +13 -0
- package/dist/utils/evmAccount.d.ts.map +1 -0
- package/dist/utils/http.d.ts +95 -0
- package/dist/utils/http.d.ts.map +1 -0
- package/dist/utils/numbers.d.ts +20 -0
- package/dist/utils/numbers.d.ts.map +1 -1
- package/dist/utils/satoshi.d.ts +17 -4
- package/dist/utils/satoshi.d.ts.map +1 -1
- package/dist/vaults/index.d.ts +1 -1
- package/dist/vaults/index.d.ts.map +1 -1
- package/dist/vaults/lib/config.d.ts +3 -3
- package/dist/vaults/lib/config.d.ts.map +1 -1
- package/dist/version.d.ts +27 -0
- package/dist/version.d.ts.map +1 -0
- package/package.json +21 -4
- package/src/__tests__/AssetNamespace.spec.ts +234 -0
- package/src/__tests__/helpers/createTestConfig.ts +90 -0
- package/src/__tests__/integration/automint-fee.integration.test.ts +74 -0
- package/src/__tests__/integration/btc-deposit.integration.test.ts +109 -0
- package/src/__tests__/integration/btc-stake-and-deploy.integration.test.ts +96 -0
- package/src/__tests__/integration/btc-stake.integration.test.ts +466 -0
- package/src/__tests__/integration/evm-actions.integration.test.ts +932 -0
- package/src/__tests__/integration/evm-deploy.integration.test.ts +122 -0
- package/src/__tests__/integration/evm-redeem.integration.test.ts +157 -0
- package/src/__tests__/integration/faq-patterns.integration.test.ts +465 -0
- package/src/__tests__/integration/getLBTCMintingFee.integration.test.ts +195 -0
- package/src/__tests__/real-wallet/btc/btc-stake.real.test.ts +70 -0
- package/src/__tests__/real-wallet/evm/evm-stake.real.test.ts +47 -0
- package/src/__tests__/real-wallet/evm/evm-unstake.real.test.ts +49 -0
- package/src/__tests__/real-wallet/non-evm/solana-unstake.real.test.ts +19 -0
- package/src/__tests__/real-wallet/non-evm/starknet-unstake.real.test.ts +19 -0
- package/src/__tests__/real-wallet/non-evm/sui-unstake.real.test.ts +19 -0
- package/src/__tests__/services/ApiService.test.ts +62 -0
- package/src/__tests__/services/BtcService.test.ts +30 -0
- package/src/__tests__/services/EvmService.test.ts +39 -0
- package/src/__tests__/setup.ts +16 -0
- package/src/__tests__/test-utils/eip1193-adapter.ts +48 -0
- package/src/__tests__/test-utils/evm-wallet.ts +38 -0
- package/src/__tests__/test-utils/solana-wallet.ts +22 -0
- package/src/__tests__/test-utils/starknet-wallet.ts +9 -0
- package/src/__tests__/test-utils/sui-wallet.ts +14 -0
- package/src/__tests__/test-utils/test-constraints.ts +110 -0
- package/src/__tests__/unit/btc/BtcDeposit.test.ts +253 -0
- package/src/__tests__/unit/btc/BtcDepositAndDeploy.test.ts +174 -0
- package/src/__tests__/unit/btc/BtcDepositConfig.test.ts +143 -0
- package/src/__tests__/unit/btc/BtcDepositStatusTransition.test.ts +221 -0
- package/src/__tests__/unit/btc/BtcStakeAndDeploy.test.ts +194 -0
- package/src/__tests__/unit/btc/ExistingSignatureHandling.test.ts +301 -0
- package/src/__tests__/unit/btc/StakeAndBakeRatioConversion.test.ts +200 -0
- package/src/__tests__/unit/btc/StakeAndBakeSignatureRestore.test.ts +216 -0
- package/src/__tests__/unit/btc/TokenParameterConsistency.test.ts +184 -0
- package/src/__tests__/unit/btc/btc-deposit-token.test.ts +191 -0
- package/src/__tests__/unit/catalog/AssetCatalog.test.ts +293 -0
- package/src/__tests__/unit/config/ChainConfig.test.ts +47 -0
- package/src/__tests__/unit/config/FeeAuthConfig.test.ts +76 -0
- package/src/__tests__/unit/contract-functions/getLBTCMintingFee.test.ts +128 -0
- package/src/__tests__/unit/core/chain-parsing.test.ts +257 -0
- package/src/__tests__/unit/defi/AvailableProtocols.test.ts +100 -0
- package/src/__tests__/unit/defi/DefiRegistry.test.ts +25 -0
- package/src/__tests__/unit/evm/EvmDeploy.test.ts +224 -0
- package/src/__tests__/unit/evm/EvmRedeem.test.ts +207 -0
- package/src/__tests__/unit/evm/EvmRedeemFeeAuth.test.ts +93 -0
- package/src/__tests__/unit/evm/EvmStake.test.ts +207 -0
- package/src/__tests__/unit/evm/EvmStakeFeeAuth.test.ts +193 -0
- package/src/__tests__/unit/evm/EvmUnstakeAllowance.test.ts +69 -0
- package/src/__tests__/unit/evm/EvmUnstakeConfig.test.ts +203 -0
- package/src/__tests__/unit/fee-signature-expiration.test.ts +76 -0
- package/src/__tests__/unit/modules/CapabilityRegistry.test.ts +55 -0
- package/src/__tests__/unit/shared/BaseAction.test.ts +122 -0
- package/src/__tests__/unit/shared/BaseBtcAction.test.ts +114 -0
- package/src/__tests__/unit/solana/SolanaUnstake.test.ts +314 -0
- package/src/__tests__/unit/starknet/StarknetUnstake.test.ts +318 -0
- package/src/__tests__/unit/sui/SuiUnstake.test.ts +310 -0
- package/src/__tests__/unit/utils/satoshi.test.ts +27 -0
- package/src/__tests__/unit/validation/address-validation.test.ts +350 -0
- package/src/api-functions/generateDepositBtcAddress/generateDepositBtcAddress.stories.tsx +2 -1
- package/src/api-functions/getDepositAddressReferrer/getDepositAddressReferrer.ts +38 -0
- package/src/api-functions/getDepositAddressReferrer/index.ts +1 -0
- package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.stories.tsx +1 -0
- package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.ts +5 -4
- package/src/api-functions/getDepositBtcAddress/getDepositBtcAddresses.stories.tsx +1 -0
- package/src/api-functions/getDepositsByAddress/getDepositsByAddress.stories.tsx +2 -1
- package/src/api-functions/getLBTCExchangeRate/get-exchange-ratio.stories.tsx +1 -0
- package/src/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.stories.tsx +2 -1
- package/src/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.ts +3 -0
- package/src/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.stories.tsx +2 -1
- package/src/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.ts +18 -0
- package/src/api-functions/getPointsByAddress/getPointsByAddress.stories.tsx +2 -1
- package/src/api-functions/getUnstakesByAddress/getUnstakesByAddress.stories.tsx +2 -1
- package/src/api-functions/getUserStakeAndBakeSignature/getUserStakeAndBakeSignature.stories.tsx +2 -1
- package/src/api-functions/setReferral/setReferral.ts +6 -0
- package/src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.stories.tsx +1 -0
- package/src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.ts +17 -7
- package/src/api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature.stories.tsx +1 -0
- package/src/bridge/lib/bridge.stories.tsx +4 -3
- package/src/bridge/lib/ccip-bridge.stories.tsx +3 -2
- package/src/bridge/lib/config.ts +1 -1
- package/src/bridge/lib/oft-bridge.stories.tsx +2 -1
- package/src/chains/btc/BtcActions.ts +192 -0
- package/src/chains/btc/actions/deposit/BtcDeposit.ts +388 -0
- package/src/chains/btc/actions/deposit/config/evm.ts +197 -0
- package/src/chains/btc/actions/deposit/config/index.ts +53 -0
- package/src/chains/btc/actions/deposit/config/types.ts +108 -0
- package/src/chains/btc/actions/deposit/factory.ts +53 -0
- package/src/chains/btc/actions/deposit/index.ts +23 -0
- package/src/chains/btc/actions/deposit/types.ts +120 -0
- package/src/chains/btc/actions/depositAndDeploy/BtcDepositAndDeploy.ts +366 -0
- package/src/chains/btc/actions/depositAndDeploy/config/evm.ts +105 -0
- package/src/chains/btc/actions/depositAndDeploy/config/index.ts +111 -0
- package/src/chains/btc/actions/depositAndDeploy/config/types.ts +67 -0
- package/src/chains/btc/actions/depositAndDeploy/factory.ts +38 -0
- package/src/chains/btc/actions/depositAndDeploy/index.ts +24 -0
- package/src/chains/btc/actions/depositAndDeploy/types.ts +120 -0
- package/src/chains/btc/actions/index.ts +14 -0
- package/src/chains/btc/actions/shared/BaseBtcAction.ts +495 -0
- package/src/chains/btc/actions/shared/index.ts +28 -0
- package/src/chains/btc/actions/shared/tokenUtils.ts +68 -0
- package/src/chains/btc/actions/shared/validation.ts +180 -0
- package/src/chains/btc/actions/stake/BtcStake.ts +433 -0
- package/src/chains/btc/actions/stake/__tests__/BtcStake.test.ts +247 -0
- package/src/chains/btc/actions/stake/config/evm.ts +183 -0
- package/src/chains/btc/actions/stake/config/index.ts +122 -0
- package/src/chains/btc/actions/stake/config/solana.ts +96 -0
- package/src/chains/btc/actions/stake/config/starknet.ts +66 -0
- package/src/chains/btc/actions/stake/config/sui.ts +61 -0
- package/src/chains/btc/actions/stake/config/types.ts +165 -0
- package/src/chains/btc/actions/stake/factory.ts +53 -0
- package/src/chains/btc/actions/stake/index.ts +22 -0
- package/src/chains/btc/actions/stake/types.ts +175 -0
- package/src/chains/btc/actions/stakeAndDeploy/BtcStakeAndDeploy.ts +415 -0
- package/src/chains/btc/actions/stakeAndDeploy/config/evm.ts +135 -0
- package/src/chains/btc/actions/stakeAndDeploy/config/index.ts +119 -0
- package/src/chains/btc/actions/stakeAndDeploy/config/types.ts +93 -0
- package/src/chains/btc/actions/stakeAndDeploy/factory.ts +54 -0
- package/src/chains/btc/actions/stakeAndDeploy/index.ts +26 -0
- package/src/chains/btc/actions/stakeAndDeploy/types.ts +118 -0
- package/src/chains/btc/client/getCurrentBlockHeight.ts +28 -0
- package/src/chains/btc/client/mempool/error.ts +24 -0
- package/src/chains/btc/client/mempool/mempool.ts +23 -0
- package/src/chains/btc/index.ts +71 -0
- package/src/chains/evm/EvmActions.ts +185 -0
- package/src/chains/evm/actions/deploy/EvmDeploy.ts +256 -0
- package/src/chains/evm/actions/deploy/config/evm.ts +80 -0
- package/src/chains/evm/actions/deploy/config/index.ts +8 -0
- package/src/chains/evm/actions/deploy/config/types.ts +43 -0
- package/src/chains/evm/actions/deploy/factory.ts +44 -0
- package/src/chains/evm/actions/deploy/index.ts +17 -0
- package/src/chains/evm/actions/deploy/types.ts +74 -0
- package/src/chains/evm/actions/deposit/EvmDeposit.ts +159 -0
- package/src/chains/evm/actions/deposit/config/evm.ts +100 -0
- package/src/chains/evm/actions/deposit/config/index.ts +8 -0
- package/src/chains/evm/actions/deposit/config/types.ts +39 -0
- package/src/chains/evm/actions/deposit/factory.ts +44 -0
- package/src/chains/evm/actions/deposit/index.ts +17 -0
- package/src/chains/evm/actions/deposit/types.ts +87 -0
- package/src/chains/evm/actions/index.ts +67 -0
- package/src/chains/evm/actions/redeem/EvmRedeem.ts +263 -0
- package/src/chains/evm/actions/redeem/config/evm.ts +85 -0
- package/src/chains/evm/actions/redeem/config/index.ts +8 -0
- package/src/chains/evm/actions/redeem/config/types.ts +39 -0
- package/src/chains/evm/actions/redeem/factory.ts +43 -0
- package/src/chains/evm/actions/redeem/index.ts +17 -0
- package/src/chains/evm/actions/redeem/types.ts +93 -0
- package/src/chains/evm/actions/stake/EvmStake.ts +339 -0
- package/src/chains/evm/actions/stake/config/evm.ts +89 -0
- package/src/chains/evm/actions/stake/config/index.ts +8 -0
- package/src/chains/evm/actions/stake/config/types.ts +89 -0
- package/src/chains/evm/actions/stake/factory.ts +52 -0
- package/src/chains/evm/actions/stake/index.ts +30 -0
- package/src/chains/evm/actions/stake/types.ts +104 -0
- package/src/chains/evm/actions/unstake/EvmUnstake.ts +258 -0
- package/src/chains/evm/actions/unstake/config/evm.ts +123 -0
- package/src/chains/evm/actions/unstake/config/index.ts +13 -0
- package/src/chains/evm/actions/unstake/config/types.ts +37 -0
- package/src/chains/evm/actions/unstake/factory.ts +44 -0
- package/src/chains/evm/actions/unstake/index.ts +22 -0
- package/src/chains/evm/actions/unstake/types.ts +87 -0
- package/src/chains/evm/index.ts +16 -0
- package/src/chains/evm/shared/feeAuth.ts +198 -0
- package/src/chains/evm/shared/index.ts +7 -0
- package/src/chains/solana/SolanaActions.ts +85 -0
- package/src/chains/solana/actions/index.ts +7 -0
- package/src/chains/solana/actions/unstake/SolanaUnstake.ts +151 -0
- package/src/chains/solana/actions/unstake/config/btc.ts +47 -0
- package/src/chains/solana/actions/unstake/config/index.ts +8 -0
- package/src/chains/solana/actions/unstake/config/solana.ts +47 -0
- package/src/chains/solana/actions/unstake/config/types.ts +35 -0
- package/src/chains/solana/actions/unstake/factory.ts +34 -0
- package/src/chains/solana/actions/unstake/index.ts +14 -0
- package/src/chains/solana/actions/unstake/types.ts +58 -0
- package/src/chains/solana/index.ts +8 -0
- package/src/chains/starknet/StarknetActions.ts +85 -0
- package/src/chains/starknet/actions/index.ts +7 -0
- package/src/chains/starknet/actions/unstake/StarknetUnstake.ts +128 -0
- package/src/chains/starknet/actions/unstake/config/btc.ts +43 -0
- package/src/chains/starknet/actions/unstake/config/index.ts +8 -0
- package/src/chains/starknet/actions/unstake/config/starknet.ts +43 -0
- package/src/chains/starknet/actions/unstake/config/types.ts +27 -0
- package/src/chains/starknet/actions/unstake/factory.ts +32 -0
- package/src/chains/starknet/actions/unstake/index.ts +14 -0
- package/src/chains/starknet/actions/unstake/types.ts +57 -0
- package/src/chains/starknet/index.ts +8 -0
- package/src/chains/sui/SuiActions.ts +82 -0
- package/src/chains/sui/actions/index.ts +7 -0
- package/src/chains/sui/actions/unstake/SuiUnstake.ts +146 -0
- package/src/chains/sui/actions/unstake/config/btc.ts +43 -0
- package/src/chains/sui/actions/unstake/config/index.ts +8 -0
- package/src/chains/sui/actions/unstake/config/sui.ts +43 -0
- package/src/chains/sui/actions/unstake/config/types.ts +27 -0
- package/src/chains/sui/actions/unstake/factory.ts +32 -0
- package/src/chains/sui/actions/unstake/index.ts +14 -0
- package/src/chains/sui/actions/unstake/types.ts +57 -0
- package/src/chains/sui/index.ts +8 -0
- package/src/client/ApiNamespace.ts +302 -0
- package/src/client/AssetNamespace.ts +112 -0
- package/src/client/LombardSDK.ts +212 -0
- package/src/client/PartnerConfiguration.ts +50 -0
- package/src/client/createConfig.ts +90 -0
- package/src/client/createLombardSDK.ts +130 -0
- package/src/clients/public-client.ts +0 -4
- package/src/clients/rpc-url-config.ts +10 -3
- package/src/common/api-config.ts +1 -1
- package/src/common/blockchain-identifier.ts +6 -6
- package/src/common/chains.stories.tsx +2 -1
- package/src/common/chains.ts +28 -15
- package/src/common/feature-config.ts +66 -5
- package/src/common/fee-requirements.ts +34 -0
- package/src/config/defaults.ts +49 -0
- package/src/config/index.ts +12 -0
- package/src/config/providers.ts +81 -0
- package/src/config/types.ts +216 -0
- package/src/config/validation.ts +69 -0
- package/src/contract-functions/approveLBTC/approveLBTC.stories.tsx +5 -4
- package/src/contract-functions/claimLBTC/claimLBTC.stories.tsx +1 -0
- package/src/contract-functions/deposit/depositToken.stories.tsx +1 -0
- package/src/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.stories.tsx +2 -1
- package/src/contract-functions/getLBTCMintingFee/getLBTCMintingFee.stories.tsx +1 -0
- package/src/contract-functions/getLBTCTotalSupply/getLBTCTotalSupply.stories.tsx +1 -0
- package/src/contract-functions/getPermitNonce/getPermitNonce.stories.tsx +2 -1
- package/src/contract-functions/getShareValue/getShareValue.stories.tsx +6 -4
- package/src/contract-functions/getSharesByAddress/getSharesByAddress.stories.tsx +3 -3
- package/src/contract-functions/getStakeAndBakeFee/getStakeAndBakeFee.stories.tsx +1 -1
- package/src/contract-functions/signLbtcDestionationAddr/signLbtcDestionationAddr.stories.tsx +1 -0
- package/src/contract-functions/signNetworkFee/signNetworkFee.stories.tsx +1 -0
- package/src/contract-functions/signStakeAndBake/__tests__/signStakeAndBake.test.ts +9 -8
- package/src/contract-functions/signStakeAndBake/signStakeAndBake.stories.tsx +1 -0
- package/src/contract-functions/signStakeAndBake/signStakeAndBake.ts +3 -2
- package/src/contract-functions/signStakeAndBake/validation.ts +17 -17
- package/src/contract-functions/unstakeLBTC/unstakeLBTC.stories.tsx +1 -0
- package/src/contracts/abis/index.ts +29 -0
- package/src/contracts/index.ts +63 -0
- package/src/contracts/types.ts +143 -0
- package/src/contracts/utils.ts +288 -0
- package/src/core/assets/catalog.ts +343 -0
- package/src/core/assets/index.ts +40 -0
- package/src/core/assets/types.ts +142 -0
- package/src/core/assets/utils.ts +287 -0
- package/src/core/chains/catalog.ts +396 -0
- package/src/core/chains/index.ts +39 -0
- package/src/core/chains/types.ts +193 -0
- package/src/core/chains/utils.ts +245 -0
- package/src/core/index.ts +72 -0
- package/src/core/types.ts +126 -0
- package/src/defi/README.md +28 -12
- package/src/defi/defi-registry.stories.tsx +1 -0
- package/src/defi/defi-registry.ts +128 -12
- package/src/defi/index.ts +12 -0
- package/src/index.ts +292 -40
- package/src/metrics/get-lbtc-stats.stories.tsx +1 -0
- package/src/metrics/get-positions-summary.stories.tsx +1 -0
- package/src/modules/CapabilityRegistry.ts +125 -0
- package/src/modules/apiModule.ts +51 -0
- package/src/modules/btcModule.ts +43 -0
- package/src/modules/evmModule.ts +48 -0
- package/src/modules/index.ts +60 -0
- package/src/referrals/ReferralsClient.ts +34 -0
- package/src/referrals/index.ts +1 -0
- package/src/services/ApiService.ts +152 -0
- package/src/services/BtcService.ts +29 -0
- package/src/services/EvmService.ts +127 -0
- package/src/services/index.ts +43 -0
- package/src/shared/__tests__/errors.test.ts +185 -0
- package/src/shared/__tests__/events.test.ts +120 -0
- package/src/shared/__tests__/types.test.ts +155 -0
- package/src/shared/actions/BaseAction.ts +497 -0
- package/src/shared/actions/__tests__/BaseAction.test.ts +292 -0
- package/src/shared/actions/index.ts +9 -0
- package/src/shared/constants/statusConstants.ts +108 -0
- package/src/shared/context/ContextBuilder.ts +149 -0
- package/src/shared/context/index.ts +8 -0
- package/src/shared/context/types.ts +156 -0
- package/src/shared/deposits/depositStatus.ts +402 -0
- package/src/shared/deposits/index.ts +29 -0
- package/src/shared/errors.ts +405 -0
- package/src/shared/events.ts +260 -0
- package/src/shared/evm/switchChain.ts +109 -0
- package/src/shared/index.ts +54 -0
- package/src/shared/monitoring/__tests__/createEventEmitter.test.ts +150 -0
- package/src/shared/monitoring/createEventEmitter.ts +160 -0
- package/src/shared/monitoring/createProgressEmitter.ts +46 -0
- package/src/shared/monitoring/depositMonitor.ts +211 -0
- package/src/shared/monitoring/index.ts +25 -0
- package/src/shared/validation/index.ts +411 -0
- package/src/stories/arg-types.ts +1 -0
- package/src/stories/components/Badge.tsx +27 -0
- package/src/stories/components/Button/Button.tsx +4 -2
- package/src/stories/components/Card.tsx +18 -0
- package/src/stories/components/CodeBlock/CodeBlock.tsx +3 -2
- package/src/stories/components/ConnectButton/connect-button.tsx +1 -0
- package/src/stories/components/JsonPreview.tsx +84 -0
- package/src/stories/components/StatsCard.tsx +30 -0
- package/src/stories/components/StatusIndicator.tsx +37 -0
- package/src/stories/components/TreeNode.tsx +47 -0
- package/src/stories/components/decorators/function-type.tsx +1 -1
- package/src/stories/components/decorators/wagmi-decorator.tsx +2 -1
- package/src/stories/components/index.ts +11 -0
- package/src/stories/hooks/useConnection.ts +2 -1
- package/src/stories/hooks/useQuery.ts +1 -0
- package/src/tokens/__tests__/token-addresses.test.ts +551 -0
- package/src/tokens/cross-chain-addresses.stories.tsx +1 -0
- package/src/tokens/denomination-utils.stories.tsx +1 -0
- package/src/tokens/getLbtcContractAddresses.stories.tsx +1 -0
- package/src/tokens/getTokenByAddress.stories.tsx +1 -0
- package/src/tokens/getTokenContractInfo.stories.tsx +1 -0
- package/src/tokens/getTokenInfo.stories.tsx +1 -0
- package/src/tokens/isUpgradedContract.stories.tsx +1 -0
- package/src/tokens/token-addresses.ts +59 -10
- package/src/tokens/tokens.ts +15 -1
- package/src/utils/chain.ts +152 -0
- package/src/utils/consoleLogger.ts +140 -0
- package/src/utils/ensureNotSanctionedAddress.ts +11 -0
- package/src/utils/evmAccount.ts +47 -0
- package/src/utils/http.ts +224 -0
- package/src/utils/numbers.ts +31 -2
- package/src/utils/satoshi.ts +22 -6
- package/src/vaults/index.ts +1 -1
- package/src/vaults/lib/config.ts +4 -23
- package/src/vaults/lib/metrics/get-vault-apy.stories.tsx +2 -1
- package/src/vaults/lib/metrics/get-vault-points.stories.tsx +2 -1
- package/src/vaults/lib/metrics/get-vault-tvl.stories.tsx +2 -1
- package/src/vaults/lib/ops/cancel-withdraw.stories.tsx +2 -1
- package/src/vaults/lib/ops/deposit.stories.tsx +2 -1
- package/src/vaults/lib/ops/get-vault-deposits.stories.tsx +2 -1
- package/src/vaults/lib/ops/get-vault-withdrawals.stories.tsx +2 -1
- package/src/vaults/lib/ops/withdraw.stories.tsx +2 -1
- package/src/version.ts +56 -0
- package/dist/api-functions/generateDepositBtcAddress/generateDepositBtcAddress.stories.d.ts +0 -16
- package/dist/api-functions/generateDepositBtcAddress/generateDepositBtcAddress.stories.d.ts.map +0 -1
- package/dist/api-functions/getDepositBtcAddress/getDepositBtcAddress.stories.d.ts +0 -16
- package/dist/api-functions/getDepositBtcAddress/getDepositBtcAddress.stories.d.ts.map +0 -1
- package/dist/api-functions/getDepositBtcAddress/getDepositBtcAddress.test.d.ts +0 -2
- package/dist/api-functions/getDepositBtcAddress/getDepositBtcAddress.test.d.ts.map +0 -1
- package/dist/api-functions/getDepositBtcAddress/getDepositBtcAddresses.stories.d.ts +0 -16
- package/dist/api-functions/getDepositBtcAddress/getDepositBtcAddresses.stories.d.ts.map +0 -1
- package/dist/api-functions/getDepositsByAddress/getDepositsByAddress.stories.d.ts +0 -13
- package/dist/api-functions/getDepositsByAddress/getDepositsByAddress.stories.d.ts.map +0 -1
- package/dist/api-functions/getLBTCExchangeRate/get-exchange-ratio.stories.d.ts +0 -16
- package/dist/api-functions/getLBTCExchangeRate/get-exchange-ratio.stories.d.ts.map +0 -1
- package/dist/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.stories.d.ts +0 -16
- package/dist/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.stories.d.ts.map +0 -1
- package/dist/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.stories.d.ts +0 -17
- package/dist/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.stories.d.ts.map +0 -1
- package/dist/api-functions/getPointsByAddress/getPointsByAddress.stories.d.ts +0 -13
- package/dist/api-functions/getPointsByAddress/getPointsByAddress.stories.d.ts.map +0 -1
- package/dist/api-functions/getUnstakesByAddress/getUnstakesByAddress.stories.d.ts +0 -13
- package/dist/api-functions/getUnstakesByAddress/getUnstakesByAddress.stories.d.ts.map +0 -1
- package/dist/api-functions/getUserStakeAndBakeSignature/getUserStakeAndBakeSignature.stories.d.ts +0 -14
- package/dist/api-functions/getUserStakeAndBakeSignature/getUserStakeAndBakeSignature.stories.d.ts.map +0 -1
- package/dist/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.stories.d.ts +0 -14
- package/dist/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.stories.d.ts.map +0 -1
- package/dist/api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature.stories.d.ts +0 -14
- package/dist/api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature.stories.d.ts.map +0 -1
- package/dist/bridge/lib/bridge.stories.d.ts +0 -14
- package/dist/bridge/lib/bridge.stories.d.ts.map +0 -1
- package/dist/bridge/lib/ccip-bridge.stories.d.ts +0 -14
- package/dist/bridge/lib/ccip-bridge.stories.d.ts.map +0 -1
- package/dist/bridge/lib/oft-bridge.stories.d.ts +0 -14
- package/dist/bridge/lib/oft-bridge.stories.d.ts.map +0 -1
- package/dist/common/chains.stories.d.ts +0 -17
- package/dist/common/chains.stories.d.ts.map +0 -1
- package/dist/contract-functions/approveLBTC/approveLBTC.stories.d.ts +0 -17
- package/dist/contract-functions/approveLBTC/approveLBTC.stories.d.ts.map +0 -1
- package/dist/contract-functions/claimLBTC/claimLBTC.stories.d.ts +0 -17
- package/dist/contract-functions/claimLBTC/claimLBTC.stories.d.ts.map +0 -1
- package/dist/contract-functions/deposit/depositToken.stories.d.ts +0 -17
- package/dist/contract-functions/deposit/depositToken.stories.d.ts.map +0 -1
- package/dist/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.stories.d.ts +0 -16
- package/dist/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.stories.d.ts.map +0 -1
- package/dist/contract-functions/getLBTCMintingFee/getLBTCMintingFee.stories.d.ts +0 -17
- package/dist/contract-functions/getLBTCMintingFee/getLBTCMintingFee.stories.d.ts.map +0 -1
- package/dist/contract-functions/getLBTCTotalSupply/getLBTCTotalSupply.stories.d.ts +0 -17
- package/dist/contract-functions/getLBTCTotalSupply/getLBTCTotalSupply.stories.d.ts.map +0 -1
- package/dist/contract-functions/getPermitNonce/getPermitNonce.stories.d.ts +0 -14
- package/dist/contract-functions/getPermitNonce/getPermitNonce.stories.d.ts.map +0 -1
- package/dist/contract-functions/getShareValue/getShareValue.stories.d.ts +0 -13
- package/dist/contract-functions/getShareValue/getShareValue.stories.d.ts.map +0 -1
- package/dist/contract-functions/getSharesByAddress/getSharesByAddress.stories.d.ts +0 -13
- package/dist/contract-functions/getSharesByAddress/getSharesByAddress.stories.d.ts.map +0 -1
- package/dist/contract-functions/getStakeAndBakeFee/__tests__/getStakeAndBakeFee.test.d.ts +0 -2
- package/dist/contract-functions/getStakeAndBakeFee/__tests__/getStakeAndBakeFee.test.d.ts.map +0 -1
- package/dist/contract-functions/getStakeAndBakeFee/getStakeAndBakeFee.stories.d.ts +0 -17
- package/dist/contract-functions/getStakeAndBakeFee/getStakeAndBakeFee.stories.d.ts.map +0 -1
- package/dist/contract-functions/signLbtcDestionationAddr/signLbtcDestionationAddr.stories.d.ts +0 -9
- package/dist/contract-functions/signLbtcDestionationAddr/signLbtcDestionationAddr.stories.d.ts.map +0 -1
- package/dist/contract-functions/signNetworkFee/signNetworkFee.stories.d.ts +0 -14
- package/dist/contract-functions/signNetworkFee/signNetworkFee.stories.d.ts.map +0 -1
- package/dist/contract-functions/signStakeAndBake/__tests__/signStakeAndBake.test.d.ts +0 -17
- package/dist/contract-functions/signStakeAndBake/__tests__/signStakeAndBake.test.d.ts.map +0 -1
- package/dist/contract-functions/signStakeAndBake/signStakeAndBake.stories.d.ts +0 -50
- package/dist/contract-functions/signStakeAndBake/signStakeAndBake.stories.d.ts.map +0 -1
- package/dist/contract-functions/unstakeLBTC/unstakeLBTC.stories.d.ts +0 -17
- package/dist/contract-functions/unstakeLBTC/unstakeLBTC.stories.d.ts.map +0 -1
- package/dist/defi/defi-registry.stories.d.ts +0 -18
- package/dist/defi/defi-registry.stories.d.ts.map +0 -1
- package/dist/metrics/get-lbtc-stats.stories.d.ts +0 -17
- package/dist/metrics/get-lbtc-stats.stories.d.ts.map +0 -1
- package/dist/metrics/get-positions-summary.stories.d.ts +0 -17
- package/dist/metrics/get-positions-summary.stories.d.ts.map +0 -1
- package/dist/tokens/cross-chain-addresses.stories.d.ts +0 -60
- package/dist/tokens/cross-chain-addresses.stories.d.ts.map +0 -1
- package/dist/tokens/denomination-utils.stories.d.ts +0 -62
- package/dist/tokens/denomination-utils.stories.d.ts.map +0 -1
- package/dist/tokens/getLbtcContractAddresses.stories.d.ts +0 -59
- package/dist/tokens/getLbtcContractAddresses.stories.d.ts.map +0 -1
- package/dist/tokens/getTokenByAddress.stories.d.ts +0 -64
- package/dist/tokens/getTokenByAddress.stories.d.ts.map +0 -1
- package/dist/tokens/getTokenContractInfo.stories.d.ts +0 -52
- package/dist/tokens/getTokenContractInfo.stories.d.ts.map +0 -1
- package/dist/tokens/getTokenInfo.stories.d.ts +0 -42
- package/dist/tokens/getTokenInfo.stories.d.ts.map +0 -1
- package/dist/tokens/isUpgradedContract.stories.d.ts +0 -50
- package/dist/tokens/isUpgradedContract.stories.d.ts.map +0 -1
- package/dist/vaults/lib/metrics/get-vault-apy.stories.d.ts +0 -14
- package/dist/vaults/lib/metrics/get-vault-apy.stories.d.ts.map +0 -1
- package/dist/vaults/lib/metrics/get-vault-points.stories.d.ts +0 -14
- package/dist/vaults/lib/metrics/get-vault-points.stories.d.ts.map +0 -1
- package/dist/vaults/lib/metrics/get-vault-tvl.stories.d.ts +0 -14
- package/dist/vaults/lib/metrics/get-vault-tvl.stories.d.ts.map +0 -1
- package/dist/vaults/lib/ops/cancel-withdraw.stories.d.ts +0 -14
- package/dist/vaults/lib/ops/cancel-withdraw.stories.d.ts.map +0 -1
- package/dist/vaults/lib/ops/deposit.stories.d.ts +0 -14
- package/dist/vaults/lib/ops/deposit.stories.d.ts.map +0 -1
- package/dist/vaults/lib/ops/get-vault-deposits.stories.d.ts +0 -14
- package/dist/vaults/lib/ops/get-vault-deposits.stories.d.ts.map +0 -1
- package/dist/vaults/lib/ops/get-vault-withdrawals.stories.d.ts +0 -14
- package/dist/vaults/lib/ops/get-vault-withdrawals.stories.d.ts.map +0 -1
- package/dist/vaults/lib/ops/withdraw.stories.d.ts +0 -14
- package/dist/vaults/lib/ops/withdraw.stories.d.ts.map +0 -1
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Strategy Context Types
|
|
3
|
+
*
|
|
4
|
+
* Defines the lightweight context objects passed to strategies instead of the full SDK.
|
|
5
|
+
* This improves testability, reduces coupling, and makes dependencies explicit.
|
|
6
|
+
*
|
|
7
|
+
* Architecture:
|
|
8
|
+
* - CoreContext = What ALL strategies of a source chain need (env, partner, chain service)
|
|
9
|
+
* - Destination = What strategies need for their destination chain (injected by namespace)
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import type {
|
|
13
|
+
ApiService,
|
|
14
|
+
BtcService,
|
|
15
|
+
Env,
|
|
16
|
+
EvmService,
|
|
17
|
+
SolanaService,
|
|
18
|
+
StarknetService,
|
|
19
|
+
SuiService,
|
|
20
|
+
} from '@lombard.finance/sdk-common';
|
|
21
|
+
// Note: EvmService is still imported for EvmCoreContext and EvmDestination
|
|
22
|
+
import type { EIP1193Provider } from 'viem';
|
|
23
|
+
|
|
24
|
+
import type { PartnerConfiguration } from '../../client/PartnerConfiguration';
|
|
25
|
+
import type { CapabilityRegistry } from '../../modules/CapabilityRegistry';
|
|
26
|
+
|
|
27
|
+
// ============ Logger ============
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Logger interface for strategy operations
|
|
31
|
+
*/
|
|
32
|
+
export interface Logger {
|
|
33
|
+
debug(message: string, meta?: Record<string, unknown>): void;
|
|
34
|
+
info(message: string, meta?: Record<string, unknown>): void;
|
|
35
|
+
warn(message: string, meta?: Record<string, unknown>): void;
|
|
36
|
+
error(message: string, meta?: Record<string, unknown>): void;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
// ============ Provider Resolution ============
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Provider key for chain-specific wallet providers
|
|
43
|
+
*/
|
|
44
|
+
export type ProviderKey = 'bitcoin' | 'evm' | 'solana' | 'sui' | 'starknet';
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Provider resolver function
|
|
48
|
+
* Lazily resolves chain-specific wallet providers
|
|
49
|
+
*/
|
|
50
|
+
export type ProviderResolver = (
|
|
51
|
+
key: ProviderKey,
|
|
52
|
+
) => Promise<EIP1193Provider | unknown>;
|
|
53
|
+
|
|
54
|
+
// ============ Core Contexts (Source Chain) ============
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* Base Core Context
|
|
58
|
+
*
|
|
59
|
+
* Minimal context shared by ALL strategies, regardless of chain.
|
|
60
|
+
* Contains only environment, partner config, and provider resolution.
|
|
61
|
+
*
|
|
62
|
+
* TODO (v4.1): Add `catalog: AssetCatalog` field for remote catalog support.
|
|
63
|
+
* See: docs/ADDRESS_SYSTEM_UNIFICATION.md
|
|
64
|
+
*/
|
|
65
|
+
export interface CoreContext {
|
|
66
|
+
readonly env: Env;
|
|
67
|
+
readonly partner: PartnerConfiguration;
|
|
68
|
+
readonly getProvider: ProviderResolver;
|
|
69
|
+
readonly logger?: Logger;
|
|
70
|
+
// TODO (v4.1): readonly catalog: AssetCatalog;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
/**
|
|
74
|
+
* BTC Core Context
|
|
75
|
+
*
|
|
76
|
+
* What ALL Bitcoin strategies need (source chain operations).
|
|
77
|
+
* Includes BTC service, API service, and capabilities registry.
|
|
78
|
+
*
|
|
79
|
+
* Note: Chain-specific destination services (EVM, Solana, etc.) are accessed
|
|
80
|
+
* via capabilities.require('evm') when needed by chain configs.
|
|
81
|
+
*/
|
|
82
|
+
export interface BtcCoreContext extends CoreContext {
|
|
83
|
+
readonly btc: BtcService;
|
|
84
|
+
readonly api: ApiService;
|
|
85
|
+
readonly capabilities: CapabilityRegistry;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* EVM Core Context
|
|
90
|
+
*
|
|
91
|
+
* What ALL EVM strategies need (source chain operations).
|
|
92
|
+
*/
|
|
93
|
+
export interface EvmCoreContext extends CoreContext {
|
|
94
|
+
readonly evm: EvmService;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
/**
|
|
98
|
+
* Solana Core Context
|
|
99
|
+
*
|
|
100
|
+
* What ALL Solana strategies need (source chain operations).
|
|
101
|
+
*/
|
|
102
|
+
export interface SolanaCoreContext extends CoreContext {
|
|
103
|
+
readonly solana: SolanaService;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* Sui Core Context
|
|
108
|
+
*
|
|
109
|
+
* What ALL Sui strategies need (source chain operations).
|
|
110
|
+
*/
|
|
111
|
+
export interface SuiCoreContext extends CoreContext {
|
|
112
|
+
readonly sui: SuiService;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
/**
|
|
116
|
+
* Starknet Core Context
|
|
117
|
+
*
|
|
118
|
+
* What ALL Starknet strategies need (source chain operations).
|
|
119
|
+
*/
|
|
120
|
+
export interface StarknetCoreContext extends CoreContext {
|
|
121
|
+
readonly starknet: StarknetService;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
// ============ Destination Services (Injected per-strategy) ============
|
|
125
|
+
|
|
126
|
+
/**
|
|
127
|
+
* EVM as destination chain
|
|
128
|
+
* Injected into strategies that mint/send to EVM chains
|
|
129
|
+
*/
|
|
130
|
+
export interface EvmDestination {
|
|
131
|
+
readonly evm: EvmService;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* Solana as destination chain
|
|
136
|
+
* Injected into strategies that mint/send to Solana
|
|
137
|
+
*/
|
|
138
|
+
export interface SolanaDestination {
|
|
139
|
+
readonly solana: SolanaService;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
/**
|
|
143
|
+
* Sui as destination chain
|
|
144
|
+
* Injected into strategies that mint/send to Sui
|
|
145
|
+
*/
|
|
146
|
+
export interface SuiDestination {
|
|
147
|
+
readonly sui: SuiService;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
/**
|
|
151
|
+
* Starknet as destination chain
|
|
152
|
+
* Injected into strategies that mint/send to Starknet
|
|
153
|
+
*/
|
|
154
|
+
export interface StarknetDestination {
|
|
155
|
+
readonly starknet: StarknetService;
|
|
156
|
+
}
|
|
@@ -0,0 +1,402 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Deposit Status Utilities
|
|
3
|
+
*
|
|
4
|
+
* Centralized logic for determining deposit status based on notarization state,
|
|
5
|
+
* confirmations, and other factors. This module provides a single source of truth
|
|
6
|
+
* for deposit status that can be used by the SDK demo, apps/main, and other consumers.
|
|
7
|
+
*
|
|
8
|
+
* Status determination is based on both notarization status and block confirmations.
|
|
9
|
+
* The notarization status from the backend is the primary source of truth for where
|
|
10
|
+
* in the flow a deposit currently is.
|
|
11
|
+
*
|
|
12
|
+
* @module shared/deposits/depositStatus
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
import {
|
|
16
|
+
type Deposit,
|
|
17
|
+
ENotarizationStatus,
|
|
18
|
+
} from '../../api-functions/getDepositsByAddress/getDepositsByAddress';
|
|
19
|
+
|
|
20
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
21
|
+
// Constants
|
|
22
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Number of confirmations required before a deposit can be claimed.
|
|
26
|
+
* Production/Testnet: 6, Stage/Dev: 3
|
|
27
|
+
*/
|
|
28
|
+
export const REQUIRED_CONFIRMATIONS = 6;
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Minimum deposit amount that can be claimed (in BTC).
|
|
32
|
+
* Deposits below this amount cannot be minted.
|
|
33
|
+
*/
|
|
34
|
+
export const MIN_CLAIM_AMOUNT_BTC = 0.0002;
|
|
35
|
+
|
|
36
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
37
|
+
// Types
|
|
38
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Possible deposit statuses - ordered by lifecycle
|
|
42
|
+
*/
|
|
43
|
+
export type DepositStatus =
|
|
44
|
+
| 'pending_confirmations' // Waiting for BTC block confirmations
|
|
45
|
+
| 'pending_notarization' // Confirmations complete, waiting for notarization service
|
|
46
|
+
| 'claimable' // Notarization approved, ready to be claimed manually
|
|
47
|
+
| 'claiming' // Claim transaction submitted
|
|
48
|
+
| 'claimed' // Successfully claimed (has claimTxHash)
|
|
49
|
+
| 'auto_claimed' // Claimed via GMP (cross-chain messaging)
|
|
50
|
+
| 'expired' // Signature expired, needs re-auth
|
|
51
|
+
| 'failed' // Notarization failed
|
|
52
|
+
| 'restricted' // Sanctioned or restricted
|
|
53
|
+
| 'too_small'; // Amount below minimum
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Status severity for UI styling
|
|
57
|
+
*/
|
|
58
|
+
export type StatusSeverity = 'info' | 'warning' | 'success' | 'error' | 'neutral';
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* Status display configuration
|
|
62
|
+
*/
|
|
63
|
+
export interface DepositStatusDisplay {
|
|
64
|
+
/** Human-readable label for the status */
|
|
65
|
+
label: string;
|
|
66
|
+
/** Severity level for styling */
|
|
67
|
+
severity: StatusSeverity;
|
|
68
|
+
/** Detailed description of the status */
|
|
69
|
+
description: string;
|
|
70
|
+
/** Whether the deposit is in a terminal state (claimed, failed, restricted) */
|
|
71
|
+
isTerminal: boolean;
|
|
72
|
+
/** Whether user action is required */
|
|
73
|
+
requiresAction: boolean;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* Confirmation progress information
|
|
78
|
+
*/
|
|
79
|
+
export interface ConfirmationProgress {
|
|
80
|
+
/** Current number of confirmations */
|
|
81
|
+
current: number;
|
|
82
|
+
/** Required number of confirmations */
|
|
83
|
+
required: number;
|
|
84
|
+
/** Percentage complete (0-100) */
|
|
85
|
+
percentage: number;
|
|
86
|
+
/** Whether enough confirmations have been received */
|
|
87
|
+
isComplete: boolean;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
91
|
+
// Core Functions
|
|
92
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* Calculate the number of confirmations for a deposit
|
|
96
|
+
*
|
|
97
|
+
* @param currentBlockHeight - Current Bitcoin block height
|
|
98
|
+
* @param depositBlockHeight - Block height where deposit was confirmed
|
|
99
|
+
* @returns Number of confirmations (0 if either height is missing)
|
|
100
|
+
*/
|
|
101
|
+
export function calcConfirmations(
|
|
102
|
+
currentBlockHeight?: number,
|
|
103
|
+
depositBlockHeight?: number,
|
|
104
|
+
): number {
|
|
105
|
+
if (!depositBlockHeight || !currentBlockHeight) {
|
|
106
|
+
return 0;
|
|
107
|
+
}
|
|
108
|
+
// Deposit block height counts as the first confirmation
|
|
109
|
+
return Math.max(0, currentBlockHeight - depositBlockHeight + 1);
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
/**
|
|
113
|
+
* Get confirmation progress for a deposit
|
|
114
|
+
*
|
|
115
|
+
* @param currentBlockHeight - Current Bitcoin block height
|
|
116
|
+
* @param depositBlockHeight - Block height where deposit was confirmed
|
|
117
|
+
* @param requiredConfirmations - Number of confirmations required (default: REQUIRED_CONFIRMATIONS)
|
|
118
|
+
* @returns Confirmation progress info, or null if block heights unavailable
|
|
119
|
+
*/
|
|
120
|
+
export function getConfirmationProgress(
|
|
121
|
+
currentBlockHeight?: number,
|
|
122
|
+
depositBlockHeight?: number,
|
|
123
|
+
requiredConfirmations: number = REQUIRED_CONFIRMATIONS,
|
|
124
|
+
): ConfirmationProgress | null {
|
|
125
|
+
if (currentBlockHeight === undefined || depositBlockHeight === undefined) {
|
|
126
|
+
return null;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
const current = calcConfirmations(currentBlockHeight, depositBlockHeight);
|
|
130
|
+
const percentage = Math.min(
|
|
131
|
+
100,
|
|
132
|
+
Math.round((current / requiredConfirmations) * 100),
|
|
133
|
+
);
|
|
134
|
+
|
|
135
|
+
return {
|
|
136
|
+
current,
|
|
137
|
+
required: requiredConfirmations,
|
|
138
|
+
percentage,
|
|
139
|
+
isComplete: current >= requiredConfirmations,
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
/**
|
|
144
|
+
* Determine the status of a deposit
|
|
145
|
+
*
|
|
146
|
+
* Logic priority (matches apps/main useDepositState):
|
|
147
|
+
* 1. Sanctioned → restricted
|
|
148
|
+
* 2. Already claimed → claimed
|
|
149
|
+
* 3. Amount too small → too_small
|
|
150
|
+
* 4. GMP handled → auto_claimed
|
|
151
|
+
* 5. Notarization failed → failed
|
|
152
|
+
* 6. Based on notarization status + proof availability:
|
|
153
|
+
* - PENDING/SUBMITTED without enough confirmations → pending_confirmations
|
|
154
|
+
* - PENDING/SUBMITTED with confirmations → pending_notarization
|
|
155
|
+
* - SESSION_APPROVED with proof → claimable
|
|
156
|
+
* - SESSION_APPROVED without proof → pending_notarization (edge case)
|
|
157
|
+
*
|
|
158
|
+
* @param deposit - The deposit object from the SDK
|
|
159
|
+
* @param currentBlockHeight - Current BTC block height (optional, enhances accuracy)
|
|
160
|
+
* @param requiredConfirmations - Confirmations required (default: REQUIRED_CONFIRMATIONS)
|
|
161
|
+
* @returns The deposit status
|
|
162
|
+
*/
|
|
163
|
+
export function getDepositStatus(
|
|
164
|
+
deposit: Deposit,
|
|
165
|
+
currentBlockHeight?: number,
|
|
166
|
+
requiredConfirmations: number = REQUIRED_CONFIRMATIONS,
|
|
167
|
+
): DepositStatus {
|
|
168
|
+
// 1. Check for sanctioned/restricted first
|
|
169
|
+
if (deposit.sanctioned) {
|
|
170
|
+
return 'restricted';
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
// 2. Check if already claimed
|
|
174
|
+
if (deposit.isClaimed || deposit.claimTxHash) {
|
|
175
|
+
return 'claimed';
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
// 3. Check if amount is too small
|
|
179
|
+
const amountBtc = deposit.amount?.toNumber?.() ?? Number(deposit.amount);
|
|
180
|
+
if (amountBtc > 0 && amountBtc < MIN_CLAIM_AMOUNT_BTC) {
|
|
181
|
+
return 'too_small';
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
// 4. Check for GMP auto-claim
|
|
185
|
+
if (
|
|
186
|
+
deposit.notarizationStatus ===
|
|
187
|
+
ENotarizationStatus.NOTARIZATION_STATUS_GMP_HANDLED
|
|
188
|
+
) {
|
|
189
|
+
return 'auto_claimed';
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
// 5. Check for notarization failure
|
|
193
|
+
if (
|
|
194
|
+
deposit.notarizationStatus ===
|
|
195
|
+
ENotarizationStatus.NOTARIZATION_STATUS_FAILED
|
|
196
|
+
) {
|
|
197
|
+
return 'failed';
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
// 6. Determine status based on notarization status and proof availability
|
|
201
|
+
const hasProof = !!deposit.proof && !!deposit.rawPayload;
|
|
202
|
+
const notarizationStatus = deposit.notarizationStatus;
|
|
203
|
+
|
|
204
|
+
// Check confirmations only if we have block height data
|
|
205
|
+
const confirmations = calcConfirmations(
|
|
206
|
+
currentBlockHeight,
|
|
207
|
+
deposit.blockHeight,
|
|
208
|
+
);
|
|
209
|
+
const hasEnoughConfirmations =
|
|
210
|
+
currentBlockHeight === undefined ||
|
|
211
|
+
confirmations >= requiredConfirmations;
|
|
212
|
+
|
|
213
|
+
switch (notarizationStatus) {
|
|
214
|
+
case ENotarizationStatus.NOTARIZATION_STATUS_PENDING:
|
|
215
|
+
case ENotarizationStatus.NOTARIZATION_STATUS_SUBMITTED:
|
|
216
|
+
// Still in notarization queue
|
|
217
|
+
// If we know block height and not enough confirmations, show that
|
|
218
|
+
if (currentBlockHeight !== undefined && !hasEnoughConfirmations) {
|
|
219
|
+
return 'pending_confirmations';
|
|
220
|
+
}
|
|
221
|
+
// Otherwise, we're waiting for notarization
|
|
222
|
+
return 'pending_notarization';
|
|
223
|
+
|
|
224
|
+
case ENotarizationStatus.NOTARIZATION_STATUS_SESSION_APPROVED:
|
|
225
|
+
// Notarization approved
|
|
226
|
+
if (hasProof) {
|
|
227
|
+
return 'claimable';
|
|
228
|
+
}
|
|
229
|
+
// Edge case: approved but no proof yet (should be rare)
|
|
230
|
+
return 'pending_notarization';
|
|
231
|
+
|
|
232
|
+
case ENotarizationStatus.NOTARIZATION_STATUS_UNSPECIFIED:
|
|
233
|
+
default:
|
|
234
|
+
// Unknown status - check confirmations if we can
|
|
235
|
+
if (currentBlockHeight !== undefined && !hasEnoughConfirmations) {
|
|
236
|
+
return 'pending_confirmations';
|
|
237
|
+
}
|
|
238
|
+
return 'pending_notarization';
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
/**
|
|
243
|
+
* Get display configuration for a deposit status
|
|
244
|
+
*
|
|
245
|
+
* @param status - The deposit status
|
|
246
|
+
* @returns Display configuration with label, severity, and description
|
|
247
|
+
*/
|
|
248
|
+
export function getDepositStatusDisplay(
|
|
249
|
+
status: DepositStatus,
|
|
250
|
+
): DepositStatusDisplay {
|
|
251
|
+
switch (status) {
|
|
252
|
+
case 'pending_confirmations':
|
|
253
|
+
return {
|
|
254
|
+
label: 'Pending Confirmations',
|
|
255
|
+
severity: 'warning',
|
|
256
|
+
description: `Waiting for Bitcoin block confirmations (${REQUIRED_CONFIRMATIONS} required)`,
|
|
257
|
+
isTerminal: false,
|
|
258
|
+
requiresAction: false,
|
|
259
|
+
};
|
|
260
|
+
case 'pending_notarization':
|
|
261
|
+
return {
|
|
262
|
+
label: 'Pending Notarization',
|
|
263
|
+
severity: 'info',
|
|
264
|
+
description:
|
|
265
|
+
'Confirmations complete, waiting for notarization service to generate proof',
|
|
266
|
+
isTerminal: false,
|
|
267
|
+
requiresAction: false,
|
|
268
|
+
};
|
|
269
|
+
case 'claimable':
|
|
270
|
+
return {
|
|
271
|
+
label: 'Claimable',
|
|
272
|
+
severity: 'success',
|
|
273
|
+
description: 'Ready to mint - proof available, claim to receive tokens',
|
|
274
|
+
isTerminal: false,
|
|
275
|
+
requiresAction: true,
|
|
276
|
+
};
|
|
277
|
+
case 'claiming':
|
|
278
|
+
return {
|
|
279
|
+
label: 'Claiming',
|
|
280
|
+
severity: 'info',
|
|
281
|
+
description: 'Claim transaction in progress',
|
|
282
|
+
isTerminal: false,
|
|
283
|
+
requiresAction: false,
|
|
284
|
+
};
|
|
285
|
+
case 'claimed':
|
|
286
|
+
return {
|
|
287
|
+
label: 'Claimed',
|
|
288
|
+
severity: 'neutral',
|
|
289
|
+
description: 'Tokens have been minted to your address',
|
|
290
|
+
isTerminal: true,
|
|
291
|
+
requiresAction: false,
|
|
292
|
+
};
|
|
293
|
+
case 'auto_claimed':
|
|
294
|
+
return {
|
|
295
|
+
label: 'Auto-Claimed',
|
|
296
|
+
severity: 'success',
|
|
297
|
+
description: 'Automatically claimed via cross-chain messaging (GMP)',
|
|
298
|
+
isTerminal: true,
|
|
299
|
+
requiresAction: false,
|
|
300
|
+
};
|
|
301
|
+
case 'expired':
|
|
302
|
+
return {
|
|
303
|
+
label: 'Expired',
|
|
304
|
+
severity: 'error',
|
|
305
|
+
description: 'Fee signature expired, requires re-authorization',
|
|
306
|
+
isTerminal: false,
|
|
307
|
+
requiresAction: true,
|
|
308
|
+
};
|
|
309
|
+
case 'failed':
|
|
310
|
+
return {
|
|
311
|
+
label: 'Failed',
|
|
312
|
+
severity: 'error',
|
|
313
|
+
description: 'Notarization failed - contact support',
|
|
314
|
+
isTerminal: true,
|
|
315
|
+
requiresAction: false,
|
|
316
|
+
};
|
|
317
|
+
case 'restricted':
|
|
318
|
+
return {
|
|
319
|
+
label: 'Restricted',
|
|
320
|
+
severity: 'error',
|
|
321
|
+
description: 'This deposit is restricted or sanctioned',
|
|
322
|
+
isTerminal: true,
|
|
323
|
+
requiresAction: false,
|
|
324
|
+
};
|
|
325
|
+
case 'too_small':
|
|
326
|
+
return {
|
|
327
|
+
label: 'Too Small',
|
|
328
|
+
severity: 'neutral',
|
|
329
|
+
description: `Amount below minimum claimable amount (${MIN_CLAIM_AMOUNT_BTC} BTC)`,
|
|
330
|
+
isTerminal: true,
|
|
331
|
+
requiresAction: false,
|
|
332
|
+
};
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
|
|
336
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
337
|
+
// Helper Functions
|
|
338
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
339
|
+
|
|
340
|
+
/**
|
|
341
|
+
* Check if a deposit can be claimed manually
|
|
342
|
+
*
|
|
343
|
+
* @param deposit - The deposit object
|
|
344
|
+
* @param currentBlockHeight - Current BTC block height (optional)
|
|
345
|
+
* @returns True if the deposit is in claimable state
|
|
346
|
+
*/
|
|
347
|
+
export function isDepositClaimable(
|
|
348
|
+
deposit: Deposit,
|
|
349
|
+
currentBlockHeight?: number,
|
|
350
|
+
): boolean {
|
|
351
|
+
return getDepositStatus(deposit, currentBlockHeight) === 'claimable';
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
/**
|
|
355
|
+
* Check if a deposit is in a pending state (confirmations or notarization)
|
|
356
|
+
*
|
|
357
|
+
* @param deposit - The deposit object
|
|
358
|
+
* @param currentBlockHeight - Current BTC block height (optional)
|
|
359
|
+
* @returns True if deposit is pending
|
|
360
|
+
*/
|
|
361
|
+
export function isDepositPending(
|
|
362
|
+
deposit: Deposit,
|
|
363
|
+
currentBlockHeight?: number,
|
|
364
|
+
): boolean {
|
|
365
|
+
const status = getDepositStatus(deposit, currentBlockHeight);
|
|
366
|
+
return (
|
|
367
|
+
status === 'pending_confirmations' || status === 'pending_notarization'
|
|
368
|
+
);
|
|
369
|
+
}
|
|
370
|
+
|
|
371
|
+
/**
|
|
372
|
+
* Check if a deposit is in a terminal state (no further action possible)
|
|
373
|
+
*
|
|
374
|
+
* @param deposit - The deposit object
|
|
375
|
+
* @param currentBlockHeight - Current BTC block height (optional)
|
|
376
|
+
* @returns True if deposit is in terminal state
|
|
377
|
+
*/
|
|
378
|
+
export function isDepositTerminal(
|
|
379
|
+
deposit: Deposit,
|
|
380
|
+
currentBlockHeight?: number,
|
|
381
|
+
): boolean {
|
|
382
|
+
const status = getDepositStatus(deposit, currentBlockHeight);
|
|
383
|
+
const display = getDepositStatusDisplay(status);
|
|
384
|
+
return display.isTerminal;
|
|
385
|
+
}
|
|
386
|
+
|
|
387
|
+
/**
|
|
388
|
+
* Check if a deposit requires user action
|
|
389
|
+
*
|
|
390
|
+
* @param deposit - The deposit object
|
|
391
|
+
* @param currentBlockHeight - Current BTC block height (optional)
|
|
392
|
+
* @returns True if user action is required
|
|
393
|
+
*/
|
|
394
|
+
export function depositRequiresAction(
|
|
395
|
+
deposit: Deposit,
|
|
396
|
+
currentBlockHeight?: number,
|
|
397
|
+
): boolean {
|
|
398
|
+
const status = getDepositStatus(deposit, currentBlockHeight);
|
|
399
|
+
const display = getDepositStatusDisplay(status);
|
|
400
|
+
return display.requiresAction;
|
|
401
|
+
}
|
|
402
|
+
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Deposit Utilities
|
|
3
|
+
*
|
|
4
|
+
* Centralized utilities for working with deposits, including status
|
|
5
|
+
* determination, confirmation tracking, and display helpers.
|
|
6
|
+
*
|
|
7
|
+
* @module shared/deposits
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
export {
|
|
11
|
+
// Core functions
|
|
12
|
+
calcConfirmations,
|
|
13
|
+
// Types
|
|
14
|
+
type ConfirmationProgress,
|
|
15
|
+
depositRequiresAction,
|
|
16
|
+
type DepositStatus,
|
|
17
|
+
type DepositStatusDisplay,
|
|
18
|
+
getConfirmationProgress,
|
|
19
|
+
getDepositStatus,
|
|
20
|
+
getDepositStatusDisplay,
|
|
21
|
+
isDepositClaimable,
|
|
22
|
+
isDepositPending,
|
|
23
|
+
isDepositTerminal,
|
|
24
|
+
// Constants
|
|
25
|
+
MIN_CLAIM_AMOUNT_BTC,
|
|
26
|
+
REQUIRED_CONFIRMATIONS,
|
|
27
|
+
type StatusSeverity,
|
|
28
|
+
} from './depositStatus';
|
|
29
|
+
|