Contracts Overview
The Zest Borrow contracts are divided into 6 directories:
math includes helper functions for yield and interest related calculations.
mocks holds examples of the lp-tokens, oracles, and read-only calls to fetch protocol related data.
pool holds pool logic contracts.
token is the token directory.
traits used by the protocol.
vaults, reserve and configuration/admin functions.
The contracts in the above directories fall into 4 categories of function:
Reserve and configuration
Pool logic
Tokenization
Misc
Reserve and Configuration
pool-0-reserve
The pool-0-reserve.clar
contract manages lending pool operations, including user-specific reserve tracking and dynamic interest rate adjustments. It supports borrowing, repayments, liquidation, and administrative controls, providing comprehensive data aggregation and retrieval.
pool-reserve-data
The pool-reserve-data.clar
contract maintains various parameters and states essential for the operation of lending and borrowing. It stores and manages flash loan fees, health factor liquidation thresholds, protocol treasury addresses, and reserve vaults. The contract allows approved entities to update and retrieve user reserve data, reserve states, and user assets. It controls interest rates, reserve factors, and liquidation parameters, ensuring secure and controlled access to modify these critical values.
The pool-vault.clar
contract facilitates asset transfers, managing the flow of assets within the system. It supports a transfer function that allows approved contracts to move specified amounts of a fungible token to a recipient. The contract maintains an owner and a list of approved contracts, ensuring that only authorized entities can initiate transfers. It provides functions to check contract ownership and verify if a contract is approved, maintaining a secure environment for asset operations.
Pool Logic
The pool-borrow.clar
contract handles the core functionalities related to borrowing, supplying, withdrawing, and repaying assets. It includes functions to:
Supply: Users can supply assets to the pool, which may then be used as collateral depending on the asset's configuration within the system.
Withdraw: Allows users to withdraw their supplied assets, subject to the constraints imposed by their current borrowing status and the pool's available liquidity.
Borrow: Users can borrow assets from the pool, with the amount being determined by their collateral value and the asset's borrowing conditions.
Repay: Borrowers can repay their loans to adjust their borrowing balance and overall health factor.
Liquidation Call: This function facilitates the liquidation process when a user's position becomes undercollateralized.
Flashloan: Offers flash loan functionality, allowing users to borrow and repay within a single transaction while paying a fee.
Configurations: The contract includes various settings related to collateral usage, borrowing caps, interest rates, and other parameters crucial for the lending and borrowing mechanics.
The contract ensures that only authorized operations are performed.
The liquidation-manager
contract is a focused component designed to manage the liquidation process within Zest. It interacts with various assets, user balances, and oracles to assess and execute liquidations based on predefined criteria. Key functionalities include:
liquidation-call
: Executes the liquidation of undercollateralized positions, ensuring that the health factor is below the threshold and that the collateral is appropriately valued and available for liquidation.calculate-user-global-data
: Aggregates a user's financial data across the platform to determine their eligibility for liquidation.calculate-available-collateral-to-liquidate
: Determines the amount of collateral available for liquidation in relation to the user's debt, taking into account the asset's price and liquidation thresholds.Administrative functions: Include setting and querying reserve states, user reserve data, and collateral balances to facilitate liquidation decisions.
The contract ensures that liquidations are conducted fairly and efficiently.
Tokenization
Examples of tokens associated with the protocol during testnet can be seen in the mocks directory of the contracts repository. However, in mainnet for the moment these only include LP-tokens for the assets that can currently be supplied.
Misc
math
The math.clar
contract provides a suite of mathematical operations and constants to support various calculations for Zest Borrow operations, including:
Multiplication and Division: Functions to multiply and divide numbers with precision handling.
Fixed-Precision Operations: Methods to perform arithmetic operations on numbers with a specific decimal precision.
Percentage Calculations: Function to calculate a percentage of a number with precision adjustments.
Conversion Functions: Utilities to convert numbers between different precisions or to fixed precision.
Taylor Series Expansion: An implementation of the Taylor series to estimate exponential functions up to the 6th degree.
Utility Functions: Includes checks for odd/even numbers and getters for various constants like
e
,one-8
,seconds-in-year
, andseconds-in-block
.
This contract is crucial for accurate financial computations, ensuring consistent precision and rounding throughout the lending operations.
fees-calculator
The fees-calculator.clar
contract provides functionalities related to fee calculation within the lending platform. It includes functions to:
Get Origination Fee Percentage: Retrieves the origination fee percentage for a specified asset from the pool reserve data.
Multiply Percentage: A utility function that multiplies a given amount by a percentage, accounting for the asset's decimal precision.
Calculate Origination Fee: Determines the origination fee for a given amount of an asset borrowed by a user, based on the asset's origination fee percentage and its decimal precision.
These functions are essential for calculating the fees associated with borrowing, ensuring that users are charged appropriately when they take out loans.
oracle
The oracle.clar
contract is responsible for managing asset price information within the platform. It includes functionalities to:
Get Asset Price: Fetches the current price of a specified asset. Prices are stored with a fixed precision of 8 decimals.
Set Price: Allows updating the price of a given asset in the contract's storage.
Tickers Storage: Utilizes a data map to store the asset prices, indexed by the asset's contract principal.
Last updated