Metadata-Version: 1.1
Name: dj-webhooks
Version: 0.1.0
Summary: Django + Webhooks Made Easy
Home-page: https://github.com/pydanny/dj-webhooks
Author: Daniel Greenfeld
Author-email: pydanny@gmail.com
License: BSD
Description: =============================
        dj-webhooks
        =============================
        
        .. image:: https://badge.fury.io/py/dj-webhooks.png
            :target: https://badge.fury.io/py/dj-webhooks
        
        .. image:: https://pypip.in/wheel/dj-webhooks/badge.png
            :target: https://pypi.python.org/pypi/dj-webhooks/
            :alt: Wheel Status
        
        .. image:: https://travis-ci.org/pydanny/dj-webhooks.png?branch=master
            :target: https://travis-ci.org/pydanny/dj-webhooks
        
        Django + Webhooks Made Easy
        
        **Warning:** Still in pre-alpha status. Not used in production on ANYTHING.
        
        Documentation
        -------------
        
        The full documentation is at https://dj-webhooks.readthedocs.org.
        
        Requirements
        ------------
        
        * django>=1.5.5
        * webhooks
        * django-jsonfield
        
        Quickstart
        ----------
        
        Install dj-webhooks::
        
            pip install dj-webhooks
        
        Configure some webhook events:
        
        .. code-block:: python
        
            # settings.py
            WEBHOOK_EVENTS = (
                "purchase.paid",
                "purchase.refunded",
                "purchase.fulfilled"
            )
        
        Add some webhook targets:
        
        .. code-block:: python
        
            from django.contrib.auth import get_user_model
            User = get_user_model()
            user = User.objects.get(username="pydanny")
        
            from webhooks.models import Webhook
            WebhookTarget.objects.create(
                owner=user,
                event="purchase.confirmed",
                target_url="https://mystorefront.com/webhooks/",
                header_content_type=Webhook.CONTENT_TYPE_JSON,
            )
        
        Then use it in a project:
        
            from django.contrib.auth import get_user_model
            User = get_user_model()
            user = User.objects.get(username="pydanny")
        
            from djwebhooks.decorators import webhook
        
            from myproject.models import Purchase
        
            # Event argument helps identify the webhook target
            @hook(event="purchase.paid")
            def send_purchase_confirmation(purchase, webhook_owner):
                # Webhook_owner also helps identify the webhook target
                return {
                    "order_num": purchase.order_num,
                    "date": purchase.confirm_date,
                    "line_items": [x.sku for x in purchase.lineitem_set.filter(inventory__gt=0)]
                }
        
            for purchase in Purchase.objects.filter(status="paid"):
                send_purchase_confirmation(purchase, user)
        
        
        Requirements
        -------------
        
        * Python 2.7.x or 3.3.2 or higher
        * Django 1.5 or higher
        
        Features
        --------
        
        * Synchronous webhooks
        * Delivery tracking via Django ORM.
        
        Planned Features
        -----------------
        
        * Options for asynchronous webhooks
        * Delivery tracking via Redis and other write-fast datastores.
        
        
        
        
        History
        -------
        
        0.1.0 (2014-05-12)
        ++++++++++++++++++
        
        * First release on PyPI.
Keywords: dj-webhooks
Platform: UNKNOWN
Classifier: Development Status :: 2 - Pre-Alpha
Classifier: Framework :: Django
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: BSD License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
