Skip to main content

An implementation of Interactive Connectivity Establishment (RFC 5245)

Project description

rtd pypi-v pypi-pyversions pypi-l pypi-wheel tests codecov

What is aioice?

aioice is a library for Interactive Connectivity Establishment (RFC 5245) in Python. It is built on top of asyncio, Python’s standard asynchronous I/O framework.

Interactive Connectivity Establishment (ICE) is useful for applications that establish peer-to-peer UDP data streams, as it facilitates NAT traversal. Typical usecases include SIP and WebRTC.

To learn more about aioice please read the documentation.

Example

#!/usr/bin/env python

import asyncio
import aioice

async def connect_using_ice():
    connection = aioice.Connection(ice_controlling=True)

    # gather local candidates
    await connection.gather_candidates()

    # send your information to the remote party using your signaling method
    send_local_info(
        connection.local_candidates,
        connection.local_username,
        connection.local_password)

    # receive remote information using your signaling method
    remote_candidates, remote_username, remote_password = get_remote_info()

    # perform ICE handshake
    for candidate in remote_candidates:
        await connection.add_remote_candidate(candidate)
    await connection.add_remote_candidate(None)
    connection.remote_username = remote_username
    connection.remote_password = remote_password
    await connection.connect()

    # send and receive data
    await connection.sendto(b'1234', 1)
    data, component = await connection.recvfrom()

    # close connection
    await connection.close()

asyncio.get_event_loop().run_until_complete(connect_using_ice())

License

aioice is released under the BSD license.

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

aionice_dimos-0.9.0.tar.gz (41.7 kB view details)

Uploaded Source

Built Distribution

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

aionice_dimos-0.9.0-py3-none-any.whl (24.1 kB view details)

Uploaded Python 3

File details

Details for the file aionice_dimos-0.9.0.tar.gz.

File metadata

  • Download URL: aionice_dimos-0.9.0.tar.gz
  • Upload date:
  • Size: 41.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for aionice_dimos-0.9.0.tar.gz
Algorithm Hash digest
SHA256 cba3f1ec5f1f27744675eb82ab3e3675727ea11f065d12f9518bf55771ebdef3
MD5 02018c634949797d56265b7833c022b7
BLAKE2b-256 eb2f83a1f162e9bda976b030cd74b9c72a0044293a7d3959c29c30f3f65a435f

See more details on using hashes here.

File details

Details for the file aionice_dimos-0.9.0-py3-none-any.whl.

File metadata

  • Download URL: aionice_dimos-0.9.0-py3-none-any.whl
  • Upload date:
  • Size: 24.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for aionice_dimos-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 59e061219d8d6dcdbd74dc2a670ec8232bcdf67af4b06919ec683faae3f8a5e0
MD5 18828fcfb6e976c66b825a775f9e48bd
BLAKE2b-256 b96ba91f16131fe29d96714fdf202e6db645b5ff6fdf7b69e90ab02c00878a4b

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