Mundus Security Technical Blog
Announcement

MahaDAO Interim Security Audit

Mundus Security is thrilled to announce the release of Interim Security Audit Report for ARTH Value Token of MahaDAO (https://mahadao.com/) project. If you want to increase trust for your users, we are here to talk (Calendly).

About MahaDAO

MahaDAO is a mission to create a decentralized and stable economy. That is driven by the people, for the people.
MahaDAO is a community-powered, decentralized organization on a mission to empower billions with a stable economy through the world’s first valuecoin, ARTH.
To do this, MahaDAO uses two tokens to achieve this vision - the governance token MAHA, and the valuecoin ARTH.

About ARTH value token

ARTH is a stablecoin that is designed to appreciate overtime against the US dollar while at the same time it remains relatively stable.
ARTH is minted/burnt using decentralized smart contracts that use ETH as collateral to maintain its peg. The interest rate charged to mint ARTH using ETH is 0%, which makes it very cost-effective for borrowing/lending.
ARTH is fully collateralized with mechanisms that give it a backing of at least 110% in ETH.
You can find more information about the project here: Website, Twitter, Discord!

Summary of the ARTH Value Token Report

During the smart contract audit process, our security team has identified 26 potential vulnerabilities. In which 2 High and 3 Medium vulnerabilities. The MahaDAO team is fixing the vulnerabilities. There is no negative effect on current user assets.
You can find our classification in the Appendix of this announcement.
Vulnerabilities found
  • High 2
  • Medium 3
  • Low 2
  • Informational 16
  • Gas 3
You can find a full audit report here (Github).

Scope of Work

For source code audit purposes, we split SoW into two sets of contracts. The first set (we will call it ARTH Core) consists of these contracts:
  • ActivePool
  • ARTHValuecoin
  • BorrowerOperations
  • CollSurplusPool
  • CommunityIssuance
  • DefaultPool
  • Governance
  • SortedTroves
  • StabilityPool
  • TroveManager
These contracts are part of arth-core repository (with exception of ARTHValuecoin. It belongs to separate token repository). And all of these contracts are derived from Liquity project. For these contracts, SoW was settled as audit of changes made after the last audit of Liquity project in 2021.
The second set (we will call it ARTH Periphery) consists of these contracts:
  • ARTHFlashMinter
  • ARTHUSDCCurveStrategy with proxy
  • ETHGMUOracle
  • ETHTroveStrategy with proxy
  • GMUOracle
  • StabilityPoolKeeper
For these contracts, we performed source code audit as usual.

High and Medium Vulnerabilities Description

ARTH Core

ID-01. Medium: Wrong depositorETHGain receiver when invoking provideToSPFor method in StabilityPool.sol
Description The provideToSPFor method of StabilityPool.sol is a restricted function that allows contract admin to execute the provideToSP method on behalf of another account. In that function the depositorETHGain is sent to depositor via _sendETHGainToDepositor method. However, the _sendETHGainToDepositor function deals only with msg.sender, which means that in the case of using provideToSPFor the depositorETHGain is sent to msg.sender, rather than _who.
Recommendation Modify the _sendETHGainToDepositor(uint256 amount) function as well as all its use cases to contain the recipient address, i.e. _sendETHGainToDepositor(uint256 amount, _who).

ARTH Periphery

ID-14. High: Insufficient access control for notifyRewardAmount in StakingRewardsChild.sol -> USDCCurveStrategy.sol
Description The notifyRewardAmount method of StakingRewardsChild.sol in the USDCCurveStrategy contract lacks access control. Thus, any account is able to modify the rewardRate, lastUpdateTime and periodFinish state variables of the USDCCurveStrategy contract.
Recommendation Add onlyOwner modifier to the notifyRewardAmount method of StakingRewardsChild.sol.
ID-15. High: Wrong fee mechanism when invoking flashLoan in ARTHFlashMinter.sol Description The flashLoan method of ARTHFlashMinter.sol is implemented with the wrong fee mechanism. According to the code below, after a successful callback, the amount of receiver's tokens is burned, and the _fee is transferred to the ecosystemFund at the expense of the ARTHFlashMinter contract.
Recommendations:
Modify the flashLoan method of ARTHFlashMinter.sol in either of the two following ways.
ID-16. Medium: minDepositForPermit is never initialized in USDCCurveStrategy.sol
Description The minDepositForPermit state variable of USDCCurveStrategy.sol is never initialized.
NOTE: At the time of initial discovery of this issue the USDCCurveStrategy implementation address was 0x122f4530c2c8ed9a7dc4846a155579ede0e23ecb. Since then, the MAHADAO team has resolved this issue by deploying a new USDCCurveStrategy implementation (0x9ff6629d08fddaec63b0d855b9c29acdf4dc14e4) with proper minDepositForPermit initialization.
ID-17. Medium: Wrong fee value set in ARTHFlashMinter.sol Description The flashloan fee of the ARTHFlashMinter contract is 100 larger than the value stated in the comments to the source code.

Conclusion

We are happy to work with the MahaDAO team to improve security and build trust for the community and investors. Stay tuned to receive the following security updates soon: Twitter, Telegram!

Appendix

Severity Description

High - Bugs that can trigger a contract failure or theft of assets. Further recovery is possible only by manual modification of the contract state or replacement.
Medium - Bugs that can break the intended contract logic or expose it to DoS attacks, but do not cause direct loss of funds.
Low - Bugs that do not pose significant danger to the project or its users but are recommended to be fixed nonetheless.