Skip to main content

PondSocket Python client — connect to a PondSocket server from Python.

Project description

pondsocket-client

Python client for the PondSocket server. Connects to PondSocket servers (Python, Go, or TypeScript implementation) over WebSocket.

Modeled after the JavaScript client architecture (@eleven-am/pondsocket-client) rather than the Go one — the JS client fixes several bugs the Go client has (see Parity notes below).

Install

pip install pondsocket-client

Quick start

import asyncio
from pondsocket_client import PondClient


async def main() -> None:
    client = PondClient("ws://localhost:8000/ws", {"token": "secret"})
    await client.connect()

    channel = client.create_channel("/chat/42", {"username": "alice"})
    channel.on_message_event("message", lambda m: print(m.payload))
    channel.on_join(lambda user: print("joined:", user))
    channel.join()

    channel.send_message("message", {"text": "hello"})

    response = await channel.send_for_response("ping", {"text": "abc"})
    print("got pong:", response)

    await asyncio.sleep(10)
    await client.disconnect()


asyncio.run(main())

Architecture

BaseClient (abstract)
  ├── channel registry
  ├── inbound event routing (ACK / UNAUTHORIZED / CONNECTION / per-channel)
  ├── connection state machine: DISCONNECTED → CONNECTING → CONNECTED
  └── exponential reconnect

WebSocketClient(BaseClient)  (abstract)
  ├── opens via `websockets` library
  └── receive loop pumps inbound to BaseClient

PondClient(WebSocketClient)  (concrete)
  ├── URL handling (http → ws, https → wss)
  └── appends query-string params

The Channel class holds the per-channel state machine (IDLE → JOINING → JOINED → STALLED → CLOSED/DECLINED), a bounded outbound queue (drops oldest on overflow), and a send_for_response that correlates inbound replies by requestId.

Connection states

Subscribe via client.on_connection_change(handler):

State When
DISCONNECTED initial; after disconnect or socket close
CONNECTING connect() called; socket handshake in flight
CONNECTED socket open AND server sent the CONNECTION event

Channel states

Subscribe via channel.on_channel_state_change(handler):

State Meaning
IDLE created but join() not called
JOINING join() called; awaiting ACKNOWLEDGE
JOINED server acknowledged; messages flow
STALLED socket dropped while JOINED; will rejoin on reconnect
CLOSED leave() called
DECLINED server sent UNAUTHORIZED; channel is terminal — create a new one

Parity notes

Compared to the Go client (go/pondsocket-client/):

Behavior Go Python
send_for_response correlation event name (buggy) requestId (correct)
Reconnect backoff linear despite comment true exponential, capped
UNAUTHORIZED handling not implemented DECLINED state
Connection state bool (no CONNECTING) three-state enum
Outbound queue unbounded bounded, drops oldest
Join while disconnected dropped silently deferred until CONNECTED

The Python client follows the JS client design where the two diverge.

Public API

from pondsocket_client import (
    PondClient,
    Channel,
    ConnectionState,
    ClientOptions,
    ResponseTimeoutError,
)

Also exposed for adapter authors: BaseClient, WebSocketClient, Publisher (type alias).

License

GPL-3.0-or-later.

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

pondsocket_client-0.0.2.tar.gz (10.3 kB view details)

Uploaded Source

Built Distribution

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

pondsocket_client-0.0.2-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file pondsocket_client-0.0.2.tar.gz.

File metadata

  • Download URL: pondsocket_client-0.0.2.tar.gz
  • Upload date:
  • Size: 10.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.0

File hashes

Hashes for pondsocket_client-0.0.2.tar.gz
Algorithm Hash digest
SHA256 3b5f40511c1d90b3275b801233d4fa58488d22649ebe6f5e90f6d41d90770772
MD5 2a9d862de5fc8ce42934ffa2b936ad5d
BLAKE2b-256 bd7782332662434963667dc3d28a0877095a058fd8794618f10225e47fa416d1

See more details on using hashes here.

File details

Details for the file pondsocket_client-0.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for pondsocket_client-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c7b8e82ed1f66b285970e7251da512237708eb06928a4afbab05ab1cb420615a
MD5 e37a5c9eec5655a73babb642aac51b5d
BLAKE2b-256 351661f60a5e412c11ba3cab2cbd454a6467250c47e4882c0793b1f6a3c26b52

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