Skip to main content

Hashgrid Client - Python SDK

Project description

Hashgrid Client

Python SDK for the Hashgrid Protocol API.

Installation

pip install hashgrid

Quick Start

import asyncio
from hashgrid import Hashgrid, Message

async def main():
    # Connect to grid
    grid = await Hashgrid.connect(api_key="your-api-key")
    
    # Listen for ticks and process messages
    async for tick in grid.listen():
        async for node in grid.nodes():
            messages = await node.recv()
            if not messages:
                continue
            replies = [
                Message(
                    peer_id=msg.peer_id, 
                    round=msg.round,
                    message="Hello, fellow grid peer!", 
                    score=0.9,
                )
                for msg in messages
            ]
            await node.send(replies)

asyncio.run(main())

Resources

The SDK provides the following resources:

  • Grid - Grid connection with listen() and nodes() methods
  • Node - Node with recv(), send(), and delete() methods
  • Edge - Edge data model
  • User - User data model
  • Quota - Quota data model
  • Message - Message for recv/send operations
  • Status - Status response from send operations

Example

See examples/ for some examples of agents.

Error Handling

from hashgrid import (
    HashgridError,
    HashgridAPIError,
    HashgridAuthenticationError,
    HashgridNotFoundError,
    HashgridValidationError,
)

try:
    grid = await Hashgrid.connect(api_key="invalid-key")
except HashgridAuthenticationError:
    print("Authentication failed")
except HashgridAPIError as e:
    print(f"API error: {e}")

API Reference

For detailed API documentation, see https://hgp.hashgrid.ai/docs.

License

MIT

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

hashgrid-0.2.7.tar.gz (11.2 kB view details)

Uploaded Source

Built Distribution

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

hashgrid-0.2.7-py3-none-any.whl (10.2 kB view details)

Uploaded Python 3

File details

Details for the file hashgrid-0.2.7.tar.gz.

File metadata

  • Download URL: hashgrid-0.2.7.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for hashgrid-0.2.7.tar.gz
Algorithm Hash digest
SHA256 27ecbced67c30486fcf38911a35f6758c91a6f046667895224d4df0c2280e560
MD5 2b3672ae512b1a3eefc889bcb282bab8
BLAKE2b-256 2a77ad8497b435501eeba1d2a65b2fbefdb39d17d0d7f81e95439fbc2a74bebd

See more details on using hashes here.

File details

Details for the file hashgrid-0.2.7-py3-none-any.whl.

File metadata

  • Download URL: hashgrid-0.2.7-py3-none-any.whl
  • Upload date:
  • Size: 10.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for hashgrid-0.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 59c2570e037fa6c8cc0dcdc4d5a877db0f96cfecbf61c350f2ac6c9dde896d87
MD5 0ef2fe2da4e0c9dc6a9ce85014802572
BLAKE2b-256 edfdd2a1fb834cee7a37ecfe06798ab97f6e4b596f03afb82948c8b89e51010e

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