Skip to main content

Django Channels, without the Pain

Project description

django-channels-handlers

Latest PyPI version image

Django Channels consumers, without the Pain 💊

django-channels-handers is an abstraction for Django Channels that makes it easy to implement elegant protocols without having to worry about the communication layer.

Requirements

  • Django>=2.1
  • channels~=2.4
  • pydantic~=1.4

Usage

Install django-channels-handlers from pypi:

pip install django-channels-handlers

Create pydantic models for each message you intend to handle. This allows the handler to validate the message and parse it into an object.

from pydantic import BaseModel, UUID4
from typing import Dict, Optional
from datetime import datetime


class ChatMessage(BaseModel):
    type: str = "chat.message"
    id: UUID4
    thread: UUID4
    sender: UUID4
    content: str
    data: Optional[Dict] = {}
    created: datetime

Create a message handler.

This will first validate and parse a message that matches handled_types using the corresponding entry in models. It will then execute the method specified in handled_types, passing the newly parsed message object.

from channels_handlers.handlers import MessageHandler
# For async, import AsyncMessageHandler


class ChatHandler(MessageHandler):
    namespace = "chat"
    models = {
        "chat.message": ChatMessage,
    }

    def message(self, message):
        # Some logic with message, e.g. save to database
        pass

Import ConsumerHandlerMixin and add it to your Django Channels consumer. Then, add your custom handler to the consumer's handler_classes.

from channels_handlers.consumers import ConsumerHandlerMixin
# For async, import AsyncConsumerHandlerMixin
from channels.generic.websocket import JsonWebsocketConsumer


class MyConsumer(ConsumerHandlerMixin, JsonWebsocketConsumer):
    handler_classes = [ChatHandler]

Compatibility

django-channels-handlers is compatible with Python 3.7+, Django 2.2+, and Django Channels 2.2+.

License

django-channels-handlers is licensed under the MIT License.

Authors

See AUTHORS.md.

Contributing

django-channels-handlers relies on the contributions of talented coders like you. See CONTRIBUTING.md for more information.

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

django-channels-handlers-0.2.2.tar.gz (4.7 kB view details)

Uploaded Source

Built Distribution

django_channels_handlers-0.2.2-py3-none-any.whl (4.9 kB view details)

Uploaded Python 3

File details

Details for the file django-channels-handlers-0.2.2.tar.gz.

File metadata

  • Download URL: django-channels-handlers-0.2.2.tar.gz
  • Upload date:
  • Size: 4.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.10 CPython/3.8.5 Darwin/19.6.0

File hashes

Hashes for django-channels-handlers-0.2.2.tar.gz
Algorithm Hash digest
SHA256 898edde81d5e3cbdca0e5af0fe7a52bb037dba3e769ad2c5ab422e5545901dfb
MD5 6d26d0d1dd8e295d984c281ca47d45a6
BLAKE2b-256 1abcb8d400abe8e360ecbc8a3c557f4fc03f14712d0c3e01792039c88296a726

See more details on using hashes here.

File details

Details for the file django_channels_handlers-0.2.2-py3-none-any.whl.

File metadata

File hashes

Hashes for django_channels_handlers-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 379b3ebcc26f613b722ef476b785da846cb7ff08a397d909cf75949138f15143
MD5 a547ff284978a8d8b990c8187ae3d8e5
BLAKE2b-256 1977a4aba9f93ac932a619ebb0cc8d944dcf9bb1d10040380be65705409f6bfb

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