Skip to main content

data channel feature only version of aiortc which implements WebRTC and ORTC

Project description

this repo is special version of aiortc which can be install data channel feature only and it works on windows palatrom.

PRs is already requested. So this is tempolary repository.

Install procedure

::

pip install aiortc-dc

File transfer example of P2P direct communication over NAT (which can run on Windows platform!)

Please See: README_WS_SIGNALING_VERSION_

.. _README_WS_SIGNALING_VERSION: https://github.com/ryogrid/aiortc-dc/blob/pr-websocket-version-filexfer/examples/datachannel-filexfer/README_WS_SIGNALING_VERSION.rst


aiortc

|rtd| |pypi-v| |pypi-pyversions| |pypi-l| |travis| |codecov| |gitter|

.. |rtd| image:: https://readthedocs.org/projects/aiortc/badge/?version=latest :target: https://aiortc.readthedocs.io/

.. |pypi-v| image:: https://img.shields.io/pypi/v/aiortc.svg :target: https://pypi.python.org/pypi/aiortc

.. |pypi-pyversions| image:: https://img.shields.io/pypi/pyversions/aiortc.svg :target: https://pypi.python.org/pypi/aiortc

.. |pypi-l| image:: https://img.shields.io/pypi/l/aiortc.svg :target: https://pypi.python.org/pypi/aiortc

.. |travis| image:: https://img.shields.io/travis/com/aiortc/aiortc.svg :target: https://travis-ci.com/aiortc/aiortc

.. |codecov| image:: https://img.shields.io/codecov/c/github/aiortc/aiortc.svg :target: https://codecov.io/gh/aiortc/aiortc

.. |gitter| image:: https://img.shields.io/gitter/room/aiortc/Lobby.svg :target: https://gitter.im/aiortc/Lobby

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_.

.. _Web Real-Time Communication (WebRTC): https://webrtc.org/ .. _Object Real-Time Communication (ORTC): https://ortc.org/ .. _read the documentation: https://aiortc.readthedocs.io/en/latest/

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, including half-trickle
  • 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

Requirements

In addition to aiortc's Python dependencies you need a couple of libraries installed on your system for media codecs. FFmpeg 3.2 or greater is required.

On Debian/Ubuntu run:

.. code:: bash

apt install libavdevice-dev libavfilter-dev libopus-dev libvpx-dev pkg-config

On OS X run:

.. code:: bash

brew install ffmpeg opus libvpx pkg-config

License

aiortc is released under the BSD license_.

.. _BSD license: https://aiortc.readthedocs.io/en/latest/license.html

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-dc-0.5.5.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

aiortc_dc-0.5.5-py3-none-any.whl (69.5 kB view details)

Uploaded Python 3

File details

Details for the file aiortc-dc-0.5.5.tar.gz.

File metadata

  • Download URL: aiortc-dc-0.5.5.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.1

File hashes

Hashes for aiortc-dc-0.5.5.tar.gz
Algorithm Hash digest
SHA256 e0e49bde9012f51a16f8cd41869d2549df7f605b69c5f9190f9c979549919f7b
MD5 95f4c7a1de5f3716547d58eff8635824
BLAKE2b-256 15227377559982ec946a8d92dfa3a27fe10b06e3dd644806bf54c6bb55c237e7

See more details on using hashes here.

File details

Details for the file aiortc_dc-0.5.5-py3-none-any.whl.

File metadata

  • Download URL: aiortc_dc-0.5.5-py3-none-any.whl
  • Upload date:
  • Size: 69.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.1

File hashes

Hashes for aiortc_dc-0.5.5-py3-none-any.whl
Algorithm Hash digest
SHA256 ccffb2b57754c13ba100978e8acfe782de0b14e54680d06619a8b4068cf8656c
MD5 5878f271d437032e7437b2dfbf2b1b12
BLAKE2b-256 9f47d858393dd8b3c01fdd8f0c2c90947e1c55591a9013cc6dee86b463adc8f0

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