Skip to main content

Python asyncio library for VoIP calls.

Project description

Python VoIP
Documentation | Issues | Changelog | Funding

Python VoIP

Async VoIP Python library for the AI age.

[!WARNING] This library is in early development and may contain breaking changes. Use with caution.

Usage

To get started, you will need a SIP account. One is usually included with ISP. Check your ISP's documentation or router for details.

You will need a SIP AOR (URI), which looks like this:

sip:USER:PASSWORD@SIP_SERVER;transport=TCP

[!NOTE] This library uses secure defaults (TLS transport on port 5061). However, most SIP servers only support unencrypted connections. Therefore, you will need to provide an explict transport parameter.

CLI

A simple echo call can be started with:

uvx 'voip[cli]' sip sips:alice:********@sip.example.com echo

Each command supports an optional --dial argument to initiate an outbound call instead of waiting for an inbound one.

To dial a number, say a message, and hang up automatically:

uvx 'voip[cli]' sip sips:alice:********@sip.example.com say sip:+15551234567@sip.example.com "Your package has arrived."

You can also talk to a local agent (needs Ollama):

uvx 'voip[cli]' sip sips:alice:********@sip.example.com agent --initial-prompt "Hi, I am looking for a Mr. Ron, first name Mo?"

Python API

uv add voip[audio,ai,pygments]

Subclass TranscribeCall and override transcription_received to handle results. Pass it as session_class when answering an incoming call:

import asyncio
import dataclasses
import ssl
from voip.ai import TranscribeCall
from voip.sip.protocol import SIP
from voip.sip.types import SipURI
from voip.sip.transactions import InviteTransaction
from voip.rtp import RealtimeTransportProtocol
from faster_whisper import WhisperModel


@dataclasses.dataclass(kw_only=True, slots=True)
class TranscribingCall(TranscribeCall):
    def transcription_received(self, text) -> None:
        print(text)


class TranscribeInviteTransaction(InviteTransaction):
    def invite_received(self, request) -> None:
        self.ringing()
        self.answer(
            session_class=TranscribingCall,
            stt_model=WhisperModel("kyutai/stt-1b-en_fr-trfs", device="cuda"),
        )


async def main():
    loop = asyncio.get_running_loop()
    _, rtp_protocol = await loop.create_datagram_endpoint(
        RealtimeTransportProtocol,
        local_addr=("0.0.0.0", 0),
    )
    ssl_context = ssl.create_default_context()
    await loop.create_connection(
        lambda: SIP(
            rtp=rtp_protocol,
            aor=SipURI.parse("sips:alice:********@example.com"),
            transaction_class=TranscribeInviteTransaction,
        ),
        host="sip.example.com",
        port=5061,
        ssl=ssl_context,
    )
    await asyncio.Future()


asyncio.run(main())

For raw audio access without transcription, subclass AudioCall and override audio_received(self, audio: np.ndarray) instead.

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

voip-0.4.0.tar.gz (59.2 kB view details)

Uploaded Source

Built Distribution

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

voip-0.4.0-py3-none-any.whl (71.6 kB view details)

Uploaded Python 3

File details

Details for the file voip-0.4.0.tar.gz.

File metadata

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

File hashes

Hashes for voip-0.4.0.tar.gz
Algorithm Hash digest
SHA256 e8cf3774e01092f6e933690c29e3b9a4f968a0977c8a13d607f7a5d4143f0fd0
MD5 61c0b16daca01f0368623f586c20c779
BLAKE2b-256 facb7146157871f3e3c708d5fd787eb9b1342481fc0bad9728e934759512e93f

See more details on using hashes here.

Provenance

The following attestation bundles were made for voip-0.4.0.tar.gz:

Publisher: release.yml on codingjoe/VoIP

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

File details

Details for the file voip-0.4.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for voip-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2bf58c48a6a287051dbc0d0748e237a6c8335c1072a3e743004a1287e25a7b15
MD5 6885df20a9fcf067a36eea0ff8d2bcbc
BLAKE2b-256 82eb1b46c506fa2f63dbbe52120b5329aee9ee8d980519e91d751f58fff6a700

See more details on using hashes here.

Provenance

The following attestation bundles were made for voip-0.4.0-py3-none-any.whl:

Publisher: release.yml on codingjoe/VoIP

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