PalPool
PalPools are the main component of the Protocol.
Each PalPool is independent and holds its own underlying ERC20 governance token.
Users can deposit the underlying token in the PalPool, receiving an amount of PalToken representing their share in the PalPool, and receive part of the fees of the PalPool.
The main use of the PalPool is to Borrow voting/proposition power. When starting a Borrow, the PalPool will create a PalLoan, by cloning the Delegator contract set in the PalPool, it will transfer the amount of tokens borrowed and the fees paid by the borrower, delegate the PalLoan voting power to the borrower, and issue a PalLoanToken to represent the ownership of the PalLoan.
The Borrow can later be extended, closed (and the unused fees will be returned to the borrower), or killed if all the fees were used. The owner of the Borrow can also change the recipient of his PalLoan voting power.
A Borrow is the data struct listed in the PalPool storage, listing all the data relative to the borrowed voting power. A PalLoan (also referred as Loan) is the contract holding the voting power, and delegating it to the given address.
Each PalLoan is linked to a Borrow, and to a PalLoanToken (ERC 721 token representing ownership of a PalLoan and its Borrow)
Methods :
Events :
Deposit
event Deposit(address user, uint amount, address palPool);
When a user deposits in the Pool.
Withdraw
event Withdraw(address user, uint amount, address palPool);
When a user withdraws from the Pool.
NewLoan
event NewLoan(address borrower, address delegatee, address underlying, uint amount, address palPool, address loanAddress, uint256 palLoanTokenId, uint startBlock);
When a Borrow is started and a PalLoan is created.
ExpandLoan
event ExpandLoan(address borrower, address delegatee, address underlying, address palPool, uint newFeesAmount, address loanAddress, uint256 palLoanTokenId);
When the borrower adds more fees to the PalLoan to extend the duration of the loan.
ChangeLoanDelegatee
event ChangeLoanDelegatee( address borrower, address newDelegatee, address underlying, address palPool, address loanAddress, uint256 palLoanTokenId);
When the borrower change the delegatee (recipient of the voting power) of the PalLoan
CloseLoan
event CloseLoan(address borrower, address delegatee, address underlying, uint amount, address palPool, uint usedFees, address loanAddress, uint256 palLoanTokenId, bool wasKilled);
When the Borrow is either closed or killed (the wasKilled flag is ‘true’ if the Borrow was killed).
Read-only methods :
palLoanToken
function palLoanToken() public view returns(address);
Returns the address of the PalLoanToken contract
underlying
function underlying() public view returns(address);
Returns the underlying governance token held by the Pool
palToken
function palToken() public view returns(address);
Returns the address of the palToken linked to this Pool
totalReserve
function totalReserve() public view returns(uint);
Returns the amount in the Pool’s Reserve (in wei)
totalBorrowed
function totalBorrowed() public view returns(uint);
Returns the current total amount of funds borrowed from the Pool (in wei)
minBorrowLength
function minBorrowLength() public view returns(uint);
Returns the minimum duration of a Borrow (in number of blocks)
killFactor
function killFactor() public view returns(uint);
Returns the health factor value at which a Borrow can be killed (scale 1e18)
killerRatio
function killerRatio() public view returns(uint);
Returns the ratio of fees to reward the killer of a Borrow (scale 1e18)
reserveFactor
function reserveFactor() public view returns(uint);
Returns the factor of fees to set as Reserve (scale 1e18)
accrualBlockNumber
function accrualBlockNumber() public view returns(uint);
Returns the block number for the last interest update for this Pool
borrowIndex
function borrowIndex() public view returns(uint);
Returns the last computed Borrow Index for this Pool (scale 1e18)
controller
function controller() public view returns(address);
Returns the address of the current Controller for this Pool
underlyingBalance
function underlyingBalance() public view returns(uint);
Returns the amount of underlying token in the Pool (in wei)
balanceOf
function balanceOf(address _account) external view returns(uint);
Returns balance of the user in palToken (in wei)
underlyingBalanceOf
function underlyingBalanceOf(address _account) external view returns(uint)
Returns balance of the user in the underlying token (in wei)
isLoanOwner
function isLoanOwner(address _loanAddress, address _user) external view returns(bool)
Returns 'true' if the given user is the owner of the PalLoan
idOfLoan
function idOfLoan(address _loanAddress) external view returns(uint256)
Returns the PalLoanToken Id for the given PalLoan
getLoansPools
function getLoansPools() external view returns(address [] memory);
Returns a list of all the Loans (active or closed)
getLoansByBorrower
function getLoansByBorrower(address _borrower) external view returns(address [] memory);
Returns a list of all the user's Loans (active or closed)
getBorrowData
function getBorrowData(address _loanAddress) external view returns (address _borrower, address _loan, uint _amount, address _underlying, uint _feesAmount, uint _feesUsed, uint _startBlock, bool _closed)
Returns all the data stored for the given Borrow (for the given PalLoan)
Parameters :
name | type | desc |
_loanAddress | address | address of the PalLoan |
Returns :
name | type | desc |
_borrower | address | address of the owner of the Borrow (by being owner of the PalLoanToken) |
_delegatee | address | address of the recipient of the voting power |
_loanPool | address | address of the PalLoan for this Borrow |
_palLoanTokenId | uint256 | id of the PalLoanToken for this PalLoan |
_amount | uint | amount of token borrowed for delegation |
_underlying | address | address of the governance token |
_feesAmount | uint | amount of fees paid by the borrower |
_feesUsed | uint | amount of fees already used by the Borrow |
_startBlock | uint | block where the Borrow was started |
_closed | bool | ‘false’ if the Borrow is still active |
_killed | bool | 'true' if the Borrow was killed |
borrowRatePerBlock
function borrowRatePerBlock() external view returns (uint);
Returns the current Borrow Rate (scale 1e18)
supplyRatePerBlock
function supplyRatePerBlock() external view returns (uint);
Returns the current Supply Rate (scale 1e18)
exchangeRateStored
function exchangeRateStored() external view returns (uint);
Returns the last updated Exchange Rate (scale 1e18)
minBorrowFees
function minBorrowFees(uint _amount) external view returns (uint);
Amount minimum of fees to allow the borrow() method. Calculated on the given amount parameter (in wei). Return the minimum amount of fees (in wei)
isKillable
function isKillable(address _loan) external view returns(bool);
Returns true if the health factor of a Borrow (given by the PalLoan address) is low enough to be killed
State-changing methods :
deposit
function deposit(uint _amount) external returns(uint);
Deposit the underlying token into the Pool, and receive an amount of palToken corresponding to the deposit.
Parameters :
name | type | desc |
_amount | uint | amount of token to deposit in the Pool |
Returns :
name | type | desc |
uint | amount of palTokens minted to the user |
The _amount value must be approved for the PalPool before this transaction
withdraw
function withdraw(uint _amount) external returns(uint);
Burn an amount of palToken to withdraw the underlying token of the Pool.
Parameters :
name | type | desc |
_amount | uint | amount of palToken to burn |
Returns :
name | type | desc |
uint | amount of underlying token returned to the user |
borrow
function borrow(address _delegatee, uint _amount, uint _feeAmount) external returns(uint);
Starts a Borrow, creates a PalLoan (and mint the PalLoanToken linked to this PalLoan), and sends the borrowed amount and the fees to the PalLoan, to delegate the voting/proposition power to the delegatee.
A minimum of fees, to cover the Minimum Borrow Length, is required to start the Borrow
Parameters :
name | type | desc |
_delegatee | address | address to receive the voting power |
_amount | uint | amount of governance token to borrow (representing how much power to receive through delegation) |
_feeAmount | uint | amount of fees paid for the Borrow |
Returns :
name | type | desc |
uint | amount of token delegated to the borrower |
The _feeAmount value must be approved for the PalPool before this transaction
expandBorrow
function expandBorrow(address _loanPool, uint _feeAmount) external returns(uint);
If the borrower wants to extend his Borrow length, fees can be paid to be added to the Borrow (and transferred to the corresponding PalLoan)
Parameters :
name | type | desc |
_loanPool | address | address of the PalLoan linked to the Borrow to expand |
_feeAmount | uint | amount of fees to add to the Borrow |
Returns :
name | type | desc |
uint | amount of fees added to the Borrow |
The _feeAmount value must be approved for the PalPool before this transaction
closeBorrow
function closeBorrow(address _loanPool) external;
A borrower can close his own Borrows if he wants, recovering the fees not used.
If the borrower tries to close the Borrow before the Minimum Borrow Length, Penalty Fees will be be applied to the fees to return to the users, corresponding to the amount of fees to pay up to the Minimum Borrow Length (applied using the Borrow Rate at the time of closing).
Parameters :
name | type | desc |
_loanPool | address | address of the PalLoan linked to the Borrow to close |
killBorrow
function killBorrow(address _loanPool) external;
If a Borrow used all its fees, it can be killed to stop the delegation, and return the voting power to the Pool.
The Killer cannot be the user owning the Borrow, and the Killer is rewarded a part of the fees of this Borrow.
Parameters :
name | type | desc |
_loanPool | address | address of the PalLoan linked to the Borrow to kill |
changeBorrowDelegatee
function changeBorrowDelegatee(address _loanPool, address _newDelegatee) external;
Changes the recipient of voting power for the given PalLoan, updating the data in the Borrow, and triggering a delegation process for the PalLoan to give the voting power to the new delegatee address.
Parameters :
name | type | desc |
_loanPool | address | address of the PalLoan |
_newDelegatee | address | address of the new delegatee to receive the PalLoan voting power |
exchangeRateCurrent
function exchangeRateCurrent() external returns (uint);
Updates the Pool state & returns the last updated Exchange Rate
Returns :
name | type | desc |
uint | current Exchange Rate for the palToken (scale 1e18) |
_updateInterest
function _updateInterest() external returns (uint);
Update the Pool interests & storage values. This method is called before any deposit/withdraw/borrow/closeBorrow/…, but can also be called to update the Pool state.
Returns :
name | type | desc |
bool | Update success |
Last updated