Skip to main content

RaiBlocks Python RPC client for rai_node

Project description

https://img.shields.io/pypi/l/raiblocks.svg https://travis-ci.org/dourvaris/raiblocks-python.svg?branch=1.0.0rc1 Documentation Status https://github.com/dourvaris/raiblocks-python/raw/master/coverage.svg?sanitize=true https://img.shields.io/pypi/pyversions/raiblocks.svg?style=flat-square https://img.shields.io/pypi/v/raiblocks.svg

This library contains a python wrapper for the RaiBlocks RPC server which tries to make it a little easier to work with by converting RPC responses to native python ones and exposing a pythonic api for making RPC calls.

Also included are utilities such as converting rai/xrb and interesting accounts

Installation

pip install raiblocks

Documentation

https://raiblocks-python.readthedocs.io/

RPC client

You can browse the available RPC methods list or check the RPC Client API documentation for examples of usage.

>>> from raiblocks import RPCClient
>>> rpc = RPCClient('http://localhost:7076')
>>> rpc.version()
{
    'rpc_version': 1,
    'store_version': 10,
    'node_vendor': 'RaiBlocks 9.0'
}
>>> rpc.peers()
{
    '[::ffff:75.171.168.5]:7075': 4,
    '[::ffff:108.44.38.183]:1032': 4
}

Conversion

>>> from raiblocks import convert
>>> convert(12, from_unit='XRB', to_unit='raw')
Decimal('1.2E+31')

>>> convert(0.4, from_unit='krai', to_unit='XRB')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: float values can lead to unexpected
precision loss, please use a Decimal or string
eg. convert('0.4', 'krai', 'XRB')

>>> convert('0.4', from_unit='krai', to_unit='XRB')
Decimal('0.0004')

Known Accounts / Constants

>>> from raiblocks import GENESIS_BLOCK_HASH
>>> GENESIS_BLOCK_HASH
'991CF190094C00F0B68E2E5F75F6BEE95A2E0BD93CEAA4A6734DB9F19B728948'
>>> from raiblocks import KNOWN_ACCOUNT_IDS
>>> KNOWN_ACCOUNT_IDS['xrb_1ipx847tk8o46pwxt5qjdbncjqcbwcc1rrmqnkztrfjy5k7z4imsrata9est']
'Developer Fund'
>>> from raiblocks import KNOWN_ACCOUNT_NAMES
>>> KNOWN_ACCOUNT_NAMES['Burn']
'xrb_1111111111111111111111111111111111111111111111111111hifc8npp'

Development

Setup

virtualenv venv
source venv/bin/activate
pip install -r requirements.pip -r requirements-dev.pip
python setup.py develop

Running tests

# regular
pytest

# coverage
./coverage

Building docs

cd docs

# generate once
make html

# live building
make live

Making a release

  • Update CHANGELOG.rst

  • bumpversion [major|minor|patch]

  • python setup.py upload

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

raiblocks-1.1.0.tar.gz (23.0 kB view details)

Uploaded Source

Built Distribution

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

raiblocks-1.1.0-py2.py3-none-any.whl (24.3 kB view details)

Uploaded Python 2Python 3

File details

Details for the file raiblocks-1.1.0.tar.gz.

File metadata

  • Download URL: raiblocks-1.1.0.tar.gz
  • Upload date:
  • Size: 23.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for raiblocks-1.1.0.tar.gz
Algorithm Hash digest
SHA256 57bb9e2267d41731c591357ee9af400642b53bf5afade05162c7327c5178de5c
MD5 750301eacc2524ae64acf3d55e063ff5
BLAKE2b-256 d959d32309d135ff073934fa02f4ec7047976446a1101391728fdde74d8ae800

See more details on using hashes here.

File details

Details for the file raiblocks-1.1.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for raiblocks-1.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 b06576cf1547f7b53a7a30f3f1edc46a962ac021bd01b464a98d7d938b2d8c8f
MD5 b9be4892330ba69cc7aa93fc227d08cf
BLAKE2b-256 babc6dc40c5e5bccb92228616a19b911ae4c5b3c92cd0cb6bd21df313885c452

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