cometbft module - github.com/cometbft/cometbft - Go Packages

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.5
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

cmd/abci-cli command

server

Package server is used to start a new ABCI server.

Package server is used to start a new ABCI server.

api module

cmd

cometbft command

contract_tests command

priv_val_server command

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

autofile/cmd command

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.

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

jsonrpc/test command

scripts

json2wal command

metricsgen command

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 command

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.

wal2json command

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/generator command

e2e/node command

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/runner command

e2e module