Skip to main content

An implementation of WebRTC and ORTC

Project description

aiortc License Version Python versions Tests Coverage Documentation

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

pip install aiortc-h264-nvenc

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

aiortc_h264_nvenc-1.14.0.post8.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

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

aiortc_h264_nvenc-1.14.0.post8-py3-none-any.whl (94.8 kB view details)

Uploaded Python 3

File details

Details for the file aiortc_h264_nvenc-1.14.0.post8.tar.gz.

File metadata

File hashes

Hashes for aiortc_h264_nvenc-1.14.0.post8.tar.gz
Algorithm Hash digest
SHA256 fa541db249c5a448b524de1580004db38e20be594afb59376938348fc5dc6dfd
MD5 de42a5d670c1dcafb898f6bfa15c88ba
BLAKE2b-256 a8c8693065281eaba2f70d3eaa36e124cccfb93cb99ea24fb56e6444479f4ee2

See more details on using hashes here.

Provenance

The following attestation bundles were made for aiortc_h264_nvenc-1.14.0.post8.tar.gz:

Publisher: release.yml on onezillion/aiortc_h264_nvenc

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

File details

Details for the file aiortc_h264_nvenc-1.14.0.post8-py3-none-any.whl.

File metadata

File hashes

Hashes for aiortc_h264_nvenc-1.14.0.post8-py3-none-any.whl
Algorithm Hash digest
SHA256 a8b725ebc54c70816a2e2b8381cf5699d9e3331e3122d52a94378418985445fc
MD5 012485e50ed0994bbb85800c2b11a921
BLAKE2b-256 89c79ee7d3cbcbb91d8f2f9703713ccdd6580d4dd0d3c79178bfad264a24697a

See more details on using hashes here.

Provenance

The following attestation bundles were made for aiortc_h264_nvenc-1.14.0.post8-py3-none-any.whl:

Publisher: release.yml on onezillion/aiortc_h264_nvenc

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