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

realtime_aioice-0.9.0.tar.gz (42.3 kB view details)

Uploaded Source

Built Distribution

realtime_aioice-0.9.0-py3-none-any.whl (24.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: realtime_aioice-0.9.0.tar.gz
  • Upload date:
  • Size: 42.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.3

File hashes

Hashes for realtime_aioice-0.9.0.tar.gz
Algorithm Hash digest
SHA256 a0fb283809b2c37cd1c2c9c73b220bbd125e2d87ea412b9577e17fb6fa34b2da
MD5 f3446b5e54c35cb168998fadcae8a30c
BLAKE2b-256 2abbd2d74c05ab10b34f1ebfc8f989652f17d591b80a0925ecaf468eaec473d9

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for realtime_aioice-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 094d87866995da707dfefc6710d57987e674b0e7e82a01a83336c5d8cb7bf9c3
MD5 75bcd626b215ba5c051613a74c22026c
BLAKE2b-256 9502fa5f6f721029ef5c645e05cf0518bd062ef9807c0e661f64309269a7f0d5

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page