Skip to main content

This package contains a compiled python version of all celestia protobuf files with their dependencies

Project description

Cosmos Protobuf

This repository compains the whole cosmos protobuf files compiled for python and ready to use with grpc. Please use the according .proto file as documentation for each python file.

Installation

You can install this package directly from the repository by using:

python -m pip install cosmospy_protobuf_celestia

Usage

The following code snippet will query the balances for the address osmo15hzhcvgs2ljfng6unghvr5l32prwqdyq4aguxn. The according query.proto file in the bank subdirectory contains the Request and the Response for this request. The details for the response are defined in QueryAllBalancesResponse. It contains the balances and pagination attribute which can be accessed as shown in the example below.

import grpc # using grpcio
import cosmospy_protobuf.cosmos.bank.v1beta1.query_pb2_grpc as query_pb2_grpc # for gprcio
#import cosmospy_protobuf.cosmos.bank.v1beta1.query_grpc as query_grpc # for gprclib
import cosmospy_protobuf.cosmos.bank.v1beta1.query_pb2 as query_pb2

host = "osmosis.strange.love"
port = "9090"

c = grpc.insecure_channel(f'{host}:{port}')
stub = query_pb2_grpc.QueryStub(c)

r = stub.AllBalances(query_pb2.QueryAllBalancesRequest(address="osmo15hzhcvgs2ljfng6unghvr5l32prwqdyq4aguxn"))
print(r.balances)

Build yourself

There are two scripts helping you to fork this repository to work with any cosmos based coin.

Addititional Requirements:

  1. grpcio-tools
  2. grpclib
  3. GitPython
  4. protoletariat

Steps:

  1. Create a config in configs and take a existing one as example
  2. Run the aggregate.py file with your filename without .json (Example python aggregate.py cosmos)
  3. Run the compile.py to compile all your files to protobuf
  4. Build your package. You're done!

Protobuf compilation

The files are compiled using the grpc_tools.protoc command from the grpcio-tools library. To compile a .proto file manually use following command:

python -m grpc_tools.protoc -I <absolute path to project root> --python_out=. --grpc_python_out=. --grpclib_python_out=. <absolute path to .proto file>

After compiling all the files with protoc you need to fix the imports by using protoletariat

Note:

  • The --grpc_python_out=. and --grpclib_python_out=. is only needed when compiling a query.proto file as these define the actual grpc query
  • To compile the whole project it is favorable to match all proto files by using *.proto instead of each individual file. You can also match the whole folders to compile multiple folders at the same time. Not that the folders might contain sub-folders.

Other Cosmos based coins

Currently following coins are maintained by me:

  • Cosmos (this branch)
  • Evmos (branch: chain/evmos, package name: evmos-protobuf)
  • Osmosis (branch: chain/osmosis, package name: osmosis-protobuf)
  • Stargaze (branch: chain/stargaze, package name: stargaze-protobuf)

Maintained by external contributors:

  • Sentinel (branch: chain/sentinel, package name: sentinel-protobuf)

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

cosmospy_protobuf_celestia-0.5.1.tar.gz (844.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cosmospy_protobuf_celestia-0.5.1-py2.py3-none-any.whl (1.2 MB view details)

Uploaded Python 2Python 3

File details

Details for the file cosmospy_protobuf_celestia-0.5.1.tar.gz.

File metadata

File hashes

Hashes for cosmospy_protobuf_celestia-0.5.1.tar.gz
Algorithm Hash digest
SHA256 295292aefc70d360030b71145f9f3820e8c538bbb6bb972a0750e64a9f8b1c7d
MD5 9051539e10e084a706e5e676b04dbe16
BLAKE2b-256 0b55b05259bfcd6c8a7bc02641fd94b7b4db1fa748a0c103bf052fc69b4ac76a

See more details on using hashes here.

File details

Details for the file cosmospy_protobuf_celestia-0.5.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for cosmospy_protobuf_celestia-0.5.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 f4e954ba26e63b8ef45b7902a634d839f208a38f76e49874327c706d9868c3d8
MD5 a596f36db10386bada3a541c604cd2b3
BLAKE2b-256 d2cbcfc57a69028cd2a374d3ccac2700a2684fb28a14e31a3915b1cf1277fdbe

See more details on using hashes here.

Supported by

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