Skip to content

xrplevm/evm

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Cosmos EVM - A plug-and-play solution that adds EVM compatibility and customizability to your chain

Please note: This repo is undergoing changes while the code is being audited and tested. For the time being we will be making v0.x releases. Some breaking changes might occur. While the original evmOS repo is currently being used in production on a few chains without fault, Interchain Labs will only mark the Cosmos EVM repository as stable with a v1 release after the audit, key stability features and benchmarking are completed.

Visit the official documentation for Cosmos EVM: evm.cosmos.network

What is Cosmos EVM?

Cosmos EVM is a plug-and-play solution that adds EVM compatibility and customizability to your Cosmos SDK chain.

  • Build an app-chain with the control and extensibility of the Cosmos SDK
  • With native support for EVM as VM and seamless EVM<>Cosmos wallet / token / user experience.
  • Leverage IBC with EVM, native support of ERC20 on Cosmos, and more with extensions and precompiles.

Cosmos EVM is a fork of evmOS, maintained by Interchain Labs and the Interchain Foundation after the latter funded Tharsis to open-source the original codebase.

Cosmos EVM is fully open-source under the Apache 2.0 license. With this open-sourced version, you can get:

  • Full access to Cosmos EVM's modules and updates
  • Smooth onboarding experience for an existing or new Cosmos chain
  • Full access to product partnerships (block explorers, RPCs, indexers etc.)
  • Continuous upgrades, access to product and engineering support

Want to use Cosmos EVM but want to discuss it with an expert first? Contact the Interchain Labs team.

For live discussions or support regarding advisories, join the #cosmos-tech channel in Slack. Get a Slack invite here or join the Telegram Group

Plug-in Cosmos EVM into your chain

Integration

Cosmos EVM can easily be integrated into your existing chain or added during the development of your upcoming chain launch by importing Cosmos EVM as a go module library. The Interchain Labs team provides you with integration guides and core protocol support depending on your needs and configurations. Updated documentation will be releasing soon!

Configurations

Cosmos EVM solution is engineered to provide unique flexibility, empowering you to tailor every aspect of your Ethereum Virtual Machine (EVM) environment. Whether you're launching a new blockchain or optimizing an existing one, the Cosmos EVM offers a suite of features designed to meet the unique demands of your project.

Powerful defaults

Cosmos EVM’s modules come out of the box with defaults that will get you up and running instantly.

When integrating all available modules you will get a permissionless EVM-enabled blockchain that exposes JSON-RPC endpoints for connectivity with all EVM tooling like wallets (MetaMask, Rabby, and others) or block explorers (Blockscout and others). You will have access to all of Cosmos EVM’ extensions, which enable access to chain-native functionality through Solidity smart contracts. Your chain provides a seamless use of any IBC asset in the EVM without liquidity fragmentation between wrapped and unwrapped tokens. Transaction surges are handled by the self-regulating fee market mechanism based on EIP-1559 and EIP-712 allows for structured data si gning for arbitrary messages.

Everything can be controlled by on-chain governance to create alignment between chain teams and their communities.

Extensive customizations

Based on these powerful defaults, the feature set is easily and highly customizable:

  • Permissioned/Restricted EVM

    Maintain control over your network with permissioned or restricted EVM capabilities. Implement customized access controls to either blacklist or whitelist individual addresses for calling and/or creating smart contracts on the network.

  • EVM Extensions

    Extend the capabilities of your EVM! These EVM extensions allow functionality that is native to Cosmos SDK modules to be accessible from Solidity smart contracts. We provide a selection of plug-and-play EVM extensions that are ready to be used today.

    Push the boundaries of what’s possible with fully custom EVM extensions. Develop the business logic that sets your chain apart from others with the mature tooling for the Go language and offer its functionality to the masses of Solidity smart contract developers to integrate in their dApps.

  • Single Token Representation v2 & ERC-20 Module

    Simplify token management with Single Token Representation v2 and our x/erc20 module to elevate the user experience on your chain. Align IBC coins and ERC-20s and say goodbye to fragmented liquidity. One balance. In every tool.

  • EIP-1559 Fee Market Mechanism

    Take control of transaction costs with our ready-to-use EIP-1559 fee market solution. Tailor fee structures to suit your network’s specific needs, balancing user affordability with network sustainability. Or disable it altogether.

  • JSON-RPC Server

    There is full control over the exposed namespaces and fine-grained control of the JSON-RPC server. Adjust the configuration to your liking, including custom timeouts for EVM calls or HTTP requests, maximum block gas, the number of maximum open connections, and more.

  • EIP-712 Signing

    You have the option to integrate our EIP-712 signature implementation, which allows Cosmos SDK messages to be signed with EVM wallets like MetaMask.

  • Custom Improvement Proposals (Opcodes)

    Any Cosmos EVM user is provided the opportunity to customize bits of their EVM opcodes and add new ones. Read more on custom operations here.

Forward-compatibility with Ethereum

Ethereum-equivalence describes any EVM solution, that is identical in transaction execution to the Ethereum client. It does not more, but also not less than that. Ethereum-compatible means, that the EVM can be set up to run every transaction that is valid on Ethereum, while the handling of the transactions can diverge in e.g. result or cost.

We like to coin the term forward-compatible as a description of our EVM solution, meaning that any Cosmos EVM chain can run any valid smart contract from Ethereum but can also implement new features that are not (yet) available on the standard Ethereum VM, thus moving the standard forward.

Getting started

To run the example evmd chain, run the script using ./local_node.sh from the root folder of the repository.

Migrations

We provide upgrade guides here for upgrading your chain from various Cosmos EVM versions.

Testing

All test scripts are found in Makefile in the root of the repository. Listed below are the commands for various tests:

Unit Testing

make test-unit

Coverage Test

This generates a code coverage file filtered_coverage.txt and prints out the covered code percentage for the working files.

make test-unit-cover

Fuzz Testing

make test-fuzz

Solidity Tests

make test-solidity

Benchmark Tests

make benchmark

Contributing

We welcome open source contributions and discussions! For more on contributing, read our guide.

Open-source License & Credits

Cosmos EVM is open-source under the Apache 2.0 license, an extension of the license of the original codebase (https://github.com/evmos/OS) created by Tharsis and the evmOS team - who conducted the foundational work for EVM compatibility and interoperability in Cosmos.

About

An EVM compatible framework for blockchain development with the Cosmos SDK

Resources

License

Contributing

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 90.7%
  • Solidity 4.8%
  • JavaScript 2.4%
  • Shell 1.5%
  • Python 0.3%
  • Makefile 0.3%