Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Update to add acceptLender function (SC-9368) #67

Merged
merged 2 commits into from
Nov 3, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
23 changes: 17 additions & 6 deletions contracts/DebtLocker.sol
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,23 @@ contract DebtLocker is IDebtLocker, DebtLockerStorage, MapleProxiedInternals {
IMapleProxyFactory(_factory()).upgradeInstance(toVersion_, arguments_);
}

/*************************************/
/*** Liquidity Migration Functions ***/
/*************************************/

function acceptLender() override external whenProtocolNotPaused {
require(msg.sender == _loanMigrator, "DL:SPL:NOT_MIGRATOR");
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Incorrect func selector in error string


IMapleLoanLike(_loan).acceptLender();
}

function setPendingLender(address newLender_) override external whenProtocolNotPaused {
require(msg.sender == _loanMigrator, "DL:SPL:NOT_MIGRATOR");

IMapleLoanLike(_loan).setPendingLender(newLender_);
}


/*******************************/
/*** Pool Delegate Functions ***/
/*******************************/
Expand Down Expand Up @@ -110,12 +127,6 @@ contract DebtLocker is IDebtLocker, DebtLockerStorage, MapleProxiedInternals {
emit FundsToCaptureSet(_fundsToCapture = amount_);
}

function setPendingLender(address newLender_) override external whenProtocolNotPaused {
require(msg.sender == _loanMigrator, "DL:SPL:NOT_MIGRATOR");

IMapleLoanLike(_loan).setPendingLender(newLender_);
}

function setMinRatio(uint256 minRatio_) external override whenProtocolNotPaused {
require(msg.sender == _getPoolDelegate(), "DL:SMR:NOT_PD");

Expand Down
5 changes: 5 additions & 0 deletions contracts/interfaces/IDebtLocker.sol
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,11 @@ interface IDebtLocker is IMapleProxied {
/*** Functions ***/
/*****************/

/**
* @dev Accepts the lender on a Maple Loan.
*/
function acceptLender() external;

/**
* @dev Accept the new loan terms and trigger a refinance.
* @param refinancer_ The address of the refinancer contract.
Expand Down
2 changes: 2 additions & 0 deletions contracts/interfaces/Interfaces.sol
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,8 @@ interface IMapleGlobalsLike {

interface IMapleLoanLike {

function acceptLender() external;

function acceptNewTerms(address refinancer_, uint256 deadline_, bytes[] calldata calls_, uint256 amount_) external;

function claimableFunds() external view returns (uint256 claimableFunds_);
Expand Down
17 changes: 16 additions & 1 deletion tests/DebtLocker.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -1114,7 +1114,6 @@ contract DebtLockerV4Migration is TestUtils {
assertEq(debtLocker_.loanMigrator(), loanMigrator);
}


function test_acl_setPendingLender() external {
( MapleLoan loan, DebtLocker debtLocker ) = _createFundAndDrawdownLoan(1_000_000, 30_000);

Expand All @@ -1133,6 +1132,22 @@ contract DebtLockerV4Migration is TestUtils {
assertEq(loan.pendingLender(), newLender);
}

function test_acl_acceptLender() external {
( MapleLoan loan, DebtLocker debtLocker ) = _createFundAndDrawdownLoan(1_000_000, 30_000);

LoanMigrator loanMigrator = new LoanMigrator();
LoanMigrator notLoanMigrator = new LoanMigrator();

address newLender = address(3);

poolDelegate.debtLocker_upgrade(address(debtLocker), 2, abi.encode(address(loanMigrator)));

loanMigrator.debtLocker_setPendingLender(address(debtLocker), address(debtLocker)); // Set pending lender in Loan to get ACL to work

assertTrue(!notLoanMigrator.try_debtLocker_acceptLender(address(debtLocker)));
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Think we should assert with the correct error msg as it would have highlighted the incorrect func selector but appreciate this means adjust the LoanMigrator.sol in accounts

assertTrue( loanMigrator.try_debtLocker_acceptLender(address(debtLocker)));
}

function _createLoan(uint256 principalRequested_, uint256 collateralRequired_) internal returns (MapleLoan loan_) {
address[2] memory assets = [address(collateralAsset), address(fundsAsset)];
uint256[3] memory termDetails = [uint256(10 days), uint256(30 days), 6];
Expand Down
8 changes: 8 additions & 0 deletions tests/accounts/LoanMigrator.sol
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,18 @@ import { IDebtLocker } from "../../contracts/interfaces/IDebtLocker.sol";

contract LoanMigrator {

function debtLocker_acceptLender(address debtLocker_) external {
IDebtLocker(debtLocker_).acceptLender();
}

function debtLocker_setPendingLender(address debtLocker_, address newLender_) external {
IDebtLocker(debtLocker_).setPendingLender(newLender_);
}

function try_debtLocker_acceptLender(address debtLocker_) external returns (bool ok_) {
( ok_, ) = debtLocker_.call(abi.encodeWithSelector(IDebtLocker.acceptLender.selector));
}

function try_debtLocker_setPendingLender(address debtLocker_, address newLender_) external returns (bool ok_) {
( ok_, ) = debtLocker_.call(abi.encodeWithSelector(IDebtLocker.setPendingLender.selector, newLender_));
}
Expand Down
8 changes: 8 additions & 0 deletions tests/mocks/Mocks.sol
Original file line number Diff line number Diff line change
Expand Up @@ -74,10 +74,18 @@ contract MockLoan {
return 0;
}

function acceptLender() external {
// Empty, just testing ACL
}

function acceptNewTerms(address refinancer_, bytes[] calldata calls_, uint256 amount_) external {
// Empty, just testing ACL
}

function setPendingLender(address lender_) external {
// Empty, just testing ACL
}

}

contract MockGlobals {
Expand Down