The core protocol of WoopChain
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
woop/README.md

112 lines
3.1 KiB

6 years ago
# Harmony
[![Build Status](https://travis-ci.com/harmony-one/harmony.svg?token=DnoYvYiTAk7pqTo9XsTi&branch=master)](https://travis-ci.com/harmony-one/harmony)
<a href='https://github.com/jpoles1/gopherbadger' target='_blank'>![gopherbadger-tag-do-not-edit](https://img.shields.io/badge/Go%20Coverage-45%25-brightgreen.svg?longCache=true&style=flat)</a>
6 years ago
<a href="https://discord.gg/kdf8a6T">![Discord](https://img.shields.io/discord/532383335348043777.svg)</a>
6 years ago
7 years ago
## Dev Environment Setup
```bash
export GOPATH=$HOME/<path_of_your_choice>
6 years ago
mkdir -p $HOME/<path_of_your_choice>/src/github.com/harmony-one
6 years ago
cd $HOME/<path_of_your_choice>/src/github.com/harmony-one
git clone git@github.com:harmony-one/harmony.git
6 years ago
cd harmony
6 years ago
go get ./...
git submodule update --init --recursive
```
6 years ago
## Build
Harmony server / main node:
```
go build -o bin/harmony cmd/harmony.go
```
Beacon node:
```
go build -o bin/beacon cmd/beaconchain/main.go
```
Wallet:
```
go build -o bin/wallet cmd/client/wallet/main.go
```
Tx Generator:
```
go build -o bin/txgen cmd/client/txgen/main.go
```
You can also run the script `./script/go_executable_build.sh` to build all the executables.
Some of our scripts require bash 4.x support, please [install bash 4.x](http://tldrdevnotes.com/bash-upgrade-3-4-macos) on MacOS X.
## Usage
You may build the src/harmony.go locally and run local test.
6 years ago
### Running local test
The deploy.sh script creates a local environment of Harmony blockchain devnet based on the configuration file.
The configuration file configures number of nodes and their IP/Port.
The script starts one local beacon chain node, the blockchain nodes, and run a transactional generator program which generates and sends simulated trnsactions to the local blockchain.
```bash
6 years ago
./test/deploy.sh ./test/configs/local_config1.txt
6 years ago
```
## Testing
Make sure you the following command and make sure everything passed before submitting your code.
6 years ago
```bash
./test/test_before_submit.sh
6 years ago
```
6 years ago
## License
Harmony is licensed under the MIT License. See [`LICENSE`](LICENSE) file for
the terms and conditions.
Also please see [our Fiduciary License Agreement](FLA.md) if you are
contributing to the project. By your submission of your contribution to us, you
and we mutually agree to the terms and conditions of the agreement.
6 years ago
## Contributing To Harmony
6 years ago
See [`CONTRIBUTING`](CONTRIBUTING.md) for details.
## Development Status
### Features Done
* Basic consensus protocol with O(n) complexity
* Basic validator server
* P2p network connection and unicast
* Account model and support for Solidity
* Simple wallet program
* Mock beacon chain with static sharding
* Information disposal algorithm using erasure encoding (to be integrated)
* Blockchain explorer with performance report and transaction lookup
* Transaction generator for loadtesting
### Features To Be Implemented
* Full beacon chain with multiple validators
* Resharding
* Staking on beacon chain
* Fast state synchronization
* Distributed randomness generation with VRF and VDF
* Kademlia routing
* P2p network and gossiping
* Full protocol of consensus with BLS multi-sig and view-change protocol
* Integration with WASM
* Cross-shard transaction