Skip to main content

High-performance Web3 client with batching and latency optimization.

Project description

fastweb3

High-performance Web3 client.

NOTE: This library is still in early alpha development. Prior to a v1.0.0 (which may never come), expect breaking changes and no backward compatibility between versions.

Installation

You can install the latest release via pip:

pip install fastweb3

Or clone the repository for the most up-to-date version:

git clone https://github.com/iamdefinitelyahuman/fastweb3.git
cd fastweb3
pip install -e .

Features

Automatic public RPC discovery and pooling

fastweb3 queries a list of public RPC endpoints, maintains a pool of useable nodes, distributes requests between them, and reroutes failed requests. Users can rely on public infrastructure without thinking about timeouts, rate limiting, nodes falling out of sync, etc.

>>> from fw3 import Web3

# only a chainId is needed to connect
>>> w3 = Web3(1)

# the object immediately begins querying endpoints to check availability and latency
# the best nodes are selected to be used in an "active pool"
>>> w3.active_pool_size()
6

# we continue to monitor all known good endpoints, in case we have issues with any
# member of the active pool
>>> w3.pool_capacity()
11

Users with their own RPC can target it as their primary endpoint. This endpoint is then favored for write methods, but read methods continue to be distributed amongst the node pool.

>>> w3 = Web3(1, primary_endpoint=["my.local.node"])

Deferred Execution

RPC calls return Proxy objects immediately, while network I/O happens in the background.

>>> amount = w3.eth.get_balance('0xd8da6bf26964af9d7eed9e03e53415d37aa96045')
>>> amount
<Proxy at 0x7b9ac0764a40 of object ... >
>>> print(amount)
32131215082101779377

Simple Batching Semantics

Batching uses natural syntax. With a context manager open, each requests is queued in the same batch until one of the Proxy objects is read, at which point the entire request is processed. This also guarantees queried values are all read from the same block.

>>> with w3.batch_requests():
...     a = w3.eth.get_balance("0xd8da6bf26964af9d7eed9e03e53415d37aa96045")
...     b = w3.eth.get_balance("0x1db3439a222c519ab44bb1144fc28167b4fa6ee6")
...     # both eth_getBalance queries are sent in the same batched request
...     print(a + b)
...
32840401623804415458

Tests

First, install the dev dependencies:

pip install -e ".[dev]"

To run the test suite:

pytest

License

This project is licensed under the MIT license.

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

fastweb3-0.1.3.tar.gz (48.4 kB view details)

Uploaded Source

Built Distribution

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

fastweb3-0.1.3-py3-none-any.whl (57.9 kB view details)

Uploaded Python 3

File details

Details for the file fastweb3-0.1.3.tar.gz.

File metadata

  • Download URL: fastweb3-0.1.3.tar.gz
  • Upload date:
  • Size: 48.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for fastweb3-0.1.3.tar.gz
Algorithm Hash digest
SHA256 0793b97e6342b595c7c4d44e3eff713367d35b9af347c442cf007d833ee3d418
MD5 486a94698f14e98d79c3cb26b2a8ff77
BLAKE2b-256 d01ed3f2c2878b57a940101aa09f25eb5b30b63a233b8dab003e43b7e6a8b2d8

See more details on using hashes here.

File details

Details for the file fastweb3-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: fastweb3-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 57.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for fastweb3-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 a044966bffa85d13cee0178ea3dfab77e24f89eb6b549b2e9076c300b69f1caa
MD5 e31c4b571ab002fc8d5c7748bb35cc00
BLAKE2b-256 758460cc8f6dd313f690d56ec5a56c849126373cacac8b1a98bb6e7fca269ecd

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