@lombard.finance/sdk 4.0.0 → 4.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/dist/bridge/lib/ccip-config.d.ts.map +1 -1
- package/dist/bridge/lib/config.d.ts +3 -3
- package/dist/bridge/lib/config.d.ts.map +1 -1
- package/dist/common/chains.d.ts +2 -2
- package/dist/common/chains.d.ts.map +1 -1
- package/dist/common/feature-config.d.ts.map +1 -1
- package/dist/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.d.ts.map +1 -1
- package/dist/index2.cjs +6 -6
- package/dist/index2.js +792 -759
- package/dist/vaults/lib/config.d.ts +1 -1
- 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,415 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* BTC StakeAndDeploy Action
|
|
3
|
-
*
|
|
4
|
-
* Handles BTC → LBTC → Vault deposit in a single atomic operation.
|
|
5
|
-
* Also known as "Stake and Bake".
|
|
6
|
-
*
|
|
7
|
-
* @module chains/btc/actions/stakeAndDeploy/BtcStakeAndDeploy
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import type { z } from 'zod';
|
|
11
|
-
|
|
12
|
-
import type { ChainId } from '../../../../common/chains';
|
|
13
|
-
import { isValidChain } from '../../../../common/chains';
|
|
14
|
-
import { AssetId, parseChainIdentifier, StepStatus } from '../../../../core';
|
|
15
|
-
import type { BtcCoreContext } from '../../../../shared/context';
|
|
16
|
-
import { LombardError, ValidationErrorCode } from '../../../../shared/errors';
|
|
17
|
-
import type { StakeAndDeployEventMap } from '../../../../shared/events';
|
|
18
|
-
import {
|
|
19
|
-
monitorDeposit,
|
|
20
|
-
type MonitorProgress,
|
|
21
|
-
} from '../../../../shared/monitoring';
|
|
22
|
-
import { Token } from '../../../../tokens/token-addresses';
|
|
23
|
-
import { ensureNotSanctionedAddress } from '../../../../utils/ensureNotSanctionedAddress';
|
|
24
|
-
import { toSatoshi } from '../../../../utils/satoshi';
|
|
25
|
-
import {
|
|
26
|
-
assetIdToToken,
|
|
27
|
-
BaseBtcAction,
|
|
28
|
-
type StatusConfig,
|
|
29
|
-
type StepDefinition,
|
|
30
|
-
} from '../shared';
|
|
31
|
-
import {
|
|
32
|
-
getVaultKey,
|
|
33
|
-
isAssetOutSupported,
|
|
34
|
-
isDestChainSupported,
|
|
35
|
-
isProtocolSupported,
|
|
36
|
-
isRouteAvailable,
|
|
37
|
-
stakeAndDeployConfig,
|
|
38
|
-
} from './config';
|
|
39
|
-
import {
|
|
40
|
-
BtcActionStatus,
|
|
41
|
-
type BtcStakeAndDeploy as IBtcStakeAndDeploy,
|
|
42
|
-
type BtcStakeAndDeployParams,
|
|
43
|
-
type BtcStakeAndDeployPrepareParams,
|
|
44
|
-
} from './types';
|
|
45
|
-
|
|
46
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
47
|
-
// Types
|
|
48
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
49
|
-
|
|
50
|
-
interface AuthState {
|
|
51
|
-
fee?: string;
|
|
52
|
-
signature?: string;
|
|
53
|
-
typedData?: string;
|
|
54
|
-
authorized: boolean;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
58
|
-
// BtcStakeAndDeploy Implementation
|
|
59
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* BTC StakeAndDeploy Action
|
|
63
|
-
*
|
|
64
|
-
* Combines staking and vault deployment in a single atomic operation.
|
|
65
|
-
*
|
|
66
|
-
* @example
|
|
67
|
-
* ```typescript
|
|
68
|
-
* const stakeAndDeploy = new BtcStakeAndDeploy(ctx, {
|
|
69
|
-
* assetOut: AssetId.LBTC,
|
|
70
|
-
* destChain: Chain.ETHEREUM,
|
|
71
|
-
* protocol: DeployProtocol.Veda,
|
|
72
|
-
* });
|
|
73
|
-
*
|
|
74
|
-
* await stakeAndDeploy.prepare({ amount: '0.1', recipient: '0x...' });
|
|
75
|
-
* await stakeAndDeploy.authorizeDeposit();
|
|
76
|
-
* const address = await stakeAndDeploy.generateDepositAddress();
|
|
77
|
-
* ```
|
|
78
|
-
*/
|
|
79
|
-
export class BtcStakeAndDeploy
|
|
80
|
-
extends BaseBtcAction<
|
|
81
|
-
StakeAndDeployEventMap,
|
|
82
|
-
BtcActionStatus,
|
|
83
|
-
BtcStakeAndDeployParams
|
|
84
|
-
>
|
|
85
|
-
implements IBtcStakeAndDeploy
|
|
86
|
-
{
|
|
87
|
-
private readonly chainId: ChainId;
|
|
88
|
-
private readonly authState: AuthState = { authorized: false };
|
|
89
|
-
|
|
90
|
-
constructor(ctx: BtcCoreContext, params: BtcStakeAndDeployParams) {
|
|
91
|
-
super(ctx, params, BtcActionStatus.IDLE);
|
|
92
|
-
|
|
93
|
-
// Validate assetOut - StakeAndDeploy should only produce LBTC
|
|
94
|
-
if (!isAssetOutSupported(params.assetOut)) {
|
|
95
|
-
throw new LombardError(
|
|
96
|
-
ValidationErrorCode.INVALID_ASSET,
|
|
97
|
-
`Asset ${params.assetOut} is not supported for stake and deploy. ` +
|
|
98
|
-
`StakeAndDeploy produces LBTC which is then deployed to a vault.`,
|
|
99
|
-
);
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
if (!isDestChainSupported(params.destChain)) {
|
|
103
|
-
throw new LombardError(
|
|
104
|
-
ValidationErrorCode.INVALID_CHAIN,
|
|
105
|
-
`Destination chain ${params.destChain} is not supported for stake and deploy`,
|
|
106
|
-
);
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
if (!isProtocolSupported(params.protocol)) {
|
|
110
|
-
throw new LombardError(
|
|
111
|
-
ValidationErrorCode.INVALID_PARAMETER,
|
|
112
|
-
`Protocol ${params.protocol} is not supported for stake and deploy`,
|
|
113
|
-
);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
if (!isRouteAvailable(params.sourceChain, ctx.env)) {
|
|
117
|
-
throw LombardError.routeNotFound({
|
|
118
|
-
assetOut: params.assetOut,
|
|
119
|
-
sourceChain: params.sourceChain,
|
|
120
|
-
destChain: params.destChain,
|
|
121
|
-
env: ctx.env,
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
const parsed = parseChainIdentifier(params.destChain);
|
|
126
|
-
if (typeof parsed !== 'number' || !isValidChain(parsed)) {
|
|
127
|
-
throw new LombardError(
|
|
128
|
-
ValidationErrorCode.INVALID_CHAIN,
|
|
129
|
-
`Unsupported EVM chain: ${params.destChain}`,
|
|
130
|
-
);
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
this.chainId = parsed as ChainId;
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
// ─────────────────────────────────────────────────────────────────────────
|
|
137
|
-
// Abstract Method Implementations
|
|
138
|
-
// ─────────────────────────────────────────────────────────────────────────
|
|
139
|
-
|
|
140
|
-
protected getAddressSchema(): z.ZodType<string> {
|
|
141
|
-
return stakeAndDeployConfig.addressSchema;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
protected getStatusConfig(): StatusConfig<BtcActionStatus> {
|
|
145
|
-
return {
|
|
146
|
-
idle: BtcActionStatus.IDLE,
|
|
147
|
-
ready: BtcActionStatus.READY,
|
|
148
|
-
addressReady: BtcActionStatus.ADDRESS_READY,
|
|
149
|
-
};
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
protected getInitialSteps(): StepDefinition {
|
|
153
|
-
return {
|
|
154
|
-
created: StepStatus.IDLE,
|
|
155
|
-
verifying: StepStatus.IDLE,
|
|
156
|
-
issuing: StepStatus.IDLE,
|
|
157
|
-
depositing: StepStatus.IDLE,
|
|
158
|
-
};
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
protected isAuthorized(): boolean {
|
|
162
|
-
return this.authState.authorized;
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
protected getChainId(): ChainId {
|
|
166
|
-
return this.chainId;
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
protected getDepositAddressParams() {
|
|
170
|
-
const recipient = this.ensureRecipient();
|
|
171
|
-
return {
|
|
172
|
-
address: recipient,
|
|
173
|
-
chainId: this.chainId,
|
|
174
|
-
signature: this.authState.signature!,
|
|
175
|
-
token: this.getExpectedToken(),
|
|
176
|
-
eip712Data: this.authState.typedData,
|
|
177
|
-
partnerId: this.ctx.partner.getPartnerId(),
|
|
178
|
-
referrerCode: this._referralCode,
|
|
179
|
-
};
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
/**
|
|
183
|
-
* Get expected token for this action (LBTC by default for StakeAndDeploy)
|
|
184
|
-
*/
|
|
185
|
-
protected getExpectedToken(): string {
|
|
186
|
-
return assetIdToToken(this.params.assetOut, Token.LBTC);
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
protected getAuthRequiredMessage(): string {
|
|
190
|
-
return 'Deposit authorization required. Call authorizeDeposit() first.';
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
// ─────────────────────────────────────────────────────────────────────────
|
|
194
|
-
// Public Getters
|
|
195
|
-
// ─────────────────────────────────────────────────────────────────────────
|
|
196
|
-
|
|
197
|
-
/** Get stake and bake fee (available after prepare()) */
|
|
198
|
-
get fee(): string | undefined {
|
|
199
|
-
return this.authState.fee;
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
// ─────────────────────────────────────────────────────────────────────────
|
|
203
|
-
// Public Methods
|
|
204
|
-
// ─────────────────────────────────────────────────────────────────────────
|
|
205
|
-
|
|
206
|
-
async prepare(params: BtcStakeAndDeployPrepareParams): Promise<void> {
|
|
207
|
-
this.assertStatus(BtcActionStatus.IDLE, 'prepare');
|
|
208
|
-
|
|
209
|
-
return this.act(async () => {
|
|
210
|
-
const validated = this.validatePrepareParams(params);
|
|
211
|
-
|
|
212
|
-
this._amount = validated.amount;
|
|
213
|
-
this._recipient = validated.recipient;
|
|
214
|
-
this._referralCode = validated.referralCode;
|
|
215
|
-
|
|
216
|
-
// Get fee for stake and bake
|
|
217
|
-
this.authState.fee = await stakeAndDeployConfig.getStakeAndBakeFee(
|
|
218
|
-
this.ctx,
|
|
219
|
-
this.chainId,
|
|
220
|
-
this.params.protocol,
|
|
221
|
-
);
|
|
222
|
-
|
|
223
|
-
// Check for existing deposit address (resume flow)
|
|
224
|
-
const hasExistingDeposit = await this.resumeFromExistingDeposit(
|
|
225
|
-
validated.recipient,
|
|
226
|
-
);
|
|
227
|
-
|
|
228
|
-
if (hasExistingDeposit) {
|
|
229
|
-
// We have a deposit address - check if stake and bake signature is still valid
|
|
230
|
-
const stored = await stakeAndDeployConfig.restoreStakeAndBakeSignature(
|
|
231
|
-
this.ctx,
|
|
232
|
-
this.chainId,
|
|
233
|
-
validated.recipient,
|
|
234
|
-
);
|
|
235
|
-
|
|
236
|
-
if (stored?.hasSignature) {
|
|
237
|
-
// Valid signature exists - skip authorization step
|
|
238
|
-
if (stored.signature) {
|
|
239
|
-
this.authState.signature = stored.signature;
|
|
240
|
-
}
|
|
241
|
-
this.authState.authorized = true;
|
|
242
|
-
this.updateStatus(BtcActionStatus.ADDRESS_READY);
|
|
243
|
-
this.emitInitialProgress();
|
|
244
|
-
return;
|
|
245
|
-
}
|
|
246
|
-
|
|
247
|
-
// Deposit exists but signature expired/missing - need re-authorization
|
|
248
|
-
this.updateStatus(BtcActionStatus.NEEDS_DEPLOY_AUTHORIZATION);
|
|
249
|
-
this.emitInitialProgress();
|
|
250
|
-
return;
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
// No existing deposit - check if there's a valid signature anyway
|
|
254
|
-
// (signature was created but deposit address not yet generated)
|
|
255
|
-
const existingSignature =
|
|
256
|
-
await stakeAndDeployConfig.restoreStakeAndBakeSignature(
|
|
257
|
-
this.ctx,
|
|
258
|
-
this.chainId,
|
|
259
|
-
validated.recipient,
|
|
260
|
-
);
|
|
261
|
-
|
|
262
|
-
if (existingSignature?.hasSignature) {
|
|
263
|
-
// Valid signature exists - skip to READY state
|
|
264
|
-
if (existingSignature.signature) {
|
|
265
|
-
this.authState.signature = existingSignature.signature;
|
|
266
|
-
}
|
|
267
|
-
this.authState.authorized = true;
|
|
268
|
-
this.updateStatus(BtcActionStatus.READY);
|
|
269
|
-
this.emitInitialProgress();
|
|
270
|
-
return;
|
|
271
|
-
}
|
|
272
|
-
|
|
273
|
-
// No existing signature - require authorization
|
|
274
|
-
this.updateStatus(BtcActionStatus.NEEDS_DEPLOY_AUTHORIZATION);
|
|
275
|
-
this.emitInitialProgress();
|
|
276
|
-
}, BtcActionStatus.NEEDS_DEPLOY_AUTHORIZATION);
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
async authorizeDeposit(): Promise<void> {
|
|
280
|
-
this.assertStatus(
|
|
281
|
-
[BtcActionStatus.NEEDS_DEPLOY_AUTHORIZATION, BtcActionStatus.READY],
|
|
282
|
-
'authorizeDeposit',
|
|
283
|
-
);
|
|
284
|
-
|
|
285
|
-
if (this.status === BtcActionStatus.READY) return;
|
|
286
|
-
|
|
287
|
-
const recipient = this.ensureRecipient();
|
|
288
|
-
const amount = this.ensureAmount();
|
|
289
|
-
|
|
290
|
-
return this.act(async () => {
|
|
291
|
-
const amountSats = toSatoshi(amount);
|
|
292
|
-
|
|
293
|
-
// For BTC → LBTC stake and bake, use AssetId.BTC to trigger ratio conversion.
|
|
294
|
-
// The DEFI_REGISTRY maps 'BTC' to { amountStrategy: 'btcToLbtc' } which divides
|
|
295
|
-
// the BTC amount by BTCTokenRatio to get the correct LBTC amount for the signature.
|
|
296
|
-
// This is critical because the backend expects the ratio-adjusted amount.
|
|
297
|
-
//
|
|
298
|
-
// Note: assetIn is optional but for BtcStakeAndDeploy, the source is always
|
|
299
|
-
// native BTC since we're receiving deposits on the Bitcoin blockchain.
|
|
300
|
-
const sourceToken = this.params.assetIn ?? AssetId.BTC;
|
|
301
|
-
|
|
302
|
-
const result = await stakeAndDeployConfig.authorizeStakeAndBake(
|
|
303
|
-
this.ctx,
|
|
304
|
-
{
|
|
305
|
-
chainId: this.chainId,
|
|
306
|
-
recipient,
|
|
307
|
-
amount: amountSats.toString(),
|
|
308
|
-
vaultKey: getVaultKey(this.params.protocol),
|
|
309
|
-
token: sourceToken,
|
|
310
|
-
},
|
|
311
|
-
);
|
|
312
|
-
|
|
313
|
-
this.authState.signature = result.signature;
|
|
314
|
-
this.authState.typedData = result.typedData;
|
|
315
|
-
this.authState.authorized = true;
|
|
316
|
-
}, BtcActionStatus.READY);
|
|
317
|
-
}
|
|
318
|
-
|
|
319
|
-
async generateDepositAddress(): Promise<string> {
|
|
320
|
-
this.assertStatus(BtcActionStatus.READY, 'generateDepositAddress');
|
|
321
|
-
this.ensureAuthorized();
|
|
322
|
-
|
|
323
|
-
if (this._depositAddress) {
|
|
324
|
-
return this._depositAddress;
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
return this.act(async () => {
|
|
328
|
-
const apiParams = this.getDepositAddressParams();
|
|
329
|
-
const depositAddress =
|
|
330
|
-
await this.ctx.api.generateDepositAddress(apiParams);
|
|
331
|
-
|
|
332
|
-
ensureNotSanctionedAddress(depositAddress);
|
|
333
|
-
this._depositAddress = depositAddress;
|
|
334
|
-
|
|
335
|
-
this.emitProgress({
|
|
336
|
-
status: BtcActionStatus.ADDRESS_READY,
|
|
337
|
-
steps: {
|
|
338
|
-
created: StepStatus.COMPLETE,
|
|
339
|
-
verifying: StepStatus.IDLE,
|
|
340
|
-
issuing: StepStatus.IDLE,
|
|
341
|
-
depositing: StepStatus.IDLE,
|
|
342
|
-
},
|
|
343
|
-
metadata: { depositAddress },
|
|
344
|
-
});
|
|
345
|
-
|
|
346
|
-
return depositAddress;
|
|
347
|
-
}, BtcActionStatus.ADDRESS_READY);
|
|
348
|
-
}
|
|
349
|
-
|
|
350
|
-
async execute(): Promise<{ depositAddress: string; txHash?: string }> {
|
|
351
|
-
return this.act(async () => {
|
|
352
|
-
this.assertStatus(BtcActionStatus.ADDRESS_READY, 'execute');
|
|
353
|
-
|
|
354
|
-
if (!this._depositAddress) {
|
|
355
|
-
await this.generateDepositAddress();
|
|
356
|
-
}
|
|
357
|
-
|
|
358
|
-
const depositAddress = this.ensureDepositAddress();
|
|
359
|
-
const txHash = await this.trySendBitcoin(depositAddress);
|
|
360
|
-
|
|
361
|
-
return txHash ? { depositAddress, txHash } : { depositAddress };
|
|
362
|
-
});
|
|
363
|
-
}
|
|
364
|
-
|
|
365
|
-
// Custom monitorDeposit with different step names
|
|
366
|
-
async monitorDeposit(): Promise<MonitorProgress | undefined> {
|
|
367
|
-
const depositAddress = this._depositAddress;
|
|
368
|
-
const recipient = this._recipient;
|
|
369
|
-
|
|
370
|
-
if (!depositAddress || !recipient) {
|
|
371
|
-
throw LombardError.missingParameter('depositAddress or recipient');
|
|
372
|
-
}
|
|
373
|
-
|
|
374
|
-
const progress = await monitorDeposit({
|
|
375
|
-
network: this.bitcoinNetwork,
|
|
376
|
-
btcService: this.ctx.btc,
|
|
377
|
-
fetchDeposit: async () => {
|
|
378
|
-
const deposits = await this.ctx.api.getDeposits(recipient);
|
|
379
|
-
const ourDeposit = deposits.find(
|
|
380
|
-
deposit => deposit.depositAddress === depositAddress,
|
|
381
|
-
);
|
|
382
|
-
|
|
383
|
-
if (!ourDeposit) {
|
|
384
|
-
return undefined;
|
|
385
|
-
}
|
|
386
|
-
|
|
387
|
-
return {
|
|
388
|
-
blockHeight: ourDeposit.blockHeight,
|
|
389
|
-
isClaimed: ourDeposit.isClaimed,
|
|
390
|
-
};
|
|
391
|
-
},
|
|
392
|
-
onProgress: p => {
|
|
393
|
-
this.emitProgress({
|
|
394
|
-
status: this.status,
|
|
395
|
-
steps: {
|
|
396
|
-
created: StepStatus.COMPLETE,
|
|
397
|
-
verifying: p.hasEnoughConfirmations
|
|
398
|
-
? StepStatus.COMPLETE
|
|
399
|
-
: StepStatus.PENDING,
|
|
400
|
-
issuing: p.isClaimed ? StepStatus.COMPLETE : StepStatus.PENDING,
|
|
401
|
-
depositing: StepStatus.PENDING,
|
|
402
|
-
},
|
|
403
|
-
confirmations: p.confirmations,
|
|
404
|
-
requiredConfirmations: p.requiredConfirmations,
|
|
405
|
-
metadata: { isClaimed: p.isClaimed },
|
|
406
|
-
});
|
|
407
|
-
},
|
|
408
|
-
onComplete: () => {
|
|
409
|
-
this.emitCompleted();
|
|
410
|
-
},
|
|
411
|
-
});
|
|
412
|
-
|
|
413
|
-
return progress;
|
|
414
|
-
}
|
|
415
|
-
}
|
|
@@ -1,135 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Chain Configuration for BTC StakeAndDeploy
|
|
3
|
-
*
|
|
4
|
-
* BTC StakeAndDeploy: BTC → LBTC → DeFi vault (Veda, Silo)
|
|
5
|
-
*
|
|
6
|
-
* Note: StakeAndDeploy is limited to chains that have both LBTC deployed
|
|
7
|
-
* AND Veda/Silo vault support. This is a subset of all LBTC chains.
|
|
8
|
-
*
|
|
9
|
-
* @module chains/btc/actions/stakeAndDeploy/config/evm
|
|
10
|
-
*/
|
|
11
|
-
|
|
12
|
-
import type { EvmService } from '@lombard.finance/sdk-common';
|
|
13
|
-
import type { EIP1193Provider } from 'viem';
|
|
14
|
-
|
|
15
|
-
import { getUserStakeAndBakeSignature } from '../../../../../api-functions/getUserStakeAndBakeSignature';
|
|
16
|
-
import type { ChainId } from '../../../../../common/chains';
|
|
17
|
-
import { AssetId, Chain, Env, evmChainIdToChain } from '../../../../../core';
|
|
18
|
-
import { LombardError } from '../../../../../shared/errors';
|
|
19
|
-
import { ensureCorrectChain } from '../../../../../shared/evm/switchChain';
|
|
20
|
-
import { evmAddressSchema } from '../../../../../shared/validation';
|
|
21
|
-
import { VEDA_VAULT_STAKE_AND_BAKE_CHAINS } from '../../../../../vaults/lib/config';
|
|
22
|
-
import { getSupportedProtocols } from '../../depositAndDeploy/config';
|
|
23
|
-
import type { StakeAndDeployChainConfig } from './types';
|
|
24
|
-
|
|
25
|
-
// Convert chain IDs to Chain enum values (CAIP-2 format)
|
|
26
|
-
// Uses VEDA_VAULT_STAKE_AND_BAKE_CHAINS as source of truth
|
|
27
|
-
const STAKE_AND_DEPLOY_DEST_CHAINS = VEDA_VAULT_STAKE_AND_BAKE_CHAINS.map(
|
|
28
|
-
chainId => evmChainIdToChain(chainId),
|
|
29
|
-
);
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* EVM stake and deploy configuration
|
|
33
|
-
*
|
|
34
|
-
* StakeAndDeploy produces LBTC then deploys to a vault.
|
|
35
|
-
* Limited to chains with Veda/Silo vault support.
|
|
36
|
-
*/
|
|
37
|
-
export const evmStakeAndDeployConfig: StakeAndDeployChainConfig = {
|
|
38
|
-
chainType: 'evm',
|
|
39
|
-
|
|
40
|
-
routes: [
|
|
41
|
-
{
|
|
42
|
-
sourceChains: [Chain.BITCOIN_MAINNET],
|
|
43
|
-
envs: [Env.prod],
|
|
44
|
-
},
|
|
45
|
-
{
|
|
46
|
-
sourceChains: [Chain.BITCOIN_SIGNET],
|
|
47
|
-
envs: [Env.stage, Env.dev, Env.testnet, Env.ibc],
|
|
48
|
-
},
|
|
49
|
-
],
|
|
50
|
-
|
|
51
|
-
// StakeAndDeploy requires vault support - uses VEDA_VAULT_STAKE_AND_BAKE_CHAINS as source of truth
|
|
52
|
-
destChains: STAKE_AND_DEPLOY_DEST_CHAINS,
|
|
53
|
-
|
|
54
|
-
// StakeAndDeploy produces LBTC (then deposits to vault)
|
|
55
|
-
supportedAssetsOut: [AssetId.LBTC],
|
|
56
|
-
|
|
57
|
-
supportedProtocols: getSupportedProtocols(AssetId.LBTC),
|
|
58
|
-
|
|
59
|
-
addressSchema: evmAddressSchema,
|
|
60
|
-
|
|
61
|
-
async getStakeAndBakeFee(ctx, chainId, protocol) {
|
|
62
|
-
const evm = ctx.capabilities.require('evm') as EvmService;
|
|
63
|
-
return evm.getStakeAndBakeFee(chainId as ChainId, protocol);
|
|
64
|
-
},
|
|
65
|
-
|
|
66
|
-
async authorizeStakeAndBake(
|
|
67
|
-
ctx,
|
|
68
|
-
{ chainId, recipient, amount, vaultKey, token },
|
|
69
|
-
) {
|
|
70
|
-
const evm = ctx.capabilities.require('evm') as EvmService;
|
|
71
|
-
const provider = await ctx.getProvider('evm');
|
|
72
|
-
if (!provider) {
|
|
73
|
-
throw LombardError.providerMissing(String(chainId), 'evm');
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
// Ensure wallet is on the correct chain before signing
|
|
77
|
-
await ensureCorrectChain(provider as EIP1193Provider, chainId as ChainId);
|
|
78
|
-
|
|
79
|
-
const result = await evm.signStakeAndBake({
|
|
80
|
-
value: amount,
|
|
81
|
-
account: recipient,
|
|
82
|
-
chainId: chainId as ChainId,
|
|
83
|
-
provider: provider as EIP1193Provider,
|
|
84
|
-
vaultKey,
|
|
85
|
-
token,
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
// Store signature via API
|
|
89
|
-
await ctx.api.storeStakeAndBakeSignature({
|
|
90
|
-
signature: result.signature,
|
|
91
|
-
typedData: result.typedData,
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
return {
|
|
95
|
-
signature: result.signature,
|
|
96
|
-
typedData: result.typedData,
|
|
97
|
-
};
|
|
98
|
-
},
|
|
99
|
-
|
|
100
|
-
async restoreStakeAndBakeSignature(ctx, chainId, recipient) {
|
|
101
|
-
try {
|
|
102
|
-
const result = await getUserStakeAndBakeSignature({
|
|
103
|
-
userDestinationAddress: recipient,
|
|
104
|
-
chainId: chainId as ChainId,
|
|
105
|
-
env: ctx.env,
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
// Check if signature exists and hasn't expired
|
|
109
|
-
if (!result.signature) {
|
|
110
|
-
return null;
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
// Check expiration - expirationDate is Unix timestamp in seconds
|
|
114
|
-
// Convert to milliseconds for Date comparison
|
|
115
|
-
if (result.expirationDate) {
|
|
116
|
-
const expirationMs = Number(result.expirationDate) * 1000;
|
|
117
|
-
if (expirationMs < Date.now()) {
|
|
118
|
-
// Signature has expired
|
|
119
|
-
return null;
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
return {
|
|
124
|
-
hasSignature: true,
|
|
125
|
-
signature: result.signature,
|
|
126
|
-
depositAmount: result.depositAmount,
|
|
127
|
-
expirationDate: result.expirationDate,
|
|
128
|
-
};
|
|
129
|
-
} catch {
|
|
130
|
-
// API error (e.g., signature not found, network error)
|
|
131
|
-
// Return null to indicate no valid signature exists
|
|
132
|
-
return null;
|
|
133
|
-
}
|
|
134
|
-
},
|
|
135
|
-
};
|
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* BTC StakeAndDeploy Chain Configuration Registry
|
|
3
|
-
*
|
|
4
|
-
* BTC StakeAndDeploy: BTC → LBTC → DeFi vault
|
|
5
|
-
* Uses DEFI_REGISTRY as the single source of truth for protocol validation.
|
|
6
|
-
*
|
|
7
|
-
* @module chains/btc/actions/stakeAndDeploy/config
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import type { AssetId, Chain, Env } from '../../../../../core';
|
|
11
|
-
import { DEFI_REGISTRY,DefiProtocol } from '../../../../../defi';
|
|
12
|
-
import { Token } from '../../../../../tokens/token-addresses';
|
|
13
|
-
import { evmStakeAndDeployConfig } from './evm';
|
|
14
|
-
|
|
15
|
-
export type {
|
|
16
|
-
StakeAndBakeAuthResult,
|
|
17
|
-
StakeAndDeployChainConfig,
|
|
18
|
-
StakeAndDeployRouteDefinition,
|
|
19
|
-
} from './types';
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* Config (currently EVM only)
|
|
23
|
-
*/
|
|
24
|
-
export const stakeAndDeployConfig = evmStakeAndDeployConfig;
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Check if destination chain is supported
|
|
28
|
-
*/
|
|
29
|
-
export function isDestChainSupported(chain: Chain): boolean {
|
|
30
|
-
return stakeAndDeployConfig.destChains.includes(chain);
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
/**
|
|
34
|
-
* Check if assetOut is supported
|
|
35
|
-
* StakeAndDeploy should only produce LBTC
|
|
36
|
-
*/
|
|
37
|
-
export function isAssetOutSupported(assetOut: AssetId): boolean {
|
|
38
|
-
return stakeAndDeployConfig.supportedAssetsOut.includes(assetOut);
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Check if route is available
|
|
43
|
-
*/
|
|
44
|
-
export function isRouteAvailable(
|
|
45
|
-
sourceChain: Chain | undefined,
|
|
46
|
-
env: Env,
|
|
47
|
-
): boolean {
|
|
48
|
-
if (!sourceChain) return true;
|
|
49
|
-
return stakeAndDeployConfig.routes.some(
|
|
50
|
-
route =>
|
|
51
|
-
route.sourceChains.includes(sourceChain) && route.envs.includes(env),
|
|
52
|
-
);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* Check if protocol is supported for stake and deploy
|
|
57
|
-
* Uses DEFI_REGISTRY as the single source of truth
|
|
58
|
-
*/
|
|
59
|
-
export function isProtocolSupported(protocol: string): boolean {
|
|
60
|
-
// Check if protocol exists in DEFI_REGISTRY
|
|
61
|
-
return protocol in DEFI_REGISTRY;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
/**
|
|
65
|
-
* Get the vault key for a protocol
|
|
66
|
-
* Returns the protocol key if valid, throws if not supported
|
|
67
|
-
*
|
|
68
|
-
* @param protocol - Protocol identifier from DefiProtocol
|
|
69
|
-
* @returns The vault key for API calls
|
|
70
|
-
* @throws If protocol is not in DEFI_REGISTRY
|
|
71
|
-
*/
|
|
72
|
-
export function getVaultKey(protocol: string): string {
|
|
73
|
-
if (!isProtocolSupported(protocol)) {
|
|
74
|
-
const supportedProtocols = Object.keys(DEFI_REGISTRY).join(', ');
|
|
75
|
-
throw new Error(
|
|
76
|
-
`Unsupported protocol: ${protocol}. ` +
|
|
77
|
-
`Supported protocols: ${supportedProtocols}`,
|
|
78
|
-
);
|
|
79
|
-
}
|
|
80
|
-
// Protocol keys in DEFI_REGISTRY match DefiProtocol values
|
|
81
|
-
return protocol;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
/**
|
|
85
|
-
* Get list of supported protocols for StakeAndDeploy
|
|
86
|
-
* This returns protocols that support LBTC or BTC (for StakeAndDeploy from BTC)
|
|
87
|
-
*
|
|
88
|
-
* TODO: Update this to match against asset and chain
|
|
89
|
-
*/
|
|
90
|
-
export function getSupportedProtocols(assetId: AssetId): DefiProtocol[] {
|
|
91
|
-
return Object.entries(DEFI_REGISTRY)
|
|
92
|
-
.filter(([_, tokenMap]) => assetId in tokenMap)
|
|
93
|
-
.map(([protocol]) => protocol as DefiProtocol);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
/**
|
|
97
|
-
* Check if a protocol supports a specific chain for stake and deploy
|
|
98
|
-
*/
|
|
99
|
-
export function isProtocolChainSupported(
|
|
100
|
-
protocol: string,
|
|
101
|
-
chainId: number,
|
|
102
|
-
env: Env,
|
|
103
|
-
): boolean {
|
|
104
|
-
const protocolRegistry = DEFI_REGISTRY[protocol as DefiProtocol];
|
|
105
|
-
if (!protocolRegistry) return false;
|
|
106
|
-
|
|
107
|
-
// Check LBTC token first, then BTC
|
|
108
|
-
const lbtcRegistry =
|
|
109
|
-
protocolRegistry[Token.LBTC as keyof typeof protocolRegistry];
|
|
110
|
-
const btcRegistry = protocolRegistry['BTC' as keyof typeof protocolRegistry];
|
|
111
|
-
|
|
112
|
-
const tokenRegistry = lbtcRegistry || btcRegistry;
|
|
113
|
-
if (!tokenRegistry) return false;
|
|
114
|
-
|
|
115
|
-
const envRegistry = tokenRegistry[env];
|
|
116
|
-
if (!envRegistry) return false;
|
|
117
|
-
|
|
118
|
-
return chainId in envRegistry;
|
|
119
|
-
}
|