Python client for the Hashiverse decentralized social network
Project description
hashiverse-client
Python client for Hashiverse — your open-source decentralized X/Twitter replacement. Wraps the Rust hashiverse-lib via PyO3 for native performance.
Install
pip install hashiverse-client
Requires Python 3.9+. Pre-built wheels are published for Linux, macOS, and Windows.
Quick start
from hashiverse_client import HashiverseClient
client = HashiverseClient.create_from_keyphrase(
key_phrase="my secret keyphrase",
data_dir="~/.hashiverse",
passphrase="my secret passphrase", # encrypts key files at rest (default: "" = no encryption)
)
print(client.client_id)
client.post("Hello from Python! #hashiverse-python")
timeline = client.get_hashtag_timeline("hashiverse-python")
for post in timeline.posts:
print(f"{post.client_id[:8]}: {post.post}")
What you can do
- Create or reload a cryptographic identity from a key phrase, with optional at-rest encryption.
- Post messages to the network.
- Read hashtag timelines.
- Fetch trending hashtags.
- Persist keys to a local data directory and reconnect to the same identity later.
See examples/hello_hashiverse.py for an end-to-end walkthrough covering identity creation, key reload, timeline reads, and trending hashtags.
Reloading a stored identity
After create_from_keyphrase has run once, the key is persisted in data_dir. Subsequent runs can skip the keyphrase and reconnect via the stored key:
client = HashiverseClient.create_from_stored_key(
client_id_hex=client_id,
data_dir="~/.hashiverse",
passphrase="my secret passphrase", # must match the passphrase used to create the key
)
Connecting to a local server
By default the client uses the public bootstrap addresses. To point at a local cluster (handy for testing), pass bootstrap_addresses:
client = HashiverseClient.create_from_keyphrase(
key_phrase="my example keyphrase",
data_dir=data_dir,
passphrase="my secret passphrase",
bootstrap_addresses=["127.0.0.1:443"],
)
A local cluster can be started with the test harness from this repository — see the "Running the example" section below.
Developing this package
The rest of this document describes how to build, test, and release hashiverse-client itself. End-user usage is covered above.
Prerequisites
- Python 3.9+
- Rust nightly toolchain (see
rust-toolchain.tomlin the workspace root)
Development build
cd hashiverse-rust/hashiverse-client-python
# Create and activate a virtual environment
python -m venv .venv
# Windows
.venv\Scripts\activate
# Linux/macOS
source .venv/bin/activate
# Install maturin and build the extension into the venv
pip install maturin
maturin develop
maturin develop compiles the Rust code in debug mode and installs the resulting Python package into the active venv. Re-run it after any Rust code changes.
For a faster extension (recommended if exercising PoW or network operations):
maturin develop --release
Production build
To build a distributable wheel:
maturin build --release
The wheel is written to target/wheels/ and can be installed with:
pip install target/wheels/hashiverse_client-*.whl
Running tests
The test suite exercises offline client operations (no server required): identity creation, key management, and storage operations.
cd hashiverse-rust/hashiverse-client-python
source .venv/bin/activate # or .venv\Scripts\activate on Windows
pip install pytest
maturin develop --release
python -m pytest tests/ -v
Running the example
The example connects to a local hashiverse server, creates an identity, fetches trending hashtags, and reads the #hashiverse timeline.
- Start a local server cluster using the test harness (in a separate terminal from the workspace root):
cd hashiverse-rust
cargo run -p hashiverse-integration-tests --bin test_harness
- Run the example:
cd hashiverse-rust/hashiverse-client-python
python examples/hello_hashiverse.py
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 Distributions
Built Distributions
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 hashiverse_client-1.0.6-cp39-abi3-win_amd64.whl.
File metadata
- Download URL: hashiverse_client-1.0.6-cp39-abi3-win_amd64.whl
- Upload date:
- Size: 6.7 MB
- Tags: CPython 3.9+, Windows x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
11225fcfe0b806ad41553dc9f25cdbd7b674cf3e4155cfd8e746113921403e41
|
|
| MD5 |
415b1a67d376d632ff1aef94e256b489
|
|
| BLAKE2b-256 |
4567c42c16beadd547b5c6dd4b1551c5938bfe94df0e0a80d623fe216ba958a6
|
Provenance
The following attestation bundles were made for hashiverse_client-1.0.6-cp39-abi3-win_amd64.whl:
Publisher:
publish-hashiverse-client-python.yml on hashiverse/hashiverse
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hashiverse_client-1.0.6-cp39-abi3-win_amd64.whl -
Subject digest:
11225fcfe0b806ad41553dc9f25cdbd7b674cf3e4155cfd8e746113921403e41 - Sigstore transparency entry: 1644121808
- Sigstore integration time:
-
Permalink:
hashiverse/hashiverse@ada0a5d186ca0eb71b5e2d94ee1461c30ea60b15 -
Branch / Tag:
refs/tags/v1.0.6 - Owner: https://github.com/hashiverse
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-hashiverse-client-python.yml@ada0a5d186ca0eb71b5e2d94ee1461c30ea60b15 -
Trigger Event:
release
-
Statement type:
File details
Details for the file hashiverse_client-1.0.6-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.
File metadata
- Download URL: hashiverse_client-1.0.6-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 6.8 MB
- Tags: CPython 3.9+, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9ccb25d374ab28ca6ee9fda11f822931b96693bc61cd3e120db07304f425bddd
|
|
| MD5 |
0c6a4e8ef78e2e4ccc37739f515ed407
|
|
| BLAKE2b-256 |
3b197efe7468161e9c9019f15b35ef4a9cb0d9b80c79a8a6fb1427fef0519542
|
Provenance
The following attestation bundles were made for hashiverse_client-1.0.6-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:
Publisher:
publish-hashiverse-client-python.yml on hashiverse/hashiverse
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hashiverse_client-1.0.6-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl -
Subject digest:
9ccb25d374ab28ca6ee9fda11f822931b96693bc61cd3e120db07304f425bddd - Sigstore transparency entry: 1644121402
- Sigstore integration time:
-
Permalink:
hashiverse/hashiverse@ada0a5d186ca0eb71b5e2d94ee1461c30ea60b15 -
Branch / Tag:
refs/tags/v1.0.6 - Owner: https://github.com/hashiverse
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-hashiverse-client-python.yml@ada0a5d186ca0eb71b5e2d94ee1461c30ea60b15 -
Trigger Event:
release
-
Statement type:
File details
Details for the file hashiverse_client-1.0.6-cp39-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl.
File metadata
- Download URL: hashiverse_client-1.0.6-cp39-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
- Upload date:
- Size: 6.9 MB
- Tags: CPython 3.9+, manylinux: glibc 2.17+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9f8b7eed726f807f0fbb343dafded1debbb4473370c96ca72a58f00009e6de3c
|
|
| MD5 |
6c75ec0da83abab8b33e079d21049c97
|
|
| BLAKE2b-256 |
bf3586faf327243d40cb813cfe1f88e34b7d8431de7bf2735a4001f22321e7aa
|
Provenance
The following attestation bundles were made for hashiverse_client-1.0.6-cp39-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl:
Publisher:
publish-hashiverse-client-python.yml on hashiverse/hashiverse
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hashiverse_client-1.0.6-cp39-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl -
Subject digest:
9f8b7eed726f807f0fbb343dafded1debbb4473370c96ca72a58f00009e6de3c - Sigstore transparency entry: 1644121562
- Sigstore integration time:
-
Permalink:
hashiverse/hashiverse@ada0a5d186ca0eb71b5e2d94ee1461c30ea60b15 -
Branch / Tag:
refs/tags/v1.0.6 - Owner: https://github.com/hashiverse
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-hashiverse-client-python.yml@ada0a5d186ca0eb71b5e2d94ee1461c30ea60b15 -
Trigger Event:
release
-
Statement type:
File details
Details for the file hashiverse_client-1.0.6-cp39-abi3-macosx_11_0_arm64.whl.
File metadata
- Download URL: hashiverse_client-1.0.6-cp39-abi3-macosx_11_0_arm64.whl
- Upload date:
- Size: 6.4 MB
- Tags: CPython 3.9+, macOS 11.0+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b0d89ef6bc2a98c1ff35ccc61ad464ef3e5466f7689c5ff7bee397d56d7d6f1b
|
|
| MD5 |
a40b839f5892f829d525a706d2092ecd
|
|
| BLAKE2b-256 |
fdd90d571373e36a146d89f5eb7b9d694ad2c0f7ae856222a932ea4045a62972
|
Provenance
The following attestation bundles were made for hashiverse_client-1.0.6-cp39-abi3-macosx_11_0_arm64.whl:
Publisher:
publish-hashiverse-client-python.yml on hashiverse/hashiverse
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hashiverse_client-1.0.6-cp39-abi3-macosx_11_0_arm64.whl -
Subject digest:
b0d89ef6bc2a98c1ff35ccc61ad464ef3e5466f7689c5ff7bee397d56d7d6f1b - Sigstore transparency entry: 1644121253
- Sigstore integration time:
-
Permalink:
hashiverse/hashiverse@ada0a5d186ca0eb71b5e2d94ee1461c30ea60b15 -
Branch / Tag:
refs/tags/v1.0.6 - Owner: https://github.com/hashiverse
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-hashiverse-client-python.yml@ada0a5d186ca0eb71b5e2d94ee1461c30ea60b15 -
Trigger Event:
release
-
Statement type:
File details
Details for the file hashiverse_client-1.0.6-cp39-abi3-macosx_10_12_x86_64.whl.
File metadata
- Download URL: hashiverse_client-1.0.6-cp39-abi3-macosx_10_12_x86_64.whl
- Upload date:
- Size: 6.8 MB
- Tags: CPython 3.9+, macOS 10.12+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c5dc210d6d7ea3ed8bb0e00a525a55e69dc183ac271ca4e9fa3b44e3afb5208b
|
|
| MD5 |
ff194c130d581c0f6b3e50bc7c7efe6b
|
|
| BLAKE2b-256 |
3c9b61c7035e2bc1214b1486f5a29980ff355896a77e9d8cecfd21016197c694
|
Provenance
The following attestation bundles were made for hashiverse_client-1.0.6-cp39-abi3-macosx_10_12_x86_64.whl:
Publisher:
publish-hashiverse-client-python.yml on hashiverse/hashiverse
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hashiverse_client-1.0.6-cp39-abi3-macosx_10_12_x86_64.whl -
Subject digest:
c5dc210d6d7ea3ed8bb0e00a525a55e69dc183ac271ca4e9fa3b44e3afb5208b - Sigstore transparency entry: 1644121691
- Sigstore integration time:
-
Permalink:
hashiverse/hashiverse@ada0a5d186ca0eb71b5e2d94ee1461c30ea60b15 -
Branch / Tag:
refs/tags/v1.0.6 - Owner: https://github.com/hashiverse
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-hashiverse-client-python.yml@ada0a5d186ca0eb71b5e2d94ee1461c30ea60b15 -
Trigger Event:
release
-
Statement type: