This page contains an introductory overview of the Enigma protocol and this Docker testnet release aimed at experienced dApp developers. More thorough and indepth information can be found in the various architecture, topology and cryptography related pages in the documentation index.
How Enigma Works¶
The Enigma network provides a permissionless peer-to-peer network that facilitates the execution of code (secret contracts) with strong correctness and privacy guarantees, similar to smart-contract platforms such as Ethereum - the key difference in Enigma is that the data itself is concealed from the nodes that execute computations. This allows developers to include sensitive data in their smart contracts without moving off-chain to centralized (and less secure) systems, thus allowing for truly private and scalable decentralized applications.
Secret contracts are executed in a retrofitted EVM (Ethereum Virtual Machine) running inside a Trusted Execution Environment (TEE), based on Intel’s SGX technology. This supports out-of-the-box interoperability with the Ethereum network as well as Solidity.
The Enigma Network offloads private computation tasks initiated by end-users of Ethereum dApps. These tasks are then handled by the Enigma-JS client library, which encrypts sensitive data in memory for immediate use.
The Enigma Contract deployed on-chain broadcasts the task in the Enigma Network and performs a random sampling lottery to determine which node should execute it. The selected worker then instructs its trusted hardware to unpack the task, decrypt its arguments and delegate execution to its internal EVM.
The Enigma Testnet - What’s Inside?¶
This initial testnet release is a highly simplified containerized Docker release which includes every core component of a functional Enigma Network, down to the nodes and the blockchain itself. By using this release in combination with the examples provided in this documentation, dApp developers will be able to have some hands-on experience with the code, learn how to deploy secret contracts / dApps as well as gain a thorough understanding of how the various components of Enigma’s functionality interconnect.
For a visual of the Enigma Docker Network topology, see this page.