Skip to main content

An implementation of WebRTC and ORTC

Project description

aiortc License Version Python versions Tests Coverage Documentation

This is a fork of the aiortc project with slight modification neeeded in the crosslab project

What is aiortc?

aiortc is a library for Web Real-Time Communication (WebRTC) and Object Real-Time Communication (ORTC) in Python. It is built on top of asyncio, Python’s standard asynchronous I/O framework.

The API closely follows its Javascript counterpart while using pythonic constructs:

  • promises are replaced by coroutines

  • events are emitted using pyee.EventEmitter

To learn more about aiortc please read the documentation.

Why should I use aiortc?

The main WebRTC and ORTC implementations are either built into web browsers, or come in the form of native code. While they are extensively battle tested, their internals are complex and they do not provide Python bindings. Furthermore they are tightly coupled to a media stack, making it hard to plug in audio or video processing algorithms.

In contrast, the aiortc implementation is fairly simple and readable. As such it is a good starting point for programmers wishing to understand how WebRTC works or tinker with its internals. It is also easy to create innovative products by leveraging the extensive modules available in the Python ecosystem. For instance you can build a full server handling both signaling and data channels or apply computer vision algorithms to video frames using OpenCV.

Furthermore, a lot of effort has gone into writing an extensive test suite for the aiortc code to ensure best-in-class code quality.

Implementation status

aiortc allows you to exchange audio, video and data channels and interoperability is regularly tested against both Chrome and Firefox. Here are some of its features:

  • SDP generation / parsing

  • Interactive Connectivity Establishment, with half-trickle and mDNS support

  • DTLS key and certificate generation

  • DTLS handshake, encryption / decryption (for SCTP)

  • SRTP keying, encryption and decryption for RTP and RTCP

  • Pure Python SCTP implementation

  • Data Channels

  • Sending and receiving audio (Opus / PCMU / PCMA)

  • Sending and receiving video (VP8 / H.264)

  • Bundling audio / video / data channels

  • RTCP reports, including NACK / PLI to recover from packet loss

Installing

The easiest way to install aiortc is to run:

pip install aiortc

Building from source

If there are no wheels for your system or if you wish to build aiortc from source you will need a couple of libraries installed on your system:

  • Opus for audio encoding / decoding

  • LibVPX for video encoding / decoding

Linux

On Debian/Ubuntu run:

apt install libopus-dev libvpx-dev

OS X

On OS X run:

brew install opus libvpx

License

aiortc 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

crosslab_aiortc-1.9.0.tar.gz (1.2 MB view hashes)

Uploaded Source

Built Distributions

crosslab_aiortc-1.9.0-pp310-pypy310_pp73-win_amd64.whl (1.0 MB view hashes)

Uploaded PyPy Windows x86-64

crosslab_aiortc-1.9.0-pp310-pypy310_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.8 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

crosslab_aiortc-1.9.0-pp310-pypy310_pp73-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (1.9 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

crosslab_aiortc-1.9.0-pp310-pypy310_pp73-macosx_11_0_arm64.whl (889.1 kB view hashes)

Uploaded PyPy macOS 11.0+ ARM64

crosslab_aiortc-1.9.0-pp310-pypy310_pp73-macosx_10_15_x86_64.whl (1.2 MB view hashes)

Uploaded PyPy macOS 10.15+ x86-64

crosslab_aiortc-1.9.0-pp39-pypy39_pp73-win_amd64.whl (1.0 MB view hashes)

Uploaded PyPy Windows x86-64

crosslab_aiortc-1.9.0-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.8 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

crosslab_aiortc-1.9.0-pp39-pypy39_pp73-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (1.9 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

crosslab_aiortc-1.9.0-pp39-pypy39_pp73-macosx_11_0_arm64.whl (889.1 kB view hashes)

Uploaded PyPy macOS 11.0+ ARM64

crosslab_aiortc-1.9.0-pp39-pypy39_pp73-macosx_10_15_x86_64.whl (1.2 MB view hashes)

Uploaded PyPy macOS 10.15+ x86-64

crosslab_aiortc-1.9.0-pp38-pypy38_pp73-win_amd64.whl (1.0 MB view hashes)

Uploaded PyPy Windows x86-64

crosslab_aiortc-1.9.0-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.8 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

crosslab_aiortc-1.9.0-pp38-pypy38_pp73-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (1.9 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

crosslab_aiortc-1.9.0-pp38-pypy38_pp73-macosx_11_0_arm64.whl (889.1 kB view hashes)

Uploaded PyPy macOS 11.0+ ARM64

crosslab_aiortc-1.9.0-pp38-pypy38_pp73-macosx_10_9_x86_64.whl (1.2 MB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

crosslab_aiortc-1.9.0-cp38-abi3-win_amd64.whl (1.0 MB view hashes)

Uploaded CPython 3.8+ Windows x86-64

crosslab_aiortc-1.9.0-cp38-abi3-win32.whl (922.6 kB view hashes)

Uploaded CPython 3.8+ Windows x86

crosslab_aiortc-1.9.0-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.9 MB view hashes)

Uploaded CPython 3.8+ manylinux: glibc 2.17+ x86-64

crosslab_aiortc-1.9.0-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (1.8 MB view hashes)

Uploaded CPython 3.8+ manylinux: glibc 2.17+ ARM64

crosslab_aiortc-1.9.0-cp38-abi3-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (1.9 MB view hashes)

Uploaded CPython 3.8+ manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

crosslab_aiortc-1.9.0-cp38-abi3-macosx_11_0_arm64.whl (896.3 kB view hashes)

Uploaded CPython 3.8+ macOS 11.0+ ARM64

crosslab_aiortc-1.9.0-cp38-abi3-macosx_10_9_x86_64.whl (1.2 MB view hashes)

Uploaded CPython 3.8+ macOS 10.9+ x86-64

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