Skip to main content

Python based ABCI Server for Tendermint

Project description

pypi build codecoverage

Py-ABCI

Build Tendermint blockchain applications in Python. It's fun. This library provides the core functionality needed to create Tendermint ABCI applications.

Supported Tendermint Version

  • Tendermint 0.34.11
  • ABCI 0.17.0

Installation

Requires Python >= 3.9

pip install abci

You'll need a binary version of the Tendermint engine. Available here: https://github.com/tendermint/tendermint/releases

Make sure the Tendermint version you download matches the current support version of this library

Quick Start - demo

A very simple demo application is included and available from the command line as counter. You can find the code here: https://github.com/davebryson/py-abci/blob/master/src/example/counter.py

To try it out:

  1. Make sure you have the Tendermint binary setup locally and in your path. To test it's working open a terminal window and type:
>> tendermint version

It should output your version of Tendermint that should match the currently supported version of this library.

  1. Next, initialize Tendermint by running:
>> tendermint init
  1. Start the Tendermint node:
>> tendermint node

The node will start, but will be waiting for you application to start.

  1. Open another terminal, and start the counter application. The counter will be available from within the Python environment where you installed abci
>> counter

You'll see the application start, and in the Tendermint terminal, you'll see the output of blocks being produced

  1. Now, open a 3rd terminal window to send some transaction to the blockchain. To do this we'll use the curl application to send transaction to the local blockchain over http. For example:
>> curl http://localhost:26657/broadcast_tx_commit?tx=0x01
>> curl http://localhost:26657/broadcast_tx_commit?tx=0x02

The counter application expects you to send transactions as numbers encoded as hex in order: 1,2,3... It will reject and out-of-order numbers. You can always see the latest accepted value by sending the request:

>> curl http://localhost:26657/abci_query

To shut down the application enter CTRL-C

Get Started

To start building your own application:

  1. Extend the abci.application.BaseApplication class
  2. Implement the Tendermint ABCI callbacks - see https://docs.tendermint.com/v0.34/spec/abci for details on how they work
  3. Start it:
from abci.server import ABCIServer

app = ABCIServer(app=MyApplication())
app.run()

See the counter.py application in the example directory https://github.com/davebryson/py-abci/blob/master/src/example/counter.py for a full example.

Developing on the code base

If you're working directly on the code base. Install a local editable version:

pip install --editable '.[test]'

Updating Protobuf code

You should only re-generate the protobuf code if you're updating the associated protobuf files, and/or contributing to this code base. You do not need to rebuild protos to create apps.

A note on protobuf: The primary code directory is abci, but you'll notice additional directories: gogoproto, tendermint, and protos.

The gogoproto and tendermint directories are the protobuf generated code used by abci. It adds proper Python modules and preserves all the import statements used by Tendermint for the various protobuf files spread across their codebase. The protos directory is the source .proto files.

To (re)build the protobuf files:

  1. Install protoc so it's available in your PATH as a command
  2. Run make update-proto

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

abci-0.8.3.tar.gz (34.9 kB view details)

Uploaded Source

Built Distribution

abci-0.8.3-py3-none-any.whl (39.5 kB view details)

Uploaded Python 3

File details

Details for the file abci-0.8.3.tar.gz.

File metadata

  • Download URL: abci-0.8.3.tar.gz
  • Upload date:
  • Size: 34.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.5

File hashes

Hashes for abci-0.8.3.tar.gz
Algorithm Hash digest
SHA256 2c85c7aa78b7a1785b72e6af789ca9f132088b2ba63d90e85af114d65b609fb3
MD5 2ac78e1b5218885b34ca78b3042df6c7
BLAKE2b-256 77c3a8fab381b7456ba8b9b12210c8a4fd01f26aaa7e40a24d075a3a4b010429

See more details on using hashes here.

File details

Details for the file abci-0.8.3-py3-none-any.whl.

File metadata

  • Download URL: abci-0.8.3-py3-none-any.whl
  • Upload date:
  • Size: 39.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.5

File hashes

Hashes for abci-0.8.3-py3-none-any.whl
Algorithm Hash digest
SHA256 9f6b9d9a28ccb90bc158572fd05d7a196e09cbe774c72053a18a7b5f602e406f
MD5 df19588f590a9705f35c0853aa5bc050
BLAKE2b-256 5a3c4e055523734294f5b1bfec2b467238c62dd05c09858b716d7b3a625dd055

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page