Skip to main content

Developer SDK for Unpod voice infrastructure — management + connectivity + adapters.

Project description

Unpod Python SDK

Developer SDK for Unpod voice infrastructure — management, connectivity, and adapters for building voice agents that talk over real phone calls, browsers, and WebRTC.

Single architectural commitment: the wire between Unpod infrastructure and your code carries text, not audio. You bring the brain; Unpod brings the voice.

Installation

The package is not yet published on PyPI — install from GitHub for now:

pip install "unpod @ git+https://github.com/unpod-ai/unpod-python-sdk"

# With superdialog integration (recommended)
pip install "unpod[dialog] @ git+https://github.com/unpod-ai/unpod-python-sdk"

# With LangChain adapter
pip install "unpod[langchain] @ git+https://github.com/unpod-ai/unpod-python-sdk"

# With MCP adapter
pip install "unpod[mcp] @ git+https://github.com/unpod-ai/unpod-python-sdk"

PyPI publication (pip install unpod) is upcoming.

What's Inside

unpod
├── Management SDK (REST)   numbers, voice profiles, speech pipes, calls,
│                           sessions, trunks, recordings, transcripts, api keys
├── Connectivity SDK (WSS)  AgentRunner, Session, CallContext, hooks
└── Adapters                superdialog, LangChain, OpenAI, Anthropic, HTTP, MCP
  • Management SDK — CRUD against the Unpod Control Plane: purchase numbers, browse voice profiles, bind Speech Pipes, trigger and inspect calls.
  • Connectivity SDK — runtime for live calls: a long-lived AgentRunner receives plain-text turns over WSS and dispatches them to your agent, regardless of transport (phone, browser, WebRTC).
  • Adapters — plug any brain into a call: superdialog dialog machines, LangChain runnables, your own HTTP endpoint, or an MCP server.

Quick Example

from unpod import AsyncClient, AgentRunner, CallContext

client = AsyncClient()  # reads UNPOD_API_KEY from env

# Management: pick a voice, bind a Speech Pipe to your agent
profiles = await client.voice_profiles.list(language="en")
pipe = await client.pipes.create(
    name="support-line",
    voice_profile=profiles[0].id,
    agent_id="my-voice-agent",
)


# Connectivity: handle every live call with your own logic
async def entrypoint(ctx: CallContext) -> None:
    await ctx.session.say("Hi! How can I help you today?")
    await ctx.session.run()


AgentRunner(entrypoint=entrypoint, agent_id="my-voice-agent").start()

Documentation

Guide What it covers
Overview What Unpod owns vs what you own, the three layers
Architecture Package structure, data flow, protocol details
Management SDK REST client API reference
Connectivity SDK AgentRunner, Session, hooks, controls
Adapters DialogAdapter protocol and bundled adapters
Quickstart 10 steps to your first phone call
Browser Quickstart Test in Chrome, no phone number needed

Full platform documentation: docs.unpod.ai

Development

git clone https://github.com/unpod-ai/unpod-python-sdk
cd unpod-python-sdk
uv sync --extra dev
uv run pytest

License

Apache-2.0

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

unpod-0.1.0a2.tar.gz (307.3 kB view details)

Uploaded Source

Built Distribution

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

unpod-0.1.0a2-py3-none-any.whl (49.4 kB view details)

Uploaded Python 3

File details

Details for the file unpod-0.1.0a2.tar.gz.

File metadata

  • Download URL: unpod-0.1.0a2.tar.gz
  • Upload date:
  • Size: 307.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.12

File hashes

Hashes for unpod-0.1.0a2.tar.gz
Algorithm Hash digest
SHA256 7d3461ed66c7cadd020ecab8b37e1c0fb52352302fb0a7ab372ad0d924474b34
MD5 77d7d3419f1c36dabc5ecb59e12c491e
BLAKE2b-256 46c3290d70eb73cc051bd7a1f51ef5e90ea72a331421c2ad773c2e81a6ad0d7f

See more details on using hashes here.

File details

Details for the file unpod-0.1.0a2-py3-none-any.whl.

File metadata

  • Download URL: unpod-0.1.0a2-py3-none-any.whl
  • Upload date:
  • Size: 49.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.12

File hashes

Hashes for unpod-0.1.0a2-py3-none-any.whl
Algorithm Hash digest
SHA256 37214eeb493f33986dc7572e6f63d1852ed1a080cf7cfe808f243fa922ac71ea
MD5 9cc7c6fbbc2d4a462f6a3e38e0dee840
BLAKE2b-256 93efebe834ac5a26229a6e1934faceee0c5a7abcaab7cf053890efcfac6cedd6

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