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.4.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.

pondsocket_client-0.0.4-py3-none-any.whl (11.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pondsocket_client-0.0.4.tar.gz
  • Upload date:
  • Size: 11.2 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.4.tar.gz
Algorithm Hash digest
SHA256 351368e0cb91ddebfd80d6d7f58ca1c2612521048003f93e5bf2103fa206ff0b
MD5 82d7420be7e5646c732815ee6eba5e6f
BLAKE2b-256 b51d76fc8d0637d791e114d931933e3660c3f59d1f02359067af4de2b16d757e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pondsocket_client-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 37a2c3b912205198071d2bc28f66b3389fb6de8f20ab08521ca6256ad21fef54
MD5 bd6d26a30bb2ed59f9915d0318879493
BLAKE2b-256 e31524db46f5546cfabacaf7cf087ee477cb5ae722fc68885f0451817486d1e7

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