Chain Configuration and Addresses
Access all the addresses, contract interfaces, and chain configurations
Being the interface to a cross-chain protocol, the IonicSdk
is configured to seamlessly work across chains, and allows developers to introspect each chain's available infrastructure, as well as the deployed contracts in that chain.
These values are directly available via the instantiated SDK, for the selected chain with which the SDK is instantiated.
E.g.:
Here's an overview of the available properties of MidasSdk
:
IonicSdk.supportedAssets
IonicSdk.supportedAssets
Type: Array of SupportedAsset
Returns an array of the supported assets for Ionic Protocol given a specific chain.
E.g.:
IonicSdk.irms
IonicSdk.irms
Type: IrmConfig
Returns an object mapping IRM contract names to their deployment specification, i.e., its address and ABI.
IonicSdk.availableIrms
IonicSdk.availableIrms
Type: Array<
IrmTypes
>
Returns an array of the supported IRMs for a specific chain.
IonicSdk.oracles
IonicSdk.oracles
Type: OracleConfig
Returns an object mapping oracle contract names to their deployment specification, i.e., its address and ABI.
IonicSdk.availableOracles
IonicSdk.availableOracles
Type: Array<
OracleTypes
>
Returns an array of the supported Oracles for a specific chain
IonicSdk.chainSpecificAddresses
IonicSdk.chainSpecificAddresses
Type: ChainAddresses
This object contains a set of addresses for infra specific to this chain. The chain's Native Wrapped Token address, and the main Uniswap-like router and factory addresses are amongst them. Widely used within the SDK.
IonicSdk.chainSpecificParams
IonicSdk.chainSpecificParams
Type: ChainParams
A few chain-specific parameters, such as the Blocks Per Year and the coingecko ID for the chain's native token.
IonicSdk.deployedPlugins
IonicSdk.deployedPlugins
Type: DeployedPlugins
Object containing the address, names, and strategies for the ERC4626 plugins deployed in a specific chain.
IonicSdk.contracts
IonicSdk.contracts
Set of already instantiated ethers.Contract
for the core Ionic Protocol contracts that are widely used across the SDK. The functionality of these contracts is mostly wrapped by other SDK functions, so these are unlikely to be widely used by developers. They are given however as instantiated contracts for ease of access from the SDK's codebase.
Type: [contractName: string]: ethers.Contract]
The main contracts are the following:
FuseFeeDistributor
: the "admin" contract, in charge of collecting protocol fees, and of performing admin functionality over the protocolFusePoolDirectory
: a registry contract in charge of keeping track of deployed poolsFusePoolLens
: introspection module for querying Ionic Pool's data at different levels of aggregationFusePoolLensSecondary
: secondary introspection module, in charge of querying a specific pool's informationFuseSafeLiquidator
: the contract in charge of performing the liquidations on Fuse Pools
IonicSdk.artifacts
IonicSdk.artifacts
Type: object containing as keys the Contract Name, and as object an Artifact
type. Once more, this is provided as a shorthand for other SDK functions.
E.g, to instantiate a cToken as an ethers.Contract
, the following code is used:
IonicSdk.chainDeployment
IonicSdk.chainDeployment
Type: ChainDeployment
Returns all the contract ABIs and addresses for the Ionic Protocol's deployment in a given chain.
E.g.:
Last updated