@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,100 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Chain Configuration for Deposit
|
|
3
|
-
*
|
|
4
|
-
* Handles depositing wrapped BTC (WBTC, BTCb) to get LBTC.
|
|
5
|
-
* Routes are derived from ASSET_CATALOG to ensure consistency.
|
|
6
|
-
*
|
|
7
|
-
* @module chains/evm/actions/deposit/config/evm
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import {
|
|
11
|
-
AssetId,
|
|
12
|
-
Chain,
|
|
13
|
-
Env,
|
|
14
|
-
getEvmAssetChains,
|
|
15
|
-
} from '../../../../../core';
|
|
16
|
-
import { evmAddressSchema } from '../../../../../shared/validation';
|
|
17
|
-
import type { ChainConfig } from './types';
|
|
18
|
-
|
|
19
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
20
|
-
// Catalog-Derived Chain Lists
|
|
21
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Source chains: EVM chains with deposit assets (WBTC or BTCb)
|
|
25
|
-
* Note: We check for chains with any of the deposit assets
|
|
26
|
-
*/
|
|
27
|
-
const DEPOSIT_PROD_SOURCE_CHAINS = [
|
|
28
|
-
...new Set([
|
|
29
|
-
...getEvmAssetChains(AssetId.WBTC, [Env.prod]),
|
|
30
|
-
...getEvmAssetChains(AssetId.BTCb, [Env.prod]),
|
|
31
|
-
]),
|
|
32
|
-
];
|
|
33
|
-
|
|
34
|
-
const DEPOSIT_TESTNET_SOURCE_CHAINS = [
|
|
35
|
-
...new Set([
|
|
36
|
-
...getEvmAssetChains(AssetId.WBTC, [Env.testnet, Env.stage, Env.dev, Env.ibc]),
|
|
37
|
-
...getEvmAssetChains(AssetId.BTCb, [Env.testnet, Env.stage, Env.dev, Env.ibc]),
|
|
38
|
-
]),
|
|
39
|
-
];
|
|
40
|
-
|
|
41
|
-
/** Dest chains: EVM chains with LBTC deployed */
|
|
42
|
-
const LBTC_PROD_CHAINS = getEvmAssetChains(AssetId.LBTC, [Env.prod]);
|
|
43
|
-
const LBTC_TESTNET_CHAINS = getEvmAssetChains(AssetId.LBTC, [
|
|
44
|
-
Env.testnet,
|
|
45
|
-
Env.stage,
|
|
46
|
-
Env.dev,
|
|
47
|
-
Env.ibc,
|
|
48
|
-
]);
|
|
49
|
-
|
|
50
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
51
|
-
// Configuration Objects
|
|
52
|
-
// ═══════════════════════════════════════════════════════════════════════════
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* EVM deposit configuration
|
|
56
|
-
*
|
|
57
|
-
* Supports depositing WBTC/BTCb to get LBTC on EVM chains.
|
|
58
|
-
* Source chains derived from WBTC/BTCb deployments.
|
|
59
|
-
* Dest chains derived from LBTC deployments.
|
|
60
|
-
*/
|
|
61
|
-
export const evmConfig: ChainConfig = {
|
|
62
|
-
chainType: 'evm',
|
|
63
|
-
|
|
64
|
-
routes: [
|
|
65
|
-
// Production: WBTC/BTCb → LBTC
|
|
66
|
-
{
|
|
67
|
-
assetsIn: [AssetId.WBTC, AssetId.BTCb],
|
|
68
|
-
assetOut: AssetId.LBTC,
|
|
69
|
-
sourceChains: DEPOSIT_PROD_SOURCE_CHAINS,
|
|
70
|
-
destChains: LBTC_PROD_CHAINS,
|
|
71
|
-
envs: [Env.prod],
|
|
72
|
-
},
|
|
73
|
-
// Testnet
|
|
74
|
-
{
|
|
75
|
-
assetsIn: [AssetId.WBTC, AssetId.BTCb],
|
|
76
|
-
assetOut: AssetId.LBTC,
|
|
77
|
-
sourceChains: DEPOSIT_TESTNET_SOURCE_CHAINS,
|
|
78
|
-
destChains: LBTC_TESTNET_CHAINS,
|
|
79
|
-
envs: [Env.testnet, Env.stage, Env.dev, Env.ibc],
|
|
80
|
-
},
|
|
81
|
-
],
|
|
82
|
-
|
|
83
|
-
addressSchema: evmAddressSchema,
|
|
84
|
-
};
|
|
85
|
-
|
|
86
|
-
/**
|
|
87
|
-
* Check if a deposit route is supported
|
|
88
|
-
*/
|
|
89
|
-
export function isDepositSupported(
|
|
90
|
-
assetIn: AssetId,
|
|
91
|
-
sourceChain: Chain,
|
|
92
|
-
env: Env,
|
|
93
|
-
): boolean {
|
|
94
|
-
return evmConfig.routes.some(
|
|
95
|
-
route =>
|
|
96
|
-
route.assetsIn.includes(assetIn) &&
|
|
97
|
-
route.sourceChains.includes(sourceChain) &&
|
|
98
|
-
route.envs.includes(env),
|
|
99
|
-
);
|
|
100
|
-
}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Deposit Chain Configuration Types
|
|
3
|
-
*
|
|
4
|
-
* @module chains/evm/actions/deposit/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 deposit operations
|
|
13
|
-
*/
|
|
14
|
-
export interface RouteDefinition {
|
|
15
|
-
/** Supported input assets (e.g., WBTC, BTCb) */
|
|
16
|
-
assetsIn: AssetId[];
|
|
17
|
-
/** Output asset (e.g., LBTC) */
|
|
18
|
-
assetOut: AssetId;
|
|
19
|
-
/** Supported source chains */
|
|
20
|
-
sourceChains: Chain[];
|
|
21
|
-
/** Supported destination chains */
|
|
22
|
-
destChains: Chain[];
|
|
23
|
-
/** Supported environments */
|
|
24
|
-
envs: Env[];
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
/**
|
|
28
|
-
* Chain-specific configuration for EVM deposit 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
|
-
/** Address validation Zod schema */
|
|
38
|
-
addressSchema: z.ZodString;
|
|
39
|
-
}
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Deposit Factory Functions
|
|
3
|
-
*
|
|
4
|
-
* @module chains/evm/actions/deposit/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 { EvmDeposit } from './EvmDeposit';
|
|
11
|
-
import type { EvmDepositParams } from './types';
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Create EvmDeposit 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 deposit = sdk.chain.evm.deposit({
|
|
22
|
-
* sourceChain: Chain.ETHEREUM,
|
|
23
|
-
* assetIn: AssetId.WBTC,
|
|
24
|
-
* });
|
|
25
|
-
* await deposit.prepare({ amount: '0.1' });
|
|
26
|
-
* ```
|
|
27
|
-
*/
|
|
28
|
-
export function evmDeposit(
|
|
29
|
-
config: LombardConfig,
|
|
30
|
-
params: EvmDepositParams,
|
|
31
|
-
): EvmDeposit {
|
|
32
|
-
const ctx = createEvmCoreContext(config);
|
|
33
|
-
return new EvmDeposit(ctx, params);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* Create EvmDeposit action from context
|
|
38
|
-
*/
|
|
39
|
-
export function createEvmDeposit(
|
|
40
|
-
ctx: EvmCoreContext,
|
|
41
|
-
params: EvmDepositParams,
|
|
42
|
-
): EvmDeposit {
|
|
43
|
-
return new EvmDeposit(ctx, params);
|
|
44
|
-
}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Deposit Action
|
|
3
|
-
*
|
|
4
|
-
* @module chains/evm/actions/deposit
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
export type { ChainConfig, RouteDefinition } from './config';
|
|
8
|
-
export { evmConfig, isDepositSupported } from './config';
|
|
9
|
-
export { EvmDeposit } from './EvmDeposit';
|
|
10
|
-
export { createEvmDeposit,evmDeposit } from './factory';
|
|
11
|
-
export {
|
|
12
|
-
type EvmDepositParams,
|
|
13
|
-
type EvmDepositPrepareParams,
|
|
14
|
-
type EvmDepositProgress,
|
|
15
|
-
EvmDepositStatus,
|
|
16
|
-
type IEvmDeposit,
|
|
17
|
-
} from './types';
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Deposit Action Types
|
|
3
|
-
*
|
|
4
|
-
* @module chains/evm/actions/deposit/types
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import type {
|
|
8
|
-
AssetId,
|
|
9
|
-
Chain,
|
|
10
|
-
StepStatus,
|
|
11
|
-
StrategyProgress,
|
|
12
|
-
} from '../../../../core';
|
|
13
|
-
import type { MonitorableAction } from '../../../../shared/actions/BaseAction';
|
|
14
|
-
import type { LombardError } from '../../../../shared/errors';
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* EVM Deposit status
|
|
18
|
-
*
|
|
19
|
-
* Note: There is NO 'failed' status. Error handling is separate from status:
|
|
20
|
-
* - `status` = "What step are you at?" (flow position)
|
|
21
|
-
* - `error` = "Did something go wrong?" (Error | null)
|
|
22
|
-
* - `isFailed` = Derived from `error !== null`
|
|
23
|
-
*
|
|
24
|
-
* Use `isLoading` for operation-in-progress state (no transitional statuses).
|
|
25
|
-
*/
|
|
26
|
-
export enum EvmDepositStatus {
|
|
27
|
-
IDLE = 'idle',
|
|
28
|
-
NEEDS_APPROVAL = 'needs-approval',
|
|
29
|
-
READY = 'ready',
|
|
30
|
-
BRIDGING = 'bridging',
|
|
31
|
-
COMPLETED = 'completed',
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* EVM Deposit parameters
|
|
36
|
-
*/
|
|
37
|
-
export interface EvmDepositParams {
|
|
38
|
-
/** Input asset (WBTC, BTCb) */
|
|
39
|
-
assetIn: AssetId;
|
|
40
|
-
/** Output asset (LBTC) */
|
|
41
|
-
assetOut: AssetId;
|
|
42
|
-
/** Source chain */
|
|
43
|
-
sourceChain: Chain;
|
|
44
|
-
/** Destination chain */
|
|
45
|
-
destChain: Chain;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
/**
|
|
49
|
-
* EVM Deposit prepare parameters
|
|
50
|
-
*/
|
|
51
|
-
export interface EvmDepositPrepareParams {
|
|
52
|
-
/** Amount to deposit */
|
|
53
|
-
amount: string;
|
|
54
|
-
/** Recipient address */
|
|
55
|
-
recipient: string;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
/**
|
|
59
|
-
* EVM Deposit progress
|
|
60
|
-
*/
|
|
61
|
-
export interface EvmDepositProgress extends StrategyProgress<EvmDepositStatus> {
|
|
62
|
-
status: EvmDepositStatus;
|
|
63
|
-
steps: {
|
|
64
|
-
approval: StepStatus;
|
|
65
|
-
execution: StepStatus;
|
|
66
|
-
bridging?: StepStatus;
|
|
67
|
-
};
|
|
68
|
-
txHash?: string;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* EVM Deposit interface
|
|
73
|
-
*/
|
|
74
|
-
export interface IEvmDeposit extends MonitorableAction {
|
|
75
|
-
readonly status: EvmDepositStatus;
|
|
76
|
-
readonly error: LombardError | null;
|
|
77
|
-
readonly amount?: string;
|
|
78
|
-
readonly recipient?: string;
|
|
79
|
-
readonly needsApproval: boolean;
|
|
80
|
-
readonly txHash?: string;
|
|
81
|
-
|
|
82
|
-
/** Set claim data from a notarized deposit (required before execute) */
|
|
83
|
-
setClaimData(data: string, proofSignature: string): void;
|
|
84
|
-
prepare(params: EvmDepositPrepareParams): Promise<void>;
|
|
85
|
-
approve(): Promise<void>;
|
|
86
|
-
execute(): Promise<{ txHash: string }>;
|
|
87
|
-
}
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Actions
|
|
3
|
-
*
|
|
4
|
-
* Exports for all EVM chain actions.
|
|
5
|
-
*
|
|
6
|
-
* @module chains/evm/actions
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
// Stake action
|
|
10
|
-
export {
|
|
11
|
-
createEvmStake,
|
|
12
|
-
EvmStake,
|
|
13
|
-
evmStake,
|
|
14
|
-
type EvmStakeParams,
|
|
15
|
-
type EvmStakePrepareParams,
|
|
16
|
-
type EvmStakeProgress,
|
|
17
|
-
EvmStakeStatus,
|
|
18
|
-
type IEvmStake,
|
|
19
|
-
} from './stake';
|
|
20
|
-
|
|
21
|
-
// Unstake action
|
|
22
|
-
export {
|
|
23
|
-
createEvmUnstake,
|
|
24
|
-
EvmUnstake,
|
|
25
|
-
evmUnstake,
|
|
26
|
-
type EvmUnstakeParams,
|
|
27
|
-
type EvmUnstakePrepareParams,
|
|
28
|
-
type EvmUnstakeProgress,
|
|
29
|
-
EvmUnstakeStatus,
|
|
30
|
-
type IEvmUnstake,
|
|
31
|
-
} from './unstake';
|
|
32
|
-
|
|
33
|
-
// Deposit action
|
|
34
|
-
export {
|
|
35
|
-
createEvmDeposit,
|
|
36
|
-
EvmDeposit,
|
|
37
|
-
evmDeposit,
|
|
38
|
-
type EvmDepositParams,
|
|
39
|
-
type EvmDepositPrepareParams,
|
|
40
|
-
type EvmDepositProgress,
|
|
41
|
-
EvmDepositStatus,
|
|
42
|
-
type IEvmDeposit,
|
|
43
|
-
} from './deposit';
|
|
44
|
-
|
|
45
|
-
// Deploy action
|
|
46
|
-
export {
|
|
47
|
-
createEvmDeploy,
|
|
48
|
-
EvmDeploy,
|
|
49
|
-
evmDeploy,
|
|
50
|
-
type EvmDeployParams,
|
|
51
|
-
type EvmDeployPrepareParams,
|
|
52
|
-
type EvmDeployProgress,
|
|
53
|
-
EvmDeployStatus,
|
|
54
|
-
type IEvmDeploy,
|
|
55
|
-
} from './deploy';
|
|
56
|
-
|
|
57
|
-
// Redeem action
|
|
58
|
-
export {
|
|
59
|
-
createEvmRedeem,
|
|
60
|
-
EvmRedeem,
|
|
61
|
-
evmRedeem,
|
|
62
|
-
type EvmRedeemParams,
|
|
63
|
-
type EvmRedeemPrepareParams,
|
|
64
|
-
type EvmRedeemProgress,
|
|
65
|
-
EvmRedeemStatus,
|
|
66
|
-
type IEvmRedeem,
|
|
67
|
-
} from './redeem';
|
|
@@ -1,263 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Redeem Action
|
|
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
|
-
* This covers the gas cost of the auto-mint operation on the destination.
|
|
13
|
-
*
|
|
14
|
-
* **Flow with fee auth (Ethereum/Sepolia):**
|
|
15
|
-
* IDLE → NEEDS_FEE_AUTHORIZATION → READY → COMPLETED
|
|
16
|
-
*
|
|
17
|
-
* **Flow without fee auth (Base, BSC - subsidized):**
|
|
18
|
-
* IDLE → READY → COMPLETED
|
|
19
|
-
*
|
|
20
|
-
* @module chains/evm/actions/redeem/EvmRedeem
|
|
21
|
-
*/
|
|
22
|
-
|
|
23
|
-
import type { EIP1193Provider } from 'viem';
|
|
24
|
-
import { z } from 'zod';
|
|
25
|
-
|
|
26
|
-
import type { ChainId } from '../../../../common/chains';
|
|
27
|
-
import { redeemToken } from '../../../../contract-functions';
|
|
28
|
-
import { parseChainIdentifier, StepStatus } from '../../../../core';
|
|
29
|
-
import { BaseAction } from '../../../../shared/actions/BaseAction';
|
|
30
|
-
import { EvmOperationStatus } from '../../../../shared/constants/statusConstants';
|
|
31
|
-
import type { EvmCoreContext } from '../../../../shared/context';
|
|
32
|
-
import { LombardError } from '../../../../shared/errors';
|
|
33
|
-
import type { RedeemEventMap } from '../../../../shared/events';
|
|
34
|
-
import {
|
|
35
|
-
evmAmountSchema,
|
|
36
|
-
validatePrepareParams,
|
|
37
|
-
} from '../../../../shared/validation';
|
|
38
|
-
import { Token } from '../../../../tokens/token-addresses';
|
|
39
|
-
import {
|
|
40
|
-
authorizeFee as authorizeFeeShared,
|
|
41
|
-
checkFeeAuthorization,
|
|
42
|
-
createInitialFeeAuthState,
|
|
43
|
-
type FeeAuthState,
|
|
44
|
-
} from '../../shared/feeAuth';
|
|
45
|
-
import { evmConfig } from './config';
|
|
46
|
-
import type {
|
|
47
|
-
EvmRedeemParams,
|
|
48
|
-
EvmRedeemPrepareParams,
|
|
49
|
-
IEvmRedeem,
|
|
50
|
-
} from './types';
|
|
51
|
-
|
|
52
|
-
export class EvmRedeem
|
|
53
|
-
extends BaseAction<RedeemEventMap, EvmOperationStatus>
|
|
54
|
-
implements IEvmRedeem
|
|
55
|
-
{
|
|
56
|
-
private _amount?: string;
|
|
57
|
-
private _recipient?: string;
|
|
58
|
-
private _needsApproval = false;
|
|
59
|
-
private _txHash?: string;
|
|
60
|
-
private _feeAuth: FeeAuthState = createInitialFeeAuthState();
|
|
61
|
-
|
|
62
|
-
constructor(
|
|
63
|
-
private readonly ctx: EvmCoreContext,
|
|
64
|
-
private readonly params: EvmRedeemParams,
|
|
65
|
-
) {
|
|
66
|
-
super(EvmOperationStatus.IDLE);
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
get amount(): string | undefined {
|
|
70
|
-
return this._amount;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
get recipient(): string | undefined {
|
|
74
|
-
return this._recipient;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
get needsApproval(): boolean {
|
|
78
|
-
return this._needsApproval;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
get txHash(): string | undefined {
|
|
82
|
-
return this._txHash;
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
/** Fee authorization state (for UI display) */
|
|
86
|
-
get feeAuth(): FeeAuthState {
|
|
87
|
-
return this._feeAuth;
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
async prepare(params: EvmRedeemPrepareParams): Promise<void> {
|
|
91
|
-
this.assertStatus(EvmOperationStatus.IDLE, 'prepare');
|
|
92
|
-
|
|
93
|
-
return this.act(async () => {
|
|
94
|
-
const validated = validatePrepareParams(this.prepareSchema, params, {
|
|
95
|
-
destChain: this.params.destChain,
|
|
96
|
-
});
|
|
97
|
-
this._amount = validated.amount as string;
|
|
98
|
-
this._recipient = validated.recipient as string;
|
|
99
|
-
|
|
100
|
-
const chainId = parseChainIdentifier(this.params.sourceChain) as ChainId;
|
|
101
|
-
|
|
102
|
-
// Get EVM account for fee auth check
|
|
103
|
-
const provider = await this.ctx.getProvider('evm');
|
|
104
|
-
if (!provider) {
|
|
105
|
-
throw LombardError.providerMissing(this.params.sourceChain, 'evm');
|
|
106
|
-
}
|
|
107
|
-
const accounts = await (provider as EIP1193Provider).request({
|
|
108
|
-
method: 'eth_accounts',
|
|
109
|
-
});
|
|
110
|
-
const account = accounts[0] as `0x${string}`;
|
|
111
|
-
|
|
112
|
-
// Check fee authorization status (BTC.b redeem uses Token.BTCb)
|
|
113
|
-
const feeAuthResult = await checkFeeAuthorization(
|
|
114
|
-
chainId,
|
|
115
|
-
account,
|
|
116
|
-
this.ctx.env,
|
|
117
|
-
Token.BTCb,
|
|
118
|
-
);
|
|
119
|
-
|
|
120
|
-
// Update fee auth state
|
|
121
|
-
this._feeAuth = {
|
|
122
|
-
requiresAuth: feeAuthResult.requiresAuth,
|
|
123
|
-
isAuthorized: feeAuthResult.hasValidSignature,
|
|
124
|
-
feeInSatoshis: feeAuthResult.feeInSatoshis,
|
|
125
|
-
feeFormatted: feeAuthResult.feeFormatted,
|
|
126
|
-
expirationDate: feeAuthResult.expirationDate,
|
|
127
|
-
};
|
|
128
|
-
|
|
129
|
-
// Determine next status based on fee auth
|
|
130
|
-
if (feeAuthResult.requiresAuth && !feeAuthResult.hasValidSignature) {
|
|
131
|
-
this.emitProgress({
|
|
132
|
-
status: EvmOperationStatus.NEEDS_FEE_AUTHORIZATION,
|
|
133
|
-
steps: { burning: StepStatus.IDLE, releasing: StepStatus.IDLE },
|
|
134
|
-
});
|
|
135
|
-
return; // Don't transition to READY yet
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
// No fee auth required or already authorized
|
|
139
|
-
this._needsApproval = false;
|
|
140
|
-
this.emitProgress({
|
|
141
|
-
status: EvmOperationStatus.READY,
|
|
142
|
-
steps: { burning: StepStatus.IDLE, releasing: StepStatus.IDLE },
|
|
143
|
-
});
|
|
144
|
-
}, this._feeAuth.requiresAuth && !this._feeAuth.isAuthorized
|
|
145
|
-
? EvmOperationStatus.NEEDS_FEE_AUTHORIZATION
|
|
146
|
-
: EvmOperationStatus.READY);
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
/**
|
|
150
|
-
* Authorize the network fee
|
|
151
|
-
*
|
|
152
|
-
* Must be called when status is NEEDS_FEE_AUTHORIZATION.
|
|
153
|
-
* Signs the fee authorization and stores it on the server.
|
|
154
|
-
*/
|
|
155
|
-
async authorizeFee(): Promise<void> {
|
|
156
|
-
this.assertStatus(EvmOperationStatus.NEEDS_FEE_AUTHORIZATION, 'authorizeFee');
|
|
157
|
-
|
|
158
|
-
if (!this._feeAuth.feeInSatoshis) {
|
|
159
|
-
throw LombardError.missingParameter('feeInSatoshis');
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
return this.act(async () => {
|
|
163
|
-
const chainId = parseChainIdentifier(this.params.sourceChain) as ChainId;
|
|
164
|
-
|
|
165
|
-
const provider = await this.ctx.getProvider('evm');
|
|
166
|
-
if (!provider) {
|
|
167
|
-
throw LombardError.providerMissing(this.params.sourceChain, 'evm');
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
const accounts = await (provider as EIP1193Provider).request({
|
|
171
|
-
method: 'eth_accounts',
|
|
172
|
-
});
|
|
173
|
-
const account = accounts[0] as `0x${string}`;
|
|
174
|
-
|
|
175
|
-
// Sign and store fee authorization
|
|
176
|
-
await authorizeFeeShared({
|
|
177
|
-
chainId,
|
|
178
|
-
account,
|
|
179
|
-
feeInSatoshis: this._feeAuth.feeInSatoshis!,
|
|
180
|
-
provider: provider as EIP1193Provider,
|
|
181
|
-
env: this.ctx.env,
|
|
182
|
-
token: Token.BTCb,
|
|
183
|
-
});
|
|
184
|
-
|
|
185
|
-
// Update state
|
|
186
|
-
this._feeAuth.isAuthorized = true;
|
|
187
|
-
|
|
188
|
-
this.emitProgress({
|
|
189
|
-
status: EvmOperationStatus.READY,
|
|
190
|
-
steps: { burning: StepStatus.IDLE, releasing: StepStatus.IDLE },
|
|
191
|
-
});
|
|
192
|
-
}, EvmOperationStatus.READY);
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
async approve(): Promise<void> {
|
|
196
|
-
this.assertStatus(EvmOperationStatus.NEEDS_APPROVAL, 'approve');
|
|
197
|
-
|
|
198
|
-
return this.act(async () => {
|
|
199
|
-
this._needsApproval = false;
|
|
200
|
-
this.emitProgress({
|
|
201
|
-
status: EvmOperationStatus.READY,
|
|
202
|
-
steps: { burning: StepStatus.IDLE, releasing: StepStatus.IDLE },
|
|
203
|
-
});
|
|
204
|
-
}, EvmOperationStatus.READY);
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
async execute(): Promise<{ txHash: string }> {
|
|
208
|
-
this.assertStatus(EvmOperationStatus.READY, 'execute');
|
|
209
|
-
|
|
210
|
-
return this.act(async () => {
|
|
211
|
-
const provider = await this.ctx.getProvider('evm');
|
|
212
|
-
if (!provider) {
|
|
213
|
-
throw LombardError.providerMissing(this.params.sourceChain, 'evm');
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
// Get the connected EVM account address from the provider
|
|
217
|
-
const accounts = await (provider as EIP1193Provider).request({
|
|
218
|
-
method: 'eth_accounts',
|
|
219
|
-
});
|
|
220
|
-
const evmAccount = accounts[0] as `0x${string}`;
|
|
221
|
-
if (!evmAccount) {
|
|
222
|
-
throw LombardError.providerMissing(this.params.sourceChain, 'evm');
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
const chainId = parseChainIdentifier(this.params.sourceChain) as ChainId;
|
|
226
|
-
|
|
227
|
-
this.emitProgress({
|
|
228
|
-
status: EvmOperationStatus.READY,
|
|
229
|
-
steps: { burning: StepStatus.PENDING, releasing: StepStatus.IDLE },
|
|
230
|
-
});
|
|
231
|
-
|
|
232
|
-
// Execute BTC.b → BTC redemption (burn BTC.b, release BTC to Bitcoin address)
|
|
233
|
-
const txHash = await redeemToken({
|
|
234
|
-
provider: provider as EIP1193Provider,
|
|
235
|
-
account: evmAccount,
|
|
236
|
-
amount: this._amount!,
|
|
237
|
-
btcAddress: this._recipient!, // Bitcoin address to receive BTC
|
|
238
|
-
chainId,
|
|
239
|
-
env: this.ctx.env,
|
|
240
|
-
tokenIn: Token.BTCb,
|
|
241
|
-
tokenOut: undefined, // Native BTC output
|
|
242
|
-
});
|
|
243
|
-
|
|
244
|
-
this._txHash = txHash;
|
|
245
|
-
|
|
246
|
-
this.emitProgress({
|
|
247
|
-
status: EvmOperationStatus.COMPLETED,
|
|
248
|
-
steps: { burning: StepStatus.COMPLETE, releasing: StepStatus.PENDING },
|
|
249
|
-
});
|
|
250
|
-
|
|
251
|
-
this.emitCompleted();
|
|
252
|
-
|
|
253
|
-
return { txHash };
|
|
254
|
-
}, EvmOperationStatus.COMPLETED);
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
private get prepareSchema() {
|
|
258
|
-
return z.object({
|
|
259
|
-
amount: evmAmountSchema,
|
|
260
|
-
recipient: evmConfig.recipientSchema,
|
|
261
|
-
});
|
|
262
|
-
}
|
|
263
|
-
}
|