Laconic state machine
Go to file
2018-07-13 13:37:32 -07:00
.github Add ISSUE_TEMPLATES 2018-07-12 13:53:09 -07:00
core Fix import paths (replace ledgerwatch with cosmos) 2018-07-09 14:25:00 -04:00
state Fix import paths (replace ledgerwatch with cosmos) 2018-07-09 14:25:00 -04:00
.gitignore Add makefile modified from cosmos/cosmos-sdk 2018-07-10 17:12:30 -07:00
blockchain Fixed BLOCKHASH opcode and added blockchain file for smoke testing 2018-07-05 22:01:52 +01:00
CONTRIBUTING.md Fix unstable mention 2018-07-10 12:00:21 -07:00
copied.go [WIP] structure/dep refactor 2018-07-04 19:38:20 -04:00
Dockerfile Add Dockerfile 2018-07-12 16:22:19 -07:00
Gopkg.lock Address PR comments and add clean makefile target 2018-07-11 09:15:39 -07:00
Gopkg.toml Lock in versions of dependencies 2018-07-09 14:24:19 -04:00
LICENSE Initial commit 2018-06-10 14:25:18 +01:00
main.go Timing 2018-07-10 10:17:56 +01:00
Makefile Add Dockerfile 2018-07-12 16:22:19 -07:00
README.md Address PR comment 2018-07-13 12:47:48 -07:00

Go Report Card

Ethermint

WARNING: Ethermint is under VERY ACTIVE DEVELOPMENT and should be treated as pre-alpha software. This means it is not meant to be run in production, its APIs are subject to change without warning and should not be relied upon, and it should not be used to hold any value. We will remove this warning when we have a release that is stable, secure, and properly tested.

What is it?

ethermint will be an implementation of the EVM that runs on top of tendermint consensus, a Proof of Stake system. This project has as its primary goals:

  • Hard Spoon enablement: This is the ability to take a token from the Ethereum mainnet and "spoon" (shift) the balances over to another network. This feature is intended to make it easy for applications that require more transactions than the Ethereum main chain can provide to move their code over to a compatible chain with much more capacity.
  • Web3 Compatibility: In order enable applications to be moved over to an ethermint chain existing tooling (i.e. web3 compatable clients) need to be able to interact with ethermint.

Implementation Steps

  • Have a working implementation that can parse and validate the existing ETH Chain and persist it in a Tendermint store
  • Benchmark this implementation to ensure performance
  • Allow the Ethermint EVM to interact with other Cosmos SDK modules
  • Implement the Web3 APIs as a Cosmos Light Client for Ethermint
  • Ethermint is a full Cosmos SDK application and can be deployed as it's own zone

Building Ethermint

To build, execute the following commands:

# To build the binary and put the results in ./build
$ make get-tools get-vendor-deps build

# To build the project and install it in $GOBIN
$ make get-tools get-vendor-deps install

Community

The following chat channels and forums are a great spot to ask questions about Ethermint: