Skip to main content

A Quart thing to handle pubsub tasks in particular the event source

Project description

bovine_pubsub

Note: Development of bovine_pubsub will probably be discontinued

bovine_pubsub is a simple wrapper to enable server sent events in bovine. These are used to communicate real time with clients without forcing them to use polling. If multiple workers are used with bovine, one needs to use Redis as the implementation with queues only works for a single process.

Starting with bovine-pubsub support for server side clients is available using AMQP. See examples/bovine_listen.py for details.

Usage

The simplest usage example is given by

from quart import Quart
from bovine_pubsub import BovinePubSub

app = Quart(__name__)
BovinePubSub(app)

it adds the config variable app.config["bovine_pub_sub"] to the Quart application. By calling

await app.config["bovine_pub_sub"].send("channel:test", b"test")

one sends the bytes b"test" to the channel channel:test. By calling

pub_sub.event_stream("channel:test")

one receives an async iterator that can be used as server sent events.

Example usage

A usage example is provided by examples/basic_app.py. By running

python examples/basic.app

one can start a server that sends "test" 10 times a new socket is opened on localhost:5000. The above implementation will use the local queues. To use with Redis start

BOVINE_REDIS=redis://localhost:6379 python examples/basic_app.py 

with an appropriate value for the environment variable BOVINE_REDIS.

Running tests

Testing redis can be done inside of the docker compose setup, e.g.

docker compose up -d
docker compose run main /bin/sh
cd bovine_pubsub
poetry install
poetry run pytest
BOVINE_REDIS=redis://redis:6379 poetry run pytest
BOVINE_AMQP=amqp://rabbitmq poetry run pytest

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

bovine_pubsub-0.5.19.tar.gz (4.3 kB view details)

Uploaded Source

Built Distribution

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

bovine_pubsub-0.5.19-py3-none-any.whl (6.8 kB view details)

Uploaded Python 3

File details

Details for the file bovine_pubsub-0.5.19.tar.gz.

File metadata

  • Download URL: bovine_pubsub-0.5.19.tar.gz
  • Upload date:
  • Size: 4.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.11.3 Linux/6.12.32+bpo-amd64

File hashes

Hashes for bovine_pubsub-0.5.19.tar.gz
Algorithm Hash digest
SHA256 58123276f21f8ebb85a3af0f444236286fec4dae8a12280bbedfee6b678a1759
MD5 00a3bcbc096c12203ff261541f1c9b0a
BLAKE2b-256 ea9445fc224bec0468521f512f50a0461e7bec61c6c84b6a45a50c4b750c8f78

See more details on using hashes here.

File details

Details for the file bovine_pubsub-0.5.19-py3-none-any.whl.

File metadata

  • Download URL: bovine_pubsub-0.5.19-py3-none-any.whl
  • Upload date:
  • Size: 6.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.11.3 Linux/6.12.32+bpo-amd64

File hashes

Hashes for bovine_pubsub-0.5.19-py3-none-any.whl
Algorithm Hash digest
SHA256 e0568a3ed5d31689674e07d0a1e5b8b58e6d06be685e1a01acc15acc4ef4ccc1
MD5 ac62062a76e3e2f7ea6d022ac8f99ff4
BLAKE2b-256 cfad98581f88d1b4e4dd6b24fa53176dc2369b6c12b07d5e410e958dc112d5d6

See more details on using hashes here.

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