@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,81 +0,0 @@
|
|
|
1
|
-
import { Abi } from 'viem';
|
|
2
|
-
|
|
3
|
-
import { makePublicClient } from '../../clients/public-client';
|
|
4
|
-
import { makeWalletClient } from '../../clients/wallet-client';
|
|
5
|
-
import { ChainId } from '../../common/chains';
|
|
6
|
-
import {
|
|
7
|
-
ISignStakeAndBakeParams,
|
|
8
|
-
ISignStakeAndBakeResult,
|
|
9
|
-
} from './signStakeAndBake';
|
|
10
|
-
import { buildTypedData, serializeTypedData } from './typed-data-builder';
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Handle approve flow (on-chain transaction).
|
|
14
|
-
* Checks allowance and submits approve transaction if needed.
|
|
15
|
-
*/
|
|
16
|
-
export async function handleApproveFlow(params: {
|
|
17
|
-
account: `0x${string}`;
|
|
18
|
-
chainId: ChainId;
|
|
19
|
-
provider: ISignStakeAndBakeParams['provider'];
|
|
20
|
-
rpcUrl: ISignStakeAndBakeParams['rpcUrl'];
|
|
21
|
-
tokenAddress: `0x${string}`;
|
|
22
|
-
tokenAbi: Abi;
|
|
23
|
-
spenderAddress: `0x${string}`;
|
|
24
|
-
typedData: ReturnType<typeof buildTypedData>;
|
|
25
|
-
requiredAmount: bigint;
|
|
26
|
-
}): Promise<ISignStakeAndBakeResult> {
|
|
27
|
-
const {
|
|
28
|
-
account,
|
|
29
|
-
chainId,
|
|
30
|
-
provider,
|
|
31
|
-
rpcUrl,
|
|
32
|
-
tokenAddress,
|
|
33
|
-
tokenAbi,
|
|
34
|
-
spenderAddress,
|
|
35
|
-
typedData,
|
|
36
|
-
requiredAmount,
|
|
37
|
-
} = params;
|
|
38
|
-
|
|
39
|
-
const publicClient = makePublicClient({ chainId, rpcUrl });
|
|
40
|
-
const walletClient = makeWalletClient({ chainId, provider });
|
|
41
|
-
|
|
42
|
-
// Check current allowance
|
|
43
|
-
const currentAllowance = (await publicClient.readContract({
|
|
44
|
-
address: tokenAddress,
|
|
45
|
-
abi: tokenAbi,
|
|
46
|
-
functionName: 'allowance',
|
|
47
|
-
args: [account, spenderAddress],
|
|
48
|
-
})) as bigint;
|
|
49
|
-
|
|
50
|
-
let approvalTxHash: string | undefined;
|
|
51
|
-
|
|
52
|
-
// Submit approve transaction if allowance is insufficient
|
|
53
|
-
if (currentAllowance < requiredAmount) {
|
|
54
|
-
const hash = await walletClient.writeContract({
|
|
55
|
-
address: tokenAddress,
|
|
56
|
-
abi: tokenAbi,
|
|
57
|
-
functionName: 'approve',
|
|
58
|
-
args: [spenderAddress, requiredAmount],
|
|
59
|
-
account,
|
|
60
|
-
chain: null,
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
// Wait for transaction confirmation
|
|
64
|
-
const receipt = await publicClient.waitForTransactionReceipt({ hash });
|
|
65
|
-
|
|
66
|
-
if (receipt.status !== 'success') {
|
|
67
|
-
throw new Error(
|
|
68
|
-
`Approve transaction failed: ${hash}. Please try again or contact support.`,
|
|
69
|
-
);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
approvalTxHash = hash;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
return {
|
|
76
|
-
mode: 'approve',
|
|
77
|
-
signature: '',
|
|
78
|
-
typedData: serializeTypedData(typedData),
|
|
79
|
-
approvalTxHash,
|
|
80
|
-
};
|
|
81
|
-
}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { makeWalletClient } from '../../clients/wallet-client';
|
|
2
|
-
import { ChainId } from '../../common/chains';
|
|
3
|
-
import {
|
|
4
|
-
ISignStakeAndBakeParams,
|
|
5
|
-
ISignStakeAndBakeResult,
|
|
6
|
-
} from './signStakeAndBake';
|
|
7
|
-
import { buildTypedData, serializeTypedData } from './typed-data-builder';
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Handle permit flow (off-chain signature).
|
|
11
|
-
* Signs EIP-2612 typed data for gasless approval.
|
|
12
|
-
*/
|
|
13
|
-
export async function handlePermitFlow(params: {
|
|
14
|
-
chainId: ChainId;
|
|
15
|
-
provider: ISignStakeAndBakeParams['provider'];
|
|
16
|
-
typedData: ReturnType<typeof buildTypedData>;
|
|
17
|
-
}): Promise<ISignStakeAndBakeResult> {
|
|
18
|
-
const { chainId, provider, typedData } = params;
|
|
19
|
-
|
|
20
|
-
const walletClient = makeWalletClient({ chainId, provider });
|
|
21
|
-
const signature = await walletClient.signTypedData(typedData);
|
|
22
|
-
|
|
23
|
-
return {
|
|
24
|
-
mode: 'permit',
|
|
25
|
-
signature,
|
|
26
|
-
typedData: serializeTypedData(typedData),
|
|
27
|
-
};
|
|
28
|
-
}
|
|
@@ -1,202 +0,0 @@
|
|
|
1
|
-
import { Env } from '@lombard.finance/sdk-common';
|
|
2
|
-
import type { Meta, StoryObj } from '@storybook/react';
|
|
3
|
-
import { useState } from 'react';
|
|
4
|
-
|
|
5
|
-
import { DefiProtocol } from '../../defi/defi-registry';
|
|
6
|
-
import { Button } from '../../stories/components/Button';
|
|
7
|
-
import { CodeBlock } from '../../stories/components/CodeBlock';
|
|
8
|
-
import { ConnectButton } from '../../stories/components/ConnectButton';
|
|
9
|
-
import {
|
|
10
|
-
functionType,
|
|
11
|
-
wagmiDecorator,
|
|
12
|
-
} from '../../stories/components/decorators';
|
|
13
|
-
import {
|
|
14
|
-
canPerformAction,
|
|
15
|
-
useConnection,
|
|
16
|
-
} from '../../stories/hooks/useConnection';
|
|
17
|
-
import useQuery from '../../stories/hooks/useQuery';
|
|
18
|
-
import { Token } from '../../tokens/token-addresses';
|
|
19
|
-
import { ISignStakeAndBakeParams, signStakeAndBake } from './signStakeAndBake';
|
|
20
|
-
|
|
21
|
-
const meta = {
|
|
22
|
-
title: 'write/signStakeAndBake',
|
|
23
|
-
component: StoryView,
|
|
24
|
-
tags: ['autodocs'],
|
|
25
|
-
decorators: [wagmiDecorator, functionType('write')],
|
|
26
|
-
argTypes: {
|
|
27
|
-
token: {
|
|
28
|
-
options: ['BTC', Token.LBTC, Token.BTCb],
|
|
29
|
-
control: { type: 'select' },
|
|
30
|
-
description:
|
|
31
|
-
'Token to stake (BTC converts to LBTC, BTCb uses approve mode)',
|
|
32
|
-
},
|
|
33
|
-
vault: {
|
|
34
|
-
options: Object.values(DefiProtocol),
|
|
35
|
-
control: { type: 'select' },
|
|
36
|
-
description: 'Vault to stake into (Veda: LBTC/BTC, Silo: BTCb)',
|
|
37
|
-
},
|
|
38
|
-
env: {
|
|
39
|
-
options: [Env.prod, Env.testnet, Env.stage, Env.dev],
|
|
40
|
-
control: { type: 'select' },
|
|
41
|
-
description: 'Environment (affects contract addresses)',
|
|
42
|
-
},
|
|
43
|
-
value: {
|
|
44
|
-
control: { type: 'text' },
|
|
45
|
-
description: 'Amount to stake (in token units)',
|
|
46
|
-
},
|
|
47
|
-
},
|
|
48
|
-
} satisfies Meta<typeof StoryView>;
|
|
49
|
-
|
|
50
|
-
export default meta;
|
|
51
|
-
|
|
52
|
-
type Story = StoryObj<typeof meta>;
|
|
53
|
-
|
|
54
|
-
export const PermitFlow_LBTC_Ethereum: Story = {
|
|
55
|
-
name: 'Permit Flow: LBTC on Ethereum',
|
|
56
|
-
args: {
|
|
57
|
-
value: '10000',
|
|
58
|
-
token: Token.LBTC,
|
|
59
|
-
vault: DefiProtocol.Veda,
|
|
60
|
-
env: Env.prod,
|
|
61
|
-
},
|
|
62
|
-
};
|
|
63
|
-
|
|
64
|
-
export const PermitFlow_BTC_Ethereum: Story = {
|
|
65
|
-
name: 'Permit Flow: BTC to LBTC on Ethereum',
|
|
66
|
-
args: {
|
|
67
|
-
value: '10000',
|
|
68
|
-
token: 'BTC',
|
|
69
|
-
vault: DefiProtocol.Veda,
|
|
70
|
-
env: Env.prod,
|
|
71
|
-
},
|
|
72
|
-
};
|
|
73
|
-
|
|
74
|
-
export const ApproveFlow_BTCb_Fuji: Story = {
|
|
75
|
-
name: 'Approve Flow: BTCb on Avalanche Fuji',
|
|
76
|
-
args: {
|
|
77
|
-
value: '5000',
|
|
78
|
-
token: Token.BTCb,
|
|
79
|
-
vault: DefiProtocol.Silo,
|
|
80
|
-
env: Env.testnet,
|
|
81
|
-
},
|
|
82
|
-
};
|
|
83
|
-
|
|
84
|
-
type SignStakeAndBakeParams = Omit<
|
|
85
|
-
ISignStakeAndBakeParams,
|
|
86
|
-
'account' | 'chainId' | 'provider'
|
|
87
|
-
> & {
|
|
88
|
-
vault?: DefiProtocol;
|
|
89
|
-
env?: Env;
|
|
90
|
-
};
|
|
91
|
-
|
|
92
|
-
export function StoryView(props: SignStakeAndBakeParams) {
|
|
93
|
-
const connection = useConnection();
|
|
94
|
-
const [showRawData, setShowRawData] = useState(false);
|
|
95
|
-
|
|
96
|
-
const request = async () => {
|
|
97
|
-
if (!canPerformAction(connection)) {
|
|
98
|
-
alert('Not connected.');
|
|
99
|
-
return;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
return signStakeAndBake({
|
|
103
|
-
value: props.value,
|
|
104
|
-
expiry: props.expiry,
|
|
105
|
-
token: props.token,
|
|
106
|
-
vaultKey: props.vault || DefiProtocol.Veda,
|
|
107
|
-
account: connection.account.address,
|
|
108
|
-
chainId: connection.account.chainId,
|
|
109
|
-
provider: connection.provider,
|
|
110
|
-
env: props.env || Env.stage,
|
|
111
|
-
});
|
|
112
|
-
};
|
|
113
|
-
|
|
114
|
-
const { data, error, isLoading, refetch } = useQuery(request, [], false);
|
|
115
|
-
|
|
116
|
-
return (
|
|
117
|
-
<>
|
|
118
|
-
<p>
|
|
119
|
-
Generates a signature that allows Lombard to claim specified amount of
|
|
120
|
-
BTC and deposit the equivalent LBTC amount (calculated using current
|
|
121
|
-
ratio) automatically to the DeFi vault.
|
|
122
|
-
</p>
|
|
123
|
-
|
|
124
|
-
<p>
|
|
125
|
-
<strong>Note:</strong> Pass the original BTC amount directly. The
|
|
126
|
-
function automatically calculates the correct LBTC amount using the
|
|
127
|
-
current exchange ratio.
|
|
128
|
-
</p>
|
|
129
|
-
|
|
130
|
-
{props.token === Token.BTCb && (
|
|
131
|
-
<p className="text-danger">
|
|
132
|
-
<strong>Important:</strong> BTCb uses on-chain approve. You'll need to
|
|
133
|
-
sign a transaction and pay gas fees. Make sure you're on Avalanche
|
|
134
|
-
Fuji testnet.
|
|
135
|
-
</p>
|
|
136
|
-
)}
|
|
137
|
-
|
|
138
|
-
<div className="mb-4">
|
|
139
|
-
<ConnectButton />
|
|
140
|
-
</div>
|
|
141
|
-
|
|
142
|
-
<Button
|
|
143
|
-
onClick={refetch}
|
|
144
|
-
disabled={isLoading || !connection.account.address}
|
|
145
|
-
isLoading={isLoading}
|
|
146
|
-
actionName={signStakeAndBake.name}
|
|
147
|
-
/>
|
|
148
|
-
|
|
149
|
-
{!showRawData && data && (
|
|
150
|
-
<div className="mt-4">
|
|
151
|
-
<p>
|
|
152
|
-
<strong>Mode:</strong> {data.mode}
|
|
153
|
-
</p>
|
|
154
|
-
{data.mode === 'permit' && (
|
|
155
|
-
<p>
|
|
156
|
-
<strong>Signature:</strong> <code>{data.signature}</code>
|
|
157
|
-
</p>
|
|
158
|
-
)}
|
|
159
|
-
{data.mode === 'approve' && data.approvalTxHash && (
|
|
160
|
-
<p>
|
|
161
|
-
<strong>Transaction Hash:</strong>{' '}
|
|
162
|
-
<code>{data.approvalTxHash}</code>
|
|
163
|
-
</p>
|
|
164
|
-
)}
|
|
165
|
-
<button
|
|
166
|
-
type="button"
|
|
167
|
-
className="btn btn-sm btn-outline-secondary mt-2"
|
|
168
|
-
onClick={() => {
|
|
169
|
-
setShowRawData(true);
|
|
170
|
-
}}
|
|
171
|
-
>
|
|
172
|
-
Show full response
|
|
173
|
-
</button>
|
|
174
|
-
</div>
|
|
175
|
-
)}
|
|
176
|
-
|
|
177
|
-
{showRawData && data && (
|
|
178
|
-
<>
|
|
179
|
-
<button
|
|
180
|
-
type="button"
|
|
181
|
-
className="btn btn-sm btn-outline-secondary mt-3 mb-2"
|
|
182
|
-
onClick={() => {
|
|
183
|
-
setShowRawData(false);
|
|
184
|
-
}}
|
|
185
|
-
>
|
|
186
|
-
Hide full response
|
|
187
|
-
</button>
|
|
188
|
-
<CodeBlock
|
|
189
|
-
text={{
|
|
190
|
-
mode: data.mode,
|
|
191
|
-
signature: data.signature,
|
|
192
|
-
approvalTxHash: data.approvalTxHash,
|
|
193
|
-
typedData: data.typedData ? JSON.parse(data.typedData) : '',
|
|
194
|
-
}}
|
|
195
|
-
/>
|
|
196
|
-
</>
|
|
197
|
-
)}
|
|
198
|
-
|
|
199
|
-
{error && <CodeBlock text={error} />}
|
|
200
|
-
</>
|
|
201
|
-
);
|
|
202
|
-
}
|
|
@@ -1,160 +0,0 @@
|
|
|
1
|
-
import { DEFAULT_ENV } from '@lombard.finance/sdk-common';
|
|
2
|
-
import BigNumber from 'bignumber.js';
|
|
3
|
-
|
|
4
|
-
import { CommonWriteParameters } from '../../common/parameters';
|
|
5
|
-
import {
|
|
6
|
-
ApprovalMode,
|
|
7
|
-
DefiProtocol,
|
|
8
|
-
StakeAndBakeToken,
|
|
9
|
-
} from '../../defi/defi-registry';
|
|
10
|
-
import { DAY, now, toUnix } from '../../utils/time';
|
|
11
|
-
import { getPermitNonce } from '../getPermitNonce/getPermitNonce';
|
|
12
|
-
import { handleApproveFlow } from './handleApprove';
|
|
13
|
-
import { handlePermitFlow } from './handlePermit';
|
|
14
|
-
import { buildTypedData } from './typed-data-builder';
|
|
15
|
-
import {
|
|
16
|
-
calculateStakeAndBakeLBTCAmount,
|
|
17
|
-
getStakeAndBakeTokenContract,
|
|
18
|
-
} from './utils';
|
|
19
|
-
import { getStakeAndBakeConfig } from './validation';
|
|
20
|
-
|
|
21
|
-
export interface ISignStakeAndBakeParams extends CommonWriteParameters {
|
|
22
|
-
/**
|
|
23
|
-
* The approved BTC value that will be automatically claimed and deposited
|
|
24
|
-
* to the chosen vault. The function will internally calculate the correct LBTC amount using the current ratio.
|
|
25
|
-
*/
|
|
26
|
-
value: BigNumber.Value;
|
|
27
|
-
/**
|
|
28
|
-
* The expiration UNIX time of the signature.
|
|
29
|
-
* Defaults to 24 hours from the time of signing.
|
|
30
|
-
*/
|
|
31
|
-
expiry?: number;
|
|
32
|
-
/**
|
|
33
|
-
* The chosen DeFi vault to which the funds will be deposited.
|
|
34
|
-
*/
|
|
35
|
-
vaultKey?: DefiProtocol;
|
|
36
|
-
/**
|
|
37
|
-
* The token for which the signature is generated.
|
|
38
|
-
* - Defaults to **BTC**: the amount will be converted to the corresponding
|
|
39
|
-
* **LBTC** value based on the current ratio.
|
|
40
|
-
* - If **LBTC** is chosen: no conversion is performed.
|
|
41
|
-
*/
|
|
42
|
-
token?: StakeAndBakeToken;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
export interface ISignStakeAndBakeResult {
|
|
46
|
-
/**
|
|
47
|
-
* The approval mode used for this signature.
|
|
48
|
-
* - `permit`: Off-chain signature (EIP-2612), can be used directly by backend
|
|
49
|
-
* - `approve`: On-chain approval transaction was submitted
|
|
50
|
-
*/
|
|
51
|
-
mode: ApprovalMode;
|
|
52
|
-
|
|
53
|
-
/**
|
|
54
|
-
* The signature.
|
|
55
|
-
* - For permit mode: Contains the EIP-2612 signature
|
|
56
|
-
* - For approve mode: Empty string (approval was done on-chain)
|
|
57
|
-
*/
|
|
58
|
-
signature: string;
|
|
59
|
-
|
|
60
|
-
/**
|
|
61
|
-
* The typed data used to generate the signature.
|
|
62
|
-
* Contains the full EIP-712 structure for both permit and approve modes.
|
|
63
|
-
*/
|
|
64
|
-
typedData: string;
|
|
65
|
-
|
|
66
|
-
/**
|
|
67
|
-
* Transaction hash for approve mode (when allowance was set).
|
|
68
|
-
* Only present when mode is 'approve' and a transaction was submitted.
|
|
69
|
-
*/
|
|
70
|
-
approvalTxHash?: string;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
/**
|
|
74
|
-
* Signs the "stake and bake" signature that allows Lombard to claim specified
|
|
75
|
-
* amount of BTC (converted to LBTC using current ratio) and deposit that amount directly to the specified DeFi
|
|
76
|
-
* vault.
|
|
77
|
-
*
|
|
78
|
-
* In order for the "stake and bake" process to work a user has to store the
|
|
79
|
-
* signature to the Lombard's system, see: `storeStakeAndBakeSignature`
|
|
80
|
-
*
|
|
81
|
-
* @param {ISignStakeAndBakeParams} parameters - The parameters.
|
|
82
|
-
* @param {BigNumber.Value} parameters.value - The amount of BTC that will be converted to LBTC using current ratio and deposited to the DeFi vault.
|
|
83
|
-
* @param {number} parameters.expiry = The optional expiration UNIX time of the signature.
|
|
84
|
-
* @param {DefiProtocol} parameters.vaultKey - The optional DeFi vault identifier.
|
|
85
|
-
* @param {Address} parameters.account - The EVM account address.
|
|
86
|
-
* @param {ChainId} parameters.chainId - The chain id.
|
|
87
|
-
* @param {EIP1193Provider} parameters.provider - The EIP1193 provider.
|
|
88
|
-
* @param {string} parameters.rpcUrl - The optional rpc url.
|
|
89
|
-
*
|
|
90
|
-
* @returns {Promise<ISignStakeAndBakeResult>} - The signature and typed data.
|
|
91
|
-
*/
|
|
92
|
-
export async function signStakeAndBake({
|
|
93
|
-
account,
|
|
94
|
-
expiry = toUnix(now() + DAY),
|
|
95
|
-
value,
|
|
96
|
-
// TODO: Rename vaultKey to protocol
|
|
97
|
-
vaultKey: protocol = DefiProtocol.Veda,
|
|
98
|
-
token = 'BTC',
|
|
99
|
-
chainId,
|
|
100
|
-
provider,
|
|
101
|
-
rpcUrl,
|
|
102
|
-
env = DEFAULT_ENV,
|
|
103
|
-
}: ISignStakeAndBakeParams): Promise<ISignStakeAndBakeResult> {
|
|
104
|
-
const strategy = getStakeAndBakeConfig(protocol, token, chainId, env);
|
|
105
|
-
|
|
106
|
-
const spenderAddress = strategy.spenderContract.address;
|
|
107
|
-
|
|
108
|
-
// Calculate permit value (with conversion if needed)
|
|
109
|
-
const permitValue =
|
|
110
|
-
strategy.amountStrategy === 'btcToLbtc'
|
|
111
|
-
? await calculateStakeAndBakeLBTCAmount(value, env)
|
|
112
|
-
: new BigNumber(value);
|
|
113
|
-
|
|
114
|
-
// Get token contract (always use Token address for permits/approves, not adapter)
|
|
115
|
-
const tokenContract = await getStakeAndBakeTokenContract(token, chainId, env);
|
|
116
|
-
const tokenAddress = tokenContract.address;
|
|
117
|
-
const tokenAbi = tokenContract.abi;
|
|
118
|
-
|
|
119
|
-
// Calculate deadline based on expiry behavior
|
|
120
|
-
const deadline =
|
|
121
|
-
strategy.approval.deadlineStrategy === 'zero' ? 0n : BigInt(expiry);
|
|
122
|
-
|
|
123
|
-
// Get nonce if required
|
|
124
|
-
const nonce =
|
|
125
|
-
strategy.approval.nonceStrategy === 'chain'
|
|
126
|
-
? BigInt(await getPermitNonce({ owner: account, chainId, rpcUrl, env }))
|
|
127
|
-
: 0n;
|
|
128
|
-
|
|
129
|
-
// Build typed data using config
|
|
130
|
-
const typedData = buildTypedData({
|
|
131
|
-
mode: strategy.approval.mode,
|
|
132
|
-
account,
|
|
133
|
-
chainId,
|
|
134
|
-
verifyingContract: tokenAddress,
|
|
135
|
-
domainName: strategy.approval.domainName,
|
|
136
|
-
domainVersion: strategy.approval.domainVersion,
|
|
137
|
-
spender: spenderAddress,
|
|
138
|
-
value: BigInt(permitValue.toFixed(0, BigNumber.ROUND_DOWN)),
|
|
139
|
-
nonce,
|
|
140
|
-
deadline,
|
|
141
|
-
});
|
|
142
|
-
|
|
143
|
-
// Delegate to appropriate handler based on mode
|
|
144
|
-
if (strategy.approval.mode === 'approve') {
|
|
145
|
-
return handleApproveFlow({
|
|
146
|
-
account,
|
|
147
|
-
chainId,
|
|
148
|
-
provider,
|
|
149
|
-
rpcUrl,
|
|
150
|
-
tokenAddress,
|
|
151
|
-
tokenAbi,
|
|
152
|
-
spenderAddress,
|
|
153
|
-
typedData,
|
|
154
|
-
requiredAmount: BigInt(permitValue.toFixed(0, BigNumber.ROUND_DOWN)),
|
|
155
|
-
});
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
// Permit mode
|
|
159
|
-
return handlePermitFlow({ chainId, provider, typedData });
|
|
160
|
-
}
|
|
@@ -1,137 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Typed data builders for EIP-712 signatures.
|
|
3
|
-
* Centralizes EIP-712 structure creation for stake and bake operations.
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import type { Address } from 'viem';
|
|
7
|
-
|
|
8
|
-
import type { ChainId } from '../../common/chains';
|
|
9
|
-
import type { ApprovalMode } from '../../defi/defi-registry';
|
|
10
|
-
|
|
11
|
-
/**
|
|
12
|
-
* EIP-712 domain type definition.
|
|
13
|
-
* Standard across all EIP-712 signatures.
|
|
14
|
-
*/
|
|
15
|
-
export const EIP712_DOMAIN_TYPES = [
|
|
16
|
-
{ name: 'name', type: 'string' },
|
|
17
|
-
{ name: 'version', type: 'string' },
|
|
18
|
-
{ name: 'chainId', type: 'uint256' },
|
|
19
|
-
{ name: 'verifyingContract', type: 'address' },
|
|
20
|
-
] as const;
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
* EIP-712 Permit message type definition (EIP-2612).
|
|
24
|
-
* Used for gasless token approvals.
|
|
25
|
-
*/
|
|
26
|
-
export const PERMIT_MESSAGE_TYPES = [
|
|
27
|
-
{ name: 'owner', type: 'address' },
|
|
28
|
-
{ name: 'spender', type: 'address' },
|
|
29
|
-
{ name: 'value', type: 'uint256' },
|
|
30
|
-
{ name: 'nonce', type: 'uint256' },
|
|
31
|
-
{ name: 'deadline', type: 'uint256' },
|
|
32
|
-
] as const;
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* EIP-712 Approve message type definition.
|
|
36
|
-
* Used for traditional on-chain approvals (same structure as Permit).
|
|
37
|
-
*/
|
|
38
|
-
export const APPROVE_MESSAGE_TYPES = PERMIT_MESSAGE_TYPES;
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Parameters for building typed data.
|
|
42
|
-
*/
|
|
43
|
-
export interface TypedDataParams {
|
|
44
|
-
/** Approval mode (determines primary type) */
|
|
45
|
-
mode: ApprovalMode;
|
|
46
|
-
/** User's account address */
|
|
47
|
-
account: Address;
|
|
48
|
-
/** Chain ID */
|
|
49
|
-
chainId: ChainId;
|
|
50
|
-
/** Token contract address (verifying contract) */
|
|
51
|
-
verifyingContract: Address;
|
|
52
|
-
/** EIP-712 domain name */
|
|
53
|
-
domainName: string;
|
|
54
|
-
/** EIP-712 domain version */
|
|
55
|
-
domainVersion: string;
|
|
56
|
-
/** Spender contract address */
|
|
57
|
-
spender: Address;
|
|
58
|
-
/** Amount to approve/permit (in base units) */
|
|
59
|
-
value: bigint;
|
|
60
|
-
/** Nonce for replay protection */
|
|
61
|
-
nonce: bigint;
|
|
62
|
-
/** Deadline timestamp (or 0 for no deadline) */
|
|
63
|
-
deadline: bigint;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
/**
|
|
67
|
-
* Builds EIP-712 typed data structure for signatures.
|
|
68
|
-
*
|
|
69
|
-
* @param params - Typed data parameters
|
|
70
|
-
* @returns EIP-712 typed data structure ready for signing
|
|
71
|
-
*
|
|
72
|
-
* @example
|
|
73
|
-
* ```typescript
|
|
74
|
-
* const typedData = buildTypedData({
|
|
75
|
-
* mode: 'permit',
|
|
76
|
-
* account: '0x...',
|
|
77
|
-
* chainId: 1,
|
|
78
|
-
* verifyingContract: '0x...',
|
|
79
|
-
* domainName: 'Lombard Staked Bitcoin',
|
|
80
|
-
* domainVersion: '1',
|
|
81
|
-
* spender: '0x...',
|
|
82
|
-
* value: 1000000n,
|
|
83
|
-
* nonce: 0n,
|
|
84
|
-
* deadline: 1234567890n,
|
|
85
|
-
* });
|
|
86
|
-
*
|
|
87
|
-
* const signature = await walletClient.signTypedData(typedData);
|
|
88
|
-
* ```
|
|
89
|
-
*/
|
|
90
|
-
export function buildTypedData(params: TypedDataParams) {
|
|
91
|
-
const primaryType = params.mode === 'permit' ? 'Permit' : 'Approve';
|
|
92
|
-
|
|
93
|
-
return {
|
|
94
|
-
account: params.account,
|
|
95
|
-
domain: {
|
|
96
|
-
name: params.domainName,
|
|
97
|
-
version: params.domainVersion,
|
|
98
|
-
chainId: BigInt(params.chainId),
|
|
99
|
-
verifyingContract: params.verifyingContract,
|
|
100
|
-
},
|
|
101
|
-
types: {
|
|
102
|
-
EIP712Domain: EIP712_DOMAIN_TYPES,
|
|
103
|
-
[primaryType]:
|
|
104
|
-
params.mode === 'permit' ? PERMIT_MESSAGE_TYPES : APPROVE_MESSAGE_TYPES,
|
|
105
|
-
},
|
|
106
|
-
primaryType,
|
|
107
|
-
message: {
|
|
108
|
-
owner: params.account,
|
|
109
|
-
spender: params.spender,
|
|
110
|
-
value: params.value,
|
|
111
|
-
nonce: params.nonce,
|
|
112
|
-
deadline: params.deadline,
|
|
113
|
-
},
|
|
114
|
-
} as const;
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
/**
|
|
118
|
-
* Serializes typed data to JSON string.
|
|
119
|
-
* Handles BigInt serialization by converting to strings.
|
|
120
|
-
*
|
|
121
|
-
* @param typedData - Typed data structure from buildTypedData
|
|
122
|
-
* @returns JSON string representation
|
|
123
|
-
*
|
|
124
|
-
* @example
|
|
125
|
-
* ```typescript
|
|
126
|
-
* const typedData = buildTypedData(params);
|
|
127
|
-
* const json = serializeTypedData(typedData);
|
|
128
|
-
* // Store or transmit JSON string
|
|
129
|
-
* ```
|
|
130
|
-
*/
|
|
131
|
-
export function serializeTypedData(
|
|
132
|
-
typedData: ReturnType<typeof buildTypedData>,
|
|
133
|
-
): string {
|
|
134
|
-
return JSON.stringify(typedData, (_, v) =>
|
|
135
|
-
typeof v === 'bigint' ? v.toString() : v,
|
|
136
|
-
);
|
|
137
|
-
}
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import { Env } from '@lombard.finance/sdk-common';
|
|
2
|
-
import BigNumber from 'bignumber.js';
|
|
3
|
-
|
|
4
|
-
import { getExchangeRatio } from '../../api-functions/getLBTCExchangeRate/get-exchange-ratio';
|
|
5
|
-
import { StakeAndBakeToken } from '../../defi/defi-registry';
|
|
6
|
-
import { AddressKind, Token } from '../../tokens/token-addresses';
|
|
7
|
-
import { getTokenContractInfo } from '../../tokens/tokens';
|
|
8
|
-
import { ISignStakeAndBakeParams } from './signStakeAndBake';
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Calculate the permit value, applying BTC -> LBTC conversion if needed.
|
|
12
|
-
*/
|
|
13
|
-
export const getPermitValue = async (
|
|
14
|
-
token: StakeAndBakeToken,
|
|
15
|
-
value: BigNumber.Value,
|
|
16
|
-
env: Env,
|
|
17
|
-
): Promise<BigNumber> => {
|
|
18
|
-
if (!token || token === 'BTC') {
|
|
19
|
-
return await calculateStakeAndBakeLBTCAmount(value, env);
|
|
20
|
-
}
|
|
21
|
-
return new BigNumber(value);
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
/**
|
|
25
|
-
* Get the token contract info for the given token.
|
|
26
|
-
* For BTCb, always uses AddressKind.Token (the ERC20 token contract, not the adapter).
|
|
27
|
-
*/
|
|
28
|
-
export const getStakeAndBakeTokenContract = async (
|
|
29
|
-
token: StakeAndBakeToken,
|
|
30
|
-
chainId: ISignStakeAndBakeParams['chainId'],
|
|
31
|
-
env: Env,
|
|
32
|
-
): Promise<Awaited<ReturnType<typeof getTokenContractInfo>>> => {
|
|
33
|
-
if (!token || token === 'BTC' || token === Token.LBTC) {
|
|
34
|
-
return await getTokenContractInfo(Token.LBTC, chainId, env);
|
|
35
|
-
}
|
|
36
|
-
// For BTCb, use AddressKind.Token (ERC20 contract for permit/approve)
|
|
37
|
-
return await getTokenContractInfo(token, chainId, env, AddressKind.Token);
|
|
38
|
-
};
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Helper function to calculate the correct LBTC amount for stake and bake
|
|
42
|
-
* based on the current BTC to LBTC ratio.
|
|
43
|
-
*
|
|
44
|
-
* @param btcAmount - The original BTC amount entered by the user
|
|
45
|
-
* @param env - The environment for fetching the exchange ratio
|
|
46
|
-
* @returns The calculated LBTC amount that should be used in the permit signature
|
|
47
|
-
*/
|
|
48
|
-
export async function calculateStakeAndBakeLBTCAmount(
|
|
49
|
-
btcAmount: BigNumber.Value,
|
|
50
|
-
env?: Env,
|
|
51
|
-
): Promise<BigNumber> {
|
|
52
|
-
try {
|
|
53
|
-
const ratios = await getExchangeRatio({ env });
|
|
54
|
-
const btcTokenRatio = ratios.LBTC?.BTCTokenRatio || new BigNumber(1);
|
|
55
|
-
const lbtcAmount = new BigNumber(btcAmount).dividedBy(btcTokenRatio);
|
|
56
|
-
|
|
57
|
-
return lbtcAmount;
|
|
58
|
-
} catch {
|
|
59
|
-
throw new Error('Failed to get exchange ratio for stake and bake');
|
|
60
|
-
}
|
|
61
|
-
}
|