Lighthouse is an open-source Ethereum consensus client. We're community driven and welcome all contribution. We aim to provide a constructive, respectful and fun environment for collaboration.
We are active contributors to the Ethereum Proof-of-Stake Consensus specification and attend all Ethereum implementers calls.
This guide is geared towards beginners. If you're an open-source veteran feel free to just skim this document and get straight into crushing issues.
There are many reasons you might contribute to Lighthouse. For example, you may wish to:
- contribute to the Ethereum ecosystem.
- establish yourself as a layer-1 Ethereum developer.
- work in the amazing Rust programming language.
- learn how to participate in open-source projects.
- expand your software development skills.
- flex your skills in a public forum to expand your career opportunities (or simply for the fun of it).
- grow your network by working with core Ethereum developers.
Regardless of the reason, the process to begin contributing is very much the same. We operate like a typical open-source project operating on GitHub: the repository Issues is where we track what needs to be done and Pull Requests is where code gets reviewed. We use discord to chat informally.
We recommend the following work-flow for contributors:
- Find an issue to work on, either because it's interesting or suitable to your skill-set. Use comments to communicate your intentions and ask questions.
- Work in a feature branch of your personal fork (github.com/YOUR_NAME/lighthouse) of the main repository (github.com/sigp/lighthouse).
- Once you feel you have addressed the issue, create a pull-request with
unstable
as the base branch to merge your changes into the main repository. - Wait for the repository maintainers to review your changes to ensure the issue is addressed satisfactorily. Optionally, mention your PR on discord.
- If the issue is addressed the repository maintainers will merge your pull-request and you'll be an official contributor!
Generally, you find an issue you'd like to work on and announce your intentions to start work in a comment on the issue. Then, do your work on a separate branch (a "feature branch") in your own fork of the main repository. Once you're happy and you think the issue has been addressed, create a pull request into the main repository.
First time contributors can get their git environment up and running with these steps:
- Create a fork and clone it to your local machine.
- Add an "upstream"
branch
that tracks github.com/sigp/lighthouse using
$ git remote add upstream https://github.com/sigp/lighthouse.git
( pro-tip: use SSH instead of HTTPS). - Create a new feature branch with
$ git checkout -b your_feature_name
. The name of your branch isn't critical but it should be short and instructive. E.g., if you're fixing a bug with serialization, you could name your branchfix_serialization_bug
. - Make sure you sign your commits. See relevant doc.
- Commit your changes and push them to your fork with
$ git push origin your_feature_name
. - Go to your fork on github.com and use the web interface to create a pull request into the sigp/lighthouse repo.
From there, the repository maintainers will review the PR and either accept it or provide some constructive feedback.
There's a great guide by Rob Allen that provides much more detail on each of these steps, if you're having trouble. As always, jump on discord if you get stuck.
Additionally, the "Contributing to Lighthouse" section of the Lighthouse Book provides more details on the setup.
There's lots to be done and there's all sorts of tasks. You can do anything from enhancing documentation through to writing core consensus code. If you reach out, we'll include you.
Please note, to maintain project quality, we may not accept PRs for small typos or changes with minimal impact.
We're open to developers of all levels. If you create a PR and your code doesn't meet our standards, we'll help you fix it and we'll share the reasoning with you. Contributing to open-source is a great way to learn.
No problems, there's plenty of tasks that don't require extensive Ethereum knowledge. You can learn about Ethereum as you go.
Don't be. We're all about personal development and constructive feedback. If you make a mistake and learn from it, everyone wins.
Please, make an issue and explain why. We're open to constructive criticism and will happily change our ways.