@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
package/src/modules/index.ts
DELETED
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Module System Exports
|
|
3
|
-
*
|
|
4
|
-
* Modules provide service implementations using the Service-First pattern:
|
|
5
|
-
* - Service interfaces define the contract (in sdk-common)
|
|
6
|
-
* - Service classes implement the interfaces (in services/)
|
|
7
|
-
* - Module factories instantiate services with context
|
|
8
|
-
*
|
|
9
|
-
* Module Types:
|
|
10
|
-
* - SdkModule: Generic module (e.g., apiModule) - for non-chain services
|
|
11
|
-
* - ChainModule: Chain-specific module (e.g., btcModule, evmModule)
|
|
12
|
-
*
|
|
13
|
-
* Service Types:
|
|
14
|
-
* - Internal services: Minimal types, for action DI (not exposed publicly)
|
|
15
|
-
* - Public APIs: Rich types, for user-facing methods (sdk.deposits.*, etc.)
|
|
16
|
-
*
|
|
17
|
-
* @module modules
|
|
18
|
-
*/
|
|
19
|
-
|
|
20
|
-
export { CapabilityRegistry } from './CapabilityRegistry';
|
|
21
|
-
|
|
22
|
-
// BTC Module (chain-specific)
|
|
23
|
-
export { btcModule, BtcService } from './btcModule';
|
|
24
|
-
|
|
25
|
-
// EVM Module (chain-specific)
|
|
26
|
-
export type {
|
|
27
|
-
EvmChainId,
|
|
28
|
-
FeeAuthorizationResult,
|
|
29
|
-
StoredFeeSignature,
|
|
30
|
-
} from './evmModule';
|
|
31
|
-
export { evmModule, EvmService } from './evmModule';
|
|
32
|
-
|
|
33
|
-
// API Module (generic SDK module, not chain-specific)
|
|
34
|
-
export type {
|
|
35
|
-
DepositInfo,
|
|
36
|
-
GenerateDepositAddressParams,
|
|
37
|
-
GetDepositAddressParams,
|
|
38
|
-
} from './apiModule';
|
|
39
|
-
export { apiModule, ApiService } from './apiModule';
|
|
40
|
-
|
|
41
|
-
// Module types from sdk-common
|
|
42
|
-
export type {
|
|
43
|
-
// Any module
|
|
44
|
-
AnyModule,
|
|
45
|
-
// Chain-specific module type
|
|
46
|
-
ChainModule,
|
|
47
|
-
ModuleId,
|
|
48
|
-
// Helper types
|
|
49
|
-
RegisterContext,
|
|
50
|
-
// Generic module type
|
|
51
|
-
SdkModule,
|
|
52
|
-
ServiceOf,
|
|
53
|
-
} from '@lombard.finance/sdk-common';
|
|
54
|
-
|
|
55
|
-
// Service interface types (from sdk-common, aliased for clarity)
|
|
56
|
-
export type {
|
|
57
|
-
ApiService as IApiService,
|
|
58
|
-
BtcService as IBtcService,
|
|
59
|
-
EvmService as IEvmService,
|
|
60
|
-
} from '@lombard.finance/sdk-common';
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import { getDepositAddressReferrer } from '../api-functions/getDepositAddressReferrer';
|
|
2
|
-
import type { LombardSDK } from '../client/LombardSDK';
|
|
3
|
-
|
|
4
|
-
export interface ReferralLookupParams {
|
|
5
|
-
/** Destination account that previously generated a BTC deposit address */
|
|
6
|
-
address: string;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export interface ReferralLookupResult {
|
|
10
|
-
hasDepositAddress: boolean;
|
|
11
|
-
referrer?: string;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Referral helper namespace.
|
|
16
|
-
*
|
|
17
|
-
* Provides read APIs for referral metadata so partners do not need to query
|
|
18
|
-
* Lombard REST endpoints directly.
|
|
19
|
-
*/
|
|
20
|
-
export class ReferralsClient {
|
|
21
|
-
constructor(private readonly sdk: LombardSDK) {}
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Fetch the referrer bound to a previously generated BTC deposit address.
|
|
25
|
-
*/
|
|
26
|
-
async lookupReferrer({
|
|
27
|
-
address,
|
|
28
|
-
}: ReferralLookupParams): Promise<ReferralLookupResult> {
|
|
29
|
-
return getDepositAddressReferrer({
|
|
30
|
-
address,
|
|
31
|
-
env: this.sdk.config.env,
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
}
|
package/src/referrals/index.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './ReferralsClient';
|
|
@@ -1,152 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* API Service
|
|
3
|
-
*
|
|
4
|
-
* Provides Lombard backend API operations for internal use by actions.
|
|
5
|
-
* Returns minimal types defined in sdk-common.
|
|
6
|
-
*
|
|
7
|
-
* For public APIs with full types, use the exported functions in api-functions/
|
|
8
|
-
* or the SDK namespace methods.
|
|
9
|
-
*
|
|
10
|
-
* @module services/ApiService
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
import type { Env } from '@lombard.finance/sdk-common';
|
|
14
|
-
import type {
|
|
15
|
-
ApiService as IApiService,
|
|
16
|
-
DepositInfo,
|
|
17
|
-
FeeSignatureResult,
|
|
18
|
-
GenerateDepositAddressParams,
|
|
19
|
-
GetDepositAddressParams,
|
|
20
|
-
GetFeeSignatureParams,
|
|
21
|
-
StoreFeeSignatureParams,
|
|
22
|
-
StoreStakeAndBakeParams,
|
|
23
|
-
} from '@lombard.finance/sdk-common';
|
|
24
|
-
|
|
25
|
-
import { generateDepositBtcAddress } from '../api-functions/generateDepositBtcAddress/generateDepositBtcAddress';
|
|
26
|
-
import { getDepositBtcAddress } from '../api-functions/getDepositBtcAddress/getDepositBtcAddress';
|
|
27
|
-
import { getDepositsByAddress } from '../api-functions/getDepositsByAddress/getDepositsByAddress';
|
|
28
|
-
import { getNetworkFeeSignature } from '../api-functions/getNetworkFeeSignature/getNetworkFeeSignature';
|
|
29
|
-
import { storeNetworkFeeSignature } from '../api-functions/storeNetworkFeeSignature/storeNetworkFeeSignature';
|
|
30
|
-
import { storeStakeAndBakeSignature } from '../api-functions/storeStakeAndBakeSignature/storeStakeAndBakeSignature';
|
|
31
|
-
import type {
|
|
32
|
-
ChainId,
|
|
33
|
-
SolanaChain,
|
|
34
|
-
StarknetChainId,
|
|
35
|
-
SuiChain,
|
|
36
|
-
} from '../common/chains';
|
|
37
|
-
import { Token } from '../tokens/token-addresses';
|
|
38
|
-
|
|
39
|
-
type DestChainId = ChainId | SolanaChain | SuiChain | StarknetChainId;
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* API Service
|
|
43
|
-
*
|
|
44
|
-
* Implementation of the ApiService interface from sdk-common.
|
|
45
|
-
* Wraps low-level API functions for use by actions.
|
|
46
|
-
*
|
|
47
|
-
* @remarks
|
|
48
|
-
* This service returns minimal types (DepositInfo) suitable for internal use.
|
|
49
|
-
* For full deposit details, use getDepositsByAddress() directly.
|
|
50
|
-
*/
|
|
51
|
-
export class ApiService implements IApiService {
|
|
52
|
-
constructor(private readonly env: Env) {}
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* Generate a new BTC deposit address
|
|
56
|
-
*/
|
|
57
|
-
async generateDepositAddress(
|
|
58
|
-
params: GenerateDepositAddressParams,
|
|
59
|
-
): Promise<string> {
|
|
60
|
-
return generateDepositBtcAddress({
|
|
61
|
-
address: params.address,
|
|
62
|
-
chainId: params.chainId as DestChainId,
|
|
63
|
-
signature: params.signature,
|
|
64
|
-
token: params.token as Token,
|
|
65
|
-
eip712Data: params.eip712Data,
|
|
66
|
-
signatureData: params.signatureData,
|
|
67
|
-
pubKey: params.pubKey,
|
|
68
|
-
env: this.env,
|
|
69
|
-
partnerId: params.partnerId,
|
|
70
|
-
referrerCode: params.referrerCode,
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
/**
|
|
75
|
-
* Get existing deposit address for a recipient
|
|
76
|
-
*/
|
|
77
|
-
async getDepositAddress(
|
|
78
|
-
params: GetDepositAddressParams,
|
|
79
|
-
): Promise<string | undefined> {
|
|
80
|
-
try {
|
|
81
|
-
const address = await getDepositBtcAddress({
|
|
82
|
-
address: params.address,
|
|
83
|
-
chainId: params.chainId as DestChainId,
|
|
84
|
-
token: params.token as Token,
|
|
85
|
-
env: this.env,
|
|
86
|
-
partnerId: params.partnerId,
|
|
87
|
-
});
|
|
88
|
-
return address || undefined;
|
|
89
|
-
} catch {
|
|
90
|
-
// No address found
|
|
91
|
-
return undefined;
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* Get deposits for an address
|
|
97
|
-
*/
|
|
98
|
-
async getDeposits(address: string): Promise<DepositInfo[]> {
|
|
99
|
-
const deposits = await getDepositsByAddress({
|
|
100
|
-
address,
|
|
101
|
-
env: this.env,
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
return deposits.map(d => ({
|
|
105
|
-
depositAddress: d.depositAddress ?? '',
|
|
106
|
-
blockHeight: d.blockHeight,
|
|
107
|
-
isClaimed: d.isClaimed,
|
|
108
|
-
txid: d.txHash,
|
|
109
|
-
amount: d.amount?.toString(),
|
|
110
|
-
}));
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
/**
|
|
114
|
-
* Store network fee signature
|
|
115
|
-
*/
|
|
116
|
-
async storeFeeSignature(params: StoreFeeSignatureParams): Promise<void> {
|
|
117
|
-
await storeNetworkFeeSignature({
|
|
118
|
-
address: params.address,
|
|
119
|
-
signature: params.signature,
|
|
120
|
-
typedData: params.typedData,
|
|
121
|
-
env: this.env,
|
|
122
|
-
tokenAddress: params.tokenAddress,
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
/**
|
|
127
|
-
* Get stored network fee signature
|
|
128
|
-
*/
|
|
129
|
-
async getFeeSignature(
|
|
130
|
-
params: GetFeeSignatureParams,
|
|
131
|
-
): Promise<FeeSignatureResult> {
|
|
132
|
-
return getNetworkFeeSignature({
|
|
133
|
-
address: params.address,
|
|
134
|
-
chainId: params.chainId as ChainId,
|
|
135
|
-
env: this.env,
|
|
136
|
-
tokenAddress: params.tokenAddress,
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
/**
|
|
141
|
-
* Store stake and bake signature
|
|
142
|
-
*/
|
|
143
|
-
async storeStakeAndBakeSignature(
|
|
144
|
-
params: StoreStakeAndBakeParams,
|
|
145
|
-
): Promise<void> {
|
|
146
|
-
await storeStakeAndBakeSignature({
|
|
147
|
-
signature: params.signature,
|
|
148
|
-
typedData: params.typedData,
|
|
149
|
-
env: this.env,
|
|
150
|
-
});
|
|
151
|
-
}
|
|
152
|
-
}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* BTC Service
|
|
3
|
-
*
|
|
4
|
-
* Provides Bitcoin-specific operations via mempool API.
|
|
5
|
-
*
|
|
6
|
-
* @module services/BtcService
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
import type {
|
|
10
|
-
BtcNetworkMode,
|
|
11
|
-
BtcService as IBtcService,
|
|
12
|
-
} from '@lombard.finance/sdk-common';
|
|
13
|
-
|
|
14
|
-
import { getCurrentBlockHeight } from '../chains/btc/client/getCurrentBlockHeight';
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* BTC Service
|
|
18
|
-
*
|
|
19
|
-
* Implementation of the BtcService interface from sdk-common.
|
|
20
|
-
* Provides Bitcoin blockchain operations.
|
|
21
|
-
*/
|
|
22
|
-
export class BtcService implements IBtcService {
|
|
23
|
-
/**
|
|
24
|
-
* Get current block height from mempool
|
|
25
|
-
*/
|
|
26
|
-
async getCurrentBlockHeight(network: BtcNetworkMode): Promise<number> {
|
|
27
|
-
return getCurrentBlockHeight(network);
|
|
28
|
-
}
|
|
29
|
-
}
|
|
@@ -1,127 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* EVM Service
|
|
3
|
-
*
|
|
4
|
-
* Provides EVM-specific operations via contract functions.
|
|
5
|
-
*
|
|
6
|
-
* @module services/EvmService
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
import type {
|
|
10
|
-
Env,
|
|
11
|
-
EvmChainId,
|
|
12
|
-
EvmProvider,
|
|
13
|
-
EvmService as IEvmService,
|
|
14
|
-
SignNetworkFeeParams,
|
|
15
|
-
SignNetworkFeeResult,
|
|
16
|
-
SignStakeAndBakeParams,
|
|
17
|
-
} from '@lombard.finance/sdk-common';
|
|
18
|
-
import BigNumber from 'bignumber.js';
|
|
19
|
-
import type { EIP1193Provider } from 'viem';
|
|
20
|
-
|
|
21
|
-
import type { ChainId } from '../common/chains';
|
|
22
|
-
import { getMintingFee } from '../contract-functions/getLBTCMintingFee/getLBTCMintingFee';
|
|
23
|
-
import { getStakeAndBakeFee } from '../contract-functions/getStakeAndBakeFee/getStakeAndBakeFee';
|
|
24
|
-
import { signLbtcDestinationAddr } from '../contract-functions/signLbtcDestionationAddr/signLbtcDestinationAddr';
|
|
25
|
-
import { signNetworkFee } from '../contract-functions/signNetworkFee/signNetworkFee';
|
|
26
|
-
import { signStakeAndBake } from '../contract-functions/signStakeAndBake/signStakeAndBake';
|
|
27
|
-
import type { DefiProtocol, StakeAndBakeToken } from '../defi/defi-registry';
|
|
28
|
-
import { Token } from '../tokens/token-addresses';
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* EVM Service
|
|
32
|
-
*
|
|
33
|
-
* Implementation of the EvmService interface from sdk-common.
|
|
34
|
-
* Provides EVM contract interactions and fee authorization.
|
|
35
|
-
*/
|
|
36
|
-
export class EvmService implements IEvmService {
|
|
37
|
-
constructor(private readonly env: Env) {}
|
|
38
|
-
|
|
39
|
-
/**
|
|
40
|
-
* Get minting fee for a chain
|
|
41
|
-
* @param chainId - The chain ID
|
|
42
|
-
* @param token - Optional token (defaults to LBTC). Use Token.BTCb for BTC.b deposits.
|
|
43
|
-
*/
|
|
44
|
-
async getMintingFee(chainId: EvmChainId, token?: string): Promise<string> {
|
|
45
|
-
const fee = await getMintingFee({
|
|
46
|
-
token: (token as Token) || Token.LBTC,
|
|
47
|
-
chainId: chainId as ChainId,
|
|
48
|
-
env: this.env,
|
|
49
|
-
});
|
|
50
|
-
return fee.toString();
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
/**
|
|
54
|
-
* Sign network fee authorization (EIP-712)
|
|
55
|
-
*/
|
|
56
|
-
async signNetworkFee(
|
|
57
|
-
params: SignNetworkFeeParams,
|
|
58
|
-
): Promise<SignNetworkFeeResult> {
|
|
59
|
-
const result = await signNetworkFee({
|
|
60
|
-
fee: new BigNumber(params.fee),
|
|
61
|
-
account: params.account as `0x${string}`,
|
|
62
|
-
chainId: params.chainId as ChainId,
|
|
63
|
-
provider: params.provider as EIP1193Provider,
|
|
64
|
-
env: this.env,
|
|
65
|
-
// Pass token for signing - defaults to LBTC for backwards compatibility
|
|
66
|
-
token: (params.token as Token) ?? Token.LBTC,
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
return {
|
|
70
|
-
signature: result.signature,
|
|
71
|
-
typedData: result.typedData,
|
|
72
|
-
};
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
/**
|
|
76
|
-
* Get stake and bake fee for a vault
|
|
77
|
-
*/
|
|
78
|
-
async getStakeAndBakeFee(
|
|
79
|
-
chainId: EvmChainId,
|
|
80
|
-
protocol: DefiProtocol,
|
|
81
|
-
): Promise<string> {
|
|
82
|
-
const fee = await getStakeAndBakeFee({
|
|
83
|
-
chainId: chainId as ChainId,
|
|
84
|
-
protocol,
|
|
85
|
-
});
|
|
86
|
-
return fee.toString();
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
/**
|
|
90
|
-
* Sign stake and bake authorization
|
|
91
|
-
*/
|
|
92
|
-
async signStakeAndBake(
|
|
93
|
-
params: SignStakeAndBakeParams,
|
|
94
|
-
): Promise<SignNetworkFeeResult> {
|
|
95
|
-
const result = await signStakeAndBake({
|
|
96
|
-
value: new BigNumber(params.value),
|
|
97
|
-
account: params.account as `0x${string}`,
|
|
98
|
-
chainId: params.chainId as ChainId,
|
|
99
|
-
provider: params.provider as EIP1193Provider,
|
|
100
|
-
env: this.env,
|
|
101
|
-
vaultKey: params.vaultKey as DefiProtocol,
|
|
102
|
-
token: params.token as StakeAndBakeToken,
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
return {
|
|
106
|
-
signature: result.signature,
|
|
107
|
-
typedData: result.typedData,
|
|
108
|
-
};
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
/**
|
|
112
|
-
* Sign LBTC destination address (for non-Ethereum EVM chains)
|
|
113
|
-
*/
|
|
114
|
-
async signLbtcDestination(params: {
|
|
115
|
-
chainId: EvmChainId;
|
|
116
|
-
address: string;
|
|
117
|
-
provider: EvmProvider;
|
|
118
|
-
}): Promise<{ signature: string }> {
|
|
119
|
-
const signature = await signLbtcDestinationAddr({
|
|
120
|
-
account: params.address as `0x${string}`,
|
|
121
|
-
chainId: params.chainId as ChainId,
|
|
122
|
-
provider: params.provider as EIP1193Provider,
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
return { signature };
|
|
126
|
-
}
|
|
127
|
-
}
|
package/src/services/index.ts
DELETED
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Service Classes
|
|
3
|
-
*
|
|
4
|
-
* Concrete implementations of service interfaces defined in sdk-common.
|
|
5
|
-
* These are instantiated by modules and injected into action contexts.
|
|
6
|
-
*
|
|
7
|
-
* Naming convention:
|
|
8
|
-
* - sdk-common: `interface ApiService` (contract)
|
|
9
|
-
* - sdk: `class ApiService implements IApiService` (implementation)
|
|
10
|
-
*
|
|
11
|
-
* Type separation:
|
|
12
|
-
* - Services return minimal types (for internal use by actions)
|
|
13
|
-
* - Public APIs return rich types (for external use)
|
|
14
|
-
*
|
|
15
|
-
* @module services
|
|
16
|
-
*/
|
|
17
|
-
|
|
18
|
-
export { ApiService } from './ApiService';
|
|
19
|
-
export { BtcService } from './BtcService';
|
|
20
|
-
export { EvmService } from './EvmService';
|
|
21
|
-
|
|
22
|
-
// Re-export service interfaces from sdk-common for convenience
|
|
23
|
-
// Use these for typing, use the classes above for instantiation
|
|
24
|
-
export type {
|
|
25
|
-
BtcNetworkMode,
|
|
26
|
-
DepositInfo,
|
|
27
|
-
DestinationChainId,
|
|
28
|
-
EvmChainId,
|
|
29
|
-
FeeAuthorizationResult,
|
|
30
|
-
FeeSignatureResult,
|
|
31
|
-
GenerateDepositAddressParams,
|
|
32
|
-
GetDepositAddressParams,
|
|
33
|
-
GetFeeSignatureParams,
|
|
34
|
-
ApiService as IApiService,
|
|
35
|
-
BtcService as IBtcService,
|
|
36
|
-
EvmService as IEvmService,
|
|
37
|
-
SignNetworkFeeParams,
|
|
38
|
-
SignNetworkFeeResult,
|
|
39
|
-
SignStakeAndBakeParams,
|
|
40
|
-
StoredFeeSignature,
|
|
41
|
-
StoreFeeSignatureParams,
|
|
42
|
-
StoreStakeAndBakeParams,
|
|
43
|
-
} from '@lombard.finance/sdk-common';
|
|
@@ -1,185 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Tests for error handling
|
|
3
|
-
*
|
|
4
|
-
* Verifies LombardError class and error code enums.
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { describe, expect, it } from 'vitest';
|
|
8
|
-
|
|
9
|
-
import {
|
|
10
|
-
ContractErrorCode,
|
|
11
|
-
ErrorCode,
|
|
12
|
-
LombardError,
|
|
13
|
-
ProviderErrorCode,
|
|
14
|
-
RegistryErrorCode,
|
|
15
|
-
ValidationErrorCode,
|
|
16
|
-
} from '../errors';
|
|
17
|
-
|
|
18
|
-
describe('LombardError', () => {
|
|
19
|
-
it('should create error with code and message', () => {
|
|
20
|
-
const error = new LombardError(
|
|
21
|
-
ErrorCode.UNKNOWN_ERROR,
|
|
22
|
-
'Something went wrong',
|
|
23
|
-
);
|
|
24
|
-
|
|
25
|
-
expect(error).toBeInstanceOf(Error);
|
|
26
|
-
expect(error).toBeInstanceOf(LombardError);
|
|
27
|
-
expect(error.code).toBe(ErrorCode.UNKNOWN_ERROR);
|
|
28
|
-
expect(error.message).toBe('Something went wrong');
|
|
29
|
-
expect(error.name).toBe('LombardError');
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
it('should accept metadata', () => {
|
|
33
|
-
const error = new LombardError(
|
|
34
|
-
ProviderErrorCode.PROVIDER_MISSING,
|
|
35
|
-
'Provider not configured',
|
|
36
|
-
{
|
|
37
|
-
chain: 'ethereum',
|
|
38
|
-
requiredProvider: 'evm',
|
|
39
|
-
},
|
|
40
|
-
);
|
|
41
|
-
|
|
42
|
-
expect(error.metadata).toEqual({
|
|
43
|
-
chain: 'ethereum',
|
|
44
|
-
requiredProvider: 'evm',
|
|
45
|
-
});
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
it('should have proper stack trace', () => {
|
|
49
|
-
const error = new LombardError(ErrorCode.UNKNOWN_ERROR, 'Test error');
|
|
50
|
-
expect(error.stack).toBeDefined();
|
|
51
|
-
expect(error.stack).toContain('LombardError');
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
it('should serialize to JSON with all properties', () => {
|
|
55
|
-
const error = new LombardError(
|
|
56
|
-
RegistryErrorCode.ROUTE_NOT_FOUND,
|
|
57
|
-
'Route not found',
|
|
58
|
-
{
|
|
59
|
-
assetIn: 'BTC',
|
|
60
|
-
assetOut: 'LBTC',
|
|
61
|
-
},
|
|
62
|
-
);
|
|
63
|
-
|
|
64
|
-
const json = error.toJSON();
|
|
65
|
-
expect(json).toMatchObject({
|
|
66
|
-
code: RegistryErrorCode.ROUTE_NOT_FOUND,
|
|
67
|
-
message: 'Route not found',
|
|
68
|
-
metadata: {
|
|
69
|
-
assetIn: 'BTC',
|
|
70
|
-
assetOut: 'LBTC',
|
|
71
|
-
},
|
|
72
|
-
});
|
|
73
|
-
// Also verify new properties exist
|
|
74
|
-
expect(json.name).toBe('LombardError');
|
|
75
|
-
expect(json.sdkVersion).toBeDefined();
|
|
76
|
-
expect(json.timestamp).toBeDefined();
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
it('should include cause if provided', () => {
|
|
80
|
-
const cause = new Error('Original error');
|
|
81
|
-
const error = new LombardError(ErrorCode.UNKNOWN_ERROR, 'Wrapped error', {
|
|
82
|
-
originalError: cause.message,
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
expect(error.metadata?.originalError).toBe('Original error');
|
|
86
|
-
});
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
describe('Error Code Enums', () => {
|
|
90
|
-
describe('ErrorCode', () => {
|
|
91
|
-
it('should define general error codes', () => {
|
|
92
|
-
expect(ErrorCode.UNKNOWN_ERROR).toBe('unknown-error');
|
|
93
|
-
expect(ErrorCode.INVALID_CONFIGURATION).toBe('invalid-configuration');
|
|
94
|
-
expect(ErrorCode.OPERATION_TIMEOUT).toBe('operation-timeout');
|
|
95
|
-
expect(ErrorCode.OPERATION_CANCELLED).toBe('operation-cancelled');
|
|
96
|
-
});
|
|
97
|
-
});
|
|
98
|
-
|
|
99
|
-
describe('ProviderErrorCode', () => {
|
|
100
|
-
it('should define provider error codes', () => {
|
|
101
|
-
expect(ProviderErrorCode.PROVIDER_MISSING).toBe('provider-missing');
|
|
102
|
-
expect(ProviderErrorCode.PROVIDER_INITIALIZATION_FAILED).toBe(
|
|
103
|
-
'provider-initialization-failed',
|
|
104
|
-
);
|
|
105
|
-
expect(ProviderErrorCode.PROVIDER_CALL_FAILED).toBe(
|
|
106
|
-
'provider-call-failed',
|
|
107
|
-
);
|
|
108
|
-
expect(ProviderErrorCode.SIGNER_MISSING).toBe('signer-missing');
|
|
109
|
-
expect(ProviderErrorCode.USER_REJECTED).toBe('user-rejected');
|
|
110
|
-
});
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
describe('RegistryErrorCode', () => {
|
|
114
|
-
it('should define registry error codes', () => {
|
|
115
|
-
expect(RegistryErrorCode.ROUTE_NOT_FOUND).toBe('route-not-found');
|
|
116
|
-
expect(RegistryErrorCode.INVALID_ROUTE_DEFINITION).toBe(
|
|
117
|
-
'invalid-route-definition',
|
|
118
|
-
);
|
|
119
|
-
expect(RegistryErrorCode.UNSUPPORTED_CHAIN).toBe('unsupported-chain');
|
|
120
|
-
expect(RegistryErrorCode.UNSUPPORTED_ASSET).toBe('unsupported-asset');
|
|
121
|
-
expect(RegistryErrorCode.INCOMPATIBLE_ROUTE).toBe('incompatible-route');
|
|
122
|
-
});
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
describe('ValidationErrorCode', () => {
|
|
126
|
-
it('should define validation error codes', () => {
|
|
127
|
-
expect(ValidationErrorCode.INVALID_ADDRESS).toBe('invalid-address');
|
|
128
|
-
expect(ValidationErrorCode.INVALID_AMOUNT).toBe('invalid-amount');
|
|
129
|
-
expect(ValidationErrorCode.AMOUNT_TOO_SMALL).toBe('amount-too-small');
|
|
130
|
-
expect(ValidationErrorCode.AMOUNT_TOO_LARGE).toBe('amount-too-large');
|
|
131
|
-
expect(ValidationErrorCode.INSUFFICIENT_BALANCE).toBe(
|
|
132
|
-
'insufficient-balance',
|
|
133
|
-
);
|
|
134
|
-
expect(ValidationErrorCode.INVALID_PARAMETER).toBe('invalid-parameter');
|
|
135
|
-
});
|
|
136
|
-
});
|
|
137
|
-
|
|
138
|
-
describe('ContractErrorCode', () => {
|
|
139
|
-
it('should define contract error codes', () => {
|
|
140
|
-
expect(ContractErrorCode.CONTRACT_CALL_FAILED).toBe(
|
|
141
|
-
'contract-call-failed',
|
|
142
|
-
);
|
|
143
|
-
expect(ContractErrorCode.TRANSACTION_FAILED).toBe('transaction-failed');
|
|
144
|
-
expect(ContractErrorCode.TRANSACTION_REVERTED).toBe(
|
|
145
|
-
'transaction-reverted',
|
|
146
|
-
);
|
|
147
|
-
expect(ContractErrorCode.APPROVAL_FAILED).toBe('approval-failed');
|
|
148
|
-
expect(ContractErrorCode.INSUFFICIENT_ALLOWANCE).toBe(
|
|
149
|
-
'insufficient-allowance',
|
|
150
|
-
);
|
|
151
|
-
expect(ContractErrorCode.GAS_ESTIMATION_FAILED).toBe(
|
|
152
|
-
'gas-estimation-failed',
|
|
153
|
-
);
|
|
154
|
-
});
|
|
155
|
-
});
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
describe('Error Factory Functions', () => {
|
|
159
|
-
it('should create provider errors with factory', () => {
|
|
160
|
-
const error = LombardError.providerMissing('ethereum', 'evm');
|
|
161
|
-
|
|
162
|
-
expect(error.code).toBe(ProviderErrorCode.PROVIDER_MISSING);
|
|
163
|
-
expect(error.message).toContain('ethereum');
|
|
164
|
-
expect(error.metadata?.chain).toBe('ethereum');
|
|
165
|
-
});
|
|
166
|
-
|
|
167
|
-
it('should create validation errors with factory', () => {
|
|
168
|
-
const error = LombardError.invalidAmount('Must be greater than 0');
|
|
169
|
-
|
|
170
|
-
expect(error.code).toBe(ValidationErrorCode.INVALID_AMOUNT);
|
|
171
|
-
expect(error.message).toBe('Must be greater than 0');
|
|
172
|
-
});
|
|
173
|
-
|
|
174
|
-
it('should create registry errors with factory', () => {
|
|
175
|
-
const error = LombardError.routeNotFound({
|
|
176
|
-
assetIn: 'BTC',
|
|
177
|
-
assetOut: 'LBTC',
|
|
178
|
-
sourceChain: 'bitcoin-mainnet',
|
|
179
|
-
destChain: 'ethereum',
|
|
180
|
-
});
|
|
181
|
-
|
|
182
|
-
expect(error.code).toBe(RegistryErrorCode.ROUTE_NOT_FOUND);
|
|
183
|
-
expect(error.metadata).toBeDefined();
|
|
184
|
-
});
|
|
185
|
-
});
|