Skip to main content

RDBM like triggers for MongoDB

Project description

https://api.travis-ci.org/drorasaf/mongotriggers.svg?branch=master https://coveralls.io/repos/github/drorasaf/mongotriggers/badge.svg?branch=master https://img.shields.io/pypi/v/mongotriggers.svg https://img.shields.io/pypi/dm/mongotriggers.svg

What is this?

mongodb-triggers is a light-weight library to allow trigger capabilities with mongodb. the triggers are similar to ones that can be found in RDBM, although it is not on the server side but on the client side.

What is it good for?

Modern applications have become near real-time response and updates, this leads to the requirement that any changes done in the data to be propagated up to the top level of the application as soon as possible.

In order to allow this to happen, any changes in the databases must be notified, similar project that use this method is https://github.com/meteor/meteor.

Installation

PyInstaller is available on PyPI. You can install it through pip:

$ pip install mongotriggers

How to use?

Let’s assume the system in development is a financial one, and every deletion in the database is extremely important, so we would like to notified for each deletion.

from mongotrigger import MongoTrigger
from pymongo import MongoClient

def notify_manager(op_document):
    print ('wake up! someone is stealing money')

def myfunc():
    client = MongoClient(host='localhost', port=27017)
    triggers = MongoTrigger(conn)
    triggers.register_delete_trigger(notify_manager, 'my_account', 'my_transactions')
    thread = threading.Thread(target=triggers.listen_start)
    thread.start()

    // do something impressive

    triggers.listen_stop()
    thread.join()

Keep in mind that it is meant to run in a defered context in order to run endlessly until it is cancelled.

API

The API functionality includes:

  • register_insert_trigger

  • register_update_trigger

  • register_delete_trigger

  • listen_start

  • listen_stop

Testing

In order to develop, the additional requirements are:

  • pytest

  • pytest-cov

  • tox

All packages can be installed using pip. The easiest way to run the tests is to run tox.

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

mongotriggers-1.0.1.tar.gz (6.1 kB view hashes)

Uploaded Source

Built Distribution

mongotriggers-1.0.1-py2.py3-none-any.whl (5.9 kB view hashes)

Uploaded Python 2 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