Skip to main content

Official Dial SDK — phone numbers, SMS, WhatsApp, and voice calls for AI agents

Project description

dial-sdk

Official Python SDK for Dial — phone numbers, SMS, WhatsApp, and voice calls for AI agents.

Install

pip install dial-sdk
# or
uv add dial-sdk

Requires Python 3.11+.

Quickstart

The client is async. Construct it with a DialConfig, then call its methods inside an async with block:

import asyncio
from dial_sdk import DialClient, DialConfig, SendMessageParams, MakeCallParams

async def main():
    async with DialClient(DialConfig(api_key="sk_live_...")) as dial:
        # List your numbers
        numbers = await dial.list_numbers()
        from_id = numbers[0].id

        # Send an SMS
        await dial.send_message(SendMessageParams(
            to="+15551234567",
            from_number_id=from_id,
            body="Hello from Dial",
        ))

        # Place an AI voice call
        call = await dial.make_call(MakeCallParams(
            to="+15551234567",
            from_number_id=from_id,
            outbound_instruction="You are a friendly assistant confirming an appointment.",
        ))
        print(call.id, call.status)

asyncio.run(main())

DialConfig.base_url defaults to https://getdial.ai. Override it for local or self-hosted setups.

Live events

Incoming messages and call transcripts stream via an async generator:

async with DialClient(DialConfig(api_key="sk_live_...")) as dial:
    async with dial.new_events_connection() as events:
        async for event in events:
            print(event)  # MessageEvent / CallEvent / CallTranscribed / ...

Client methods

Method Description
list_numbers() List the phone numbers on your account
purchase_number(params) Buy a new number (PurchaseNumberParams)
set_number_properties(...) Update a number's nickname / inbound instruction
send_message(params) Send an SMS or WhatsApp message (SendMessageParams)
list_messages(...) List messages, optionally filtered
make_call(params) Place an outbound AI voice call (MakeCallParams)
list_calls(...) List calls, optionally filtered
get_call(call_id) Fetch a single call
new_events_connection() Open a live event stream

Related

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

dial_sdk-0.9.2.tar.gz (90.2 kB view details)

Uploaded Source

Built Distribution

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

dial_sdk-0.9.2-py3-none-any.whl (12.9 kB view details)

Uploaded Python 3

File details

Details for the file dial_sdk-0.9.2.tar.gz.

File metadata

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

File hashes

Hashes for dial_sdk-0.9.2.tar.gz
Algorithm Hash digest
SHA256 de9e7267f93d1771c40ae7fa6c61913edd10b6e8c6c03f22a4381afe9ddb7861
MD5 eff32798b7d86b430f4f51b13f7094bf
BLAKE2b-256 48e69cd5fd14a87421e7c77eec4255704dce13fa254d4a8398f81e7472b711de

See more details on using hashes here.

Provenance

The following attestation bundles were made for dial_sdk-0.9.2.tar.gz:

Publisher: publish-sdk-python.yml on GENWAY-AI/dial

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

File details

Details for the file dial_sdk-0.9.2-py3-none-any.whl.

File metadata

  • Download URL: dial_sdk-0.9.2-py3-none-any.whl
  • Upload date:
  • Size: 12.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for dial_sdk-0.9.2-py3-none-any.whl
Algorithm Hash digest
SHA256 a6f707a8ec0bb7b41e89bc2f53d8a5bbcb86c02e669b85771384489f86263632
MD5 cc3609dbda461ce7342e3b5ebfc7d681
BLAKE2b-256 58c8e90dd9cf8593acd6c8dd48b169a5d79f254c2dd316d1fba96b6a30fc4d2a

See more details on using hashes here.

Provenance

The following attestation bundles were made for dial_sdk-0.9.2-py3-none-any.whl:

Publisher: publish-sdk-python.yml on GENWAY-AI/dial

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