Skip to main content

WebSocket emulation - SockJS server for django channels.

Project description

sockjs-channels

sockjs-channels is a SockJS integration for Django Channels, some features are referenced from sockjs-aiohttp. sockjs-channels interface is implemented as a ASGI routing, it runs inside a ASGI application rather than ASGI server. Its possible to create any number of different sockjs routings, ie /sockjs/* or /chat-sockjs/*. You can provide different session implementation and management for each sockjs routing.

Requirements

  • Python 3.6+
  • Django 3.2+
  • Channels 3.0.0+

Installation

$ pip install sockjs-channels

ASGI routing

Here’s an example of asgi.py might look like:

import os

from channels.routing import ProtocolTypeRouter, URLRouter
from django.core.asgi import get_asgi_application
from django.urls import re_path

from sockjs import make_routing

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'chat.settings')

# Initialize Django ASGI application early to ensure the AppRegistry
# is populated before importing code that may import ORM models.
django_asgi_app = get_asgi_application()

from chat.views import chat_msg_handler

routing = make_routing(chat_msg_handler, name='chat')

# Add django's url routing
routing.http.append(re_path(r'', django_asgi_app))

application = ProtocolTypeRouter({
    'http': URLRouter([
        *routing.http,
    ]),
    'websocket': URLRouter([
        *routing.websocket
    ]),
})

Supported transports

  • websocket
  • xhr-streaming
  • xhr-polling
  • iframe-xhr-polling
  • iframe-eventsource
  • iframe-htmlfile
  • jsonp-polling

Examples

You can find a simple chat example in the sockjs-channels repository at github.

https://github.com/iTraceur/sockjs-channels/tree/master/examples

License

sockjs-channels is offered under the MIT license.

Test Coverage

Name                                Stmts   Miss Branch BrPart  Cover
---------------------------------------------------------------------
sockjs/routing.py                     116     15     30     10    83%
sockjs/session.py                     305      6    118     13    96%
sockjs/transports/base.py             137     19     38      8    83%
sockjs/transports/eventsource.py       22      0      6      1    96%
sockjs/transports/htmlfile.py          39      0     10      1    98%
sockjs/transports/rawwebsocket.py      50     19     18      5    56%
sockjs/transports/utils.py             26      3      6      3    81%
sockjs/transports/websocket.py         62     29     16      3    51%
---------------------------------------------------------------------
TOTAL                                 942     91    280     44    88%

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

sockjs-channels-0.1.0.tar.gz (15.7 kB view hashes)

Uploaded Source

Built Distribution

sockjs_channels-0.1.0-py3-none-any.whl (20.9 kB view hashes)

Uploaded Python 3

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