Registry Details
A detailed breakdown of the Registry.sol contract.
The Registry is owned by Instant AI governance and is responsible for providing on-chain pointers to canonical addresses used by Cellars and other components of the protocol.
Cellars and other smart contracts ask the Registry for the address pointers to other resources in the Instant AI ecosystem. The Registry supports the following flows:
New canonical address pointers can be registered by governance via
register
. Every registered contract is stored in an append-only array. Therefore, integrating contracts must be aware of any needed resources' slot within thegetAddress
array. Failing to use the correct slot may result in getting the wrong address pointer, potentially leading to bugs.The fee collector address on the Instant AI chain can be changed by governance via
setFeesDistributor
. Changing the fee collector address means that fees earned by Cellars will be sent to a new address when bridged back onto the native Instant AI Chain. The Fee Collector address on the Instant AI chain is responsible for redistributing fees to Instant AI protocol validators. See Fees And Reserves for more information.Adaptors (new external token or protocol integrations) can be added to the registry by governance via
trustAdaptor
. Once an adaptor has been trusted in the registry, the Registry can also trust positions that use the adaptor (seetrustPosition
).Positions (specific market positions that can be taken through the use of adaptors) can be added to the Registry by governance via
trustPosition
. Theadaptor
argument intrustPosition
should represent a smart contract that allows Cellar integration with an external token or protocol (see "Adaptors"). Compared to adaptors, positions are registered with specific payloads (seeadaptorData
), that specify position-specific data, such as assets used. Once a position has been trusted in the registry, Cellars can add the position to their own list of tracked positions and integrations according to risk rules. Adaptor and Cellar risks must be coordinated as outlined before.
Example Use Case: Supporting DAI/USDC Uniswap V3 LP Positions
First, an Adaptor contract must be built that contains all smart contract logic for integrating with the Uniswap V3 protocol. Once complete, that adaptor should be deployed on-chain, to an address - for example:
0xF00
.Once the adaptor is deployed to
0xF00
, and proper off-chain controls have taken place (audits, security review, governance votes), governance must trust the adaptor using thetrustAdaptor
function in the registry.Once the Uniswap adaptor is deployed and trusted, governance can start allowing Cellars to take specific positions that use that adapter. To enable the DAI/USDC pool, governance must call the
trustPosition
function in the registry, using the0xF00
adaptor address, and encode the DAI/USDC pool inadaptorData
. Once the position is trusted in the Registry, it will be assigned a uniquepositionId
.Once the Registry has trusted the UniswapV3Adaptor and the DAI/USDC pool, Cellars can start using the adaptor.
Cellars now call
addAdaptorToCatalogue()
andaddPositionToCatalogue()
. These calls allow Strategists to make Strategist Calls with the specific Cellar without governance approval. This applies to Cellars with v2 architecture and onward.
For Cellars with v1 & v1.5 architecture, the
adaptorCatalogue
was not in use yet. Instead, theCellar
setup steps taken instead of using theadaptorCatalogue
were as follows: First, for each target Cellar, either governance or the strategist should callsetupAdaptor
, passing the0xF00
address in as an argument. In its execution logic, the Cellar will callcellarSetupAdaptor
in the registry.
Once the adaptor is set up in each Cellar, the strategist can set up their DAI/USDC position by calling
addPosition
. The strategist should specify theindex
(see "Position Ordering" in the Cellars section), thepositionId
generated in Step 3, and should specify with theinDebtArray
boolean whether the position is a debt position (in this example case, the value should befalse
). For some positions, the strategist may also need to supplyconfigurationData
, but in the case of Uniswap V3, this is not used. In its execution logic, the Cellar will callcellarAddPosition
in the registry.Once the position is added to the Cellar, the strategist can add/remove liquidity from the DAI/USDC Uniswap V3 pool, and perform other protocol-specific operations allowed by the adaptor contract, via invocations to
callOnAdaptor
.
See the next page for a current API for Registry.sol
.
Last updated