SUAVE Rigil Testnet
⚠️ The SUAVE protocol is still in a state where the code is the most up-to-date protocol spec. The goal of these notes is to gradually evolve into an implementation agnostic specification. ⚠️
Specs
About Suave
SUAVE is a platform for building MEV applications such as OFAs and block builders in a decentralized and private way. SUAVE is looking to create a new paradigm for computation, where computation can be private and run at the speed of block building.
🥅 Design Goals
- Market for Mechanisms - create a robust environment which offers basic programmable privacy and useful MEV precompiles.
- Permissionless SUApp Deployment & Interaction - Enable permissionless innovation by allowing anyone to deploy and interact with contracts.
- SGX UX Closeness - Get as close to SGX user experience as possible and minimize breaking changes down the road.
🔒 Design Decisions
Here is a list of design decisions and tradeoffs:
- Decision 1: Weak DA Layer Guarantees
- Reason: Compute Output Validity and Heterogenous DA is an active open question, which whether or not answered does not drastically impact UX on Rigil Testnet.
- Decision 2: Proposer Centralization
- Reason: SUAVE consensus is an active open question, which whether or not answered does not drastically impact UX on Rigil Testnet.
- Decision 3: No SGX Nodes (yet)
- Reason: Research continues on the best wa to implement this, which will be detailed in a later spec.
Overview
Users
The Rigil testnet is initially focused on a specific set of actors:
- Developers - create smart contracts on SUAVE Chain that define rules for MEV applications like orderflow auctions and block building. Smart contracts deployed by developers can call special precompiles to request confidential computation.
- Users - send requests/transactions to SUAVE. Such transaction can include confidential data.
- Proposers/Sequencer - extend another blockchain with a new block.
- Builders - can be implemented as smart contracts inside Suave. In the Rigil Tesnet, Suave submits bundles to several external builders.
Architecture
SUAVE Computors house all components necessary to perform confidential compute and are the main protocol actor in the SUAVE protocol. Below is a high level architectural overview followed by a brief descriptions of the main components.
- Confidential Compute Request (CCR) [🔗spec]: A user request to Suave that contains:
- a wrapped transaction
- confidential inputs, and
- a list of programs (contracts) (← list of Exec nodes) allowed to operate on confidential inputs.
- Computor[🔗spec]: accepts and processes confidential compute requests and maintains the SUAVE chain; the logical unit of the SUAVE network and main protocol actor.
- Confidential Data Store (CDS) [🔗spec]: stores confidential data from MEV applications (L1 transactions, EIP 712 signed messages, userOps, privateKeys(?), etc).
- SUAVE Chain [🔗spec]: a fork of Ethereum designed for usage alongside credible off-chain execution in MEV use cases. Running Clique PoA consensus for the Rigil Testnet.
- MEVM [🔗spec]: modified EVM with MEV-specific precompiles that allow developers to define orderflow auctions and builder rules as smart contracts written in Solidity.
- Precompiles [🔗spec]: purpose-built functions with extended capabilities that can be called from Builder Solidity
Transaction-flow
The SUAVE-enabled node and the MEVM support multiple new data types, which are all specified in the SUAVE Chain spec.
The diagram below showcases how these different types interact to enable confidential computation on SUAVE computors.
Conceptually, transactions on SUAVE can be split into three steps:
- User -> RPC
- RPC -> MEVM
- MEVM -> Confidential compute result to SUAVE Chain
OFA Example
If we consider a specific use case, like an order flow auction, the high-level series of steps taken to complete the auction can represented as below:
Conceptually, such auction mechanisms can be split into seven steps:
- User -> RPC
- RPC -> MEVM
- MEVM -> Confidential compute result to SUAVE Chain
- Searcher, listening to events on SUAVE -> RPC
- RPC -> MEVM
- MEVM -> internal simulation (based on contract logic)
- MEVM -> send bundle to builder via precompile