Endgame is a fundamental transformation of MakerDAO that improves growth, resilience and accessibility, with the aim of scaling the Dai supply to 100 billion and beyond.
Scope
Contest Results
On what chains are the smart contracts going to be deployed?
Ethereum
If you are integrating tokens, are you allowing only whitelisted tokens to work with the codebase or any complying with the standard? Are they assumed to have certain properties, e.g. be non-reentrant? Are there any types of weird tokens you want to integrate?
The token contracts used in each repository are known in advance and there is no use of arbitrary tokens in any of the contest modules:
Issues stemming from potential different future implementations of NST and SNST (due to their upgradeability) are out of scope.
All the above means that there is no need to analyze potential use/integration of any other token code (which could potentially have weird behaviour) in any of the modules.
Are there any limitations on values set by admins (or other roles) in the codebase, including restrictions on array lengths?
No
Are there any limitations on values set by admins (or other roles) in protocols you integrate with, including restrictions on array lengths?
No
For permissioned functions, please list all checks and requirements that will be made before calling the function.
N/A
Is the codebase expected to comply with any EIPs? Can there be/are there any deviations from the specification?
Optionally Compliant
ERC20: NST, NGT and SNST tokens.
ERC4626: SNST
Are there any off-chain mechanisms or off-chain procedures for the protocol (keeper bots, arbitrage bots, etc.)?
Public Keeper Bots
Endgame Toolkit: VestedRewardsDistribution.distribute()
Arbitrage Bots
LockStake Engine: LockstakeClipper.take()
Are there any hardcoded values that you intend to change before (some) deployments?
None
If the codebase is to be deployed on an L2, what should be the behavior of the protocol in case of sequencer issues (if applicable)? Should Sherlock assume that the Sequencer won't misbehave, including going offline?
Not deployed to L2.
Should potential issues, like broken assumptions about function behavior, be reported if they could pose risks in future integrations, even if they might not be an issue in the context of the scope? If yes, can you elaborate on properties/invariants that should hold?
No
Please discuss any design choices you made.
Please refer to https://github.com/makerdao/sherlock-contest/blob/9a01337e8f82acdf699a5c1c54233636c640ca89/README.md, and the documentation present in the codebases.
Please list any known issues and explicitly state the acceptable risks for each known issue.
Please refer to https://github.com/makerdao/sherlock-contest/blob/9a01337e8f82acdf699a5c1c54233636c640ca89/README.md, and the documentation present in the codebases for a list of known issues and general disclaimers for this contest.
We will report issues where the core protocol functionality is inaccessible for at least 7 days. Would you like to override this value?
No
Please provide links to previous audits (if any).
https://github.com/makerdao/nst/tree/sherlock-contest/audit
https://github.com/makerdao/ngt/tree/sherlock-contest/audit
https://github.com/makerdao/sdai/tree/sherlock-contest/audit
https://github.com/makerdao/endgame-toolkit/tree/sherlock-contest/audits
https://github.com/makerdao/dss-flappers/tree/sherlock-contest/audit
https://github.com/makerdao/univ2-pool-migrator/tree/sherlock-contest/audit
https://github.com/makerdao/vote-delegate/tree/sherlock-contest/audit
https://github.com/makerdao/lockstake/tree/sherlock-contest/audit
Please list any relevant protocol resources.
Please find additional information about the codebases here: https://www.notion.so/jetstreamgg/Maker-Endgame-Launch-Sherlock-Audit-Contest-Scope-641baee4028548ccbb3783f2278c3215
Additional audit information.
Severity Definitions:
We are building on top of the current Sherlock severity definitions apart from changes explicitly mentioned (for example see about functionality breaking). However, we are giving guidance to the words that describe loss.
Sherlock's Medium definition:
Causes a loss of funds but requires certain external conditions or specific states, or a loss is highly constrained. The losses must exceed small, finite amount of funds, and any amount relevant based on the precision or significance of the loss.
"a loss is highly constrained". As a guideline for this contest, a highly constrained loss is a loss of up to 5% of the affected party (both protocol and user).
"The losses must exceed small, finite amount of funds". As a guideline for this contest, small, finite amount of funds are 0.5% of the affected party (both protocol and user).
With this clarification
Any loss smaller than 0.5% can never be Medium
Any loss between 0.5% and 5% loss can be Medium at most
Any issue larger than 5% can be Medium or High (depending on constraints)
If a single attack can cause a 0.01% loss but can be replayed indefinitely (assuming little to no costs), it will be perceived as a 100% loss. Note that in most modules governance can step in within hours (aka Mom contracts), or otherwise if needed plus the governance pause delay to halt the system. This should be taken into account when determining if replaying indefinitely is possible. For the contest we assume 2 hours from the point an exploit starts until a delay-bypass Mom contract executes and 50 hours for a fix that requires governance delay (including the delay).
For protocol losses, it must be demonstrated that the losses exceed the above percentage assuming protocol reserves of 100m+. For user losses, it must demonstrate those losses with the user's 10k+ of value locked/vulnerable as part of the attack.
In the lockstake case, the maximal locked MKR is assumed at $250m and the maximal line is assumed as 100m dai. A user in the lockstake case is a single urn.
For the SNST case, the maximal locked NST amount is assumed as 1B DAI.
Rules:
The protocol chooses to override at least the following from https://docs.sherlock.xyz/audits/judging/judging. Other changes may also be communicated through the competition website or elsewhere.
"Breaks core contract functionality, rendering the contract useless or leading to loss of funds." Breaking any kind of functionality is not a medium or high severity issue for this competition, only loss of funds.
"The protocol team can use the README (and only the README) to define language that indicates the codebase's restrictions and/or expected functionality." Any public material should be valid as known issues for this competition.
"Issues that break these statements, irrespective of whether the impact is low/unknown, will be assigned Medium severity." Even if an intended functionality is broken but there is no material loss of funds then it is not a medium or high issue for this competition.
"Example: The README states "Admin can only call XYZ function once" but the code allows the Admin to call XYZ function twice; this is a valid Medium" This shouldn't be a valid medium if there is no loss of funds.
"EIP Compliance: For issues related to EIP compliance, the protocol & codebase must show that there are important external integrations that would require strong compliance with the EIP's implemented in the code. The EIP must be in regular use or in the final state for EIP implementation issues to be considered valid" There is no commitment with regards to EIP compliance. On top of that, any loss of funds incurred in an integrating contract is out of scope.
"User input validation: User input validation to prevent user mistakes is not considered a valid issue. However, if a user input could result in a major protocol malfunction or significant loss of funds could be a valid high." Any user mistakes resulting in their own funds being lost is out of scope.
Please refer to https://github.com/makerdao/sherlock-contest/blob/9a01337e8f82acdf699a5c1c54233636c640ca89/README.md, and the documentation present in the codebases for a list of known issues and general disclaimers for this contest.
Also see https://hackmd.io/@h3li0s/rk3x9uFw0
Total Rewards
Contest Pool
Lead Senior Watson
Judging Pool
Lead Judge
415,000 DAI
30,000 DAI
5,000 DAI
5,000 DAI
Status
Scope
Start Time
End Time
Judging Rules
Reserved Auditors