SJIP: Clarify Oracle Staleness #21
Replies: 4 comments 8 replies
-
Instead of making the rule for any oracle and instantly introducing exceptions, consider making the rule for just Chainlink and Chainlink-like oracles (perhaps ones that fit the Chainlink interface?). This would help avoid further confusion and leave less room for judge interpretation on whether they should make an exception or not. |
Beta Was this translation helpful? Give feedback.
-
Chainlink is coming out with a pull oracle as well. I'd suggest limiting it to oracles where the api being called, or the network it relies on, already enforces a max age in some way. I'd also move the round completeness to a new rule since it's not related. |
Beta Was this translation helpful? Give feedback.
-
Can you also take a look at these and comment on whether you think each would be valid or invalid after the change? They're all slightly different variations on the same theme, and would likely lead to an escalation without clarification:
In some of the more recent contests, a lot of watsons are being rewarded for just saying 'stale price' or 'min/max not checked', without actually showing a valid attack, but they should be invalid according to duplication rules. Perhaps the rule should change to clarify that saying that is not enough, and specific examples from on-chain settings must be used, and an actual attack must be outlined. |
Beta Was this translation helpful? Give feedback.
-
@IllIllI000 @spacegliderrrr I see that we haven't quite reached a concrete conclusion here, but this seems to be the only such discussion (or one of the few) among other SJIPs, so I'm moving it to the Last Call phase. please share your opinion on the above suggestion. Re-iterating, there are three paths I can see here:
What is better for you and you think would be better for other SRs? |
Beta Was this translation helpful? Give feedback.
-
Description
Clarify that the staleness rule is about any oracle, not only Chainlink, and add an example of the exception.
Judging Guidelines PR
https://github.com/sherlock-protocol/sherlock-v2-docs/pull/50/files
Rationale
Watsons flagged that the rule reads like it is only about Chainlink, while it's supposed to be about any oracle.
Additionally, added an exception case where such issues can be judged beyond the rules:
The protocol may be using Pyth pull-based oracle, which requires requesting the price before using it. Hence, if we don't request the price firstly, or check it for staleness, then we can end up using very old price (e.g. from 1 hour/day ago). Here's the issue that was validated in such a scenario, despite this rule.
Relevant Issue Discussions
sherlock-audit/2024-12-mach-finance-judging#41
Beta Was this translation helpful? Give feedback.
All reactions