Skip to main content

Bus for anyblok

Project description

.. This file is a part of the AnyBlok / Bus project
..
.. Copyright (C) 2018 Jean-Sebastien SUZANNE <jssuzanne@anybox.fr>
..
.. This Source Code Form is subject to the terms of the Mozilla Public License,
.. v. 2.0. If a copy of the MPL was not distributed with this file,You can
.. obtain one at http://mozilla.org/MPL/2.0/.

.. image:: https://img.shields.io/pypi/pyversions/anyblok_bus.svg?longCache=True
:alt: Python versions

.. image:: https://travis-ci.org/AnyBlok/anyblok_bus.svg?branch=master
:target: https://travis-ci.org/AnyBlok/anyblok_bus
:alt: Build status

.. image:: https://coveralls.io/repos/github/AnyBlok/anyblok_bus/badge.svg?branch=master
:target: https://coveralls.io/github/AnyBlok/anyblok_bus?branch=master
:alt: Coverage

.. image:: https://img.shields.io/pypi/v/anyblok_bus.svg
:target: https://pypi.python.org/pypi/anyblok_bus/
:alt: Version status

.. image:: https://readthedocs.org/projects/anyblok-bus/badge/?version=latest
:alt: Documentation Status
:scale: 100%
:target: https://doc.anyblok-bus.anyblok.org/?badge=latest


AnyBlok / bus
=============

Improve `AnyBlok <http://doc.anyblok.org>`_ to add comunication with bus.

+---------+--------------+------------------------------------------------------------------+
| Blok | Dependancies | Description |
+=========+==============+==================================================================+
| **bus** | | Consume and publish message with |
| | | `pika <https://pika.readthedocs.io>`_ and |
| | | `marshmallow <https://github.com/marshmallow-code/marshmallow>`_ |
+---------+--------------+------------------------------------------------------------------+

AnyBlok / Bus is released under the terms of the `Mozilla Public License`.

See the `latest documentation <http://doc.anyblok-bus.anyblok.org/>`_

.. This file is a part of the AnyBlok / Bus project
..
.. Copyright (C) 2018 Jean-Sebastien SUZANNE <jssuzanne@anybox.fr>
..
.. This Source Code Form is subject to the terms of the Mozilla Public License,
.. v. 2.0. If a copy of the MPL was not distributed with this file,You can
.. obtain one at http://mozilla.org/MPL/2.0/.

.. contents::

Usage
=====

Declare a new consumer
----------------------

In an AnyBlok Model you have to decorate a method with **bus_consumer**

::

from anyblok_bus import bus_consumer
from anyblok import Declarations
from .schema import MySchema

@Declarations.register(Declarations.Model)
class MyModel:

@bus_consumer(queue_name='name of the queue', schema=MySchema())
def my_consumer(cls, body):
# do something


The schema must be an instance of marshmallow.Schema, `see the marshmallow documentation <http://marshmallow.readthedocs.io/en/latest/>`_

.. note::

The decorated method become a classmethod with always the same prototype (cls, body)
body is the desarialization of the message from the queue by the schema.


Publish a message through rabbitmq
----------------------------------

The publication is done by **registry.Bus.publish** method::

registry.Bus.publish('exchange', 'routing_key', message, mimestype)

if the message have not be send, then an exception is raised

..warning::

A profile must be defined and selected by the AnyBlok configuration **bus_profile**

.. This file is a part of the AnyBlok / Bus project
..
.. Copyright (C) 2017 Jean-Sebastien SUZANNE <jssuzanne@anybox.fr>
.. Copyright (C) 2018 Jean-Sebastien SUZANNE <jssuzanne@anybox.fr>
.. Copyright (C) 2019 Jean-Sebastien SUZANNE <js.suzanne@gmail.com>
..
.. This Source Code Form is subject to the terms of the Mozilla Public License,
.. v. 2.0. If a copy of the MPL was not distributed with this file,You can
.. obtain one at http://mozilla.org/MPL/2.0/.

Front Matter
============

Information about the AnyBlok / Bus project.

Project Homepage
----------------

AnyBlok is hosted on `github <http://github.com>`_ - the main project
page is at https://github.com/AnyBlok/anyblok_bus. Source code is
tracked here using `GIT <https://git-scm.com>`_.

Releases and project status are available on Pypi at
http://pypi.python.org/pypi/anyblok_bus.

The most recent published version of this documentation should be at
http://doc.anyblok-bus.anyblok.org.

Installation
------------

Install released versions of AnyBlok from the Python package index with
`pip <http://pypi.python.org/pypi/pip>`_ or a similar tool::

pip install anyblok_bus

Installation via source distribution is via the ``setup.py`` script::

python setup.py install

Installation will add the ``anyblok`` commands to the environment.

Unit Test
---------

Run the test with ``nose``::

pip install nose
nosetests anyblok_bus/tests

Script
------

anyblok_bus add ``console_script`` to launch worker. A worker consume a queue defined
by the decorator **anyblok_bus.bus_consumer**::

anyblok_bus -c anyblok_config_file.cfg

..note:: The profile name in the configuration is used to find the correct url to connect to rabbitmq

Dependencies
------------

AnyBlok / Bus works with **Python >= 3.4** and later and `pika >= 1.0.1 <https://pika.readthedocs.io>`_. The install process will
ensure that `AnyBlok <http://doc.anyblok.org>`_ is installed, in addition to other
dependencies. The latest version of them is strongly recommended.

Author
------

Jean-Sébastien Suzanne

Contributors
------------

`Anybox <http://anybox.fr>`_ team:

* Jean-Sébastien Suzanne
* Florent Jouatte

`Sensee <http://sensee.com>`_ team:

* Julien SZKUDLAPSKI
* Jean-Sébastien Suzanne

Bugs
----

Bugs and feature enhancements to AnyBlok should be reported on the `Issue
tracker <https://github.com/AnyBlok/anyblok_bus/issues>`_.

.. This file is a part of the AnyBlok / Bus project
..
.. Copyright (C) 2018 Jean-Sebastien SUZANNE <jssuzanne@anybox.fr>
.. Copyright (C) 2019 Jean-Sebastien SUZANNE <js.suzanne@gmail.com.fr>
..
.. This Source Code Form is subject to the terms of the Mozilla Public License,
.. v. 2.0. If a copy of the MPL was not distributed with this file,You can
.. obtain one at http://mozilla.org/MPL/2.0/.

.. contents::

CHANGELOG
=========

1.2.0 (2019-06-24)
------------------

* Update version to use pika >= 1.0.1
* Fixed Multiple consumer on the same model
* Refactored bus console script, Added processes parameter on bus_consumer.
The goal is to define processes for one queue, by default all the queues
are in the same process
* Add better logging when a queue is missing. If a queue is missing, then
workers won't start.
* Added adapter parameter to transform bus message, the schema attribute
become now a simple kwargs argument give to adapter.

The adapter is not required.

.. note::

To keep the compatibility, if no adapter is defined with a schema then
the adapter is schema_adapter

1.1.0 (2018-09-15)
------------------

* Improved logging: for helping to debug the messages
* Added create and update date columns
* fixed ``consume_all`` method. now the method does not stop when an exception is raised
* Used marsmallow version >= 3.0.0

1.0.0 (2018-06-05)
------------------

* add Worker to consume the message from rabbitmq
* add publish method to publish a message to rabbitmq
* add **anyblok_bus.bus_consumer** add decorator to défine the consumer

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

anyblok_bus-1.2.0.tar.gz (19.9 kB view details)

Uploaded Source

Built Distribution

anyblok_bus-1.2.0-py3-none-any.whl (28.8 kB view details)

Uploaded Python 3

File details

Details for the file anyblok_bus-1.2.0.tar.gz.

File metadata

  • Download URL: anyblok_bus-1.2.0.tar.gz
  • Upload date:
  • Size: 19.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Python-urllib/3.5

File hashes

Hashes for anyblok_bus-1.2.0.tar.gz
Algorithm Hash digest
SHA256 a3ba26c4323aeb462dc9f284b35d19079e5d1df96d1428a338a72e6b1c9786df
MD5 c1f42ec78cf4de285f2b7dba23f6e3f6
BLAKE2b-256 11fc19577f8458559479e6005fa296df9d36648c2f1a4acc70059f815c9f3769

See more details on using hashes here.

File details

Details for the file anyblok_bus-1.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for anyblok_bus-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 20671d1b280813fae9726a0119e320c8e667be24b849ccd88327c4a4cf99151d
MD5 8ba3eaab9692f8396f6def2d8d1b2a6b
BLAKE2b-256 80d8d4d955b7a73178524ed20d0c8773a9877c3f1f4c5f5947d68507e7d40989

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