Rigil Testnet
SUAVE Rigil Testnet
This repository hosts the current SUAVE Rigil testnet specifications and design docs.
⚠️ 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. ⚠️
Table of Contents
- About SUAVE
- Rigil Overview
- Users
- Rigil Design Goals
- Design Decisions
- Architecture
- How To Use SUAVE?
- Example Flows
Specs
About SUAVE
SUAVE - Single Unifying Auction for Value Expression - is a platform for building MEV applications such as OFAs and block builders in a decentralized and private way. SUAVE does not replace other blockchains: it is intended to aggregate and coordinate all the things that ultimately change the state of other chains.
Read more about SUAVE:
Rigil Overview
This set of specs proposes the Rigil Testnet, a continuation of the star system theme (Centauri, Andromeda, Helios) laid out in The Future of MEV; and the first in a series of SUAVE testnets based on stars in the (Alpha) Centauri system: Rigil Kentaurus (Alpha Centauri A), Toliman (B) and Proxima Centauri (C).
The Rigil Testnet is an experimental sandbox and foundation for building MEV applications in a decentralized and private manner. Applications built atop this platform gain access to encrypted orderflow and process it using confidential computation and data storage. This empowers stakeholders to articulate the intricate facets of the MEV supply chain pertinent to their order flow as smart contracts written in solidity. Catering to a diverse set of players, from developers and users to proposers, sequencers, and block builders, this testnet facilitates the design and governance of smart contracts on the SUAVE Chain, which define these MEV application rules. Rigil's key features comprise fostering a market for mechanism designs, replicating the SGX user experience, and Proof-of-Authority consensus to allow for rapid prototyping.
The network's architecture is composed of SUAVE Computors for confidential computation, the Confidential Data Store for secure and private storage, a blockchain to store MEV application rules and transparent dissemination of public data, and the MEVM, a modified EVM that exposes confidential execution and storage APIs to deevlopers. Rigil's core objective remains clear: to ensure sensitive data remains offchain unless intentionally programmed, and directing such data efficiently across all SUAVE computors, thus optimizing bundle and block construction throughout the network.
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/Sequencers - extend another blockchain with a new block.
- Block Builders - can be implemented as smart contracts inside Suave. In the Rigil Tesnet, Suave has the capability to submit bundles to several external builders to help transaction inclusion during early stages of development.
- Auctions - L1 Transactions, EIP 712 signed messages, UserOps, the right to update an oracle, and more can be programmably auctioned and utilize privacy primitives.
- Solvers - upload solver code to the chain and plug into encrypted orderflow, or monitor the chain and submit solutions based on emitted logs.
Rigil Design Goals
- Market for Mechanisms - Enable permissionless innovation by allowing anyone to deploy mechanisms as smart contracts and allowing users of those mechanisms to choose from a market of options.
- 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 made for the Rigil testnet and associated reasoning:
- Decision 1: Proof-of-Authority Consensus
- reason: SUAVE consensus is an active open question, which whether or not answered does not drastically impact UX of users on Rigil Testnet.
- Decision 2: No SGX Nodes (yet)
- reason: SGX SUAVE computors are an active area of research and development and does not drastically impact UX of users on Rigil Testnet.
- Decision 3: Weak DA Layer Guarantees
- Reason: The Confidential Data Store currently only keeps private data available for one day. Compute Output Validity and Heterogenous DA are active open questions, which whether or not answered does not drastically impact UX on Rigil Testnet.
- Decision 4: Centralized Builder Interoperability
- reason: Blocks emitted from SUAVE computors will have unpredictable inclusion in early development so SUAVE rigil supports a precompile to send bundles to off-SUAVE block 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 data, and
- a list of programs (contracts) allowed to access and operate on confidential data.
- 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
- MEV Application : MEVM compatible Solidity which defines how orderflow should be processed and routed.
How To Use SUAVE?
Deploy confidential smart contracts. Smart contracts on SUAVE follow the same rules as on Ethereum with the added advantage of being able to access additional precompiles during confidential execution. Precompiles are available through the SUAVE library.
Request confidential execution using the new confidential computation request. Contracts called using confidential compute requests have access to confidential data and APIs through SUAVE precompiles. Confidential computation is not reproducible on-chain, thus, users are required to whitelist a specific execution node trusted to provide the result. Eventually proofs and trusted enclaves will help to verify the results of execution. After the initial confidential computation, its result replaces the calldata for on-chain execution. This grants different behaviors to confidential computation and regular on-chain transactions since confidential APIs are inaccessible during regular chain state transition.
Example Flows
The example flows in the following sections are used to illustrate some of the possibilities for MEV applications on SUAVE. We start at a high level showing how an OFA and Block Builder smart contracts work together to emit a block from a SUAVE node. To understand more deeply the Confindential Compute Request Flow is detailed and from there a deeper dive into the specifics of how the OFA and Block Builder contracts work individually.
High Level - OFA + Block Builder
Below we can see the journey of orderflow from transaction, to searcher back-run, to a block emitted from SUAVE.
- A user sends their L1 transaction, EIP-712 message, UserOp, or Intent into a SUAVE computor.
- MEVM processes this L1 transaction, extracts a hint, and emits it onchain.
- Searchers listening to the chain see the hint, craft a backrun transactions, and send them to a SUAVE computor.
- SUAVE computors will process the backrun, combine it into a bundle with the original transaction, include the bundle in a block, and then emit the block to an offchain relay.
Optionally, bundles can be sent straight to a centralized block builder, or the block can also be sent to an onchain relay instead of offchain.
Confindential Compute Request 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.
Transaction Flow:
- User sends a Confidential Compute Request to the RPC - Confidential Compute Requests are made up of two components, Compute Transaction and Confidential Inputs. The Compute request will reference data inside of the Confidential Inputs that the MEVM is able to use during computation.
- Once the RPC receives the Confidential Compute Request, it will extract the confidential inputs and send them to the confidential data store. It will then send the Compute Request to the MEVM to process.
- Confidential Compute Phase - During this phase the MEVM will process the compute transaction similar to an EVM transaction except it will also have access to the confidential inputs. After doing the initial computation with the confidential data, it will then grab the results and information from the Compute Transaction and put them into their final home a SUAVE transaction.
- Block Inclusion - Once the SUAVE transaction has been created it will then quickly be included in a block by a SUAVE proposer.
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:
- The user sends a Confidential Compute Request interacting with a SUAPP by calling it's
newBid
function. Included in this request is also the user's L1 transaction as a confidential Input. - The computor will receive the transaction and process it. To do so it first runs the offchain logic assocaited with
newBid
which will extract the transaction's data and then return a callback:
return bytes.concat(this.emitHint.selector, abi.encode(hint));
which points to another function:
function emitHint(Suave.Bid calldata bid, bytes memory hint) public {
emit HintEvent(bid.id, hint);
}
- The callback is inserted into the calldata of a SUAVE transaction and then shipped off to the SUAVE mempool.
- The transaction will get picked up, inserted in a block, and propagated.
- From here a searcher monitoring the chain and this specific OFA will see the log emitted and begin processing.
- Once the searcher has a backrun crafted for the opportunity it will send it to the Computor as a Confidential Compute Request with the backrun transaction in the confidential inputs.
- The MEVM node will receive and process the searcher's Confidential Compute Request based on the contracts logic. In this case it will:
- Grab referenced User Transaction to be placed behind
- Submit to domain specific service for simulation and validation
- Construct bundle object with two transactions
- From there, in this example, the MEVM will then forward the bundle to pre-configured off-SUAVE block builders, but could as easily also forward to onchain block builders.
The important thing to note here is that this Confidential Compute pattern makes it such that no sensitive data gets leaked onchain except for what the smart contract specifies and is thus creates progammable information leakage.
Block Building Example
Blocks built from SUAVE will be unpredictable in the beginning, but adventurers are invited to hook into the block building flow already achievable today. Below is a walkthrough of a block being built via a solidity smart contract.
- The user sends a Confidential Compute Request that specifies calling
buildBlock
on the onchain block builder contract. - The Computor receives and processes the transaction; specifically the logic will:
- grab all bundles that are stored in the block builders confidential data store
- simulate all bundles
- sort bundles via arbitrary logic but in this gas by effective gas price
- compute state root and package into a block
- Optional: Similar to the above, the confidential compute result can be a callback which will emit a log of the block's bid value onchain as well as header which a validator can view.
- Similar to sending to a centralzied block builder, the MEVM will then send the block to a centralized relay where it is free to access by validators.