A simple implementation of STOMP with Django
Project description
Django Stomp
A simple implementation of STOMP with Django.
It is heavily tied to ActiveMQ, but can work with any broker which supports STOMP with minor or none adjustments.
Installation
pip install django_stomp
Add django_stomp
in your INSTALLED_APPS
and so be it.
Configuration process
Not yet fully available, but feel free to see our tests to get insights.
Consumer
First you must create a function which receives an parameter of type django_stomp.services.consumer.Payload
. Let's suppose the module app.sample
with the following content:
import logging
from django_stomp.services.consumer import Payload
logger = logging.getLogger(__name__)
def my_honest_logic(payload: Payload) -> None:
logger.info("Yeah, I received a payload from django-stomp!")
my_payload = payload.body
my_header = payload.headers
if my_payload.get("my-dict-key"):
payload.ack()
else:
logger.info("To DLQ!")
payload.nack()
Now you must provide broker connection details filling out the following parameters at least:
- STOMP_SERVER_HOST
- STOMP_SERVER_PORT
- STOMP_USE_SSL
And just create the job issuing the following command:
python manage.py pubsub "/queue/your-stuff" app.sample.my_honest_logic
That's it ✌️
Tests
In order to execute the tests, first do the following:
docker-compose up -d
Then:
pipenv run tox
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for django_stomp-0.0.15-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 95fedce6a6e3705460bc28613ff1aa6b6f876265c80f7240c4d1afd3c1cd9f5f |
|
MD5 | 3a37f6130e4f1b2d545118dc745b1d28 |
|
BLAKE2b-256 | 9d23c1c8378851a6d3fc902f852ae305fc5bb18d48b9e654e49cf295d82e804f |