Technical Architecture
DEP is a scalable Proof-of-Stake blockchain that is fully compatible and interoperable with the Ethereum Virtual Machine (EVM). It is built using the Cosmos SDK which runs on top of the CometBFT (a fork of Tendermint Core) consensus engine, to accomplish fast finality, high transaction throughput and short block times (~2 seconds).
This architecture allows users to perform both Cosmos and EVM formatted transactions, developers to scale EVM dApps cross-chain via IBC, and tokens and assets in the network to come from different independent sources.
DEP enables these key features by:
- Leveraging modules and other mechanisms implemented by the Cosmos SDK.
- Implementing CometBFT's Application Blockchain Interface (ABCI) to manage the blockchain.
- Utilizing
geth
as a library to promote code reuse and improve maintainability. - Exposing a fully compatible Web3 JSON-RPC layer for interacting with existing Ethereum clients and tooling (Metamask, Remix, Truffle, etc).
The sum of these features allows developers to leverage existing Ethereum ecosystem tooling and software to seamlessly deploy smart contracts which interact with the rest of the Cosmos ecosystem.
Cosmos SDK
DEP enables the full composability and modularity of the Cosmos SDK. As a Cosmos chain, DEP is a sovereign blockchain with its own native token, that can connect to other chains through IBC. It includes standard modules from the Cosmos SDK, that work side to side with DEP-specific modules, built by the DEP core development team. Check out the list of modules to get an overview of what each module is responsible for.
CometBFT & ABCI
CometBFT consists of two chief technical components: a blockchain consensus engine and a generic application interface. The consensus engine ensures that the same transactions are recorded on every machine in the same order. The application interface, called the Application Blockchain Interface (ABCI), enables the transactions to be processed in any programming language.
CometBFT has evolved to be a general-purpose blockchain consensus engine that can host arbitrary application states. Since it can replicate arbitrary applications, it can be used as a plug-and-play replacement for the consensus engines of other blockchains. DEP is an example of an ABCI application replacing Ethereum's PoW via CometBFT's consensus engine.
Another example of a cryptocurrency application built on CometBFT is the Cosmos network. CometBFT can decompose the blockchain design by offering a very simple API (ie. the ABCI) between the application process and consensus process.
EVM Compatibility
DEP enables EVM compatibility by implementing various components that together support all the EVM state transitions while ensuring the same developer experience as Ethereum:
- Ethereum's transaction format as a Cosmos SDK
Tx
andMsg
interface - Ethereum's
secp256k1
curve for the Cosmos Keyring StateDB
interface for state updates and queries- JSON-RPC client for interacting with the EVM
Most components are implemented in the EVM module To achieve a seamless developer UX, however, some of the components are implemented outside of the module.
If you want to learn more about how DEP achieves EVM compatibility as a Cosmos chain, we recommend understanding the following concepts:
Contributing
There are several ways to contribute to the DEP core protocol. To get some hands-on experience, we recommend you spin up a local DEP node using the DEP CLI and interact with it through queries and transactions using the supported clients.
Then if you're hooked you can
- Contribute open-source to issues on GitHub using the DEP Contributor Guideline
- Apply to open positions at DEP
- Search for bugs and earn a bounty