Skip to content

Latest commit

 

History

History
256 lines (180 loc) · 12.5 KB

README.md

File metadata and controls

256 lines (180 loc) · 12.5 KB

SYNOPSIS

Build Status Coverage Status JavaScript Style Guide Gitter

This is the work repository for the EthereumJS main chain client implementation project. This is a community project. See Development Stages for idea about the current project status, issues for open issues and a project layout and read through Community Project if you want to join.

See Technical Guidelines if you directly want to dive into development info.

Current development stage: CONCEPT ANALYSIS / EARLY DEVELOPMENT

MAIN FOKUS

Main goal of this project is to develop an Ethereum main net light client as well as a full client with fast-sync support.

The light client shall be developed towards a stage where it is production-ready and security-audited and therefor fully usable on the main net. It is intended for the mid-term future that the light client can also be used in a browser context. This can be thought along on a sideline though, during development it is sufficient to stay in a Node.js context.

There are some uncertainties around the intended development stage of the full client regarding performance and questions how to deal with the lack of (historical) fork-rule support of the underlying VM implementation. Full client support shall therefor be brought to an EXPERIMENTAL stage where it is possible to sync the main chain up to a post-Byzantium state and then process transactions and store the results. This will already be valuable for experimentation and testing purposes. Where and if to proceed from there will be decided in a later stage.

It is very probable that the Constantinople hardfork (EIP) will happen alongside the development of this library. Also Casper, the (hybrid) PoS switch (EIP) of the Ethereum network is more-or-less specified out and will come as a separete hardfork. Compatibility with these two HFs should be though along library development to be future-ready, parts of this will take place independently in other libraries (e.g. the VM) though.

SIDE FOKUS

ethereumjs-client will be classical main chain implementation - py-EVM is maybe the most appropriate project to compare with here - and there won't be too much room for additional experimentation or further-going feature requests at least during the first development period.

There are two noteworthy exceptions from this base line:

libp2p: There has been a lot of expressed interest in libp2p support for client communications in the past by various parts of the community. If there is enough capacity this can be investigated on a side track during client development and implemented in a modular way as an alternative to the classic devp2p networking communication.

sharding: It is possible to implement aspects of sharding specification along the way. Be aware though that this is still subject to heavy change and should also be added in ways not hindering the main net client development. This is also limited to the main chain parts of sharding, so e.g. developing a stateless client will be another separate project (where there is definitely a need for, so if you want to go more into research, pick up on this one! :-)).

DEVELOPMENT STAGES

The project will go through the following development stages:

CONCEPTION

This is the project start and will mainly be done by the initiator of the project (HolgerD77). During this period the various tasks will be worked out in the form of issues down to a granularity-level where they are implementable by various independent contributors. A project plan will be layed out grouping the tasks and showing work dependencies and giving an overall impression what has to be done to successfully finish the project. There will be also an informal description (this document :-)) of the organizational parts of the project.

Goals: A task list and project plan for discussion

Duration: 3-4 weeks

How to contribute: This is not yet the time for contributing. Please be patient for another week or two until we have something to discuss.

CONCEPT ANALYSIS / EARLY DEVELOPMENT

This is the time to discuss the way the project is conceptualized and the way the project plan is layed out. Feel free to join! It will be especially valuable if you deep-dive into the various issues and have a look at questions like:

  • Is this way to implement stuff realistic/can it be working?
  • Is the new module well-placed within the overall structural architecture?
  • Does the scope of module responsibilities make sense?
  • Is there already some library which does this work, are the external libs/devs proposed adequate?
  • ...

At the end we will hopefully have a work plan everyone is happy with and which serves as a solid basis for implementation.

You can also carefully start development on some commonly agreed stuff. Put some extra emphasis on communication though and announce and eventually discuss your work, so that we don't pre-early lay path we later may have to revert.

Goals: A task list and project plan for implementation / some first development progress

Duration: 4-5 weeks

How to contribute: YEAH, YEAH, contribute now!! :-) Feel free to join the discussion or do some early development.

IN DEVELOPMENT

Oh my, now there really is some work to be done. The main scope of work tasks and the directions where to head should be worked out now. Feel free to grab an issue you want to work on. Many issues will be (hopefully :-)) in a dependency-order-line, so start with issues which doesn't depend on other unfinished issues.

If you have chosen your issue please drop a note on the issue page that you will start working on the issue. If you plan to do your implementation in another way as described in the issue please present your idea there first so there won't be any conflicts/unnecessary discussions later on merging.

Goals:: All aspects/components of both the light and the full client implementation should be in a workable state. A MVP (Minimum Viable Product) containing all the functionality in a working state should be released.

Duration: 4-6+ months

How to contribute: Grab yourself an issue and start hacking (after reading the above :-))

PRE-ALPHA

Oh my oh my. This is still a bit far away. But we should finally come to a point where we can actually release some stuff.

Duration: 2-3+ months

Further release stages to be determined.

COMMUNITY PROJECT

Since capacity of current EthereumJS developers is limited and we cannot understand all the needs from the community this project will generally be conceptualized as a community project and we hope from contributions from various sides and heterogenuous backgrounds. This will generally a really exciting project to work on. There will be an ongoing project management and coordination provided by HolgerD77 who is working for the foundation as a Javascript developer and has been deep insights of the JS implementations of the VM, the networking communication layer and most of the other parts.

If you are an organization or a company being a part of the Ethereum ecosystem, consider giving interested developers some free time to work on this. If you are a developer ask your company or org if they want support you with contributing. You are of course also very welcome as a single/independent developer!

This is an inclusive project and everyone is invited to join regardless of gender, race, religion, philosophy, ethnic origin, age, physical ability or sexual orientation.

TEAM STRUCTURE

There are two stages of team-coupling :-) which come with different permissions on GitHub:

Contributor: You can always contribute to the project. Just do a PR from your own fork with the added commits containing your work.

Team Member: After you have proven that you more-or-less know what you are doing :-), can communicate about your stuff and have done some meaningful contributions you can become a member of the team with full repository read/write access. There also needs to be some consensus from the current team members on when/how the team is expanded. It is expected from team members that they commit to the project for some reasonable amount of time (2+ months).

TECHNICAL GUIDELINES

Client Setup

Running the Client

Some building blocks for the client have already been implemented or outlined to further build upon.

You can run the current state of the client with:

node lib/index.js --networkid=1 [--loglevel=debug]

Or show the help with

node lib/index.js help

If you want to have verbose logging output for the p2p communication you can use...

DEBUG=*,-babel [CLIENT_START_COMMAND]

for all output or something more targeted by listing the loggers like

DEBUG=devp2p:rlpx,devp2p:eth,-babel [CLIENT_START_COMMAND]

Environment / Ecosystem

EthereumJS Ecosystem

This project will be embedded in the EthereumJS ecosystem and many submodules already exist and can be used within the project, have a look e.g. at ethereumjs-block, ethereumjs-vm, the merkle-patricia-tree or the ethereumjs-devp2p implementation.

To play well together within a client context, many sub module libraries need enhancements, e.g. to create a common logging context. There are also larger building blocks still missing, e.g. the Node Discovery V5 p2p implementation being necessary for a proper working light client sync. Due to the distributed nature of EthereumJS there will be internal (to be done in this repo) and external issues (to be done in other EthereumJS repos) to be worked on.

All (hopefully :-)) issues referring to the client implementation will be provided with a ethereumjs-client label which should be discoverable with a label search on GitHub:

Basic Environment

For library development the following basic environment is targeted. Some base requirements like the testing tool arise from the need of maintaining a somewhat unified EthereumJS environment where developers can switch between with some ease without the need to learn (too much) new tooling.

Contribution Guidelines

Communication This is distributed team effort. If you plan to take on larger issues always pre-announce your work intention on the issue page and drop a short note on what you are planning to do. If there is no issue for the stuff you want to work on create one and describe the problem and outline the intended implementation before start working.

Branch Structure

Development will take place via feature branches being merged against a protected master branch. Always develop on branch also when being on your own fork, use meaningful branch names like new-debug-cl-option or fixed-this-really-annoying-bug.

Testing

No meaningful new PR will be accepted without associated tests (exceptions might be done on a case-by-case basis). Test coverage should not increase (significantly) by a new PR. You might also want to consider writing your tests first and then directly push them, since this would be a good starting point for discussing the scope/implementation of a feature.