描述
<h2>TL;DR</h2><ul><li><a href="https://twitter.com/samczsun/status/1642848556590723075" rel="noopener noreferrer" target="_blank">A recent hack worth $25M</a> reveals a significant mismatch between the revenue that can be captured through MEV at the application level and the cost of PoS slashing.</li><li>The difference between the benefits and comparably low costs of an attack can impact the security of the network system itself.</li><li>In an oracle network, PoS is directly related to the security of the application, as oracle network provides a data service instead of hosting a neutral computing platform like Ethereum.</li><li>Hyper Oracle is an oracle network that replaces PoS with ZK and safeguards applications with the base layer blockchain's security.</li></ul><h2>0. Introduction</h2><h3>a) Low Cost (of slashing in network) and High Profit (by hacking apps in network)</h3><p>In our <a href="https://mirror.xyz/hyperoracleblog.eth/qbefsToFgFxBZBocwlkX-HXbpeUzZiv2UB5CmxcaFTM" rel="noopener noreferrer" target="_blank">recently published whitepaper</a>, we discussed issues with traditional oracle networks. One of these issues is "Low Cost and High Profit of Attack." Attacking these protocols by attacking the oracle network can result in a high potential profit, while the cost of attacking the oracle network is low if its token price or staking requirement is too low.</p><p>The root cause of this security flaw is the staking and slashing mechanism of <a href="https://ethresear.ch/t/defining-zkoracle-for-ethereum/15131" rel="noopener noreferrer" target="_blank">the oracle network</a> (also known as middleware network).</p><h3>b) Staking & Slashing Terminology</h3><p>To ensure consistency, we will use "PoS" (Proof of Stake) to refer to the staking and slashing mechanism of the oracle network. However, there are some minor differences between PoS in a traditional blockchain network and the staking and slashing mechanism of an oracle network.</p><h3>c) PoS in Oracle Networks</h3><p>We discussed how PoS works in traditional oracle networks <a href="https://docs.hyperoracle.io/resources/faq#what-are-security-mechanisms-for-other-oracle-networks" rel="noopener noreferrer" target="_blank">in our documentation</a>. The security of these networks is based on the PoS mechanism.</p><p>PoS has two main components:</p><ul><li>Staking: Nodes must lock tokens in order to join the network.</li><li>Slashing: Bad nodes forfeit their locked tokens.</li><li class="ql-indent-1">Challenge: Report bad nodes and provide evidence.</li><li class="ql-indent-1">Arbitration: Judgment on challenges.</li></ul><p>While staking is similar, the mechanisms associated with slashing differ.</p><p>In output oracles such as The Graph, the challenge mechanism in PoS is called a fisherman mechanism (<a href="https://thegraph.com/docs/en/network/indexing/#what-are-disputes-and-where-can-i-view-them" rel="noopener noreferrer" target="_blank">docs</a>, <a href="https://github.com/graphprotocol/contracts/blob/dev/contracts/disputes/DisputeManager.sol" rel="noopener noreferrer" target="_blank">code</a>). This mechanism is similar to Optimistic Rollups' fault/fraud proof, but it lacks verifiability and decentralization. Here's how it works: during a week-long dispute period, someone can stake their token to challenge the computation (indexing or querying) and result of a node operator (indexer). Then, an arbitrator council decides if the challenge is accepted to slash the challenger or the node operator.</p><p>I/O oracles such as Gelato Network and Keep3r Network use governance-based slashing for security. However, some of them are currently <a href="https://docs.gelato.network/introduction/executor-operators#who-can-become-an-executor" rel="noopener noreferrer" target="_blank">not permissionless</a> and require legal bindings to operate a node. For the networks that have <a href="https://docs.keep3r.network/roles/governance" rel="noopener noreferrer" target="_blank">governance and PoS as a security mechanism</a>, someone must challenge a node operator (executor) on their governance platform (usually a forum), and members will manually examine the challenge. To me, this feels like <a href="https://twitter.com/GwartyGwart/status/1642921139474411523" rel="noopener noreferrer" target="_blank">the meme below</a>.</p><p class="ql-align-center"><span style="color: transparent;"><img src="https://mirror.xyz/_next/image?url=https%3A%2F%2Fimages.mirror-media.xyz%2Fpublication-images%2F1_HN-YIAogzTW-6EaShFx.png&w=3840&q=75" height="285" width="1367"></span></p><h2>2. Recent 25M Hack in Ethereum</h2><h3>a) Background Knowledge</h3><p>To start, let’s define some terms related to the hack:</p><ul><li>MEV: Miner/Maximal Extractable Value. This is the extra income that a user or node on a network can gain from the actions of other users.</li><li>Flashbots: A software that allows people to extract MEV without disrupting others’ normal usage. MEV bots use Flashbots to gain MEV, while nodes process transactions sent by MEV bots through Flashbots to receive a certain "bribe" from the MEV bots’ share.</li><li>Sandwich Attack: A “harmful” MEV practice that targets users who trade on AMMs like Uniswap or Sushi. It aims to extract profits from user transactions by sandwiching them with multiple transactions.</li><li>Ethereum PoS: Staking your ETH to become a node on the network allows you to receive staking revenue and earn MEV revenue through Flashbots. However, bad behavior on the network can result in a node's stake being slashed.</li></ul><h3>b) The Hack</h3><p>In summary, a hacker made over $20 million from MEV bots by exploiting a Flashbots vulnerability and taking advantage of Ethereum’s PoS.</p><p>If you want a very detailed and technical review of the hack, check out samczsun's <a href="https://twitter.com/samczsun/status/1642848556590723075" rel="noopener noreferrer" target="_blank">tweet</a>. But here's the story in simple terms.</p><p>The <a href="https://etherscan.io/address/0x3c98d617db017f51c6a73a13e80e1fe14cd1d8eb" rel="noopener noreferrer" target="_blank">hacker</a> set up an Ethereum node (or <a href="https://twitter.com/ratedw3b/status/1642998861487546369" rel="noopener noreferrer" target="_blank">maybe more</a>) <a href="https://etherscan.io/tx/0x9cf11fde666d94b32ee9ba3fc6aee468b03f2f5e7ef06f1642415fe0ebfe7c58" rel="noopener noreferrer" target="_blank">two weeks ago</a> by staking. Then, they <a href="https://etherscan.io/address/0x410fb10ba8af78a1e191fe3067208d3212ded961" rel="noopener noreferrer" target="_blank">deployed liquidity on an AMM</a>. The hacker posed as a trader and used this liquidity to lure other MEV bots into performing sandwich attacks.</p><p class="ql-align-center"><span style="color: transparent;"><img src="https://mirror.xyz/_next/image?url=https%3A%2F%2Fimages.mirror-media.xyz%2Fpublication-images%2FWtDft9tbeiTQmzCmocjRo.png&w=3840&q=75" height="777" width="1561"></span></p><p>Flashbots follow a basic principle that requires a node to trust that it will receive the most profitable blocks from Flashbots. To ensure that malicious nodes do not generate malicious blocks, Flashbots has two restrictions in place.</p><ol><li>The contents of the block, such as the MEV bot's arbitrage transactions, can only be unbundled and viewed after the node verifies and confirms the block by signing. If the double signing occurs, Ethereum will slash the node. Currently, this restriction is changed and <a href="https://github.com/flashbots/mev-boost-relay/pull/330" rel="noopener noreferrer" target="_blank">fixed</a>.</li><li>Additionally, blocks submitted by nodes themselves are unlikely to reach the entire network as quickly as those submitted by Flashbots.</li></ol><p>The hacker waits for its node's turn to act as a proposer for a block while tempting these MEV bots. The hacker <a href="https://twitter.com/0xSt1ng3R/status/1642940470643900446" rel="noopener noreferrer" target="_blank">tests</a> and waits until the opportunity arises. To bypass the above two restrictions, the Hacker forms a chain of two countermeasures:</p><ol><li>The hacker <a href="https://twitter.com/terencechain/status/1642898595816013824" rel="noopener noreferrer" target="_blank">chooses to get slashed</a> since it will be slashed anyway. That's only a loss of about $2000.</li><li>By <a href="https://twitter.com/samczsun/status/1642848567781105664" rel="noopener noreferrer" target="_blank">exploiting a vulnerability in Flashbots</a>, the hacker proposes an invalid block. Therefore, Flashbots cannot submit the block to the network, and the hacker wins the contest.</li></ol><p>In the end, the hacker snoops on the MEV bot's operations and extracts a large amount of MEV revenue while others explicitly show their moves. The hacker sandwich attacks the sandwich attacker (<a href="https://twitter.com/100y_kor/status/1642902739352174592" rel="noopener noreferrer" target="_blank">great illustration by 100y_kor</a>).</p><p class="ql-align-center"><span style="color: transparent;"><img src="https://mirror.xyz/_next/image?url=https%3A%2F%2Fimages.mirror-media.xyz%2Fpublication-images%2FyoAPzc_pU0joZqtoJzOls.png&w=3840&q=75" height="791" width="1430"></span></p><h3>c) Takeaways from The Hack</h3><p>It's important to note that the Flashbots bug is the fuse of the entire hack. Without the bug, the hack wouldn't exist.</p><p>But what else causes this hack? It's because MEV is much more profitable than receiving a penalty in Ethereum (<a href="https://twitter.com/Mudit__Gupta/status/1642848745460051969" rel="noopener noreferrer" target="_blank">25,000,000 profit for 1,800 penalty? Sure, i'll take that trade</a>). Ethereum isn't really at fault here; PoS is working safely as expected, and the hacker's node was indeed slashed (even though this is <a href="https://twitter.com/ks_kulk/status/1642935358508924928" rel="noopener noreferrer" target="_blank">not effectively preventing this kind of behavior</a>).</p><p>In the next chapter, we'll delve into why Ethereum isn't facing major issues, but in oracle networks, a similar PoS mechanism can lead to extremely dangerous insecurity. Thus, the "Low Cost (of slashing in network) and High Profit (by hacking apps in network)" scenario can become problematic.</p><h2>2. Different Business Model of L1 and Oracle Networks</h2><p>The main difference is that Ethereum and oracle networks have different business models.</p><ul><li>Ethereum provides the network platform for running applications.</li><li>Oracle networks provide data-related services for supporting applications.</li></ul><p>As a neutral network and platform, Ethereum is not responsible for the applications (such as Flashbots and AMMs) that run on top of it. The protocol design only needs to ensure error-free consensus and computation, without taking these applications into account.</p><p>On the other hand, the oracle network is a service provider and is responsible for ensuring the accuracy and verifiability of its own data, as well as the applications that use it. Its protocol design and consensus are also closely tied to the application as a whole. Also, the <a href="https://beincrypto.com/venus-protocol-loses-11m-chainlink-suspension-luna-price-oracle/" rel="noopener noreferrer" target="_blank">LUNA-Venus-Chainlink exploit</a> came as a result of Chainlink turning off support for LUNA price oracle proves <a href="https://ethresear.ch/t/a-not-quite-cryptoeconomic-decentralized-oracle/6453/10" rel="noopener noreferrer" target="_blank">why oracle networks need to secure its application’s data as a service provider</a>.</p><p class="ql-align-center"><span style="color: transparent;"><img src="https://mirror.xyz/_next/image?url=https%3A%2F%2Fimages.mirror-media.xyz%2Fpublication-images%2FcA_8XbmYcxkesZv4st0NU.png&w=3840&q=75" height="1440" width="2560"></span></p><h2>3. PoS is Insecure in Oracle Networks</h2><h3>a) Ethereum is not suffering too much.</h3><p>The reason I believe there is no issue with Ethereum in the above hack is because its consensus layer is functioning properly, and the profit is being generated solely from the application layer. The incident occurred due to the following reasons:</p><ol><li>MEV bots and nodes have a profit-seeking nature (High Profit).</li><li>All of them use Flashbots.</li><li>Flashbots has bugs that partially affect Ethereum's entire system.</li><li>Malicious actors are willing to ignore slashing (Low Cost) to carry out attacks.</li></ol><p>Considering the differences in business models, it is clear that Ethereum's options are limited and can only perform minor slashing.</p><h3>b) Oracle networks are far more affected.</h3><p class="ql-align-center"><span style="color: transparent;"><img src="https://mirror.xyz/_next/image?url=https%3A%2F%2Fimages.mirror-media.xyz%2Fpublication-images%2Fz3dA06iNapwasOmgKLR6t.png&w=3840&q=75" height="1440" width="2560"></span></p><p>In an oracle network, the problem of high profit and low cost can result in a large number of attack points. If it is more profitable to hack applications that use the oracle network than it is costly to hack into the oracle network, then there will be attacks that ignore these costs.</p><ul><li>High Profit: The value of application layers in Layer 1 blockchains and the one based on oracle networks is very close. This means that high profits exist in application layers of oracle networks.</li><li>Low Cost: Staking requirements in permissionless oracle networks are usually much lower than in Ethereum. Slashing punishments are also less costly.</li></ul><p>In the oracle network example, even if the oracle networks are running as expected, if the applications that rely on them as data sources or middleware are hacked due to the services they provided, then the security of the oracle network itself is compromised. It was only a matter of time before applications based on traditional oracle networks were hacked for this reason.</p><p>In PoS of Ethereum, slashing is only related to the consensus layer, while in PoS of oracle networks, slashing is directly related to the data and service they provide to the applications based on their node's computation.</p><p>The oracle network is responsible for the data and services it provides. PoS in them only makes the network itself "secure," but does not provide the essential validity to the data and services.</p><p>Overall, oracle networks and applications based on them are more affected by PoS with:</p><ul><li>service provider business model</li><li>direct correlation of data correctness and PoS mechanisms</li><li>same high potential profit of being hacked</li><li>lower staking requirement and lower cost of being slashed</li></ul><h3>c) Replace PoS with ZK</h3><p>We are building Hyper Oracle, the programmable zkOracle network.</p><p>Current oracle networks have difficulties with creating an effective punishment mechanism (slashing) that considers out-of-network applications. Therefore, we need to replace the presumption of innocence (PoS) with the presumption of guilt (zk).</p><p>We cannot replace PoS in Layer 1 blockchains with ZK to create a new consensus algorithm due to ZK's nature of only proving computation validity. However, we can replace all the PoS in oracle networks. This would raise the security of oracle networks to the same level as that of Layer 1's.</p><p>We replace the security and incentive mechanisms of traditional oracle and middleware infrastructure from PoS (staking and slashing) to ZKP. Our trustless meta apps ensure the verifiability and security of on-chain data and off-chain computation.</p><p class="ql-align-center"><span style="color: transparent;"><img src="https://mirror.xyz/_next/image?url=https%3A%2F%2Fimages.mirror-media.xyz%2Fpublication-images%2FutyPN6QAQGCSphG8r6yIN.png&w=3840&q=75" height="1440" width="2560"></span></p><h2>4. Other Noted Issues</h2><h3>a) The Creepy Dark Forest</h3><p>MEV bots are highly advanced predators in <a href="https://arxiv.org/abs/2101.05511" rel="noopener noreferrer" target="_blank">Ethereum's dark forest</a>, but they are vulnerable to more advanced creatures.</p><p>The ethical nature of a hacker's actions cannot be easily defined as good or bad. Extracting revenue from "bad" MEV bots may be seen as a way to punish the "bad" guys, but it's important to remember that MEV bots are still users of the network and contribute to stability of on-chain asset prices and trading activity. While the hacker may be following the rules of Ethereum, they are breaking the rules of Flashbots.</p><p>The more you think about it, the scarier it gets.</p><h3>b) Centralization Caused by MEV</h3><p>MEV has contributed to centralization.</p><p>On the Ethereum network, validator staking returns are much smaller than MEV returns, which may <a href="https://arxiv.org/abs/1904.05234" rel="noopener noreferrer" target="_blank">lead to centralization</a>. Larger validators will be <a href="https://twitter.com/0xdoug/status/1643059899629223938" rel="noopener noreferrer" target="_blank">favored</a>. However, Endgame's <a href="https://barnabe.substack.com/p/pbs#%C2%A7towards-in-protocol-pbs" rel="noopener noreferrer" target="_blank">in-protocol MEV</a> design may solve these issues.</p><p>Flashbots and other services are also facing <a href="https://twitter.com/pmcgoohanCrypto/status/1642973136340623362" rel="noopener noreferrer" target="_blank">centralization issues</a>. “<a href="https://twitter.com/0xShitTrader/status/1642900882281885701" rel="noopener noreferrer" target="_blank">The MEV ecosystem today relies on non-robust social consensus and reputational staking</a>”. Although there may be new systems like <a href="https://writings.flashbots.net/the-future-of-mev-is-suave" rel="noopener noreferrer" target="_blank">SUAVE</a> in the future to help decentralize, for now, the whole MEV space is very centralized.</p><h3>c) Economic-based System is Hard to Measure</h3><p>Economic systems can be challenging to analyze due to factors such as MEV. With oracle networks, it may be difficult to determine the amount of slashing required to fully secure data and computation with PoS.</p><p>A cryptography-based zkp for oracle or rollup networks may be a better option to verify the derived data correctness from the base layer PoS blockchain network. This approach can help <a href="https://mirror.xyz/msfew.eth/gBVAvKt_G6y0ns5eA5vjZYEBgWdvPRu6KI9CujUvsek" rel="noopener noreferrer" target="_blank">simplify the system and increase trust</a>, since it is based on code rather than other factors.</p>