SDK 生态系统提供程序简介
LI.FI SDK 支持不同的区块链生态系统,允许您与 EVM 和 Solana 网络集成,还有更多生态系统即将推出。在内部,提供程序充当每个生态系统的抽象,在路由/报价执行期间处理关键任务,例如地址解析、余额检查和交易处理。 这些生态系统提供程序在设计时考虑了模块化,并且完全可以进行 tree-shake,确保如果不使用它们,它们不会给您的捆绑包增加不必要的重量。 SDK 提供四个提供程序,EVM
、Solana
、UTXO
和 Sui
,每个提供程序都有各自生态系统的类似配置选项。
不同类型的钱包/账户
要通过特定提供程序执行报价/路由,该提供程序必须能够签署交易。SDK 提供程序支持通过以下类型的钱包/账户签署交易:- 本地账户(例如私钥/助记词钱包)。
- JSON-RPC 账户(例如浏览器扩展钱包、WalletConnect 等)。
window.ethereum
)进行连接,并在浏览器或移动环境中管理用户的账户。此设置在 dApp UI 中很受欢迎,通常与 Wagmi
、@solana/web3.js
或 @mysten/dapp-kit
等库一起使用。
这些账户类型和交互方法允许开发人员选择最适合将 SDK 与其应用程序集成的方法。
设置 EVM 提供程序
EVM 提供程序执行逻辑是基于Viem
库构建的,使用其一些类型和术语。
配置 EVM 提供程序的可用选项:
-
getWalletClient
: 返回WalletClient
实例的函数。 -
switchChain
: 用于在不同网络之间切换的钩子。
本地账户
使用本地账户时,开发人员需要一个预定义的链列表,他们计划在交易执行期间与之交互以切换链。这些链可以来自viem/chains
包,也可以从 LI.FI API 获取并采用 viem 的 Chain
类型。
这是一个使用 viem/chains
中的链的基本示例:
JSON-RPC 账户
与 JSON-RPC 账户交互并将WalletClient
传递给 EVM
提供程序的最佳方法是使用 Wagmi 库。开发人员可以通过使用 viem/chains
包中的链或从 LI.FI API 获取链并将其适配到 Viem 的 Chain
类型来配置 Wagmi 链。
以下是如何使用 LI.FI API 的链与 Wagmi 和 React 结合设置 EVM 提供程序的简化示例。
我们提供了一个 useSyncWagmiConfig
钩子,它将获取的链与 Wagmi 配置同步并更新连接器。请注意,我们不使用连接器初始化 Wagmi 配置。此外,我们将 reconnectOnMount
设置为 false
,因为在链与配置和连接器同步后,将在 useSyncWagmiConfig
钩子中调用 reconnect
操作。
更新提供程序配置
此外,提供程序允许通过setOptions
函数动态更新其初始配置。
这是如何修改 EVM
提供程序的初始配置的示例:
支持 Ethers.js 和其他替代方案
开发人员仍然可以在其项目中使用 Ethers.js 或任何其他替代 Web3 库,并在将Signer
/Provider
对象传递给 EVM 提供程序配置之前转换为 Viem 的 WalletClient
。
设置 Solana 提供程序
Solana 提供程序执行逻辑是基于 @solana/web3.js 和 @solana/wallet-adapter-base 库构建的,使用其一些类型和术语。 配置 EVM 提供程序的可用选项:getWalletAdapter
: 返回 WalletAdapter 实例的函数。
本地钱包适配器
标准 Solana 库不提供直接从私钥创建钱包适配器的内置方法。为了解决此限制,我们提供了KeypairWalletAdapter
。此自定义适配器使用户能够从私钥创建钱包适配器。
值得注意的是,KeypairWalletAdapter
专为后端或测试目的而设计,不应在面向用户的代码中使用,以防止暴露您的私钥的风险。
JSON-RPC 钱包适配器
要与 JSON-RPC 账户交互并将WalletAdapter
传递给 Solana 提供程序,我们建议使用 @solana/wallet-adapter-base 和 @solana/wallet-adapter-react 库。与 Wagmi 不同,React 的 Solana 配置没有全局配置。因此,我们需要使用 React 钩子在运行时更新 SDK 配置。
以下是如何设置 Solana 提供程序的简化示例。
设置 Sui 提供程序
Sui 提供程序执行逻辑是基于 @mysten/dapp-kit 和 @mysten/sui 库构建的,使用其一些类型和术语。 配置 Sui 提供程序的可用选项:getWallet
: 返回WalletWithRequiredFeatures
实例(由@mysten/wallet-standard
定义)的函数。
JSON-RPC 钱包
要与用户钱包(如 Sui Wallet、Ethos 等)交互并将WalletWithRequiredFeatures
传递给 Sui 提供程序,我们建议使用 @mysten/dapp-kit 库。
以下是如何使用用户钱包设置 Sui 提供程序的简化示例。
设置 UTXO(比特币)提供程序
比特币提供程序执行逻辑是基于 Bigmi 库构建的,使用其一些类型和术语。 配置 UTXO 提供程序的可用选项:getWalletClient
: 返回Client
实例的函数
JSON-RPC 钱包
要与用户钱包(如 Phantom、Xverse)交互,请使用getConnectorClient
操作返回 SDK 所需的 Bigmi Client 对象。