We welcome contributions from anyone on the internet, and are grateful for even a one-word correction! Note that we have a code of conduct, please follow it in all your interactions with the project.
Before you start, you should become familiar with pulling the code down locally, building the code, and running the tests. If you want more information you can visit our install guide, or how to run tests.
Thanks in advance for your help.
At the heart of the community contribution system is our verified issues list, and the idea of "verified" issues. These issues will have a green verified
tag in Github, which indicates that the issue has been reviewed and confirmed by an IF core team member as an approved change for the product.
All pull requests must reference a verified issue to be merged into the codebase. If the issue the PR solves does not link to a verified issue (or any issue at all), you must create that issue and get it verified before the PR can be reviewed.
Verification review of new issues will happen multiple times per week, so new issues will be tagged generally within 3 business days.
Pull requests are the best way to propose a new change to the codebase.
- Fork the repo
- Create a branch from
staging
- Find or create one or more issues that your change will fix, using our new issue form.
- ALL pull requests must refence a verified issue. If the issue is not verified, that has to happen before the PR is reviewed.
- Note that team members looking at a PR will try to verify any issues referenced before doing the review. As long as the issue is solid, this should be a fast process!
- Open a pull request against
staging
Once the PR is created, one of the maintainers will review it and merge it. Reference any bugs you're fixing with single lines of the form Fix #123
- We aim to review any PR submitted within 5 business days. This SLA includes verifying any issues associated with the PR.
NOTE: Read You should open a Feature Request if if you are thinking of working on a change in functionality.
Please read our README.md first, to learn how to set up Iron Fish.
If you don't know what contribution you can work on, here are a few suggestions:
- Start with our list of "good first issues", which can be found here, or take a look at our current list of verified issues.
- Claim the issue if you are interested in working on it.
- Take a look at our current pull requests and help review them.
- Help us add new tests. More testing allows everyone to ship quality code faster.
- Write documentation or fix the existing documentation
- If you still don't know what could be a good task for you, do not hesitate to contact us.
The purpose of a Feature Request is to explain an improvement you would like to make to Iron Fish, and get consensus from the core development team of Iron Fish. The reason is that we want to make sure your change fits inside of the product vision, and that you don't try to fix a bug in a piece of code already being refactored.
You can submit a Feature Request by filing an issue here: https://github.com/iron-fish/ironfish/issues/new/choose
If you are working on something in one of these categories, we will not accept your PR if you don't open a Feature Request.
-
- This is a common attack vector by malicious agents. We lock down our packages for this very reason, and only allow the core team to upgrade packages unless you submit a Feature Request first explaining why you want to upgrade the package.
-
- There is a large impact in upgrading node versions. Iron Fish takes advantage of many experimental node features, some of which are not fully fleshed out. We use workers and native code boundaries. Node is also known to introduce bugs in newer versions, even LTS. Because of this, there is production testing we do on our side when upgrading node to ensure it's compatible. Because of this, we don't allow users to upgrade our node versions unless a Feature Request is filed.
-
- Often engineers have visions for core systems, and may be in the process of changing them. Feature Requests help avoid overlap and having your changes overwritten. Some core systems include: MerkleTree, Blockchain, PeerNetwork, Verifier, and Consensus.
-
- This one is more complicated. If our product works one way, and you open a PR to change the core product principles to work in another way, then we are going to close your PR as it does not fit into our vision. Try to match existing precedent as much as possible in your code.
-
- They are not useful in their current form. Most of these tests are mocking out the entire node and sending back handcrafted values which are merely asserted and make changes to these commands more annoying. We are accepting a Feature Request for refactoring command tests to be more valuable and not use mocking.
In case of problems with trying to contribute to Iron Fish, you can contact us:
- On Github Discussions
- On Discord
- Via email