cometbft

module
v1.0.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 17, 2024 License: Apache-2.0

README

CometBFT

Byzantine-Fault Tolerant State Machine Replication. Or Blockchain, for short.

Version API Reference Go version Discord chat License Sourcegraph

Branch Tests Linting
main Tests Lint
v1.x Tests Lint
v0.38.x Tests Lint
v0.37.x Tests Lint
v0.34.x Tests Lint

CometBFT is a Byzantine Fault Tolerant (BFT) middleware that takes a state transition machine - written in any programming language - and securely replicates it on many machines.

It is a fork of Tendermint Core and implements the Tendermint consensus algorithm.

For protocol details, refer to the CometBFT Specification.

For detailed analysis of the consensus protocol, including safety and liveness proofs, read our paper, "The latest gossip on BFT consensus".

Documentation

Complete documentation can be found on the website.

Releases

Please do not depend on main as your production branch, as it may receive significant breaking changes at any time. Use releases instead.

If you intend to run CometBFT in production, we're happy to help. To contact us, in order of preference:

More on how releases are conducted can be found here.

Security

Please see SECURITY.md.

Minimum requirements

CometBFT version Requirement Version Tested with
main Go version 1.23 or higher up to 1.23.1
v1.x Go version 1.23 or higher up to 1.23.1
v0.38.x Go version 1.22 or higher up to 1.22
v0.37.x Go version 1.22 or higher up to 1.22
v0.34.x Go version 1.22 or higher up to 1.22
Install

See the install guide.

Quick Start

Contributing

Please abide by the Code of Conduct in all interactions.

Before contributing to the project, please take a look at the contributing guidelines and the style guide. You may also find it helpful to read the specifications, and familiarize yourself with our Architectural Decision Records (ADRs) and Request For Comments (RFCs).

Versioning

As of v1, CometBFT uses the following approach to versioning:

  • Major version bumps, such as v1.0.0 to v2.0.0, would generally involve changes that force users to perform a coordinated upgrade in order to use the new version, such as protocol-breaking changes (e.g. changes to how block hashes are computed and thus what the network considers to be "valid blocks", or how the consensus protocol works, or changes that affect network-level compatibility between nodes, etc.).
  • Minor version bumps, such as v1.1.0 to v1.2.0, are reserved for rolling out new features or substantial changes that do not force a coordinated upgrade (i.e. not protocol-breaking), but could potentially break Go APIs.
  • Patch version bumps, such as v1.0.0 to v1.0.1, are reserved for bug/security fixes that are not protocol- or Go API-breaking.
Upgrades

We do not guarantee compatibility between major releases of CometBFT. Minor releases of the same major release series (v1.1, v1.2, etc.) should, unless otherwise specified, be compatible with each other. Patch releases of the same minor release series (v1.0.1, v1.0.2, etc.) are guaranteed to be compatible with each other.

For more detailed information on upgrading from one version to another, see UPGRADING.md.

Supported Versions

Because we are a small core team, we have limited capacity to ship patch updates, including security updates. Consequently, we strongly recommend keeping CometBFT up-to-date. Upgrading instructions can be found in UPGRADING.md.

Currently supported versions include:

  • v1.x: Currently in pre-release with no guarantees as to API stability until a release candidate is cut. See RELEASES.md for details on our process as to API stability guarantees that can be expected of CometBFT pre-releases.
  • v0.38.x: CometBFT v0.38 introduces ABCI 2.0, which implements the entirety of ABCI++
  • v0.37.x: CometBFT v0.37 introduces ABCI 1.0, which is the first major step towards the full ABCI++ implementation in ABCI 2.0
  • v0.34.x: The CometBFT v0.34 series is compatible with the Tendermint Core v0.34 series

Resources

Libraries
Applications
Research

Below are links to the original Tendermint consensus algorithm and relevant whitepapers, which CometBFT will continue to build on.

Join us

CometBFT is currently maintained by Informal Systems. If you'd like to work full-time on CometBFT, we're hiring!

Funding for CometBFT development comes primarily from the Interchain Foundation, a Swiss non-profit. Informal Systems also maintains cometbft.com.

Directories

Path Synopsis
abci
server
Package server is used to start a new ABCI server.
Package server is used to start a new ABCI server.
api module
cmd
crypto is a customized/convenience cryptography package for CometBFT.
crypto is a customized/convenience cryptography package for CometBFT.
merkle
Package merkle computes a deterministic minimal height Merkle tree hash.
Package merkle computes a deterministic minimal height Merkle tree hash.
internal
events
Package events - Pub-Sub in go with event caching
Package events - Pub-Sub in go with event caching
evidence
Package evidence handles all evidence storage and gossiping from detection to block proposal.
Package evidence handles all evidence storage and gossiping from detection to block proposal.
flowrate
Package flowrate provides the tools for monitoring and limiting the flow rate of an arbitrary data stream.
Package flowrate provides the tools for monitoring and limiting the flow rate of an arbitrary data stream.
inspect
Package inspect provides a tool for investigating the state of a failed CometBFT node.
Package inspect provides a tool for investigating the state of a failed CometBFT node.
net
os
test
Package factory provides generation code for common structs in CometBFT.
Package factory provides generation code for common structs in CometBFT.
libs
cli
json
Package json provides functions for marshaling and unmarshaling JSON in a format that is backwards-compatible with Amino JSON encoding.
Package json provides functions for marshaling and unmarshaling JSON in a format that is backwards-compatible with Amino JSON encoding.
log
metrics
Package metrics provides a framework for application instrumentation.
Package metrics provides a framework for application instrumentation.
metrics/discard
Package discard provides a no-op metrics backend.
Package discard provides a no-op metrics backend.
metrics/prometheus
Package prometheus provides Prometheus implementations for metrics.
Package prometheus provides Prometheus implementations for metrics.
metrics/teststat
Package teststat provides helpers for testing metrics backends.
Package teststat provides helpers for testing metrics backends.
protoio
Package protoio may be internalized (made private) in future releases.
Package protoio may be internalized (made private) in future releases.
pubsub
Package pubsub implements a pub-sub model with a single publisher (Server) and multiple subscribers (clients).
Package pubsub implements a pub-sub model with a single publisher (Server) and multiple subscribers (clients).
pubsub/query
Package query implements the custom query format used to filter event subscriptions in CometBFT.
Package query implements the custom query format used to filter event subscriptions in CometBFT.
pubsub/query/syntax
Package syntax defines a scanner and parser for the CometBFT event filter query language.
Package syntax defines a scanner and parser for the CometBFT event filter query language.
service
Package service may be internalized (made private) in future releases.
Package service may be internalized (made private) in future releases.
sync
Package sync may be internalized (made private) in future releases.
Package sync may be internalized (made private) in future releases.
package light provides a light client implementation.
package light provides a light client implementation.
rpc
TODO: Better handle abci client errors.
TODO: Better handle abci client errors.
Package node is the main entry point, where the Node struct, which represents a full node, is defined.
Package node is the main entry point, where the Node struct, which represents a full node, is defined.
p2p
pex
Package privval provides different implementations of the types.PrivValidator.
Package privval provides different implementations of the types.PrivValidator.
rpc
core
Package core defines the CometBFT RPC endpoints.
Package core defines the CometBFT RPC endpoints.
grpc/client
Note that no auto-generated gRPC code is directly exposed via the client interface.
Note that no auto-generated gRPC code is directly exposed via the client interface.
jsonrpc
HTTP RPC server supporting calls via uri params, jsonrpc over HTTP, and jsonrpc over websockets
HTTP RPC server supporting calls via uri params, jsonrpc over HTTP, and jsonrpc over websockets
jsonrpc/server
Commons for HTTP handling
Commons for HTTP handling
scripts
metricsgen
metricsgen is a code generation tool for creating constructors for CometBFT metrics types.
metricsgen is a code generation tool for creating constructors for CometBFT metrics types.
metricsgen/metricsdiff
metricsdiff is a tool for generating a diff between two different files containing prometheus metrics.
metricsdiff is a tool for generating a diff between two different files containing prometheus metrics.
XXX: This package may be internalized (made private) in future releases.
XXX: This package may be internalized (made private) in future releases.
indexer/sink/psql
Package psql implements an event sink backed by a PostgreSQL database.
Package psql implements an event sink backed by a PostgreSQL database.
Package statesync may be internalized (made private) in future releases.
Package statesync may be internalized (made private) in future releases.
XXX: This package may be internalized (made private) in the future releases.
XXX: This package may be internalized (made private) in the future releases.
test
e2e/pkg/grammar/grammar-auto/lexer
Package lexer is generated by GoGLL.
Package lexer is generated by GoGLL.
e2e/pkg/grammar/grammar-auto/parser
Package parser is generated by gogll.
Package parser is generated by gogll.
e2e/pkg/grammar/grammar-auto/parser/bsr
Package bsr implements a Binary Subtree Representation set as defined in
Package bsr implements a Binary Subtree Representation set as defined in
e2e/pkg/grammar/grammar-auto/parser/slot
Package slot is generated by gogll.
Package slot is generated by gogll.
e2e/pkg/grammar/grammar-auto/parser/symbols
Package symbols is generated by gogll.
Package symbols is generated by gogll.
e2e/pkg/grammar/grammar-auto/sppf
Package sppf implements a Shared Packed Parse Forest as defined in:
Package sppf implements a Shared Packed Parse Forest as defined in:
e2e/pkg/grammar/grammar-auto/token
Package token is generated by GoGLL.
Package token is generated by GoGLL.
e2e Module

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL