From 7fbaa4cc3c1c39918be8459ae288a697171e4597 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=9Fingen?= Date: Tue, 23 Jan 2024 13:13:54 +0000 Subject: [PATCH 1/2] Fix some camel case names --- contracts/src/TroveManager.sol | 32 ++++++++++++++++---------------- 1 file changed, 16 insertions(+), 16 deletions(-) diff --git a/contracts/src/TroveManager.sol b/contracts/src/TroveManager.sol index 03d5da9f8..6e1463f86 100644 --- a/contracts/src/TroveManager.sol +++ b/contracts/src/TroveManager.sol @@ -93,7 +93,7 @@ contract TroveManager is LiquityBase, Ownable, CheckContract, ITroveManager { * L_ETH and L_boldDebt track the sums of accumulated liquidation rewards per unit staked. During its lifetime, each stake earns: * * An ETH gain of ( stake * [L_ETH - L_ETH(0)] ) - * A BoldDebt increase of ( stake * [L_boldDebt - L_boldDebt(0)] ) + * A boldDebt increase of ( stake * [L_boldDebt - L_boldDebt(0)] ) * * Where L_ETH(0) and L_boldDebt(0) are snapshots of L_ETH and L_boldDebt for the active Trove taken at the instant the stake was made */ @@ -104,7 +104,7 @@ contract TroveManager is LiquityBase, Ownable, CheckContract, ITroveManager { mapping (address => RewardSnapshot) public rewardSnapshots; // Object containing the ETH and Bold snapshots for a given active trove - struct RewardSnapshot { uint ETH; uint BoldDebt;} + struct RewardSnapshot { uint ETH; uint boldDebt;} // Array of all active trove addresses - used to to compute an approximate hint off-chain, for the sorted list insertion address[] public TroveOwners; @@ -122,7 +122,7 @@ contract TroveManager is LiquityBase, Ownable, CheckContract, ITroveManager { struct LocalVariables_OuterLiquidationFunction { uint price; - uint BoldInStabPool; + uint boldInStabPool; bool recoveryModeAtStart; uint liquidatedDebt; uint liquidatedColl; @@ -508,14 +508,14 @@ contract TroveManager is LiquityBase, Ownable, CheckContract, ITroveManager { LiquidationTotals memory totals; vars.price = priceFeed.fetchPrice(); - vars.BoldInStabPool = stabilityPoolCached.getTotalBoldDeposits(); + vars.boldInStabPool = stabilityPoolCached.getTotalBoldDeposits(); vars.recoveryModeAtStart = _checkRecoveryMode(vars.price); // Perform the appropriate liquidation sequence - tally the values, and obtain their totals if (vars.recoveryModeAtStart) { - totals = _getTotalsFromLiquidateTrovesSequence_RecoveryMode(contractsCache, vars.price, vars.BoldInStabPool, _n); + totals = _getTotalsFromLiquidateTrovesSequence_RecoveryMode(contractsCache, vars.price, vars.boldInStabPool, _n); } else { // if !vars.recoveryModeAtStart - totals = _getTotalsFromLiquidateTrovesSequence_NormalMode(contractsCache.activePool, contractsCache.defaultPool, vars.price, vars.BoldInStabPool, _n); + totals = _getTotalsFromLiquidateTrovesSequence_NormalMode(contractsCache.activePool, contractsCache.defaultPool, vars.price, vars.boldInStabPool, _n); } require(totals.totalDebtInSequence > 0, "TroveManager: nothing to liquidate"); @@ -650,14 +650,14 @@ contract TroveManager is LiquityBase, Ownable, CheckContract, ITroveManager { LiquidationTotals memory totals; vars.price = priceFeed.fetchPrice(); - vars.BoldInStabPool = stabilityPoolCached.getTotalBoldDeposits(); + vars.boldInStabPool = stabilityPoolCached.getTotalBoldDeposits(); vars.recoveryModeAtStart = _checkRecoveryMode(vars.price); // Perform the appropriate liquidation sequence - tally values and obtain their totals. if (vars.recoveryModeAtStart) { - totals = _getTotalFromBatchLiquidate_RecoveryMode(activePoolCached, defaultPoolCached, vars.price, vars.BoldInStabPool, _troveArray); + totals = _getTotalFromBatchLiquidate_RecoveryMode(activePoolCached, defaultPoolCached, vars.price, vars.boldInStabPool, _troveArray); } else { // if !vars.recoveryModeAtStart - totals = _getTotalsFromBatchLiquidate_NormalMode(activePoolCached, defaultPoolCached, vars.price, vars.BoldInStabPool, _troveArray); + totals = _getTotalsFromBatchLiquidate_NormalMode(activePoolCached, defaultPoolCached, vars.price, vars.boldInStabPool, _troveArray); } require(totals.totalDebtInSequence > 0, "TroveManager: nothing to liquidate"); @@ -1087,7 +1087,7 @@ contract TroveManager is LiquityBase, Ownable, CheckContract, ITroveManager { function _updateTroveRewardSnapshots(address _borrower) internal { rewardSnapshots[_borrower].ETH = L_ETH; - rewardSnapshots[_borrower].BoldDebt = L_boldDebt; + rewardSnapshots[_borrower].boldDebt = L_boldDebt; emit TroveSnapshotsUpdated(L_ETH, L_boldDebt); } @@ -1107,7 +1107,7 @@ contract TroveManager is LiquityBase, Ownable, CheckContract, ITroveManager { // Get the borrower's pending accumulated Bold reward, earned by their stake function getPendingBoldDebtReward(address _borrower) public view override returns (uint) { - uint snapshotBoldDebt = rewardSnapshots[_borrower].BoldDebt; + uint snapshotBoldDebt = rewardSnapshots[_borrower].boldDebt; uint rewardPerUnitStaked = L_boldDebt - snapshotBoldDebt; if ( rewardPerUnitStaked == 0 || Troves[_borrower].status != Status.active) { return 0; } @@ -1211,18 +1211,18 @@ contract TroveManager is LiquityBase, Ownable, CheckContract, ITroveManager { * 5) Note: static analysis tools complain about this "division before multiplication", however, it is intended. */ uint ETHNumerator = _coll * DECIMAL_PRECISION + lastETHError_Redistribution; - uint BoldDebtNumerator = _debt * DECIMAL_PRECISION + lastBoldDebtError_Redistribution; + uint boldDebtNumerator = _debt * DECIMAL_PRECISION + lastBoldDebtError_Redistribution; // Get the per-unit-staked terms uint ETHRewardPerUnitStaked = ETHNumerator / totalStakes; - uint BoldDebtRewardPerUnitStaked = BoldDebtNumerator / totalStakes; + uint boldDebtRewardPerUnitStaked = boldDebtNumerator / totalStakes; lastETHError_Redistribution = ETHNumerator - ETHRewardPerUnitStaked * totalStakes; - lastBoldDebtError_Redistribution = BoldDebtNumerator - BoldDebtRewardPerUnitStaked * totalStakes; + lastBoldDebtError_Redistribution = boldDebtNumerator - boldDebtRewardPerUnitStaked * totalStakes; // Add per-unit-staked terms to the running totals L_ETH = L_ETH + ETHRewardPerUnitStaked; - L_boldDebt = L_boldDebt + BoldDebtRewardPerUnitStaked; + L_boldDebt = L_boldDebt + boldDebtRewardPerUnitStaked; emit LTermsUpdated(L_ETH, L_boldDebt); @@ -1248,7 +1248,7 @@ contract TroveManager is LiquityBase, Ownable, CheckContract, ITroveManager { Troves[_borrower].debt = 0; rewardSnapshots[_borrower].ETH = 0; - rewardSnapshots[_borrower].BoldDebt = 0; + rewardSnapshots[_borrower].boldDebt = 0; _removeTroveOwner(_borrower, TroveOwnersArrayLength); sortedTroves.remove(_borrower); From 244692dece9d8e1a8879cdaab32ef8f5a96eb54e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=9Fingen?= Date: Tue, 23 Jan 2024 13:21:52 +0000 Subject: [PATCH 2/2] Remove warnings --- contracts/src/BoldToken.sol | 18 +++-- contracts/src/MultiTroveGetter.sol | 2 +- .../src/OldTestContracts/BoldTokenTester.sol | 69 +++++++++++++++++++ .../src/TestContracts/BoldTokenTester.sol | 11 +-- .../src/TestContracts/FunctionCaller.sol | 4 +- ...nagerTester.sol => TroveManagerTester.sol} | 2 +- contracts/src/test/TestContracts/BaseTest.sol | 4 +- 7 files changed, 90 insertions(+), 20 deletions(-) create mode 100644 contracts/src/OldTestContracts/BoldTokenTester.sol rename contracts/src/TestContracts/{CDPManagerTester.sol => TroveManagerTester.sol} (97%) diff --git a/contracts/src/BoldToken.sol b/contracts/src/BoldToken.sol index 8467cc656..0dad71fb5 100644 --- a/contracts/src/BoldToken.sol +++ b/contracts/src/BoldToken.sol @@ -67,9 +67,7 @@ contract BoldToken is CheckContract, IBoldToken { address _troveManagerAddress, address _stabilityPoolAddress, address _borrowerOperationsAddress - ) - public - { + ) { checkContract(_troveManagerAddress); checkContract(_stabilityPoolAddress); checkContract(_borrowerOperationsAddress); @@ -203,8 +201,8 @@ contract BoldToken is CheckContract, IBoldToken { } } - function _buildDomainSeparator(bytes32 typeHash, bytes32 name, bytes32 version) private view returns (bytes32) { - return keccak256(abi.encode(typeHash, name, version, _chainID(), address(this))); + function _buildDomainSeparator(bytes32 _typeHash, bytes32 _name, bytes32 _version) private view returns (bytes32) { + return keccak256(abi.encode(_typeHash, _name, _version, _chainID(), address(this))); } // --- Internal operations --- @@ -284,23 +282,23 @@ contract BoldToken is CheckContract, IBoldToken { // --- Optional functions --- - function name() external view override returns (string memory) { + function name() external pure override returns (string memory) { return _NAME; } - function symbol() external view override returns (string memory) { + function symbol() external pure override returns (string memory) { return _SYMBOL; } - function decimals() external view override returns (uint8) { + function decimals() external pure override returns (uint8) { return _DECIMALS; } - function version() external view override returns (string memory) { + function version() external pure override returns (string memory) { return _VERSION; } - function permitTypeHash() external view override returns (bytes32) { + function permitTypeHash() external pure override returns (bytes32) { return _PERMIT_TYPEHASH; } } diff --git a/contracts/src/MultiTroveGetter.sol b/contracts/src/MultiTroveGetter.sol index 580893b21..6c08d3f61 100644 --- a/contracts/src/MultiTroveGetter.sol +++ b/contracts/src/MultiTroveGetter.sol @@ -22,7 +22,7 @@ contract MultiTroveGetter { TroveManager public troveManager; // XXX Troves missing from ITroveManager? ISortedTroves public sortedTroves; - constructor(TroveManager _troveManager, ISortedTroves _sortedTroves) public { + constructor(TroveManager _troveManager, ISortedTroves _sortedTroves) { troveManager = _troveManager; sortedTroves = _sortedTroves; } diff --git a/contracts/src/OldTestContracts/BoldTokenTester.sol b/contracts/src/OldTestContracts/BoldTokenTester.sol new file mode 100644 index 000000000..e6acce8b9 --- /dev/null +++ b/contracts/src/OldTestContracts/BoldTokenTester.sol @@ -0,0 +1,69 @@ +// SPDX-License-Identifier: MIT + +pragma solidity 0.8.18; + +import "../BoldToken.sol"; + +contract BoldTokenTester is BoldToken { + + bytes32 private immutable _PERMIT_TYPEHASH = 0x6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9; + + constructor( + address _troveManagerAddress, + address _stabilityPoolAddress, + address _borrowerOperationsAddress + ) BoldToken( + _troveManagerAddress, + _stabilityPoolAddress, + _borrowerOperationsAddress + ) {} + + function unprotectedMint(address _account, uint256 _amount) external { + // No check on caller here + + _mint(_account, _amount); + } + + function unprotectedBurn(address _account, uint _amount) external { + // No check on caller here + + _burn(_account, _amount); + } + + function unprotectedSendToPool(address _sender, address _poolAddress, uint256 _amount) external { + // No check on caller here + + _transfer(_sender, _poolAddress, _amount); + } + + function unprotectedReturnFromPool(address _poolAddress, address _receiver, uint256 _amount ) external { + // No check on caller here + + _transfer(_poolAddress, _receiver, _amount); + } + + function callInternalApprove(address owner, address spender, uint256 amount) external returns (bool) { + _approve(owner, spender, amount); + return true; + } + + function getChainId() external view returns (uint256 chainID) { + //return _chainID(); // it’s private + assembly { + chainID := chainid() + } + } + + function getDigest(address owner, address spender, uint amount, uint nonce, uint deadline) external view returns (bytes32) { + return keccak256(abi.encodePacked( + uint16(0x1901), + domainSeparator(), + keccak256(abi.encode(_PERMIT_TYPEHASH, owner, spender, amount, nonce, deadline)) + ) + ); + } + + function recoverAddress(bytes32 digest, uint8 v, bytes32 r, bytes32 s) external pure returns (address) { + return ecrecover(digest, v, r, s); + } +} diff --git a/contracts/src/TestContracts/BoldTokenTester.sol b/contracts/src/TestContracts/BoldTokenTester.sol index 446299e6d..e6acce8b9 100644 --- a/contracts/src/TestContracts/BoldTokenTester.sol +++ b/contracts/src/TestContracts/BoldTokenTester.sol @@ -12,10 +12,12 @@ contract BoldTokenTester is BoldToken { address _troveManagerAddress, address _stabilityPoolAddress, address _borrowerOperationsAddress - ) public BoldToken(_troveManagerAddress, - _stabilityPoolAddress, - _borrowerOperationsAddress) {} - + ) BoldToken( + _troveManagerAddress, + _stabilityPoolAddress, + _borrowerOperationsAddress + ) {} + function unprotectedMint(address _account, uint256 _amount) external { // No check on caller here @@ -42,6 +44,7 @@ contract BoldTokenTester is BoldToken { function callInternalApprove(address owner, address spender, uint256 amount) external returns (bool) { _approve(owner, spender, amount); + return true; } function getChainId() external view returns (uint256 chainID) { diff --git a/contracts/src/TestContracts/FunctionCaller.sol b/contracts/src/TestContracts/FunctionCaller.sol index 04929ae66..c40ad8207 100644 --- a/contracts/src/TestContracts/FunctionCaller.sol +++ b/contracts/src/TestContracts/FunctionCaller.sol @@ -39,11 +39,11 @@ contract FunctionCaller { // --- Non-view wrapper functions used for calculating gas --- - function troveManager_getCurrentICR(address _address, uint _price) external returns (uint) { + function troveManager_getCurrentICR(address _address, uint _price) external view returns (uint) { return troveManager.getCurrentICR(_address, _price); } - function sortedTroves_findInsertPosition(uint _NICR, address _prevId, address _nextId) external returns (address, address) { + function sortedTroves_findInsertPosition(uint _NICR, address _prevId, address _nextId) external view returns (address, address) { return sortedTroves.findInsertPosition(_NICR, _prevId, _nextId); } } diff --git a/contracts/src/TestContracts/CDPManagerTester.sol b/contracts/src/TestContracts/TroveManagerTester.sol similarity index 97% rename from contracts/src/TestContracts/CDPManagerTester.sol rename to contracts/src/TestContracts/TroveManagerTester.sol index 02eee294e..625571cdc 100644 --- a/contracts/src/TestContracts/CDPManagerTester.sol +++ b/contracts/src/TestContracts/TroveManagerTester.sol @@ -46,7 +46,7 @@ contract TroveManagerTester is TroveManager { } function callGetRedemptionFee(uint _ETHDrawn) external view returns (uint) { - _getRedemptionFee(_ETHDrawn); + return _getRedemptionFee(_ETHDrawn); } function getActualDebtFromComposite(uint _debtVal) external pure returns (uint) { diff --git a/contracts/src/test/TestContracts/BaseTest.sol b/contracts/src/test/TestContracts/BaseTest.sol index bc6e82575..de45e0713 100644 --- a/contracts/src/test/TestContracts/BaseTest.sol +++ b/contracts/src/test/TestContracts/BaseTest.sol @@ -56,7 +56,7 @@ contract BaseTest is Test { accountsList = tempAccounts; } - function logContractAddresses() public { + function logContractAddresses() view public { console.log("ActivePool addr: ", address(activePool)); console.log("BorrowerOps addr: ", address(borrowerOperations)); console.log("CollSurplusPool addr: ", address(collSurplusPool)); @@ -67,4 +67,4 @@ contract BaseTest is Test { console.log("TroveManager addr: ", address(troveManager)); console.log("BoldToken addr: ", address(boldToken)); } -} \ No newline at end of file +}