@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,124 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Validation utilities for stake and bake operations.
|
|
3
|
-
* Provides early validation with descriptive error messages.
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import { Env } from '@lombard.finance/sdk-common';
|
|
7
|
-
|
|
8
|
-
import type { ChainId } from '../../common/chains';
|
|
9
|
-
import {
|
|
10
|
-
DEFI_REGISTRY,
|
|
11
|
-
DefiProtocol,
|
|
12
|
-
StakeAndBakeStrategy,
|
|
13
|
-
StakeAndBakeToken,
|
|
14
|
-
} from '../../defi/defi-registry';
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* Custom error for stake and bake validation failures.
|
|
18
|
-
* Includes error code and context for better debugging.
|
|
19
|
-
*/
|
|
20
|
-
export class StakeAndBakeValidationError extends Error {
|
|
21
|
-
constructor(
|
|
22
|
-
public readonly code: string,
|
|
23
|
-
message: string,
|
|
24
|
-
public readonly context?: Record<string, unknown>,
|
|
25
|
-
) {
|
|
26
|
-
super(message);
|
|
27
|
-
this.name = 'StakeAndBakeValidationError';
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* Validates stake and bake parameters and returns the strategy for the requested combo.
|
|
33
|
-
* Throws StakeAndBakeValidationError for invalid combinations.
|
|
34
|
-
*
|
|
35
|
-
* @param vaultKey - The vault to stake into
|
|
36
|
-
* @param token - The token to stake
|
|
37
|
-
* @param chainId - The chain ID
|
|
38
|
-
* @param env - The environment (prod, testnet, etc.)
|
|
39
|
-
* @returns TokenApprovalConfig and spenderContract
|
|
40
|
-
* @throws {StakeAndBakeValidationError} If vault/token/chain/env combination is invalid
|
|
41
|
-
*/
|
|
42
|
-
export function getStakeAndBakeConfig(
|
|
43
|
-
protocol: DefiProtocol,
|
|
44
|
-
token: StakeAndBakeToken,
|
|
45
|
-
chainId: ChainId,
|
|
46
|
-
env: Env,
|
|
47
|
-
): StakeAndBakeStrategy {
|
|
48
|
-
// Get token approval config from DeFi registry
|
|
49
|
-
const protocolRegistry = DEFI_REGISTRY[protocol];
|
|
50
|
-
if (!protocolRegistry) {
|
|
51
|
-
throw new StakeAndBakeValidationError(
|
|
52
|
-
'UNSUPPORTED_VAULT',
|
|
53
|
-
`Vault ${protocol} not found in DeFi registry`,
|
|
54
|
-
{ protocol },
|
|
55
|
-
);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
const tokenRegistry = protocolRegistry[token as keyof typeof protocolRegistry];
|
|
59
|
-
if (!tokenRegistry) {
|
|
60
|
-
throw new StakeAndBakeValidationError(
|
|
61
|
-
'UNSUPPORTED_TOKEN',
|
|
62
|
-
`Token ${token} is not supported for stake and bake on vault ${protocol}. ` +
|
|
63
|
-
`Supported tokens: ${Object.keys(protocolRegistry).join(', ')}`,
|
|
64
|
-
{ protocol, token, supportedTokens: Object.keys(protocolRegistry) },
|
|
65
|
-
);
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
const envRegistry = tokenRegistry[env];
|
|
69
|
-
if (!envRegistry) {
|
|
70
|
-
throw new StakeAndBakeValidationError(
|
|
71
|
-
'UNSUPPORTED_ENV',
|
|
72
|
-
`Environment ${env} is not supported for token ${token} on vault ${protocol}`,
|
|
73
|
-
{ protocol, token, env },
|
|
74
|
-
);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
const registryEntry = envRegistry[chainId as keyof typeof envRegistry];
|
|
78
|
-
if (!registryEntry) {
|
|
79
|
-
throw new StakeAndBakeValidationError(
|
|
80
|
-
'UNSUPPORTED_TOKEN_CHAIN',
|
|
81
|
-
`Token ${token} is not supported on chain ${chainId} for vault ${protocol} in ${env}. ` +
|
|
82
|
-
`Supported chains: ${Object.keys(envRegistry).join(', ')}`,
|
|
83
|
-
{
|
|
84
|
-
protocol,
|
|
85
|
-
token,
|
|
86
|
-
chainId,
|
|
87
|
-
env,
|
|
88
|
-
supportedChains: Object.keys(envRegistry),
|
|
89
|
-
},
|
|
90
|
-
);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
return {
|
|
94
|
-
protocol: protocol,
|
|
95
|
-
token,
|
|
96
|
-
env,
|
|
97
|
-
chainId,
|
|
98
|
-
...registryEntry,
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
/**
|
|
103
|
-
* Checks if a token approval config exists for a given vault/token/chain/env combination.
|
|
104
|
-
* Useful for determining if config-driven logic should be used.
|
|
105
|
-
*
|
|
106
|
-
* @param protocol - The vault to check
|
|
107
|
-
* @param token - The token to check
|
|
108
|
-
* @param chainId - The chain ID to check
|
|
109
|
-
* @param env - The environment to check
|
|
110
|
-
* @returns true if config exists, false otherwise
|
|
111
|
-
*/
|
|
112
|
-
export function hasTokenApprovalConfig(
|
|
113
|
-
protocol: DefiProtocol,
|
|
114
|
-
token: StakeAndBakeToken,
|
|
115
|
-
chainId: ChainId,
|
|
116
|
-
env: Env,
|
|
117
|
-
): boolean {
|
|
118
|
-
try {
|
|
119
|
-
const config = getStakeAndBakeConfig(protocol, token, chainId, env);
|
|
120
|
-
return config !== undefined;
|
|
121
|
-
} catch {
|
|
122
|
-
return false;
|
|
123
|
-
}
|
|
124
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './unstakeLBTC';
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
import { DEFAULT_ENV } from '@lombard.finance/sdk-common';
|
|
2
|
-
import type { Meta, StoryObj } from '@storybook/react';
|
|
3
|
-
|
|
4
|
-
import { makeTokenSelector } from '../../stories/arg-types';
|
|
5
|
-
import { Button } from '../../stories/components/Button';
|
|
6
|
-
import { CodeBlock } from '../../stories/components/CodeBlock';
|
|
7
|
-
import { ConnectButton } from '../../stories/components/ConnectButton';
|
|
8
|
-
import {
|
|
9
|
-
functionType,
|
|
10
|
-
wagmiDecorator,
|
|
11
|
-
} from '../../stories/components/decorators';
|
|
12
|
-
import {
|
|
13
|
-
canPerformAction,
|
|
14
|
-
useConnection,
|
|
15
|
-
} from '../../stories/hooks/useConnection';
|
|
16
|
-
import useQuery from '../../stories/hooks/useQuery';
|
|
17
|
-
import { Token } from '../../tokens/token-addresses';
|
|
18
|
-
import { redeemToken } from './unstakeLBTC';
|
|
19
|
-
|
|
20
|
-
const meta = {
|
|
21
|
-
title: 'write/unstakeLBTC',
|
|
22
|
-
component: StoryView,
|
|
23
|
-
tags: ['autodocs'],
|
|
24
|
-
decorators: [wagmiDecorator, functionType('write')],
|
|
25
|
-
argTypes: {
|
|
26
|
-
...makeTokenSelector([Token.LBTC, Token.BTCK, Token.BTCb]),
|
|
27
|
-
},
|
|
28
|
-
} satisfies Meta<typeof StoryView>;
|
|
29
|
-
|
|
30
|
-
export default meta;
|
|
31
|
-
|
|
32
|
-
type Story = StoryObj<typeof meta>;
|
|
33
|
-
|
|
34
|
-
export const WithParams: Story = {
|
|
35
|
-
args: {
|
|
36
|
-
amount: 0.00001,
|
|
37
|
-
tokenIn: Token.LBTC,
|
|
38
|
-
btcAddress: '',
|
|
39
|
-
env: DEFAULT_ENV,
|
|
40
|
-
},
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
type ClaimLBTCProps = Omit<
|
|
44
|
-
Parameters<typeof redeemToken>[0],
|
|
45
|
-
'account' | 'chainId' | 'provider'
|
|
46
|
-
>;
|
|
47
|
-
|
|
48
|
-
export function StoryView(props: ClaimLBTCProps) {
|
|
49
|
-
const connection = useConnection();
|
|
50
|
-
|
|
51
|
-
const request = async () => {
|
|
52
|
-
if (!canPerformAction(connection)) {
|
|
53
|
-
alert('Not connected');
|
|
54
|
-
return;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
return redeemToken({
|
|
58
|
-
amount: props.amount,
|
|
59
|
-
btcAddress: props.btcAddress,
|
|
60
|
-
env: props.env,
|
|
61
|
-
tokenIn: props.tokenIn,
|
|
62
|
-
|
|
63
|
-
account: connection.account.address,
|
|
64
|
-
chainId: connection.account.chainId,
|
|
65
|
-
provider: connection.provider,
|
|
66
|
-
});
|
|
67
|
-
};
|
|
68
|
-
|
|
69
|
-
const { data, error, isLoading, refetch } = useQuery(request, [], false);
|
|
70
|
-
|
|
71
|
-
return (
|
|
72
|
-
<>
|
|
73
|
-
<p>
|
|
74
|
-
This function unstakes the specified amount of LBTC and transfers the
|
|
75
|
-
equivalent amount of BTC to the provided BTC address.
|
|
76
|
-
</p>
|
|
77
|
-
|
|
78
|
-
<div className="mb-4">
|
|
79
|
-
<ConnectButton />
|
|
80
|
-
</div>
|
|
81
|
-
|
|
82
|
-
<Button
|
|
83
|
-
onClick={refetch}
|
|
84
|
-
disabled={isLoading || !connection.account.address}
|
|
85
|
-
isLoading={isLoading}
|
|
86
|
-
actionName={redeemToken.name}
|
|
87
|
-
/>
|
|
88
|
-
|
|
89
|
-
<CodeBlock text={error || data} />
|
|
90
|
-
</>
|
|
91
|
-
);
|
|
92
|
-
}
|
|
@@ -1,396 +0,0 @@
|
|
|
1
|
-
import { getOutputScript } from '@lombard.finance/sdk-common';
|
|
2
|
-
import BigNumber from 'bignumber.js';
|
|
3
|
-
import { Address, erc20Abi, Hex, parseGwei } from 'viem';
|
|
4
|
-
|
|
5
|
-
import { makePublicClient } from '../../clients/public-client';
|
|
6
|
-
import { makeWalletClient } from '../../clients/wallet-client';
|
|
7
|
-
import {
|
|
8
|
-
CHAIN_ID_TO_VIEM_CHAIN_MAP,
|
|
9
|
-
ChainId,
|
|
10
|
-
isKatanaChain,
|
|
11
|
-
} from '../../common/chains';
|
|
12
|
-
import {
|
|
13
|
-
CommonSignerWriteParameters,
|
|
14
|
-
CommonWriteParameters,
|
|
15
|
-
isProviderFlow,
|
|
16
|
-
} from '../../common/parameters';
|
|
17
|
-
import ASSET_ROUTER_ABI from '../../tokens/abi/ASSET_ROUTER_ABI';
|
|
18
|
-
import { AddressKind, Token } from '../../tokens/token-addresses';
|
|
19
|
-
import {
|
|
20
|
-
fromBaseDenomination,
|
|
21
|
-
getTokenContractInfo,
|
|
22
|
-
isUpgradedAbi,
|
|
23
|
-
retrieveTokenProperties,
|
|
24
|
-
toBaseDenomination,
|
|
25
|
-
} from '../../tokens/tokens';
|
|
26
|
-
import { UnsupportedTokenFlow } from '../../utils/err';
|
|
27
|
-
import { estimateGasFees } from '../../utils/gas';
|
|
28
|
-
import toBigInt from '../../utils/numbers';
|
|
29
|
-
import {
|
|
30
|
-
executeContractTransaction,
|
|
31
|
-
waitForTransactionReceipt,
|
|
32
|
-
} from '../../utils/transaction-executor';
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* Supported redemption flows.
|
|
36
|
-
*
|
|
37
|
-
* - If `tokenOut` is `undefined`, the redemption defaults to **BTC**
|
|
38
|
-
* and requires a BTC address as the destination.
|
|
39
|
-
* - Otherwise, redemption will return the specified output token.
|
|
40
|
-
*/
|
|
41
|
-
const AVAILABLE_FLOWS: Array<{
|
|
42
|
-
/** The token being redeemed */
|
|
43
|
-
tokenIn: Token;
|
|
44
|
-
/** The token received after redemption (or `undefined` for BTC) */
|
|
45
|
-
tokenOut?: Token;
|
|
46
|
-
}> = [
|
|
47
|
-
// Redeem to BTC
|
|
48
|
-
{ tokenIn: Token.LBTC }, // -> BTC
|
|
49
|
-
{ tokenIn: Token.BTCb }, // -> BTC
|
|
50
|
-
{ tokenIn: Token.BTCK }, // -> BTC
|
|
51
|
-
|
|
52
|
-
// Redeem to wrapped tokens
|
|
53
|
-
{ tokenIn: Token.LBTC, tokenOut: Token.BTCb }, // -> Native LBTC
|
|
54
|
-
{ tokenIn: Token.LBTC, tokenOut: Token.BTCK }, // -> Native LBTC
|
|
55
|
-
];
|
|
56
|
-
|
|
57
|
-
type RedeemTokenParameters = {
|
|
58
|
-
/**
|
|
59
|
-
* The amount to redeem, expressed in human-readable format.
|
|
60
|
-
*
|
|
61
|
-
* For example, use `"1.23"` to represent 1.23 LBTC.
|
|
62
|
-
*/
|
|
63
|
-
amount: BigNumber.Value;
|
|
64
|
-
/**
|
|
65
|
-
* (Optional) Destination BTC address for redemption.
|
|
66
|
-
*
|
|
67
|
-
* Required if {@link tokenOut} is omitted (since the default
|
|
68
|
-
* redemption flow sends BTC).
|
|
69
|
-
*/
|
|
70
|
-
btcAddress?: string;
|
|
71
|
-
/**
|
|
72
|
-
* The token to be redeemed.
|
|
73
|
-
*
|
|
74
|
-
* Defaults to {@link Token.LBTC}.
|
|
75
|
-
*/
|
|
76
|
-
tokenIn: Token;
|
|
77
|
-
/**
|
|
78
|
-
* (Optional) The token to receive after redemption.
|
|
79
|
-
*
|
|
80
|
-
* - If provided, redemption will return the specified token.
|
|
81
|
-
* - If omitted, redemption defaults to BTC and a {@link btcAddress}
|
|
82
|
-
* must be supplied.
|
|
83
|
-
*/
|
|
84
|
-
tokenOut?: Token;
|
|
85
|
-
};
|
|
86
|
-
|
|
87
|
-
/**
|
|
88
|
-
* Union type for redeem token parameters supporting both provider and signer flows.
|
|
89
|
-
*/
|
|
90
|
-
type RedeemTokenParams =
|
|
91
|
-
| (RedeemTokenParameters & CommonWriteParameters)
|
|
92
|
-
| (RedeemTokenParameters & CommonSignerWriteParameters);
|
|
93
|
-
|
|
94
|
-
/**
|
|
95
|
-
* Parameters required to unstake (redeem) LBTC into BTC.
|
|
96
|
-
*
|
|
97
|
-
* Overrides {@link RedeemTokenParameters} to make `btcAddress` required,
|
|
98
|
-
* since unstaking always goes to BTC.
|
|
99
|
-
*/
|
|
100
|
-
export type IUnstakeLBTCParams =
|
|
101
|
-
| (RedeemTokenParameters & CommonWriteParameters & { btcAddress: string })
|
|
102
|
-
| (RedeemTokenParameters &
|
|
103
|
-
CommonSignerWriteParameters & { btcAddress: string });
|
|
104
|
-
|
|
105
|
-
/**
|
|
106
|
-
* Redeems a token into **BTC** or another supported token.
|
|
107
|
-
*
|
|
108
|
-
* @remarks
|
|
109
|
-
* This is the **preferred** API for all redemption flows.
|
|
110
|
-
* - If `tokenOut` is `undefined`, redemption sends BTC and requires a valid BTC address.
|
|
111
|
-
* - If `tokenOut` is provided, redemption swaps to the target token
|
|
112
|
-
* (requires an upgraded token contract ABI).
|
|
113
|
-
*
|
|
114
|
-
* Supports two execution modes:
|
|
115
|
-
* 1. **Provider flow** (legacy): Pass `provider: EIP1193Provider`
|
|
116
|
-
* 2. **Signer flow** (unified bridge): Pass `signer: SignerAdapter`
|
|
117
|
-
*
|
|
118
|
-
* @param params - Parameters including the source token, amount, and either provider or signer.
|
|
119
|
-
* @returns Transaction hash of the executed redemption transaction.
|
|
120
|
-
*
|
|
121
|
-
* @throws {UnsupportedTokenFlow} If the requested flow is not supported.
|
|
122
|
-
* @throws {Error} If balances are insufficient or required parameters are missing.
|
|
123
|
-
* @throws {SignerError} If transaction execution fails (with detailed context).
|
|
124
|
-
*
|
|
125
|
-
* @example
|
|
126
|
-
* ```ts
|
|
127
|
-
* // Provider flow (legacy)
|
|
128
|
-
* const txHash = await redeemToken({
|
|
129
|
-
* provider,
|
|
130
|
-
* account: '0x...',
|
|
131
|
-
* amount: '1.5',
|
|
132
|
-
* btcAddress: 'bc1q...',
|
|
133
|
-
* chainId: ChainId.ethereum,
|
|
134
|
-
* env: Env.prod,
|
|
135
|
-
* tokenIn: Token.LBTC,
|
|
136
|
-
* });
|
|
137
|
-
*
|
|
138
|
-
* // Signer flow (unified bridge)
|
|
139
|
-
* const txHash = await redeemToken({
|
|
140
|
-
* signer: evmSigner,
|
|
141
|
-
* account: '0x...',
|
|
142
|
-
* amount: '1.5',
|
|
143
|
-
* btcAddress: 'bc1q...',
|
|
144
|
-
* chainId: ChainId.avalancheFuji,
|
|
145
|
-
* env: Env.testnet,
|
|
146
|
-
* tokenIn: Token.BTCb,
|
|
147
|
-
* });
|
|
148
|
-
* ```
|
|
149
|
-
*/
|
|
150
|
-
export async function redeemToken(params: RedeemTokenParams): Promise<Hex> {
|
|
151
|
-
const {
|
|
152
|
-
account: accountAddress,
|
|
153
|
-
amount: amountRaw,
|
|
154
|
-
btcAddress,
|
|
155
|
-
chainId,
|
|
156
|
-
env,
|
|
157
|
-
rpcUrl,
|
|
158
|
-
tokenIn = Token.LBTC,
|
|
159
|
-
tokenOut,
|
|
160
|
-
} = params;
|
|
161
|
-
const flow = AVAILABLE_FLOWS.find(
|
|
162
|
-
af => af.tokenIn === tokenIn && af.tokenOut === tokenOut,
|
|
163
|
-
);
|
|
164
|
-
if (!flow) {
|
|
165
|
-
throw new UnsupportedTokenFlow(tokenIn, tokenOut || 'BTC', chainId, env);
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
const publicClient = makePublicClient({ chainId, rpcUrl, env });
|
|
169
|
-
|
|
170
|
-
// Create wallet client only for provider flow
|
|
171
|
-
const walletClient = isProviderFlow(params)
|
|
172
|
-
? makeWalletClient({ provider: params.provider, chainId })
|
|
173
|
-
: undefined;
|
|
174
|
-
|
|
175
|
-
const tokenInContractInfo = await getTokenContractInfo(
|
|
176
|
-
tokenIn,
|
|
177
|
-
chainId,
|
|
178
|
-
env,
|
|
179
|
-
AddressKind.Token, // get the token contract, not adapter
|
|
180
|
-
);
|
|
181
|
-
const IN = await retrieveTokenProperties(publicClient, tokenInContractInfo);
|
|
182
|
-
if (!IN) {
|
|
183
|
-
throw new Error(
|
|
184
|
-
`Could not retrieve the properties of ${tokenIn} on ${chainId}`,
|
|
185
|
-
);
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
const amount = toBaseDenomination(amountRaw, IN.decimals);
|
|
189
|
-
|
|
190
|
-
const tokenInBalanceRaw = await publicClient.readContract({
|
|
191
|
-
address: IN.address,
|
|
192
|
-
abi: IN.abi as typeof erc20Abi,
|
|
193
|
-
functionName: 'balanceOf',
|
|
194
|
-
args: [accountAddress],
|
|
195
|
-
});
|
|
196
|
-
const tokenInBalance = fromBaseDenomination(tokenInBalanceRaw, IN.decimals);
|
|
197
|
-
if (amount.isGreaterThan(tokenInBalanceRaw)) {
|
|
198
|
-
throw new Error(
|
|
199
|
-
`Unable to redeem ${String(amountRaw)} ${IN.symbol} because the amount exceeds the account's balance of ${tokenInBalance.toString()} ${IN.symbol}`,
|
|
200
|
-
);
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
// -> BTC
|
|
204
|
-
if (!tokenOut) {
|
|
205
|
-
if (!btcAddress) {
|
|
206
|
-
throw new Error('Missing parameter: `btcAddress`.');
|
|
207
|
-
}
|
|
208
|
-
const outputScript = getOutputScript(btcAddress, env);
|
|
209
|
-
|
|
210
|
-
// The redemption of BTC.b -> BTC on Avalanche requires extra steps
|
|
211
|
-
if (
|
|
212
|
-
tokenIn === Token.BTCb &&
|
|
213
|
-
(chainId === ChainId.avalanche || chainId === ChainId.avalancheFuji)
|
|
214
|
-
) {
|
|
215
|
-
// 0. `IN` is a token contract (BTC.b)
|
|
216
|
-
// 1. Get the adapter and asset route contracts
|
|
217
|
-
const adapter = await getTokenContractInfo(
|
|
218
|
-
tokenIn,
|
|
219
|
-
chainId,
|
|
220
|
-
env,
|
|
221
|
-
AddressKind.Adapter,
|
|
222
|
-
);
|
|
223
|
-
const assetRouterContractAddress = (await publicClient.readContract({
|
|
224
|
-
address: adapter.address,
|
|
225
|
-
abi: adapter.abi,
|
|
226
|
-
functionName: 'getAssetRouter',
|
|
227
|
-
})) as Address;
|
|
228
|
-
|
|
229
|
-
// 2. Check allowance
|
|
230
|
-
const allowance = await publicClient.readContract({
|
|
231
|
-
address: IN.address,
|
|
232
|
-
abi: IN.abi,
|
|
233
|
-
functionName: 'allowance',
|
|
234
|
-
args: [accountAddress, adapter.address],
|
|
235
|
-
});
|
|
236
|
-
|
|
237
|
-
if (amount.isGreaterThan(allowance)) {
|
|
238
|
-
const { txHash } = await executeContractTransaction({
|
|
239
|
-
params,
|
|
240
|
-
publicClient,
|
|
241
|
-
walletClient,
|
|
242
|
-
simulateArgs: {
|
|
243
|
-
address: IN.address,
|
|
244
|
-
abi: IN.abi,
|
|
245
|
-
account: accountAddress as `0x${string}` | undefined,
|
|
246
|
-
functionName: 'approve',
|
|
247
|
-
args: [adapter.address, toBigInt(amount)],
|
|
248
|
-
},
|
|
249
|
-
operation: 'BTC.b approval',
|
|
250
|
-
});
|
|
251
|
-
|
|
252
|
-
const receipt = await waitForTransactionReceipt(
|
|
253
|
-
publicClient,
|
|
254
|
-
txHash,
|
|
255
|
-
'BTC.b approval',
|
|
256
|
-
);
|
|
257
|
-
|
|
258
|
-
console.info(
|
|
259
|
-
`Approved adapter (${adapter.address}) for ${new BigNumber(amountRaw).toString()} ${IN.symbol}`,
|
|
260
|
-
receipt.transactionHash,
|
|
261
|
-
receipt.status,
|
|
262
|
-
);
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
// 3. Run `redeemForBtc` on AssetRouter
|
|
266
|
-
const { txHash } = await executeContractTransaction({
|
|
267
|
-
params,
|
|
268
|
-
publicClient,
|
|
269
|
-
walletClient,
|
|
270
|
-
simulateArgs: {
|
|
271
|
-
address: assetRouterContractAddress,
|
|
272
|
-
abi: ASSET_ROUTER_ABI,
|
|
273
|
-
account: accountAddress as `0x${string}` | undefined,
|
|
274
|
-
functionName: 'redeemForBtc',
|
|
275
|
-
args: [
|
|
276
|
-
accountAddress,
|
|
277
|
-
adapter.address,
|
|
278
|
-
outputScript,
|
|
279
|
-
toBigInt(amount),
|
|
280
|
-
],
|
|
281
|
-
},
|
|
282
|
-
operation: 'BTC.b redeemForBtc',
|
|
283
|
-
});
|
|
284
|
-
|
|
285
|
-
return txHash;
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
// 0. IN is BTC.b token contract.
|
|
289
|
-
const callData = {
|
|
290
|
-
abi: IN.abi,
|
|
291
|
-
address: IN.address,
|
|
292
|
-
account: accountAddress,
|
|
293
|
-
chain: CHAIN_ID_TO_VIEM_CHAIN_MAP[chainId],
|
|
294
|
-
functionName:
|
|
295
|
-
isUpgradedAbi(IN.abi) || tokenIn === Token.BTCb
|
|
296
|
-
? 'redeemForBtc' // upgraded
|
|
297
|
-
: 'redeem', // legacy
|
|
298
|
-
args: [outputScript, toBigInt(amount)],
|
|
299
|
-
} as const;
|
|
300
|
-
|
|
301
|
-
const gasEstimationData = isKatanaChain(chainId)
|
|
302
|
-
? await estimateGasFees(publicClient, callData, parseGwei('1'))
|
|
303
|
-
: {};
|
|
304
|
-
|
|
305
|
-
const { txHash } = await executeContractTransaction({
|
|
306
|
-
params,
|
|
307
|
-
publicClient,
|
|
308
|
-
walletClient,
|
|
309
|
-
simulateArgs: {
|
|
310
|
-
...callData,
|
|
311
|
-
account: accountAddress as `0x${string}` | undefined,
|
|
312
|
-
...gasEstimationData,
|
|
313
|
-
},
|
|
314
|
-
operation: `${tokenIn} redeem to BTC`,
|
|
315
|
-
});
|
|
316
|
-
|
|
317
|
-
return txHash;
|
|
318
|
-
}
|
|
319
|
-
|
|
320
|
-
// -> tokenOut
|
|
321
|
-
if (!isUpgradedAbi(IN.abi)) {
|
|
322
|
-
throw new Error(
|
|
323
|
-
`The ${tokenIn} contract (${IN.address}) doesn't support redemptions to ${tokenOut}.`,
|
|
324
|
-
);
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
const callData = {
|
|
328
|
-
abi: IN.abi,
|
|
329
|
-
address: IN.address,
|
|
330
|
-
account: accountAddress,
|
|
331
|
-
chain: CHAIN_ID_TO_VIEM_CHAIN_MAP[chainId],
|
|
332
|
-
functionName: 'redeem',
|
|
333
|
-
args: [toBigInt(amount)],
|
|
334
|
-
} as const;
|
|
335
|
-
|
|
336
|
-
const gasEstimationData = isKatanaChain(chainId)
|
|
337
|
-
? await estimateGasFees(publicClient, callData, parseGwei('1'))
|
|
338
|
-
: {};
|
|
339
|
-
|
|
340
|
-
const { txHash } = await executeContractTransaction({
|
|
341
|
-
params,
|
|
342
|
-
publicClient,
|
|
343
|
-
walletClient,
|
|
344
|
-
simulateArgs: {
|
|
345
|
-
...callData,
|
|
346
|
-
account: accountAddress as `0x${string}` | undefined,
|
|
347
|
-
...gasEstimationData,
|
|
348
|
-
},
|
|
349
|
-
operation: `${tokenIn} redeem to ${tokenOut}`,
|
|
350
|
-
});
|
|
351
|
-
|
|
352
|
-
return txHash;
|
|
353
|
-
}
|
|
354
|
-
|
|
355
|
-
/**
|
|
356
|
-
* Convenience wrapper around {@link redeemToken} for redeeming **LBTC → BTC**.
|
|
357
|
-
*
|
|
358
|
-
* @remarks
|
|
359
|
-
* This is a helper for the common "unstake LBTC" flow.
|
|
360
|
-
* For more flexible redemptions (e.g. LBTC → BTCK), use {@link redeemToken} directly.
|
|
361
|
-
*
|
|
362
|
-
* Supports both provider and signer flows.
|
|
363
|
-
*
|
|
364
|
-
* @param params - See {@link IUnstakeLBTCParams}.
|
|
365
|
-
* @returns Transaction hash of the redemption transaction.
|
|
366
|
-
*
|
|
367
|
-
* @example
|
|
368
|
-
* ```ts
|
|
369
|
-
* // Provider flow
|
|
370
|
-
* const txHash = await unstakeLBTC({
|
|
371
|
-
* provider,
|
|
372
|
-
* account: '0x...',
|
|
373
|
-
* btcAddress: 'bc1q...',
|
|
374
|
-
* amount: '1.5',
|
|
375
|
-
* chainId: ChainId.ethereum,
|
|
376
|
-
* env: Env.prod,
|
|
377
|
-
* });
|
|
378
|
-
*
|
|
379
|
-
* // Signer flow
|
|
380
|
-
* const txHash = await unstakeLBTC({
|
|
381
|
-
* signer: evmSigner,
|
|
382
|
-
* account: '0x...',
|
|
383
|
-
* btcAddress: 'bc1q...',
|
|
384
|
-
* amount: '1.5',
|
|
385
|
-
* chainId: ChainId.ethereum,
|
|
386
|
-
* env: Env.prod,
|
|
387
|
-
* });
|
|
388
|
-
* ```
|
|
389
|
-
*/
|
|
390
|
-
export async function unstakeLBTC(params: IUnstakeLBTCParams): Promise<Hex> {
|
|
391
|
-
return redeemToken({
|
|
392
|
-
...params,
|
|
393
|
-
tokenIn: Token.LBTC,
|
|
394
|
-
tokenOut: undefined,
|
|
395
|
-
});
|
|
396
|
-
}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Contract ABIs for interacting with Lombard smart contracts.
|
|
3
|
-
*
|
|
4
|
-
* These ABIs are bundled with the SDK (not in S3) because:
|
|
5
|
-
* - They're code dependencies that generate TypeScript types
|
|
6
|
-
* - They're versioned with the SDK (contract upgrades = new SDK release)
|
|
7
|
-
* - They rarely change independently of code changes
|
|
8
|
-
*
|
|
9
|
-
* For asset addresses and metadata, see `core/assets/` which can be
|
|
10
|
-
* hosted in S3 for dynamic updates without SDK releases.
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
// Legacy LBTC contract ABI (pre-upgrade)
|
|
14
|
-
export { LBTC_ABI } from '../../tokens/abi/LBTC_ABI';
|
|
15
|
-
|
|
16
|
-
// Upgraded LBTC contract ABI (stLBTC with AssetRouter support)
|
|
17
|
-
export { default as STLBTC_ABI } from '../../tokens/abi/STLBTC_ABI';
|
|
18
|
-
|
|
19
|
-
// Native LBTC ABI (for cross-chain LBTC variants like BTCb on non-Avalanche chains)
|
|
20
|
-
export { default as NATIVE_LBTC_ABI } from '../../tokens/abi/NATIVE_LBTC_ABI';
|
|
21
|
-
|
|
22
|
-
// BTCK ABI (legacy Katana native LBTC)
|
|
23
|
-
export { default as BTCK_ABI } from '../../tokens/abi/BTCK_ABI';
|
|
24
|
-
|
|
25
|
-
// Bridge Token Adapter ABI (for BTC.b on Avalanche)
|
|
26
|
-
export { default as BRIDGE_TOKEN_ADAPTER_ABI } from '../../tokens/abi/BRIDGE_TOKEN_ADAPTER_ABI';
|
|
27
|
-
|
|
28
|
-
// Asset Router ABI (for MARS architecture deposits/redeems)
|
|
29
|
-
export { default as ASSET_ROUTER_ABI } from '../../tokens/abi/ASSET_ROUTER_ABI';
|
package/src/contracts/index.ts
DELETED
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Contract module for the Lombard SDK.
|
|
3
|
-
*
|
|
4
|
-
* This module provides everything needed to interact with Lombard smart contracts:
|
|
5
|
-
* - ABIs for all supported contracts
|
|
6
|
-
* - Types for contract interactions
|
|
7
|
-
* - Utilities for determining correct ABIs (handling upgrades, etc.)
|
|
8
|
-
*
|
|
9
|
-
* **Architecture:**
|
|
10
|
-
*
|
|
11
|
-
* The contracts module is separate from the asset catalog (`core/assets/`):
|
|
12
|
-
* - Asset catalog: "What assets exist and where?" (addresses, decimals) - S3-able
|
|
13
|
-
* - Contracts module: "How do I talk to them?" (ABIs, contract types) - bundled
|
|
14
|
-
*
|
|
15
|
-
* **Why ABIs are bundled (not in S3):**
|
|
16
|
-
* - They're code dependencies that generate TypeScript types
|
|
17
|
-
* - Contract upgrades require SDK updates anyway
|
|
18
|
-
* - They're versioned with the SDK
|
|
19
|
-
*
|
|
20
|
-
* @example
|
|
21
|
-
* ```typescript
|
|
22
|
-
* import { getContractInfo, AssetId, Chain } from '@lombard.finance/sdk';
|
|
23
|
-
*
|
|
24
|
-
* // Get contract info (handles upgrade detection)
|
|
25
|
-
* const info = await getContractInfo(AssetId.LBTC, ChainId.ethereum, Env.prod);
|
|
26
|
-
*
|
|
27
|
-
* // Create typed contract
|
|
28
|
-
* const contract = getContract({
|
|
29
|
-
* address: info.address,
|
|
30
|
-
* abi: info.abi,
|
|
31
|
-
* client: publicClient,
|
|
32
|
-
* });
|
|
33
|
-
*
|
|
34
|
-
* // Interact with fully typed methods
|
|
35
|
-
* const balance = await contract.read.balanceOf([userAddress]);
|
|
36
|
-
* ```
|
|
37
|
-
*
|
|
38
|
-
* @module contracts
|
|
39
|
-
*/
|
|
40
|
-
|
|
41
|
-
// ABIs
|
|
42
|
-
export * from './abis';
|
|
43
|
-
|
|
44
|
-
// Types
|
|
45
|
-
export {
|
|
46
|
-
AddressKind,
|
|
47
|
-
type BridgeTokenAddresses,
|
|
48
|
-
type ContractAbiMap,
|
|
49
|
-
type ContractInfo,
|
|
50
|
-
ContractType,
|
|
51
|
-
ContractVersion,
|
|
52
|
-
type GetContractInfoOptions,
|
|
53
|
-
} from './types';
|
|
54
|
-
|
|
55
|
-
// Utilities
|
|
56
|
-
export {
|
|
57
|
-
getBtckAbi,
|
|
58
|
-
getContractInfo,
|
|
59
|
-
getContractType,
|
|
60
|
-
getLbtcAbi,
|
|
61
|
-
isUpgradedAbi,
|
|
62
|
-
isUpgradedContract,
|
|
63
|
-
} from './utils';
|