Introduction

This document aims to provide a brief overview of the Introduction section of the GoQuorum codebase and its importance.

What is Introduction?

The Introduction section of the GoQuorum codebase serves as the entry point for understanding the core concepts and architecture of the project. It provides a high-level overview of GoQuorum’s features, purpose, and how it relates to Ethereum and go-ethereum.

Why is Introduction important?

The Introduction is crucial for several reasons:

  • Understanding the project’s scope: It provides a clear understanding of what GoQuorum is, its purpose, and its key features.
  • Contextualization: It establishes the relationship between GoQuorum and its parent project, go-ethereum, highlighting the key enhancements and modifications implemented.
  • Starting Point: It acts as a starting point for developers and users who are new to GoQuorum, providing a foundational understanding of the project’s architecture and its key components.
  • Guidance for further exploration: The Introduction guides users to relevant resources and documentation for a more in-depth understanding of specific features and functionalities.

Architecture

The Introduction section typically provides a high-level overview of the architectural components of GoQuorum, such as:

  • Tessera: A component that enables private transactions and contracts through public/private state separation and peer-to-peer encrypted message exchanges.
  • Consensus Mechanisms: GoQuorum offers several consensus mechanisms tailored for permissioned networks, including QBFT, Istanbul BFT, Clique POA, and Raft-based Consensus.
  • Pluggable Architecture: This feature allows GoQuorum to be extended with additional functionalities through plugins, providing flexibility and isolation.
  • Performance: GoQuorum aims to provide higher performance throughput compared to public geth.

Quickstart

The Introduction often includes information about quickstart guides and tools that make it easier for users to get started with GoQuorum.

GoQuorum Projects

This section provides a list of related GoQuorum projects, such as:

  • quorum-remix-plugin: A plugin for Ethereum’s Remix IDE that supports private contracts on a GoQuorum network.
  • Cakeshop: An integrated development environment and SDK for GoQuorum.
  • quorum-examples: A collection of GoQuorum demonstration examples.
  • Quorum-Kubernetes: A tool for deploying GoQuorum on Kubernetes.
  • we3js-quorum: An extension to web3.js that supports GoQuorum and Hyperledger Besu APIs.
  • Zero Knowledge on GoQuorum: This section may highlight projects related to zero-knowledge proofs on GoQuorum, including ZSL and Anonymous Zether.

Docker Containers

The Introduction may mention the availability of official Docker containers for GoQuorum, which can be found on Docker Hub.

Third Party Tools and Libraries

This section often lists third-party tools and libraries that enhance GoQuorum’s functionality, such as:

  • Chainlens Blockchain Explorer: A Blockchain Explorer for GoQuorum that supports viewing private transactions.
  • Quorum-Genesis: A CL utility for GoQuorum that helps populate the genesis file.
  • Quorum Maker: A utility for creating GoQuorum nodes.
  • ERC20 REST service: A GoQuorum-supported RESTful service for managing ERC-20 tokens.
  • Nethereum Quorum: A .NET GoQuorum adapter.
  • web3j-quorum: An extension to the web3j Java library that supports GoQuorum APIs.
  • Apache Camel: An Apache Camel component that provides support for the GoQuorum API using the web3j library.

Contributing

The Introduction may include information about how to contribute to GoQuorum, including guidelines for contributing code and submitting security bugs.

License

This section provides details about the licensing information for GoQuorum’s codebase, often referencing the GNU Lesser General Public License and the GNU General Public License.