Go to file
Nguyen Kien Trung 347f6fc356 Docker: Add git commit hash (#554) 2018-10-22 15:00:03 -04:00
.github Update CONTRIBUTING.md 2017-02-03 16:37:37 -05:00
accounts Travis an unit test fixes (#519) 2018-09-11 11:25:24 -04:00
bmt Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
build build: fix version comparison for go1.10 and beyond (#15781) 2018-03-01 09:51:18 +01:00
cmd Added a validateConsensus() which exits geth if no consensus is speci… (#540) 2018-10-01 16:39:01 -04:00
common Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
compression/rle Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
consensus avoid growing backlogs when valSet changes 2018-09-05 17:22:42 -04:00
console Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
containers Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
contracts Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
core Value Transfer in Private Transactions (#538) 2018-10-01 14:37:05 -04:00
crypto Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
docs Inline example data 2018-10-05 20:20:18 +01:00
eth Travis an unit test fixes (#519) 2018-09-11 11:25:24 -04:00
ethclient Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
ethdb Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
ethstats Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
event Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
internal Merge pull request #541 2018-10-08 16:29:51 -04:00
les Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
light Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
log Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
metrics Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
miner enable clique poa consensus 2018-09-05 09:49:53 -04:00
mobile Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
node Fixed missing DataDir value in p2p server that affected permissioned nodes 2018-01-24 10:13:09 -05:00
p2p look up IP if host is FQDN (#544) 2018-10-02 16:38:20 -04:00
params Quorum version update 2018-10-16 16:56:55 -04:00
private Properly close connection to Constellation to prevent panic (#491) 2018-08-22 09:32:59 -04:00
raft Raft Block Signature (#395) 2018-10-03 20:14:48 -04:00
rlp Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
rpc Adds the RPC request ID to the context which is passed to called method. 2018-09-20 12:13:09 +01:00
swarm Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
tests Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
trie Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
vendor Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
whisper Feature/fix_some_tests (#387) 2018-06-04 16:02:09 -04:00
.dockerignore Docker: Add git commit hash (#554) 2018-10-22 15:00:03 -04:00
.gitattributes .gitattributes: add 2015-08-06 17:18:59 +02:00
.gitignore Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
.gitmodules Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
.mailmap Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
.travis.yml Travis an unit test fixes (#519) 2018-09-11 11:25:24 -04:00
AUTHORS Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
BUILDING.md [docs] updated documentation: edited for clarity 2016-11-15 16:55:10 -05:00
COPYING all: update license information 2015-07-07 14:12:44 +02:00
COPYING.LESSER all: update license information 2015-07-07 14:12:44 +02:00
Dockerfile Docker: Add git commit hash (#554) 2018-10-22 15:00:03 -04:00
HACKING.md Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
Makefile Added bootnode build and to docker image (#526) 2018-09-17 11:34:29 -04:00
README.md Adding docker hub link 2018-10-05 11:39:41 -04:00
VERSION Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
appveyor.yml Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
circle.yml circleci: enable docker based hive testing 2016-07-15 16:07:34 +03:00
interfaces.go Geth 1.7.2 rebase and addition of Istanbul BFT (#207) 2017-10-31 18:24:11 -04:00
logo.png Documentation wording and formatting changes (#492) 2018-08-24 09:08:02 -04:00

README.md

Quorum Slack Build Status

Quorum is an Ethereum-based distributed ledger protocol with transaction/contract privacy and new consensus mechanisms.

Quorum is a fork of go-ethereum and is updated in line with go-ethereum releases.

Key enhancements over go-ethereum:

  • Privacy - Quorum supports private transactions and private contracts through public/private state separation, and utilises peer-to-peer encrypted message exchanges (see Constellation and Tessera) for directed transfer of private data to network participants
  • Alternative Consensus Mechanisms - with no need for POW/POS in a permissioned network, Quorum instead offers multiple consensus mechanisms that are more appropriate for consortium chains:
    • Raft-based Consensus - a consensus model for faster blocktimes, transaction finality, and on-demand block creation
    • Istanbul BFT - a PBFT-inspired consensus algorithm with transaction finality, by AMIS.
  • Peer Permissioning - node/peer permissioning using smart contracts, ensuring only known parties can join the network
  • Higher Performance - Quorum offers significantly higher performance than public geth

Architecture

Quorum Tessera Privacy Flow

The above diagram is a high-level overview of the privacy architecture used by Quorum. For more in-depth discussion of the components, refer to the wiki pages.

Quickstart

The quickest way to get started with Quorum is by following instructions in the Quorum Examples repository. This allows you to quickly create a network of Quorum nodes, and includes a step-by-step demonstration of the privacy features of Quorum.

Further Reading

Further documentation can be found in the docs folder and on the wiki.

Official Docker Containers

The official docker containers can be found under https://hub.docker.com/u/quorumengineering/

See also

Third Party Tools/Libraries

The following Quorum-related libraries/applications have been created by Third Parties and as such are not specifically endorsed by J.P. Morgan. A big thanks to the developers for improving the tooling around Quorum!

Contributing

Thank you for your interest in contributing to Quorum!

Quorum is built on open source and we invite you to contribute enhancements. Upon review you will be required to complete a Contributor License Agreement (CLA) before we are able to merge. If you have any questions about the contribution process, please feel free to send an email to quorum_info@jpmorgan.com.

License

The go-ethereum library (i.e. all code outside of the cmd directory) is licensed under the GNU Lesser General Public License v3.0, also included in our repository in the COPYING.LESSER file.

The go-ethereum binaries (i.e. all code inside of the cmd directory) is licensed under the GNU General Public License v3.0, also included in our repository in the COPYING file.