@lombard.finance/sdk 4.0.0 → 4.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +6 -0
- package/dist/common/feature-config.d.ts.map +1 -1
- package/dist/index2.cjs +6 -6
- package/dist/index2.js +762 -754
- package/package.json +7 -8
- package/src/__tests__/AssetNamespace.spec.ts +0 -234
- package/src/__tests__/helpers/createTestConfig.ts +0 -90
- package/src/__tests__/integration/automint-fee.integration.test.ts +0 -74
- package/src/__tests__/integration/btc-deposit.integration.test.ts +0 -109
- package/src/__tests__/integration/btc-stake-and-deploy.integration.test.ts +0 -96
- package/src/__tests__/integration/btc-stake.integration.test.ts +0 -466
- package/src/__tests__/integration/evm-actions.integration.test.ts +0 -932
- package/src/__tests__/integration/evm-deploy.integration.test.ts +0 -122
- package/src/__tests__/integration/evm-redeem.integration.test.ts +0 -157
- package/src/__tests__/integration/faq-patterns.integration.test.ts +0 -465
- package/src/__tests__/integration/getLBTCMintingFee.integration.test.ts +0 -195
- package/src/__tests__/real-wallet/btc/btc-stake.real.test.ts +0 -70
- package/src/__tests__/real-wallet/evm/evm-stake.real.test.ts +0 -47
- package/src/__tests__/real-wallet/evm/evm-unstake.real.test.ts +0 -49
- package/src/__tests__/real-wallet/non-evm/solana-unstake.real.test.ts +0 -19
- package/src/__tests__/real-wallet/non-evm/starknet-unstake.real.test.ts +0 -19
- package/src/__tests__/real-wallet/non-evm/sui-unstake.real.test.ts +0 -19
- package/src/__tests__/services/ApiService.test.ts +0 -62
- package/src/__tests__/services/BtcService.test.ts +0 -30
- package/src/__tests__/services/EvmService.test.ts +0 -39
- package/src/__tests__/setup.ts +0 -16
- package/src/__tests__/test-utils/eip1193-adapter.ts +0 -48
- package/src/__tests__/test-utils/evm-wallet.ts +0 -38
- package/src/__tests__/test-utils/solana-wallet.ts +0 -22
- package/src/__tests__/test-utils/starknet-wallet.ts +0 -9
- package/src/__tests__/test-utils/sui-wallet.ts +0 -14
- package/src/__tests__/test-utils/test-constraints.ts +0 -110
- package/src/__tests__/unit/btc/BtcDeposit.test.ts +0 -253
- package/src/__tests__/unit/btc/BtcDepositAndDeploy.test.ts +0 -174
- package/src/__tests__/unit/btc/BtcDepositConfig.test.ts +0 -143
- package/src/__tests__/unit/btc/BtcDepositStatusTransition.test.ts +0 -221
- package/src/__tests__/unit/btc/BtcStakeAndDeploy.test.ts +0 -194
- package/src/__tests__/unit/btc/ExistingSignatureHandling.test.ts +0 -301
- package/src/__tests__/unit/btc/StakeAndBakeRatioConversion.test.ts +0 -200
- package/src/__tests__/unit/btc/StakeAndBakeSignatureRestore.test.ts +0 -216
- package/src/__tests__/unit/btc/TokenParameterConsistency.test.ts +0 -184
- package/src/__tests__/unit/btc/btc-deposit-token.test.ts +0 -191
- package/src/__tests__/unit/catalog/AssetCatalog.test.ts +0 -293
- package/src/__tests__/unit/config/ChainConfig.test.ts +0 -47
- package/src/__tests__/unit/config/FeeAuthConfig.test.ts +0 -76
- package/src/__tests__/unit/contract-functions/getLBTCMintingFee.test.ts +0 -128
- package/src/__tests__/unit/core/chain-parsing.test.ts +0 -257
- package/src/__tests__/unit/defi/AvailableProtocols.test.ts +0 -100
- package/src/__tests__/unit/defi/DefiRegistry.test.ts +0 -25
- package/src/__tests__/unit/evm/EvmDeploy.test.ts +0 -224
- package/src/__tests__/unit/evm/EvmRedeem.test.ts +0 -207
- package/src/__tests__/unit/evm/EvmRedeemFeeAuth.test.ts +0 -93
- package/src/__tests__/unit/evm/EvmStake.test.ts +0 -207
- package/src/__tests__/unit/evm/EvmStakeFeeAuth.test.ts +0 -193
- package/src/__tests__/unit/evm/EvmUnstakeAllowance.test.ts +0 -69
- package/src/__tests__/unit/evm/EvmUnstakeConfig.test.ts +0 -203
- package/src/__tests__/unit/fee-signature-expiration.test.ts +0 -76
- package/src/__tests__/unit/modules/CapabilityRegistry.test.ts +0 -55
- package/src/__tests__/unit/shared/BaseAction.test.ts +0 -122
- package/src/__tests__/unit/shared/BaseBtcAction.test.ts +0 -114
- package/src/__tests__/unit/solana/SolanaUnstake.test.ts +0 -314
- package/src/__tests__/unit/starknet/StarknetUnstake.test.ts +0 -318
- package/src/__tests__/unit/sui/SuiUnstake.test.ts +0 -310
- package/src/__tests__/unit/utils/satoshi.test.ts +0 -27
- package/src/__tests__/unit/validation/address-validation.test.ts +0 -350
- package/src/api-functions/generateDepositBtcAddress/generateDepositBtcAddress.stories.tsx +0 -71
- package/src/api-functions/generateDepositBtcAddress/generateDepositBtcAddress.ts +0 -235
- package/src/api-functions/generateDepositBtcAddress/index.ts +0 -1
- package/src/api-functions/get-badges-by-address/get-badges-by-address.ts +0 -13
- package/src/api-functions/get-badges-by-address/index.ts +0 -1
- package/src/api-functions/getDepositAddressReferrer/getDepositAddressReferrer.ts +0 -38
- package/src/api-functions/getDepositAddressReferrer/index.ts +0 -1
- package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.stories.tsx +0 -59
- package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.test.ts +0 -265
- package/src/api-functions/getDepositBtcAddress/getDepositBtcAddress.ts +0 -167
- package/src/api-functions/getDepositBtcAddress/getDepositBtcAddresses.stories.tsx +0 -58
- package/src/api-functions/getDepositBtcAddress/index.ts +0 -1
- package/src/api-functions/getDepositBtcAddress/make-request.ts +0 -59
- package/src/api-functions/getDepositBtcAddress/types.ts +0 -106
- package/src/api-functions/getDepositsByAddress/getDepositsByAddress.stories.tsx +0 -51
- package/src/api-functions/getDepositsByAddress/getDepositsByAddress.ts +0 -502
- package/src/api-functions/getDepositsByAddress/index.ts +0 -1
- package/src/api-functions/getLBTCExchangeRate/get-exchange-ratio.stories.tsx +0 -48
- package/src/api-functions/getLBTCExchangeRate/get-exchange-ratio.ts +0 -59
- package/src/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.stories.tsx +0 -55
- package/src/api-functions/getLBTCExchangeRate/getLBTCExchangeRate.ts +0 -75
- package/src/api-functions/getLBTCExchangeRate/index.ts +0 -2
- package/src/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.stories.tsx +0 -59
- package/src/api-functions/getNetworkFeeSignature/getNetworkFeeSignature.ts +0 -116
- package/src/api-functions/getNetworkFeeSignature/index.ts +0 -1
- package/src/api-functions/getPointsByAddress/getPointsByAddress.stories.tsx +0 -51
- package/src/api-functions/getPointsByAddress/getPointsByAddress.ts +0 -304
- package/src/api-functions/getPointsByAddress/index.ts +0 -1
- package/src/api-functions/getUnstakesByAddress/getUnstakesByAddress.stories.tsx +0 -51
- package/src/api-functions/getUnstakesByAddress/getUnstakesByAddress.ts +0 -368
- package/src/api-functions/getUnstakesByAddress/index.ts +0 -1
- package/src/api-functions/getUserStakeAndBakeSignature/getUserStakeAndBakeSignature.stories.tsx +0 -70
- package/src/api-functions/getUserStakeAndBakeSignature/getUserStakeAndBakeSignature.ts +0 -91
- package/src/api-functions/getUserStakeAndBakeSignature/index.ts +0 -1
- package/src/api-functions/index.ts +0 -11
- package/src/api-functions/setReferral/index.ts +0 -1
- package/src/api-functions/setReferral/setReferral.ts +0 -67
- package/src/api-functions/storeNetworkFeeSignature/index.ts +0 -1
- package/src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.stories.tsx +0 -57
- package/src/api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature.ts +0 -75
- package/src/api-functions/storeStakeAndBakeSignature/index.ts +0 -1
- package/src/api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature.stories.tsx +0 -57
- package/src/api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature.ts +0 -61
- package/src/bridge/abi/CCIP_BRIDGE_ADAPTER_ABI.json +0 -704
- package/src/bridge/abi/CCIP_ROUTER_ABI.json +0 -702
- package/src/bridge/abi/OFT_BRIDGE_ADAPTER_ABI.json +0 -912
- package/src/bridge/index.ts +0 -16
- package/src/bridge/lib/bridge.stories.tsx +0 -90
- package/src/bridge/lib/bridge.ts +0 -115
- package/src/bridge/lib/ccip-bridge.stories.tsx +0 -91
- package/src/bridge/lib/ccip-bridge.ts +0 -214
- package/src/bridge/lib/ccip-config.ts +0 -54
- package/src/bridge/lib/config.ts +0 -384
- package/src/bridge/lib/oft-bridge.stories.tsx +0 -90
- package/src/bridge/lib/oft-bridge.ts +0 -217
- package/src/chains/btc/BtcActions.ts +0 -192
- package/src/chains/btc/actions/deposit/BtcDeposit.ts +0 -388
- package/src/chains/btc/actions/deposit/config/evm.ts +0 -197
- package/src/chains/btc/actions/deposit/config/index.ts +0 -53
- package/src/chains/btc/actions/deposit/config/types.ts +0 -108
- package/src/chains/btc/actions/deposit/factory.ts +0 -53
- package/src/chains/btc/actions/deposit/index.ts +0 -23
- package/src/chains/btc/actions/deposit/types.ts +0 -120
- package/src/chains/btc/actions/depositAndDeploy/BtcDepositAndDeploy.ts +0 -366
- package/src/chains/btc/actions/depositAndDeploy/config/evm.ts +0 -105
- package/src/chains/btc/actions/depositAndDeploy/config/index.ts +0 -111
- package/src/chains/btc/actions/depositAndDeploy/config/types.ts +0 -67
- package/src/chains/btc/actions/depositAndDeploy/factory.ts +0 -38
- package/src/chains/btc/actions/depositAndDeploy/index.ts +0 -24
- package/src/chains/btc/actions/depositAndDeploy/types.ts +0 -120
- package/src/chains/btc/actions/index.ts +0 -14
- package/src/chains/btc/actions/shared/BaseBtcAction.ts +0 -495
- package/src/chains/btc/actions/shared/index.ts +0 -28
- package/src/chains/btc/actions/shared/tokenUtils.ts +0 -68
- package/src/chains/btc/actions/shared/validation.ts +0 -180
- package/src/chains/btc/actions/stake/BtcStake.ts +0 -433
- package/src/chains/btc/actions/stake/__tests__/BtcStake.test.ts +0 -247
- package/src/chains/btc/actions/stake/config/evm.ts +0 -183
- package/src/chains/btc/actions/stake/config/index.ts +0 -122
- package/src/chains/btc/actions/stake/config/solana.ts +0 -96
- package/src/chains/btc/actions/stake/config/starknet.ts +0 -66
- package/src/chains/btc/actions/stake/config/sui.ts +0 -61
- package/src/chains/btc/actions/stake/config/types.ts +0 -165
- package/src/chains/btc/actions/stake/factory.ts +0 -53
- package/src/chains/btc/actions/stake/index.ts +0 -22
- package/src/chains/btc/actions/stake/types.ts +0 -175
- package/src/chains/btc/actions/stakeAndDeploy/BtcStakeAndDeploy.ts +0 -415
- package/src/chains/btc/actions/stakeAndDeploy/config/evm.ts +0 -135
- package/src/chains/btc/actions/stakeAndDeploy/config/index.ts +0 -119
- package/src/chains/btc/actions/stakeAndDeploy/config/types.ts +0 -93
- package/src/chains/btc/actions/stakeAndDeploy/factory.ts +0 -54
- package/src/chains/btc/actions/stakeAndDeploy/index.ts +0 -26
- package/src/chains/btc/actions/stakeAndDeploy/types.ts +0 -118
- package/src/chains/btc/client/getCurrentBlockHeight.ts +0 -28
- package/src/chains/btc/client/mempool/error.ts +0 -24
- package/src/chains/btc/client/mempool/mempool.ts +0 -23
- package/src/chains/btc/index.ts +0 -71
- package/src/chains/evm/EvmActions.ts +0 -185
- package/src/chains/evm/actions/deploy/EvmDeploy.ts +0 -256
- package/src/chains/evm/actions/deploy/config/evm.ts +0 -80
- package/src/chains/evm/actions/deploy/config/index.ts +0 -8
- package/src/chains/evm/actions/deploy/config/types.ts +0 -43
- package/src/chains/evm/actions/deploy/factory.ts +0 -44
- package/src/chains/evm/actions/deploy/index.ts +0 -17
- package/src/chains/evm/actions/deploy/types.ts +0 -74
- package/src/chains/evm/actions/deposit/EvmDeposit.ts +0 -159
- package/src/chains/evm/actions/deposit/config/evm.ts +0 -100
- package/src/chains/evm/actions/deposit/config/index.ts +0 -8
- package/src/chains/evm/actions/deposit/config/types.ts +0 -39
- package/src/chains/evm/actions/deposit/factory.ts +0 -44
- package/src/chains/evm/actions/deposit/index.ts +0 -17
- package/src/chains/evm/actions/deposit/types.ts +0 -87
- package/src/chains/evm/actions/index.ts +0 -67
- package/src/chains/evm/actions/redeem/EvmRedeem.ts +0 -263
- package/src/chains/evm/actions/redeem/config/evm.ts +0 -85
- package/src/chains/evm/actions/redeem/config/index.ts +0 -8
- package/src/chains/evm/actions/redeem/config/types.ts +0 -39
- package/src/chains/evm/actions/redeem/factory.ts +0 -43
- package/src/chains/evm/actions/redeem/index.ts +0 -17
- package/src/chains/evm/actions/redeem/types.ts +0 -93
- package/src/chains/evm/actions/stake/EvmStake.ts +0 -339
- package/src/chains/evm/actions/stake/config/evm.ts +0 -89
- package/src/chains/evm/actions/stake/config/index.ts +0 -8
- package/src/chains/evm/actions/stake/config/types.ts +0 -89
- package/src/chains/evm/actions/stake/factory.ts +0 -52
- package/src/chains/evm/actions/stake/index.ts +0 -30
- package/src/chains/evm/actions/stake/types.ts +0 -104
- package/src/chains/evm/actions/unstake/EvmUnstake.ts +0 -258
- package/src/chains/evm/actions/unstake/config/evm.ts +0 -123
- package/src/chains/evm/actions/unstake/config/index.ts +0 -13
- package/src/chains/evm/actions/unstake/config/types.ts +0 -37
- package/src/chains/evm/actions/unstake/factory.ts +0 -44
- package/src/chains/evm/actions/unstake/index.ts +0 -22
- package/src/chains/evm/actions/unstake/types.ts +0 -87
- package/src/chains/evm/index.ts +0 -16
- package/src/chains/evm/shared/feeAuth.ts +0 -198
- package/src/chains/evm/shared/index.ts +0 -7
- package/src/chains/solana/SolanaActions.ts +0 -85
- package/src/chains/solana/actions/index.ts +0 -7
- package/src/chains/solana/actions/unstake/SolanaUnstake.ts +0 -151
- package/src/chains/solana/actions/unstake/config/btc.ts +0 -47
- package/src/chains/solana/actions/unstake/config/index.ts +0 -8
- package/src/chains/solana/actions/unstake/config/solana.ts +0 -47
- package/src/chains/solana/actions/unstake/config/types.ts +0 -35
- package/src/chains/solana/actions/unstake/factory.ts +0 -34
- package/src/chains/solana/actions/unstake/index.ts +0 -14
- package/src/chains/solana/actions/unstake/types.ts +0 -58
- package/src/chains/solana/index.ts +0 -8
- package/src/chains/starknet/StarknetActions.ts +0 -85
- package/src/chains/starknet/actions/index.ts +0 -7
- package/src/chains/starknet/actions/unstake/StarknetUnstake.ts +0 -128
- package/src/chains/starknet/actions/unstake/config/btc.ts +0 -43
- package/src/chains/starknet/actions/unstake/config/index.ts +0 -8
- package/src/chains/starknet/actions/unstake/config/starknet.ts +0 -43
- package/src/chains/starknet/actions/unstake/config/types.ts +0 -27
- package/src/chains/starknet/actions/unstake/factory.ts +0 -32
- package/src/chains/starknet/actions/unstake/index.ts +0 -14
- package/src/chains/starknet/actions/unstake/types.ts +0 -57
- package/src/chains/starknet/index.ts +0 -8
- package/src/chains/sui/SuiActions.ts +0 -82
- package/src/chains/sui/actions/index.ts +0 -7
- package/src/chains/sui/actions/unstake/SuiUnstake.ts +0 -146
- package/src/chains/sui/actions/unstake/config/btc.ts +0 -43
- package/src/chains/sui/actions/unstake/config/index.ts +0 -8
- package/src/chains/sui/actions/unstake/config/sui.ts +0 -43
- package/src/chains/sui/actions/unstake/config/types.ts +0 -27
- package/src/chains/sui/actions/unstake/factory.ts +0 -32
- package/src/chains/sui/actions/unstake/index.ts +0 -14
- package/src/chains/sui/actions/unstake/types.ts +0 -57
- package/src/chains/sui/index.ts +0 -8
- package/src/client/ApiNamespace.ts +0 -302
- package/src/client/AssetNamespace.ts +0 -112
- package/src/client/LombardSDK.ts +0 -212
- package/src/client/PartnerConfiguration.ts +0 -50
- package/src/client/createConfig.ts +0 -90
- package/src/client/createLombardSDK.ts +0 -130
- package/src/clients/evm-signer-adapter.ts +0 -313
- package/src/clients/public-client.ts +0 -49
- package/src/clients/rpc-url-config.ts +0 -64
- package/src/clients/wallet-client.ts +0 -34
- package/src/common/api-config.ts +0 -48
- package/src/common/blockchain-identifier.ts +0 -217
- package/src/common/chains.stories.tsx +0 -68
- package/src/common/chains.ts +0 -449
- package/src/common/constants.ts +0 -1
- package/src/common/contract-info.ts +0 -9
- package/src/common/feature-config.ts +0 -79
- package/src/common/fee-requirements.ts +0 -34
- package/src/common/parameters.ts +0 -89
- package/src/config/defaults.ts +0 -49
- package/src/config/index.ts +0 -12
- package/src/config/providers.ts +0 -81
- package/src/config/types.ts +0 -216
- package/src/config/validation.ts +0 -69
- package/src/contract-functions/approveLBTC/approveLBTC.stories.tsx +0 -79
- package/src/contract-functions/approveLBTC/approveLBTC.ts +0 -66
- package/src/contract-functions/approveLBTC/index.ts +0 -1
- package/src/contract-functions/approveToken/approveToken.ts +0 -126
- package/src/contract-functions/approveToken/index.ts +0 -1
- package/src/contract-functions/claimLBTC/claimLBTC.stories.tsx +0 -82
- package/src/contract-functions/claimLBTC/claimLBTC.ts +0 -159
- package/src/contract-functions/claimLBTC/index.ts +0 -1
- package/src/contract-functions/claimUnstakeRedeem/claimUnstakeRedeem.ts +0 -95
- package/src/contract-functions/claimUnstakeRedeem/index.ts +0 -1
- package/src/contract-functions/deposit/depositToken.stories.tsx +0 -83
- package/src/contract-functions/deposit/depositToken.ts +0 -214
- package/src/contract-functions/deposit/index.ts +0 -1
- package/src/contract-functions/getBasculeDepositStatus/decodeBasculeDepositStatus.ts +0 -170
- package/src/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.stories.tsx +0 -62
- package/src/contract-functions/getBasculeDepositStatus/getBasculeDepositStatus.ts +0 -211
- package/src/contract-functions/getBasculeDepositStatus/index.ts +0 -2
- package/src/contract-functions/getLBTCMintingFee/getLBTCMintingFee.stories.tsx +0 -61
- package/src/contract-functions/getLBTCMintingFee/getLBTCMintingFee.ts +0 -193
- package/src/contract-functions/getLBTCMintingFee/index.ts +0 -1
- package/src/contract-functions/getLBTCTotalSupply/getLBTCTotalSupply.stories.tsx +0 -51
- package/src/contract-functions/getLBTCTotalSupply/getLBTCTotalSupply.ts +0 -40
- package/src/contract-functions/getLBTCTotalSupply/index.ts +0 -1
- package/src/contract-functions/getPermitNonce/getPermitNonce.stories.tsx +0 -56
- package/src/contract-functions/getPermitNonce/getPermitNonce.ts +0 -50
- package/src/contract-functions/getPermitNonce/index.ts +0 -1
- package/src/contract-functions/getShareValue/getShareValue.stories.tsx +0 -58
- package/src/contract-functions/getShareValue/getShareValue.ts +0 -59
- package/src/contract-functions/getShareValue/index.ts +0 -1
- package/src/contract-functions/getSharesByAddress/getSharesByAddress.stories.tsx +0 -65
- package/src/contract-functions/getSharesByAddress/getSharesByAddress.ts +0 -86
- package/src/contract-functions/getSharesByAddress/index.ts +0 -4
- package/src/contract-functions/getStakeAndBakeFee/__tests__/getStakeAndBakeFee.test.ts +0 -167
- package/src/contract-functions/getStakeAndBakeFee/getStakeAndBakeFee.stories.tsx +0 -180
- package/src/contract-functions/getStakeAndBakeFee/getStakeAndBakeFee.tsx +0 -101
- package/src/contract-functions/getStakeAndBakeFee/index.ts +0 -1
- package/src/contract-functions/index.ts +0 -21
- package/src/contract-functions/signLbtcDestionationAddr/index.ts +0 -1
- package/src/contract-functions/signLbtcDestionationAddr/signLbtcDestinationAddr.ts +0 -32
- package/src/contract-functions/signLbtcDestionationAddr/signLbtcDestionationAddr.stories.tsx +0 -64
- package/src/contract-functions/signNetworkFee/getTypedData.ts +0 -41
- package/src/contract-functions/signNetworkFee/index.ts +0 -1
- package/src/contract-functions/signNetworkFee/signNetworkFee.stories.tsx +0 -94
- package/src/contract-functions/signNetworkFee/signNetworkFee.ts +0 -106
- package/src/contract-functions/signStakeAndBake/__tests__/signStakeAndBake.test.ts +0 -888
- package/src/contract-functions/signStakeAndBake/handleApprove.ts +0 -81
- package/src/contract-functions/signStakeAndBake/handlePermit.ts +0 -28
- package/src/contract-functions/signStakeAndBake/index.ts +0 -2
- package/src/contract-functions/signStakeAndBake/signStakeAndBake.stories.tsx +0 -202
- package/src/contract-functions/signStakeAndBake/signStakeAndBake.ts +0 -160
- package/src/contract-functions/signStakeAndBake/typed-data-builder.ts +0 -137
- package/src/contract-functions/signStakeAndBake/utils.ts +0 -61
- package/src/contract-functions/signStakeAndBake/validation.ts +0 -124
- package/src/contract-functions/unstakeLBTC/index.ts +0 -1
- package/src/contract-functions/unstakeLBTC/unstakeLBTC.stories.tsx +0 -92
- package/src/contract-functions/unstakeLBTC/unstakeLBTC.ts +0 -396
- package/src/contracts/abis/index.ts +0 -29
- package/src/contracts/index.ts +0 -63
- package/src/contracts/types.ts +0 -143
- package/src/contracts/utils.ts +0 -288
- package/src/core/assets/catalog.ts +0 -343
- package/src/core/assets/index.ts +0 -40
- package/src/core/assets/types.ts +0 -142
- package/src/core/assets/utils.ts +0 -287
- package/src/core/chains/catalog.ts +0 -396
- package/src/core/chains/index.ts +0 -39
- package/src/core/chains/types.ts +0 -193
- package/src/core/chains/utils.ts +0 -245
- package/src/core/index.ts +0 -72
- package/src/core/types.ts +0 -126
- package/src/debug-api/btc-script-to-address.ts +0 -20
- package/src/debug-api/btc-tx-info.ts +0 -32
- package/src/debug-api/evm-by-btc-address.ts +0 -26
- package/src/debug-api/index.ts +0 -3
- package/src/defi/README.md +0 -517
- package/src/defi/defi-registry.stories.tsx +0 -527
- package/src/defi/defi-registry.ts +0 -295
- package/src/defi/index.ts +0 -17
- package/src/index.ts +0 -336
- package/src/metrics/get-additional-rewards.ts +0 -69
- package/src/metrics/get-lbtc-apy.ts +0 -74
- package/src/metrics/get-lbtc-stats.stories.tsx +0 -57
- package/src/metrics/get-lbtc-stats.ts +0 -59
- package/src/metrics/get-positions-summary.stories.tsx +0 -58
- package/src/metrics/get-positions-summary.ts +0 -132
- package/src/modules/CapabilityRegistry.ts +0 -125
- package/src/modules/apiModule.ts +0 -51
- package/src/modules/btcModule.ts +0 -43
- package/src/modules/evmModule.ts +0 -48
- package/src/modules/index.ts +0 -60
- package/src/referrals/ReferralsClient.ts +0 -34
- package/src/referrals/index.ts +0 -1
- package/src/services/ApiService.ts +0 -152
- package/src/services/BtcService.ts +0 -29
- package/src/services/EvmService.ts +0 -127
- package/src/services/index.ts +0 -43
- package/src/shared/__tests__/errors.test.ts +0 -185
- package/src/shared/__tests__/events.test.ts +0 -120
- package/src/shared/__tests__/types.test.ts +0 -155
- package/src/shared/actions/BaseAction.ts +0 -497
- package/src/shared/actions/__tests__/BaseAction.test.ts +0 -292
- package/src/shared/actions/index.ts +0 -9
- package/src/shared/constants/statusConstants.ts +0 -108
- package/src/shared/context/ContextBuilder.ts +0 -149
- package/src/shared/context/index.ts +0 -8
- package/src/shared/context/types.ts +0 -156
- package/src/shared/deposits/depositStatus.ts +0 -402
- package/src/shared/deposits/index.ts +0 -29
- package/src/shared/errors.ts +0 -405
- package/src/shared/events.ts +0 -260
- package/src/shared/evm/switchChain.ts +0 -109
- package/src/shared/index.ts +0 -54
- package/src/shared/monitoring/__tests__/createEventEmitter.test.ts +0 -150
- package/src/shared/monitoring/createEventEmitter.ts +0 -160
- package/src/shared/monitoring/createProgressEmitter.ts +0 -46
- package/src/shared/monitoring/depositMonitor.ts +0 -211
- package/src/shared/monitoring/index.ts +0 -25
- package/src/shared/validation/index.ts +0 -411
- package/src/stories/arg-types.ts +0 -38
- package/src/stories/components/Badge.tsx +0 -27
- package/src/stories/components/Button/Button.css +0 -10
- package/src/stories/components/Button/Button.tsx +0 -52
- package/src/stories/components/Button/index.ts +0 -1
- package/src/stories/components/Card.tsx +0 -18
- package/src/stories/components/CodeBlock/CodeBlock.tsx +0 -27
- package/src/stories/components/CodeBlock/CodeBlockStyles.css +0 -3
- package/src/stories/components/CodeBlock/index.ts +0 -1
- package/src/stories/components/ConnectButton/connect-button.tsx +0 -248
- package/src/stories/components/ConnectButton/index.ts +0 -1
- package/src/stories/components/JsonPreview.tsx +0 -84
- package/src/stories/components/Spinner/Spinner.tsx +0 -27
- package/src/stories/components/Spinner/index.ts +0 -1
- package/src/stories/components/StatsCard.tsx +0 -30
- package/src/stories/components/StatusIndicator.tsx +0 -37
- package/src/stories/components/TreeNode.tsx +0 -47
- package/src/stories/components/decorators/function-type.tsx +0 -63
- package/src/stories/components/decorators/index.ts +0 -2
- package/src/stories/components/decorators/wagmi-decorator.tsx +0 -92
- package/src/stories/components/error-block.tsx +0 -21
- package/src/stories/components/index.ts +0 -11
- package/src/stories/constants.ts +0 -3
- package/src/stories/hooks/useConnection.ts +0 -63
- package/src/stories/hooks/useQuery.ts +0 -57
- package/src/tokens/__tests__/token-addresses.test.ts +0 -551
- package/src/tokens/abi/ASSET_ROUTER_ABI.ts +0 -1966
- package/src/tokens/abi/BRIDGE_TOKEN_ADAPTER_ABI.ts +0 -1405
- package/src/tokens/abi/BTCK_ABI.ts +0 -1092
- package/src/tokens/abi/KATANA_BASCULE_ABI.ts +0 -653
- package/src/tokens/abi/LBTC_ABI.json +0 -1761
- package/src/tokens/abi/LBTC_ABI.ts +0 -1761
- package/src/tokens/abi/LBTC_BASCULE_ABI.json +0 -850
- package/src/tokens/abi/NATIVE_LBTC_ABI.ts +0 -1147
- package/src/tokens/abi/STLBTC_ABI.ts +0 -1062
- package/src/tokens/cross-chain-addresses.stories.tsx +0 -236
- package/src/tokens/denomination-utils.stories.tsx +0 -176
- package/src/tokens/getLbtcContractAddresses.stories.tsx +0 -158
- package/src/tokens/getTokenByAddress.stories.tsx +0 -172
- package/src/tokens/getTokenContractInfo.stories.tsx +0 -148
- package/src/tokens/getTokenInfo.stories.tsx +0 -133
- package/src/tokens/isUpgradedContract.stories.tsx +0 -124
- package/src/tokens/lbtc-addresses.ts +0 -18
- package/src/tokens/token-addresses.ts +0 -477
- package/src/tokens/tokens.ts +0 -249
- package/src/tokens/types.ts +0 -80
- package/src/utils/array.ts +0 -31
- package/src/utils/block.ts +0 -23
- package/src/utils/chain.ts +0 -152
- package/src/utils/consoleLogger.ts +0 -140
- package/src/utils/ensureNotSanctionedAddress.ts +0 -11
- package/src/utils/env.ts +0 -20
- package/src/utils/err.ts +0 -83
- package/src/utils/evmAccount.ts +0 -47
- package/src/utils/gas.ts +0 -36
- package/src/utils/hex.ts +0 -9
- package/src/utils/http.ts +0 -224
- package/src/utils/numbers.ts +0 -37
- package/src/utils/pagination.ts +0 -70
- package/src/utils/satoshi.ts +0 -41
- package/src/utils/time.ts +0 -12
- package/src/utils/transaction-executor.ts +0 -299
- package/src/vaults/abi/SILO_VAULT_SPENDER_ABI.json +0 -793
- package/src/vaults/abi/VEDA_VAULT_ABI.json +0 -452
- package/src/vaults/abi/VEDA_VAULT_ACCOUNTANT_ABI.json +0 -591
- package/src/vaults/abi/VEDA_VAULT_BASE_ASSET_ABI.json +0 -296
- package/src/vaults/abi/VEDA_VAULT_BORING_WITHDRAW_QUEUE_ABI.json +0 -502
- package/src/vaults/abi/VEDA_VAULT_LENS_ABI.json +0 -175
- package/src/vaults/abi/VEDA_VAULT_SPENDER_ABI.json +0 -408
- package/src/vaults/abi/VEDA_VAULT_TELLER_ABI.json +0 -700
- package/src/vaults/abi/index.ts +0 -4
- package/src/vaults/index.ts +0 -46
- package/src/vaults/lib/config.ts +0 -184
- package/src/vaults/lib/metrics/get-vault-apy.stories.tsx +0 -58
- package/src/vaults/lib/metrics/get-vault-apy.ts +0 -176
- package/src/vaults/lib/metrics/get-vault-points.stories.tsx +0 -60
- package/src/vaults/lib/metrics/get-vault-points.ts +0 -74
- package/src/vaults/lib/metrics/get-vault-tvl.stories.tsx +0 -58
- package/src/vaults/lib/metrics/get-vault-tvl.ts +0 -121
- package/src/vaults/lib/ops/cancel-withdraw.stories.tsx +0 -80
- package/src/vaults/lib/ops/deposit.stories.tsx +0 -82
- package/src/vaults/lib/ops/deposit.ts +0 -152
- package/src/vaults/lib/ops/get-vault-deposits.stories.tsx +0 -65
- package/src/vaults/lib/ops/get-vault-deposits.ts +0 -209
- package/src/vaults/lib/ops/get-vault-withdrawals.stories.tsx +0 -67
- package/src/vaults/lib/ops/get-vault-withdrawals.ts +0 -349
- package/src/vaults/lib/ops/withdraw.stories.tsx +0 -82
- package/src/vaults/lib/ops/withdraw.ts +0 -225
- package/src/version.ts +0 -56
- package/src/vite-env.d.ts +0 -1
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Chain Configuration for Redeem
|
|
3
|
-
*
|
|
4
|
-
* Handles redeeming BTC.b to native BTC (cross-chain).
|
|
5
|
-
* This is the opposite operation to BTC Deposit.
|
|
6
|
-
*
|
|
7
|
-
* Future: Will also support L-Assets (L_ZEC, L_SOL, etc.) → native chains.
|
|
8
|
-
*
|
|
9
|
-
* @module chains/evm/actions/redeem/config/evm
|
|
10
|
-
*/
|
|
11
|
-
|
|
12
|
-
import {
|
|
13
|
-
AssetId,
|
|
14
|
-
Chain,
|
|
15
|
-
Env,
|
|
16
|
-
getEvmAssetChains,
|
|
17
|
-
} from '../../../../../core';
|
|
18
|
-
import { bitcoinAddressSchema } from '../../../../../shared/validation';
|
|
19
|
-
import type { ChainConfig } from './types';
|
|
20
|
-
|
|
21
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
22
|
-
// Catalog-Derived Chain Lists
|
|
23
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
24
|
-
|
|
25
|
-
/** EVM chains with BTC.b deployed (can redeem to BTC) */
|
|
26
|
-
const BTCB_PROD_CHAINS = getEvmAssetChains(AssetId.BTCb, [Env.prod]);
|
|
27
|
-
const BTCB_TESTNET_CHAINS = getEvmAssetChains(AssetId.BTCb, [
|
|
28
|
-
Env.testnet,
|
|
29
|
-
Env.stage,
|
|
30
|
-
Env.dev,
|
|
31
|
-
Env.ibc,
|
|
32
|
-
]);
|
|
33
|
-
|
|
34
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
35
|
-
// Configuration Objects
|
|
36
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
37
|
-
|
|
38
|
-
/**
|
|
39
|
-
* EVM redeem configuration
|
|
40
|
-
*
|
|
41
|
-
* Currently supports BTC.b → BTC (cross-chain to Bitcoin).
|
|
42
|
-
* Source chains derived from BTC.b deployments in ASSET_CATALOG.
|
|
43
|
-
*/
|
|
44
|
-
export const evmConfig: ChainConfig = {
|
|
45
|
-
chainType: 'evm',
|
|
46
|
-
|
|
47
|
-
routes: [
|
|
48
|
-
// BTC.b → BTC (to Bitcoin Mainnet)
|
|
49
|
-
{
|
|
50
|
-
assetIn: AssetId.BTCb,
|
|
51
|
-
assetOut: AssetId.BTC,
|
|
52
|
-
sourceChains: BTCB_PROD_CHAINS,
|
|
53
|
-
destChain: Chain.BITCOIN_MAINNET,
|
|
54
|
-
envs: [Env.prod],
|
|
55
|
-
},
|
|
56
|
-
// BTC.b → BTC (to Bitcoin Signet - testnet)
|
|
57
|
-
{
|
|
58
|
-
assetIn: AssetId.BTCb,
|
|
59
|
-
assetOut: AssetId.BTC,
|
|
60
|
-
sourceChains: BTCB_TESTNET_CHAINS,
|
|
61
|
-
destChain: Chain.BITCOIN_SIGNET,
|
|
62
|
-
envs: [Env.testnet, Env.stage, Env.dev, Env.ibc],
|
|
63
|
-
},
|
|
64
|
-
// TODO: Add L-Asset routes when deployed
|
|
65
|
-
// L-ZEC → ZEC, L-SOL → SOL, L-XRP → XRP, L-DOGE → DOGE
|
|
66
|
-
],
|
|
67
|
-
|
|
68
|
-
recipientSchema: bitcoinAddressSchema,
|
|
69
|
-
};
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* Check if a redeem route is supported
|
|
73
|
-
*/
|
|
74
|
-
export function isRedeemSupported(
|
|
75
|
-
assetIn: AssetId,
|
|
76
|
-
sourceChain: Chain,
|
|
77
|
-
env: Env,
|
|
78
|
-
): boolean {
|
|
79
|
-
return evmConfig.routes.some(
|
|
80
|
-
route =>
|
|
81
|
-
route.assetIn === assetIn &&
|
|
82
|
-
route.sourceChains.includes(sourceChain) &&
|
|
83
|
-
route.envs.includes(env),
|
|
84
|
-
);
|
|
85
|
-
}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Redeem Chain Configuration Types
|
|
3
|
-
*
|
|
4
|
-
* @module chains/evm/actions/redeem/config/types
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import type { z } from 'zod';
|
|
8
|
-
|
|
9
|
-
import type { AssetId, Chain, ChainType, Env } from '../../../../../core';
|
|
10
|
-
|
|
11
|
-
/**
|
|
12
|
-
* Route definition for EVM redeem operations
|
|
13
|
-
*/
|
|
14
|
-
export interface RouteDefinition {
|
|
15
|
-
/** Input asset (L-ZEC, L-SOL, etc.) */
|
|
16
|
-
assetIn: AssetId;
|
|
17
|
-
/** Output asset (ZEC, SOL, etc.) */
|
|
18
|
-
assetOut: AssetId;
|
|
19
|
-
/** Supported source chains */
|
|
20
|
-
sourceChains: Chain[];
|
|
21
|
-
/** Destination chain */
|
|
22
|
-
destChain: Chain;
|
|
23
|
-
/** Supported environments */
|
|
24
|
-
envs: Env[];
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
/**
|
|
28
|
-
* Chain-specific configuration for EVM redeem operations
|
|
29
|
-
*/
|
|
30
|
-
export interface ChainConfig {
|
|
31
|
-
/** Chain type identifier */
|
|
32
|
-
chainType: ChainType;
|
|
33
|
-
|
|
34
|
-
/** Supported routes for this chain type */
|
|
35
|
-
routes: RouteDefinition[];
|
|
36
|
-
|
|
37
|
-
/** Recipient address validation Zod schema */
|
|
38
|
-
recipientSchema: z.ZodType<string>;
|
|
39
|
-
}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Redeem Factory Functions
|
|
3
|
-
*
|
|
4
|
-
* @module chains/evm/actions/redeem/factory
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import type { LombardConfig } from '../../../../config/types';
|
|
8
|
-
import type { EvmCoreContext } from '../../../../shared/context';
|
|
9
|
-
import { createEvmCoreContext } from '../../../../shared/context';
|
|
10
|
-
import { EvmRedeem } from './EvmRedeem';
|
|
11
|
-
import type { EvmRedeemParams } from './types';
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Create EvmRedeem action from config
|
|
15
|
-
*
|
|
16
|
-
* @internal This factory is for internal use. Use createLombardSDK() instead:
|
|
17
|
-
*
|
|
18
|
-
* @example
|
|
19
|
-
* ```typescript
|
|
20
|
-
* const sdk = await createLombardSDK({ env: Env.prod, providers: { evm: () => window.ethereum } });
|
|
21
|
-
* const redeem = sdk.chain.evm.redeem({
|
|
22
|
-
* sourceChain: Chain.ETHEREUM,
|
|
23
|
-
* });
|
|
24
|
-
* await redeem.prepare({ amount: '0.1' });
|
|
25
|
-
* ```
|
|
26
|
-
*/
|
|
27
|
-
export function evmRedeem(
|
|
28
|
-
config: LombardConfig,
|
|
29
|
-
params: EvmRedeemParams,
|
|
30
|
-
): EvmRedeem {
|
|
31
|
-
const ctx = createEvmCoreContext(config);
|
|
32
|
-
return new EvmRedeem(ctx, params);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
* Create EvmRedeem action from context
|
|
37
|
-
*/
|
|
38
|
-
export function createEvmRedeem(
|
|
39
|
-
ctx: EvmCoreContext,
|
|
40
|
-
params: EvmRedeemParams,
|
|
41
|
-
): EvmRedeem {
|
|
42
|
-
return new EvmRedeem(ctx, params);
|
|
43
|
-
}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Redeem Action
|
|
3
|
-
*
|
|
4
|
-
* @module chains/evm/actions/redeem
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
export type { ChainConfig, RouteDefinition } from './config';
|
|
8
|
-
export { evmConfig, isRedeemSupported } from './config';
|
|
9
|
-
export { EvmRedeem } from './EvmRedeem';
|
|
10
|
-
export { createEvmRedeem,evmRedeem } from './factory';
|
|
11
|
-
export {
|
|
12
|
-
type EvmRedeemParams,
|
|
13
|
-
type EvmRedeemPrepareParams,
|
|
14
|
-
type EvmRedeemProgress,
|
|
15
|
-
EvmRedeemStatus,
|
|
16
|
-
type IEvmRedeem,
|
|
17
|
-
} from './types';
|
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Redeem Action Types
|
|
3
|
-
*
|
|
4
|
-
* Redeems BTC.b to native BTC (cross-chain).
|
|
5
|
-
* This is the opposite operation to BTC Deposit.
|
|
6
|
-
*
|
|
7
|
-
* Flow: BTC.b (EVM) → BTC (Bitcoin)
|
|
8
|
-
*
|
|
9
|
-
* ## Fee Authorization
|
|
10
|
-
*
|
|
11
|
-
* On Ethereum/Sepolia, fee authorization is required before redemption.
|
|
12
|
-
*
|
|
13
|
-
* **Flow with fee auth (Ethereum/Sepolia):**
|
|
14
|
-
* IDLE → NEEDS_FEE_AUTHORIZATION → READY → COMPLETED
|
|
15
|
-
*
|
|
16
|
-
* **Flow without fee auth (Base, BSC - subsidized):**
|
|
17
|
-
* IDLE → READY → COMPLETED
|
|
18
|
-
*
|
|
19
|
-
* @module chains/evm/actions/redeem/types
|
|
20
|
-
*/
|
|
21
|
-
|
|
22
|
-
import type {
|
|
23
|
-
AssetId,
|
|
24
|
-
Chain,
|
|
25
|
-
StepStatus,
|
|
26
|
-
StrategyProgress,
|
|
27
|
-
} from '../../../../core';
|
|
28
|
-
import type { MonitorableAction } from '../../../../shared/actions/BaseAction';
|
|
29
|
-
import type { EvmOperationStatus } from '../../../../shared/constants/statusConstants';
|
|
30
|
-
import type { LombardError } from '../../../../shared/errors';
|
|
31
|
-
import type { FeeAuthState } from '../../shared/feeAuth';
|
|
32
|
-
|
|
33
|
-
// Re-export status for convenience
|
|
34
|
-
export { EvmOperationStatus as EvmRedeemStatus } from '../../../../shared/constants/statusConstants';
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* EVM Redeem parameters
|
|
38
|
-
*
|
|
39
|
-
* Redeems BTC.b to native BTC on Bitcoin network.
|
|
40
|
-
*/
|
|
41
|
-
export interface EvmRedeemParams {
|
|
42
|
-
/** Input asset (BTC.b) */
|
|
43
|
-
assetIn: AssetId;
|
|
44
|
-
/** Output asset (BTC) */
|
|
45
|
-
assetOut: AssetId;
|
|
46
|
-
/** Source chain (EVM chain where BTC.b is held) */
|
|
47
|
-
sourceChain: Chain;
|
|
48
|
-
/** Destination chain (Bitcoin network) */
|
|
49
|
-
destChain: Chain;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* EVM Redeem prepare parameters
|
|
54
|
-
*/
|
|
55
|
-
export interface EvmRedeemPrepareParams {
|
|
56
|
-
/** Amount of BTC.b to redeem */
|
|
57
|
-
amount: string;
|
|
58
|
-
/** Bitcoin address to receive BTC */
|
|
59
|
-
recipient: string;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
/**
|
|
63
|
-
* EVM Redeem progress
|
|
64
|
-
*/
|
|
65
|
-
export interface EvmRedeemProgress
|
|
66
|
-
extends StrategyProgress<EvmOperationStatus> {
|
|
67
|
-
status: EvmOperationStatus;
|
|
68
|
-
steps: {
|
|
69
|
-
redeeming: StepStatus;
|
|
70
|
-
};
|
|
71
|
-
txHash?: string;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
/**
|
|
75
|
-
* EVM Redeem interface
|
|
76
|
-
*/
|
|
77
|
-
export interface IEvmRedeem extends MonitorableAction {
|
|
78
|
-
readonly status: EvmOperationStatus;
|
|
79
|
-
readonly error: LombardError | null;
|
|
80
|
-
readonly amount?: string;
|
|
81
|
-
readonly recipient?: string;
|
|
82
|
-
readonly needsApproval: boolean;
|
|
83
|
-
readonly txHash?: string;
|
|
84
|
-
|
|
85
|
-
/** Fee authorization state (for UI display) */
|
|
86
|
-
readonly feeAuth: FeeAuthState;
|
|
87
|
-
|
|
88
|
-
prepare(params: EvmRedeemPrepareParams): Promise<void>;
|
|
89
|
-
/** Authorize the network fee (when status is NEEDS_FEE_AUTHORIZATION) */
|
|
90
|
-
authorizeFee(): Promise<void>;
|
|
91
|
-
approve(): Promise<void>;
|
|
92
|
-
execute(): Promise<{ txHash: string }>;
|
|
93
|
-
}
|
|
@@ -1,339 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Stake Action
|
|
3
|
-
*
|
|
4
|
-
* Stakes BTC.b to receive LBTC via the Asset Router.
|
|
5
|
-
* This is the EVM equivalent of staking - converting wrapped BTC to LBTC.
|
|
6
|
-
*
|
|
7
|
-
* ## Approval (Avalanche only)
|
|
8
|
-
*
|
|
9
|
-
* On Avalanche, users must approve the Adapter contract to spend their BTC.b.
|
|
10
|
-
*
|
|
11
|
-
* ## Fee Authorization (Ethereum/Sepolia only)
|
|
12
|
-
*
|
|
13
|
-
* Fee authorization is required on unsubsidized chains (Ethereum, Sepolia).
|
|
14
|
-
* On subsidized chains (Avalanche, Base, BSC), no fee auth is required.
|
|
15
|
-
*
|
|
16
|
-
* **Flow with approval (Avalanche):**
|
|
17
|
-
* IDLE → NEEDS_APPROVAL → READY → COMPLETED
|
|
18
|
-
*
|
|
19
|
-
* **Flow with fee auth (Ethereum/Sepolia):**
|
|
20
|
-
* IDLE → NEEDS_FEE_AUTHORIZATION → READY → COMPLETED
|
|
21
|
-
*
|
|
22
|
-
* **Flow without either (Base, BSC):**
|
|
23
|
-
* IDLE → READY → COMPLETED
|
|
24
|
-
*
|
|
25
|
-
* @module chains/evm/actions/stake/EvmStake
|
|
26
|
-
*/
|
|
27
|
-
|
|
28
|
-
import BigNumber from 'bignumber.js';
|
|
29
|
-
import type { EIP1193Provider } from 'viem';
|
|
30
|
-
import { z } from 'zod';
|
|
31
|
-
|
|
32
|
-
import { ChainId } from '../../../../common/chains';
|
|
33
|
-
import {
|
|
34
|
-
approveToken,
|
|
35
|
-
getTokenAllowance,
|
|
36
|
-
} from '../../../../contract-functions/approveToken';
|
|
37
|
-
import { depositToken } from '../../../../contract-functions/deposit';
|
|
38
|
-
import { parseChainIdentifier, StepStatus } from '../../../../core';
|
|
39
|
-
import { BaseAction } from '../../../../shared/actions/BaseAction';
|
|
40
|
-
import { EvmOperationStatus } from '../../../../shared/constants/statusConstants';
|
|
41
|
-
import type { EvmCoreContext } from '../../../../shared/context';
|
|
42
|
-
import { LombardError } from '../../../../shared/errors';
|
|
43
|
-
import type { StakeEventMap } from '../../../../shared/events';
|
|
44
|
-
import {
|
|
45
|
-
evmAmountSchema,
|
|
46
|
-
validatePrepareParams,
|
|
47
|
-
} from '../../../../shared/validation';
|
|
48
|
-
import { AddressKind, Token } from '../../../../tokens/token-addresses';
|
|
49
|
-
import { getTokenContractInfo } from '../../../../tokens/tokens';
|
|
50
|
-
import {
|
|
51
|
-
authorizeFee as authorizeFeeShared,
|
|
52
|
-
checkFeeAuthorization,
|
|
53
|
-
createInitialFeeAuthState,
|
|
54
|
-
type FeeAuthState,
|
|
55
|
-
} from '../../shared/feeAuth';
|
|
56
|
-
import type { EvmStakeParams, EvmStakePrepareParams, IEvmStake } from './types';
|
|
57
|
-
|
|
58
|
-
/**
|
|
59
|
-
* Chains that require ERC20 approval for BTC.b staking (to the Adapter)
|
|
60
|
-
*/
|
|
61
|
-
const APPROVAL_REQUIRED_CHAINS: readonly ChainId[] = [
|
|
62
|
-
ChainId.avalanche,
|
|
63
|
-
ChainId.avalancheFuji,
|
|
64
|
-
] as const;
|
|
65
|
-
|
|
66
|
-
function requiresApproval(chainId: ChainId): boolean {
|
|
67
|
-
return APPROVAL_REQUIRED_CHAINS.includes(chainId);
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
export class EvmStake
|
|
71
|
-
extends BaseAction<StakeEventMap, EvmOperationStatus>
|
|
72
|
-
implements IEvmStake
|
|
73
|
-
{
|
|
74
|
-
private _amount?: string;
|
|
75
|
-
private _txHash?: string;
|
|
76
|
-
private _feeAuth: FeeAuthState = createInitialFeeAuthState();
|
|
77
|
-
private _account?: `0x${string}`;
|
|
78
|
-
private _needsApproval = false;
|
|
79
|
-
private _spenderAddress?: `0x${string}`;
|
|
80
|
-
|
|
81
|
-
constructor(
|
|
82
|
-
private readonly ctx: EvmCoreContext,
|
|
83
|
-
private readonly params: EvmStakeParams,
|
|
84
|
-
) {
|
|
85
|
-
super(EvmOperationStatus.IDLE);
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
get amount(): string | undefined {
|
|
89
|
-
return this._amount;
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
get txHash(): string | undefined {
|
|
93
|
-
return this._txHash;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
/** Fee authorization state (for UI display) */
|
|
97
|
-
get feeAuth(): FeeAuthState {
|
|
98
|
-
return this._feeAuth;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
/** Whether approval is needed */
|
|
102
|
-
get needsApproval(): boolean {
|
|
103
|
-
return this._needsApproval;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
async prepare(params: EvmStakePrepareParams): Promise<void> {
|
|
107
|
-
this.assertStatus(EvmOperationStatus.IDLE, 'prepare');
|
|
108
|
-
|
|
109
|
-
return this.act(async () => {
|
|
110
|
-
const validated = validatePrepareParams(this.prepareSchema, params);
|
|
111
|
-
this._amount = validated.amount;
|
|
112
|
-
|
|
113
|
-
const provider = await this.ctx.getProvider('evm');
|
|
114
|
-
if (!provider) {
|
|
115
|
-
throw LombardError.providerMissing(this.params.sourceChain, 'evm');
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
const accounts = await (provider as EIP1193Provider).request({
|
|
119
|
-
method: 'eth_accounts',
|
|
120
|
-
});
|
|
121
|
-
const account = (accounts as string[])[0] as `0x${string}`;
|
|
122
|
-
|
|
123
|
-
if (!account) {
|
|
124
|
-
throw LombardError.providerMissing(this.params.sourceChain, 'evm');
|
|
125
|
-
}
|
|
126
|
-
this._account = account;
|
|
127
|
-
|
|
128
|
-
const chainId = parseChainIdentifier(this.params.sourceChain) as ChainId;
|
|
129
|
-
|
|
130
|
-
// Check if approval is required (Avalanche only)
|
|
131
|
-
if (requiresApproval(chainId)) {
|
|
132
|
-
// Get the Adapter address (spender for approval)
|
|
133
|
-
const adapterInfo = await getTokenContractInfo(
|
|
134
|
-
Token.BTCb,
|
|
135
|
-
chainId,
|
|
136
|
-
this.ctx.env,
|
|
137
|
-
AddressKind.Adapter,
|
|
138
|
-
);
|
|
139
|
-
this._spenderAddress = adapterInfo.address;
|
|
140
|
-
|
|
141
|
-
// Check current allowance
|
|
142
|
-
const allowance = await getTokenAllowance({
|
|
143
|
-
token: Token.BTCb,
|
|
144
|
-
owner: account,
|
|
145
|
-
spender: adapterInfo.address,
|
|
146
|
-
chainId,
|
|
147
|
-
env: this.ctx.env,
|
|
148
|
-
});
|
|
149
|
-
|
|
150
|
-
const requiredAmount = new BigNumber(validated.amount);
|
|
151
|
-
this._needsApproval = allowance.isLessThan(requiredAmount);
|
|
152
|
-
|
|
153
|
-
if (this._needsApproval) {
|
|
154
|
-
this.emitProgress({
|
|
155
|
-
status: EvmOperationStatus.NEEDS_APPROVAL,
|
|
156
|
-
steps: { approval: StepStatus.PENDING, staking: StepStatus.IDLE },
|
|
157
|
-
});
|
|
158
|
-
this.updateStatus(EvmOperationStatus.NEEDS_APPROVAL);
|
|
159
|
-
return;
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
// Check fee authorization status (BTC.b → LBTC uses Token.LBTC for fee signature)
|
|
164
|
-
const feeAuthResult = await checkFeeAuthorization(
|
|
165
|
-
chainId,
|
|
166
|
-
account,
|
|
167
|
-
this.ctx.env,
|
|
168
|
-
Token.LBTC,
|
|
169
|
-
);
|
|
170
|
-
|
|
171
|
-
// Update fee auth state
|
|
172
|
-
this._feeAuth = {
|
|
173
|
-
requiresAuth: feeAuthResult.requiresAuth,
|
|
174
|
-
isAuthorized: feeAuthResult.hasValidSignature,
|
|
175
|
-
feeInSatoshis: feeAuthResult.feeInSatoshis,
|
|
176
|
-
feeFormatted: feeAuthResult.feeFormatted,
|
|
177
|
-
expirationDate: feeAuthResult.expirationDate,
|
|
178
|
-
};
|
|
179
|
-
|
|
180
|
-
// Determine next status based on fee auth
|
|
181
|
-
const needsFeeAuth =
|
|
182
|
-
feeAuthResult.requiresAuth && !feeAuthResult.hasValidSignature;
|
|
183
|
-
|
|
184
|
-
if (needsFeeAuth) {
|
|
185
|
-
this.emitProgress({
|
|
186
|
-
status: EvmOperationStatus.NEEDS_FEE_AUTHORIZATION,
|
|
187
|
-
steps: { staking: StepStatus.IDLE },
|
|
188
|
-
});
|
|
189
|
-
this.updateStatus(EvmOperationStatus.NEEDS_FEE_AUTHORIZATION);
|
|
190
|
-
} else {
|
|
191
|
-
this.emitProgress({
|
|
192
|
-
status: EvmOperationStatus.READY,
|
|
193
|
-
steps: { staking: StepStatus.PENDING },
|
|
194
|
-
});
|
|
195
|
-
this.updateStatus(EvmOperationStatus.READY);
|
|
196
|
-
}
|
|
197
|
-
});
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
/**
|
|
201
|
-
* Approve BTC.b spending (Avalanche only)
|
|
202
|
-
*
|
|
203
|
-
* Must be called when status is NEEDS_APPROVAL.
|
|
204
|
-
*/
|
|
205
|
-
async approve(): Promise<void> {
|
|
206
|
-
this.assertStatus(EvmOperationStatus.NEEDS_APPROVAL, 'approve');
|
|
207
|
-
|
|
208
|
-
return this.act(async () => {
|
|
209
|
-
if (!this._account || !this._spenderAddress || !this._amount) {
|
|
210
|
-
throw LombardError.missingParameter(
|
|
211
|
-
'account, spenderAddress, or amount',
|
|
212
|
-
);
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
const provider = await this.ctx.getProvider('evm');
|
|
216
|
-
if (!provider) {
|
|
217
|
-
throw LombardError.providerMissing(this.params.sourceChain, 'evm');
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
const chainId = parseChainIdentifier(this.params.sourceChain) as ChainId;
|
|
221
|
-
|
|
222
|
-
// Execute approval transaction
|
|
223
|
-
await approveToken({
|
|
224
|
-
account: this._account,
|
|
225
|
-
token: Token.BTCb,
|
|
226
|
-
spender: this._spenderAddress,
|
|
227
|
-
amount: this._amount,
|
|
228
|
-
chainId,
|
|
229
|
-
provider: provider as EIP1193Provider,
|
|
230
|
-
env: this.ctx.env,
|
|
231
|
-
});
|
|
232
|
-
|
|
233
|
-
// Mark approval as done
|
|
234
|
-
this._needsApproval = false;
|
|
235
|
-
|
|
236
|
-
this.emitProgress({
|
|
237
|
-
status: EvmOperationStatus.READY,
|
|
238
|
-
steps: { approval: StepStatus.COMPLETE, staking: StepStatus.PENDING },
|
|
239
|
-
});
|
|
240
|
-
}, EvmOperationStatus.READY);
|
|
241
|
-
}
|
|
242
|
-
|
|
243
|
-
async authorizeFee(): Promise<void> {
|
|
244
|
-
this.assertStatus(
|
|
245
|
-
EvmOperationStatus.NEEDS_FEE_AUTHORIZATION,
|
|
246
|
-
'authorizeFee',
|
|
247
|
-
);
|
|
248
|
-
|
|
249
|
-
return this.act(async () => {
|
|
250
|
-
if (!this._feeAuth.feeInSatoshis) {
|
|
251
|
-
throw LombardError.missingParameter('feeInSatoshis');
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
const provider = await this.ctx.getProvider('evm');
|
|
255
|
-
if (!provider) {
|
|
256
|
-
throw LombardError.providerMissing(this.params.sourceChain, 'evm');
|
|
257
|
-
}
|
|
258
|
-
|
|
259
|
-
const chainId = parseChainIdentifier(this.params.sourceChain) as ChainId;
|
|
260
|
-
|
|
261
|
-
// Sign and store the fee authorization
|
|
262
|
-
await authorizeFeeShared({
|
|
263
|
-
chainId,
|
|
264
|
-
account: this._account!,
|
|
265
|
-
feeInSatoshis: this._feeAuth.feeInSatoshis,
|
|
266
|
-
provider: provider as EIP1193Provider,
|
|
267
|
-
env: this.ctx.env,
|
|
268
|
-
token: Token.LBTC, // BTC.b → LBTC uses LBTC token for fee signature
|
|
269
|
-
});
|
|
270
|
-
|
|
271
|
-
// Update fee auth state
|
|
272
|
-
this._feeAuth = {
|
|
273
|
-
...this._feeAuth,
|
|
274
|
-
isAuthorized: true,
|
|
275
|
-
};
|
|
276
|
-
|
|
277
|
-
this.emitProgress({
|
|
278
|
-
status: EvmOperationStatus.READY,
|
|
279
|
-
steps: { staking: StepStatus.PENDING },
|
|
280
|
-
});
|
|
281
|
-
}, EvmOperationStatus.READY);
|
|
282
|
-
}
|
|
283
|
-
|
|
284
|
-
async execute(): Promise<{ txHash: string }> {
|
|
285
|
-
this.assertStatus(EvmOperationStatus.READY, 'execute');
|
|
286
|
-
|
|
287
|
-
return this.act(async () => {
|
|
288
|
-
const provider = await this.ctx.getProvider('evm');
|
|
289
|
-
if (!provider) {
|
|
290
|
-
throw LombardError.providerMissing(this.params.sourceChain, 'evm');
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
const chainId = parseChainIdentifier(this.params.sourceChain) as ChainId;
|
|
294
|
-
|
|
295
|
-
// Get account from provider
|
|
296
|
-
const accounts = await (provider as EIP1193Provider).request({
|
|
297
|
-
method: 'eth_accounts',
|
|
298
|
-
});
|
|
299
|
-
const account = (accounts as string[])[0] as `0x${string}`;
|
|
300
|
-
|
|
301
|
-
if (!account) {
|
|
302
|
-
throw LombardError.providerMissing(this.params.sourceChain, 'evm');
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
this.emitProgress({
|
|
306
|
-
status: EvmOperationStatus.READY,
|
|
307
|
-
steps: { staking: StepStatus.PENDING },
|
|
308
|
-
});
|
|
309
|
-
|
|
310
|
-
// Execute BTC.b → LBTC via Asset Router
|
|
311
|
-
const txHash = await depositToken({
|
|
312
|
-
amount: this._amount!,
|
|
313
|
-
tokenIn: Token.BTCb,
|
|
314
|
-
tokenOut: Token.LBTC,
|
|
315
|
-
account,
|
|
316
|
-
chainId,
|
|
317
|
-
provider: provider as EIP1193Provider,
|
|
318
|
-
env: this.ctx.env,
|
|
319
|
-
});
|
|
320
|
-
|
|
321
|
-
this._txHash = txHash;
|
|
322
|
-
|
|
323
|
-
this.emitProgress({
|
|
324
|
-
status: EvmOperationStatus.COMPLETED,
|
|
325
|
-
steps: { staking: StepStatus.COMPLETE },
|
|
326
|
-
});
|
|
327
|
-
|
|
328
|
-
this.emitCompleted();
|
|
329
|
-
|
|
330
|
-
return { txHash };
|
|
331
|
-
}, EvmOperationStatus.COMPLETED);
|
|
332
|
-
}
|
|
333
|
-
|
|
334
|
-
private get prepareSchema() {
|
|
335
|
-
return z.object({
|
|
336
|
-
amount: evmAmountSchema,
|
|
337
|
-
});
|
|
338
|
-
}
|
|
339
|
-
}
|