Skip to main content

Server SDK for agent-phonon — orchestrate AI agents across multiple devices.

Project description

agent-phonon — Python Server SDK

让任何 Python 项目「一键成为 agent-phonon 服务端」:编排多台设备上的 AI agent(Claude Code / Codex / OpenCode / OpenClaw / Hermes)。

安装

pip install agent-phonon   # 或 pip install -e sdk-python/

用法

import asyncio
from agent_phonon import PhononServer

async def main():
    server = PhononServer(port=8080, authenticate=verify_device)

    @server.on_device
    async def handle(device):                       # 每台设备拨入时
        agents = await device.discover()            # 列设备上的 agent
        proj = await device.project_create("my-proj")
        session = await device.create_session(
            project=proj["project"]["projectId"],
            agent="openclaw:main", model="claude-opus-4.8",
        )
        # HITL:危险操作裁决
        device.set_hook_decider(
            lambda hook, s: "abort" if "rm -rf" in str(hook.get("payload", {})) else "continue"
        )
        await session.send("帮我重构这个函数")
        async for event in session.stream():        # 流式输出
            if event.get("type") == "message":
                print(event["text"], end="")

    await server.listen()
    await asyncio.Future()  # 长跑

async def verify_device(device_id, device_key):
    return "tenant-1" if device_key == "secret" else None  # None = 拒绝

asyncio.run(main())

核心抽象

  • PhononServer — ws 监听,管理多设备;authenticate(device_id, device_key) -> tenant_id | Noneon_device 回调;list_devices() / get_device()
  • PhononDevicediscover() / create_session() / list_sessions() + project_* / skill_* 封装;set_hook_decider()(HITL)/ set_unsolicited_handler()(自发输出)
  • PhononSessionsend() + async for event in session.stream()(流式);inject/interrupt/switch_model/compress/status/terminate;自动 stream.ack

多设备

一个 PhononServer 同时连多个 phonon 设备,各设备 tenant 隔离、互不干扰——这是 phonon 作为「个人设备编排中心」的核心。

协议

JSON-RPC 2.0 over WebSocket。与 TS SDK(@agent-phonon/server-sdk)完全协议兼容——Python 服务端能指挥 TS phonon,反之亦然。

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

agent_phonon_sdk-0.6.0.tar.gz (8.9 kB view details)

Uploaded Source

Built Distribution

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

agent_phonon_sdk-0.6.0-py3-none-any.whl (8.5 kB view details)

Uploaded Python 3

File details

Details for the file agent_phonon_sdk-0.6.0.tar.gz.

File metadata

  • Download URL: agent_phonon_sdk-0.6.0.tar.gz
  • Upload date:
  • Size: 8.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for agent_phonon_sdk-0.6.0.tar.gz
Algorithm Hash digest
SHA256 92bd5d3206df6262750ac7133dd0fc280aaeb281e2bb5e6b5d8772adad02e789
MD5 f0560ab8ff5ce3ca17f597c603de25d1
BLAKE2b-256 67d5304428faf2b59019876254568f1b781ab0a1d28418ee40b5524f6de9c154

See more details on using hashes here.

Provenance

The following attestation bundles were made for agent_phonon_sdk-0.6.0.tar.gz:

Publisher: publish-pypi.yml on hackerphysics/agent-phonon

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file agent_phonon_sdk-0.6.0-py3-none-any.whl.

File metadata

File hashes

Hashes for agent_phonon_sdk-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 31458e22d3c45e99cda59aeed0331dd32ab5db5990becd8bac146528c5e179fa
MD5 c98ede4b0109b751fe962b13da7a749f
BLAKE2b-256 e53b76f38e53ccc646e80c12e50caa47ced4383ba1a57c54b525c873b9e31121

See more details on using hashes here.

Provenance

The following attestation bundles were made for agent_phonon_sdk-0.6.0-py3-none-any.whl:

Publisher: publish-pypi.yml on hackerphysics/agent-phonon

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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