PrimaryLendingPlatformLeverageCore
Overview
License: MIT
The PrimaryLendingPlatformLeverageCore contract is the core contract for the leverage functionality of the primary lending platform.
Contract that allows users to leverage their positions using the exchange aggregator.
Enums info
LeverageType
Structs info
Ratio
Events info
SetExchangeAggregator
Emitted when the exchange aggregator and registry aggregator addresses are set.
Parameters:
Name | Type | Description |
---|---|---|
exchangeAggregator | address | The address of the exchange aggregator. |
registryAggregator | address | The address of the registry aggregator. |
LeveragedBorrow
Emitted when a user leverages their borrowing position.
Parameters:
Name | Type | Description |
---|---|---|
user | address | The address of the user who leveraged their position. |
projectToken | address | The address of the project token being used for leverage. |
lendingToken | address | The address of the lending token being used for leverage. |
notionalExposure | uint256 | The total notional exposure of the user's position. |
lendingAmount | uint256 | The amount of the lending token being borrowed. |
margin | uint256 | The margin required for the leverage. |
addingAmount | uint256 | The amount of the project token being added to the position. |
totalDepositedAmount | uint256 | The total amount of the project token deposited in the position. |
amountReceive | uint256 | The amount of the lending token received by the user after the leverage. |
SetPrimaryLendingPlatform
Emitted when the primary lending platform address is set.
Parameters:
Name | Type | Description |
---|---|---|
newPrimaryLendingPlatform | address | The new primary lending platform address. |
Constants info
MODERATOR_ROLE (0x797669c9)
BUFFER_PERCENTAGE (0x952038c2)
State variables info
isLeveragePosition (0x3226d284)
primaryLendingPlatform (0x92641a7c)
exchangeAggregator (0x60df4f35)
registryAggregator (0xf38cb29a)
typeOfLeveragePosition (0x4118a1bd)
Modifiers info
onlyAdmin
Modifier to restrict access to only the contract admin.
onlyModerator
Modifier to restrict access to only the contract moderator.
isProjectTokenListed
Modifier to check if the given project token is listed on the primary lending platform.
Parameters:
Name | Type | Description |
---|---|---|
projectToken | address | The address of the project token to check. |
isLendingTokenListed
Modifier to check if the given lending token is listed on the primary lending platform.
Parameters:
Name | Type | Description |
---|---|---|
lendingToken | address | The address of the lending token to check. |
isPrimaryLendingPlatform
Modifier to check if the caller is the primary lending platform contract.
onlyRelatedContracts
Modifier to check if the caller is a related contract of the primary lending platform.
Functions info
initialize (0xc4d66de8)
Initializes the contract with the given parameters. This function is called only once when deploying the contract.
Parameters:
Name | Type | Description |
---|---|---|
pit | address | The address of the primary index token contract. |
setExchangeAggregator (0x3c4841b4)
Updates the Exchange Aggregator contract and registry contract addresses.
Requirements:
The caller must be the moderator.
exchangeAggregatorAddress
must not be the zero address.registryAggregatorAddress
must be a valid Augustus contract if it is not the zero address.
Parameters:
Name | Type | Description |
---|---|---|
exchangeAggregatorAddress | address | The new address of the Exchange Aggregator contract. |
registryAggregatorAddress | address | The new address of the Aggregator registry contract. |
setPrimaryLendingPlatformAddress (0xcec5a0b0)
Sets the address of the primary lending platform contract.
Requirements:
Only the moderator can call this function.
The new primary lending platform address cannot be the zero address.
Parameters:
Name | Type | Description |
---|---|---|
newPrimaryLendingPlatform | address | The address of the new primary lending platform contract. |
getTokenPrice (0xd02641a0)
Returns the price of a given token in USD.
Parameters:
Name | Type | Description |
---|---|---|
token | address | The address of the token to get the price of. |
Return values:
Name | Type | Description |
---|---|---|
price | uint256 | The price of the token in USD. |
isValidCollateralization (0x2de0f093)
Checks if the given margin, exposure, and LVR values form a valid collateralization.
Parameters:
Name | Type | Description |
---|---|---|
margin | uint256 | The margin amount. |
exp | uint256 | The exposure amount. |
lvrNumerator | uint256 | The numerator of the loan-to-value ratio. |
lvrDenominator | uint256 | The denominator of the loan-to-value ratio. |
Return values:
Name | Type | Description |
---|---|---|
isValid | bool | True if the collateralization is valid, false otherwise. |
calculateLendingTokenCount (0xcc65e637)
Calculates the lending token count for a given notional value.
Parameters:
Name | Type | Description |
---|---|---|
lendingToken | address | The address of the lending token. |
notionalValue | uint256 | The notional value for which the lending token count is to be calculated. |
Return values:
Name | Type | Description |
---|---|---|
lendingTokenCount | uint256 | The calculated lending token count. |
calculateHF (0x2b32311b)
Calculates the health factor numerator and denominator based on the given parameters.
Parameters:
Name | Type | Description |
---|---|---|
expAmount | uint256 | The exposure amount. |
margin | uint256 | The margin amount. |
borrowAmount | uint256 | The borrowed amount. |
lvrNumerator | uint256 | The numerator of the loan-to-value ratio. |
lvrDenominator | uint256 | The denominator of the loan-to-value ratio. |
Return values:
Name | Type | Description |
---|---|---|
hfNumerator | uint256 | The calculated health factor numerator. |
hfDenominator | uint256 | The calculated health factor denominator. |
calculateMargin (0x6324eb4e)
Calculates the margin amount for a given position and safety margin.
Formula: Margin = ((Notional / LVR) * (1 + SafetyMargin)) - Notional
Parameters:
Name | Type | Description |
---|---|---|
projectToken | address | The address of the project token. |
lendingToken | address | The address of the lending token. |
safetyMarginNumerator | uint256 | The numerator of the safety margin ratio. |
safetyMarginDenominator | uint256 | The denominator of the safety margin ratio. |
expAmount | uint256 | The exposure amount. |
Return values:
Name | Type | Description |
---|---|---|
marginAmount | uint256 | The calculated margin amount. |
deleteLeveragePosition (0x0614a25a)
Deletes a leverage position for a user and project token. The caller must be the primary lending platform.
Parameters:
Name | Type | Description |
---|---|---|
user | address | The address of the user. |
projectToken | address | The address of the project token. |
calculateSafetyMargin (0x3d1aabdc)
Calculates the safety margin numerator and denominator for a given position, margin, and exposure.
Formula: Safety Margin = ((Margin + Notional) / (Notional / LVR)) - 1
Parameters:
Name | Type | Description |
---|---|---|
projectToken | address | The address of the project token. |
lendingToken | address | The address of the lending token. |
margin | uint256 | The margin amount. |
exp | uint256 | The exposure amount. |
Return values:
Name | Type | Description |
---|---|---|
safetyMarginNumerator | uint256 | The calculated safety margin numerator. |
safetyMarginDenominator | uint256 | The calculated safety margin denominator. |
calculateAddingAmount (0x545c5699)
Calculates the additional collateral amount needed for the specified user and project token.
Parameters:
Name | Type | Description |
---|---|---|
user | address | The address of the user. |
projectToken | address | The address of the project token. |
marginCollateralCount | uint256 | The margin collateral amount. |
Return values:
Name | Type | Description |
---|---|---|
addingAmount | uint256 | The additional collateral amount needed. |
getLeverageType (0x68faa77f)
Gets type of Leverage Position for given borrower and projectToken.
Parameters:
Name | Type | Description |
---|---|---|
borrower | address | The address of the borrower who's creating the leverage position |
projectToken | address | The address of the token being used as collateral. |
Return values:
Name | Type | Description |
---|---|---|
[0] | uint8 | type of leverage position or max of uint8 if leverage position is not exist. |
Last updated