Asyncio library for interacting with substrate. Mostly API-compatible with py-substrate-interface
Project description
Async Substrate Interface
This project provides an asynchronous interface for interacting with Substrate-based blockchains. It is based on the py-substrate-interface project.
Additionally, this project uses bt-decode instead of py-scale-codec for faster SCALE decoding.
Installation
To install the package, use the following command:
pip install async-substrate-interface
Usage
Here are examples of how to use the sync and async inferfaces:
from async_substrate_interface import SubstrateInterface
def main():
substrate = SubstrateInterface(
url="wss://rpc.polkadot.io"
)
with substrate:
result = substrate.query(
module='System',
storage_function='Account',
params=['5CZs3T15Ky4jch1sUpSFwkUbYEnsCfe1WCY51fH3SPV6NFnf']
)
print(result)
main()
import asyncio
from async_substrate_interface import AsyncSubstrateInterface
async def main():
substrate = AsyncSubstrateInterface(
url="wss://rpc.polkadot.io"
)
async with substrate:
result = await substrate.query(
module='System',
storage_function='Account',
params=['5CZs3T15Ky4jch1sUpSFwkUbYEnsCfe1WCY51fH3SPV6NFnf']
)
print(result)
asyncio.run(main())
Caching
There are a few different cache types used in this library to improve the performance overall. The one with which
you are probably familiar is the typical functools.lru_cache used in sync_substrate.SubstrateInterface.
By default, it uses a max cache size of 512 for smaller returns, and 16 for larger ones. These cache sizes are
user-configurable using the respective env vars, SUBSTRATE_CACHE_METHOD_SIZE and SUBSTRATE_RUNTIME_CACHE_SIZE.
They are applied only on methods whose results cannot change — such as the block hash for a given block number (small, 512 default), or the runtime for a given runtime version (large, 16 default).
Additionally, in AsyncSubstrateInterface, because of its asynchronous nature, we developed our own asyncio-friendly
LRU caches. The primary one is the CachedFetcher which wraps the same methods as functools.lru_cache does in
SubstrateInterface, but the key difference here is that each request is assigned a future that is returned when the
initial request completes. So, if you were to do:
bn = 5000
bh1, bh2 = await asyncio.gather(
asi.get_block_hash(bn),
asi.get_block_hash(bn)
)
it would actually only make one single network call, and return the result to both requests. Like SubstrateInterface,
it also takes the SUBSTRATE_CACHE_METHOD_SIZE and SUBSTRATE_RUNTIME_CACHE_SIZE vars to set cache size.
The third and final caching mechanism we use is async_substrate_interface.async_substrate.DiskCachedAsyncSubstrateInterface,
which functions the same as the normal AsyncSubstrateInterface, but that also saves this cache to the disk, so the cache
is preserved between runs. This is product for a fairly nice use-case (such as btcli). As you may call different networks
with entirely different results, this cache is keyed by the uri supplied at instantiation of the DiskCachedAsyncSubstrateInterface
object, so DiskCachedAsyncSubstrateInterface(network_1) and DiskCachedAsyncSubstrateInterface(network_2) will not share
the same on-disk cache.
As with the other two caches, this also takes SUBSTRATE_CACHE_METHOD_SIZE and SUBSTRATE_RUNTIME_CACHE_SIZE env vars.
ENV VARS
The following environment variables are used within async-substrate-interface
- NO_CACHE (default 0): if set to 1, when using the DiskCachedAsyncSubstrateInterface class, no persistent on-disk cache will be stored, instead using only in-memory cache.
- CACHE_LOCATION (default
~/.cache/async-substrate-interface): this determines the location for the cache file, if using DiskCachedAsyncSubstrateInterface - SUBSTRATE_CACHE_METHOD_SIZE (default 512): the cache size (either in-memory or on-disk) of the smaller return-size methods (see the Caching section for more info)
- SUBSTRATE_RUNTIME_CACHE_SIZE (default 16): the cache size (either in-memory or on-disk) of the larger return-size methods (see the Caching section for more info)
Contributing
Contributions are welcome! Please open an issue or submit a pull request to the staging branch.
License
This project is licensed under the MIT License. See the LICENSE file for details.
Contact
For any questions or inquiries, please join the Bittensor Development Discord server: Church of Rao.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file async_substrate_interface-1.5.3.tar.gz.
File metadata
- Download URL: async_substrate_interface-1.5.3.tar.gz
- Upload date:
- Size: 81.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6c677bb2599532385afc2f8471bc7d8f7e23d5436b2f32111a01b2df10d25dff
|
|
| MD5 |
b3642b5ab3887c0264f68303a67290e0
|
|
| BLAKE2b-256 |
aa22df5fbdae7bc865bc219aa40a0ad80f554dbf771a2ce19b0334a34c00e9ee
|
Provenance
The following attestation bundles were made for async_substrate_interface-1.5.3.tar.gz:
Publisher:
release.yml on opentensor/async-substrate-interface
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
async_substrate_interface-1.5.3.tar.gz -
Subject digest:
6c677bb2599532385afc2f8471bc7d8f7e23d5436b2f32111a01b2df10d25dff - Sigstore transparency entry: 525348271
- Sigstore integration time:
-
Permalink:
opentensor/async-substrate-interface@67bab6c141cc36ee3f83f6006e6a6bc1c9f928e8 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/opentensor
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@67bab6c141cc36ee3f83f6006e6a6bc1c9f928e8 -
Trigger Event:
workflow_dispatch
-
Statement type:
File details
Details for the file async_substrate_interface-1.5.3-py3-none-any.whl.
File metadata
- Download URL: async_substrate_interface-1.5.3-py3-none-any.whl
- Upload date:
- Size: 84.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b68af95c6d1652a968fd92a3868082024fc38732b9dabe97b3ad1a14b3c4d4c9
|
|
| MD5 |
332a08d8e4ecd8b38937a9ea2071509b
|
|
| BLAKE2b-256 |
68df399ff86d0624e5db409b287f0b5c7370c746e726bb44c98ebb79d2f06e31
|
Provenance
The following attestation bundles were made for async_substrate_interface-1.5.3-py3-none-any.whl:
Publisher:
release.yml on opentensor/async-substrate-interface
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
async_substrate_interface-1.5.3-py3-none-any.whl -
Subject digest:
b68af95c6d1652a968fd92a3868082024fc38732b9dabe97b3ad1a14b3c4d4c9 - Sigstore transparency entry: 525348323
- Sigstore integration time:
-
Permalink:
opentensor/async-substrate-interface@67bab6c141cc36ee3f83f6006e6a6bc1c9f928e8 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/opentensor
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@67bab6c141cc36ee3f83f6006e6a6bc1c9f928e8 -
Trigger Event:
workflow_dispatch
-
Statement type: