views.py 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. """celery.views"""
  2. from django.http import HttpResponse, Http404
  3. from celery.task import tasks, is_done, apply_async
  4. from celery.result import AsyncResult
  5. from anyjson import serialize as JSON_dump
  6. def apply(request, task_name, *args):
  7. """View applying a task.
  8. Example:
  9. http://e.com/celery/apply/task_name/arg1/arg2//?kwarg1=a&kwarg2=b
  10. **NOTE** Use with caution, preferably not make this publicly accessible
  11. without ensuring your code is safe!
  12. """
  13. kwargs = request.method == "POST" and \
  14. request.POST.copy() or request.GET.copy()
  15. kwargs = dict((key.encode("utf-8"), value)
  16. for key, value in kwargs.items())
  17. if task_name not in tasks:
  18. raise Http404("apply: no such task")
  19. task = tasks[task_name]
  20. result = apply_async(task, args=args, kwargs=kwargs)
  21. response_data = {"ok": "true", "task_id": result.task_id}
  22. return HttpResponse(JSON_dump(response_data), mimetype="application/json")
  23. def is_task_done(request, task_id):
  24. """Returns task execute status in JSON format."""
  25. response_data = {"task": {"id": task_id, "executed": is_done(task_id)}}
  26. return HttpResponse(JSON_dump(response_data), mimetype="application/json")
  27. def task_status(request, task_id):
  28. """Returns task status and result in JSON format."""
  29. async_result = AsyncResult(task_id)
  30. status = async_result.status
  31. result = async_result.result
  32. if status in ("FAILURE", "RETRY"):
  33. response_data = {
  34. "id": task_id,
  35. "status": status,
  36. "result": result.args[0],
  37. "traceback": result.traceback,
  38. }
  39. else:
  40. response_data = {
  41. "id": task_id,
  42. "status": status,
  43. "result": result,
  44. }
  45. return HttpResponse(JSON_dump({"task": response_data}),
  46. mimetype="application/json")