PoC illustrating usage of the Fortanix SGX platform for executing an EVM message confidentially without leaking any compute or access information.
- User manually provisions an SGX server, e.g. on Azure
- SGX-enabled server opens up a TCP Socket with TLS Enabled (assumes some kind of Certificate is already generated, see first line in main.rs - ideally there's a productionized way to do Certificate provisioning).
- User submits a TLS-encrypted payload to the server, ensuring the user and the server only have access to the information being delivered (the server actually doesn't because the socket is opened within the SGX enclave).
- The Server proceeds to parse the payload into an EVM message and execute it confidentially.
The EVM database is expected to be instantiated as empty, and the user is expected to provide a payload which contains all the storage slots & values required by their transaction, including Merkle Patricia Proofs for proving that these transactions are part of the actual state. It assumes that there is also a state root available to check against.
- Make the demo unit-testable for CI usage
- Enable TLS payload decryption on the server (currently we just submit plaintext payloads to make prototype testing with netcat easier)
- Extend the user-submitted payload to multiple transactions including merkle patricia proof verification for each access. This is kind of like a stateless node / light-client.
- Remote Attestation
On an SGX-supported machine (e.g. on Azure), you'll need to install the Fortanix SDK. Providing a quick-start below:
# From: https://edp.fortanix.com/docs/installation/guide/
# Install Rust
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
# Install Nightly -- required for SGX below
rustup toolchain install nightly
# Add SGX the platform
rustup target add x86_64-fortanix-unknown-sgx --toolchain nightly
# Missing some things..
sudo apt-get install -y pkg-config libssl-dev protobuf-compiler cmake clang
# Install the CLI tools
cargo install fortanix-sgx-tools sgxs-tools
# Override the default cargo runner with the SGX one
echo >> ~/.cargo/config -e '[target.x86_64-fortanix-unknown-sgx]\nrunner = "ftxsgx-runner-cargo"'
# Install DKMS & the SGX Service
echo "deb https://download.fortanix.com/linux/apt xenial main" | sudo tee -a /etc/apt/sources.list.d/fortanix.list >/dev/null
echo "deb https://download.01.org/intel-sgx/sgx_repo/ubuntu $(lsb_release -cs) main" | sudo tee -a /etc/apt/sources.list.d/intel-sgx.list >/dev/null
curl -sSL "https://download.01.org/intel-sgx/sgx_repo/ubuntu/intel-sgx-deb.key" | sudo -E apt-key add -
curl -sSL "https://download.fortanix.com/linux/apt/fortanix.gpg" | sudo -E apt-key add -
sudo apt-get update
sudo apt-get install intel-sgx-dkms sgx-aesm-service libsgx-aesm-launch-plugin
# Check your SGX setup, all should be green except the `libsgx_enclave_common` maybe.
sgx-detect
On a terminal run:
cargo run --release --target x86_64-fortanix-unknown-sgx
On another terminal:
nc localhost 7878
{ "sender": "0xdafea492d9c6733ae3d56b7ed1adb60692c98bc5", "amount": 40 }
Then CTRL+C to close the netcat session, and you'll see on the first terminal that the simulation has completed, without the host ever knowing what happened!