-
Notifications
You must be signed in to change notification settings - Fork 2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #84 from Chia-Network/alpha-1.3
Alpha 1.3 FullNode performance improvements - Syncing up to the blockchain by importing all blocks is faster due to improvements in VDF verification speed and multithreading block verification. Also fixed a bug where the node may not sync if it restarts close to a tip. VDF improvements - VDF verification and generation speed has increased and dependence on flint2 has been removed. We wish to thank Dr. William Hart (@wbhart) for dual licensing parts of his contributions in [FLINT](http://www.flintlib.org/) and [Antic](https://github.com/wbhart/antic) for inclusion in the Chia blockchain. Implemented an RPC interface with JSON serialization for streamables - currently on port 8555 - and moved the ssh UI to use RPC. Mongodb deprecated. Moved to [SQLite](https://www.sqlite.org/) for the blockchain database. This will require nodes to re-sync with the network. Luckily this is now faster. Changed the displayed process names for harvester, farmer, fullnode, timelords, and VDFs to to chia_full node, chia_harvester, etc. Fixed a bug that could cause inadvertent shutdown of other processes like an ongoing plotting session when new chia services were started. Added details on how to contribute in CONTRIBUTING.md. Thanks @RichardLitt. Also moved documentation from inside the repository to the [wiki](https://github.com/Chia-Network/chia-blockchain/wiki). Added color logging and now chia_harvester will periodically announce which plots it is currently farming and their k sizes. Fixed a typo in the UI. Hat tip to @lvcivs for the pr. Clarified the minimum version of boost required to build timelord/VDFs. Hat tip @AdrianScott Lots of smaller bug and documentation fixes.
- Loading branch information
Showing
632 changed files
with
46,810 additions
and
52,418 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
## Introduction | ||
Welcome to the chia-blockchain project! | ||
We are happy that you are taking a look at the code for Chia, a proof of space and time cryptocurrency. | ||
|
||
A lot of fascinating new cryptography and blockchain concepts are used and implemented here. | ||
This repo includes the code for the Chia full node, farmer, and timelord (in src), which are all written in python. | ||
It also includes a verifiable delay function implementation under lib/chiavdf (in c/c++), and a proof of space implementation under lib/chiapos. | ||
|
||
If you want to learn more about this project, read the [wiki](https://github.com/Chia-Network/chia-blockchain/wiki), or check out the [green paper](https://www.chia.net/assets/ChiaGreenPaper.pdf). | ||
|
||
### Contributions | ||
We would be pleased to accept code contributions to this project. | ||
As we are in the alpha stage, the main priority is getting a robust blockchain up and running, with as many of the mainnet features as possible. | ||
You can visit our [Trello project board](https://trello.com/b/ZuNx7sET) to get a sense of what is in the backlog. | ||
Generally things to the left are in progess or done. Some things go through "Coming up soon" but some will come directly out of other columns. | ||
Usually the things closer to the top of each column are the ones that will be worked on soonest. | ||
If you are interested in cryptography, math, or just like hacking in python, there are many interesting problems to work on. | ||
Contact any of the team members on keybase: https://keybase.io/team/chia_network.public, which we use as the main communication method and you can comment on any Trello card. | ||
|
||
### Run tests and linting | ||
The first time the tests are run, BlockTools will create and persist many plots. These are used for creating | ||
proofs of space during testing. The next time tests are run, this won't be necessary. | ||
|
||
```bash | ||
black src tests && flake8 src && mypy src tests | ||
py.test tests -s -v | ||
``` | ||
Black is used as an automatic style formatter to make things easier, and flake8 helps ensure consistent style. | ||
Mypy is very useful for ensuring objects are of the correct type, so try to always add the type of the return value, and the type of local variables. | ||
|
||
### Configure VS code | ||
1. Install Python extension | ||
2. Set the environment to ./.venv/bin/python | ||
3. Install mypy plugin | ||
4. Preferences > Settings > Python > Linting > flake8 enabled | ||
5. Preferences > Settings > Python > Linting > mypy enabled | ||
7. Preferences > Settings > Formatting > Python > Provider > black | ||
6. Preferences > Settings > mypy > Targets: set to ./src and ./tests | ||
|
||
### Submit changes | ||
To submit changes, please make a pull request to the appropriate development branch. | ||
For example, after the 1.2 release, the 1.3 branch is used for development, etc. | ||
The master branch is updated with the latest releases only. | ||
|
||
### Copyright | ||
By contributing to this repository, you agree to license your work under the Apache License Version 2.0, or the MIT License, or release your work to the public domain. Any work contributed where you are not the original author must contain its license header with the original author(s) and be in the public domain, or licensed under the Apache License Version 2.0 or the MIT License. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.