| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 | .. _guide-webhooks:================================ HTTP Callback Tasks (Webhooks)================================.. module:: celery.task.http.. contents::    :local:.. _webhook-basics:Basics======If you need to call into another language, framework or similar, you cando so by using HTTP callback tasks.The HTTP callback tasks uses GET/POST data to pass arguments and returnsresult as a JSON response. The scheme to call a task is:.. code-block:: http    GET HTTP/1.1 http://example.com/mytask/?arg1=a&arg2=b&arg3=cor using POST:.. code-block:: http    POST HTTP/1.1 http://example.com/mytask.. note::    POST data needs to be form encoded.Whether to use GET or POST is up to you and your requirements.The web page should then return a response in the following formatif the execution was successful:.. code-block:: javascript    {'status': 'success', 'retval': …}or if there was an error:.. code-block:: javascript    {'status': 'failure', 'reason': 'Invalid moon alignment.'}Enabling the HTTP task----------------------To enable the HTTP dispatch task you have to add :mod:`celery.task.http`to :setting:`imports`, or start the worker with ``-Icelery.task.http``... _webhook-django-example:Django webhook example======================With this information you could define a simple task in Django:.. code-block:: python    from django.http import HttpResponse    from json import dumps    def multiply(request):        x = int(request.GET['x'])        y = int(request.GET['y'])        result = x * y        response = {'status': 'success', 'retval': result}        return HttpResponse(dumps(response), mimetype='application/json').. _webhook-rails-example:Ruby on Rails webhook example=============================or in Ruby on Rails:.. code-block:: ruby    def multiply        @x = params[:x].to_i        @y = params[:y].to_i        @status = {:status => 'success', :retval => @x * @y}        render :json => @status    endYou can easily port this scheme to any language/framework;new examples and libraries are very welcome... _webhook-calling:Calling webhook tasks=====================To call a task you can use the :class:`~celery.task.http.URL` class:.. code-block:: pycon    >>> from celery.task.http import URL    >>> res = URL('http://example.com/multiply').get_async(x=10, y=10):class:`~celery.task.http.URL` is a shortcut to the :class:`HttpDispatchTask`.You can subclass this to extend thefunctionality:.. code-block:: pycon    >>> from celery.task.http import HttpDispatchTask    >>> res = HttpDispatchTask.delay(    ...     url='http://example.com/multiply',    ...     method='GET', x=10, y=10)    >>> res.get()    100The output of :program:`celery worker` (or the log file if enabled) should show thetask being executed::    [INFO/MainProcess] Task celery.task.http.HttpDispatchTask            [f2cc8efc-2a14-40cd-85ad-f1c77c94beeb] processed: 100Since calling tasks can be done via HTTP using the:func:`djcelery.views.apply` view, calling tasks from other languages is easy.For an example service exposing tasks via HTTP you should have a look at`examples/celery_http_gateway` in the Celery distribution:http://github.com/celery/celery/tree/master/examples/celery_http_gateway/
 |