__init__.py 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. # -*- coding: utf-8 -*-
  2. """
  3. celery.backends
  4. ~~~~~~~~~~~~~~~
  5. Backend abstract factory (...did I just say that?) and alias definitions.
  6. """
  7. from __future__ import absolute_import
  8. import sys
  9. from celery.local import Proxy
  10. from celery._state import current_app
  11. from celery.five import reraise
  12. from celery.utils.imports import symbol_by_name
  13. __all__ = ['get_backend_cls', 'get_backend_by_url']
  14. UNKNOWN_BACKEND = """\
  15. Unknown result backend: {0!r}. Did you spell that correctly? ({1!r})\
  16. """
  17. BACKEND_ALIASES = {
  18. 'amqp': 'celery.backends.amqp:AMQPBackend',
  19. 'rpc': 'celery.backends.rpc.RPCBackend',
  20. 'cache': 'celery.backends.cache:CacheBackend',
  21. 'redis': 'celery.backends.redis:RedisBackend',
  22. 'mongodb': 'celery.backends.mongodb:MongoBackend',
  23. 'db': 'celery.backends.database:DatabaseBackend',
  24. 'database': 'celery.backends.database:DatabaseBackend',
  25. 'cassandra': 'celery.backends.cassandra:CassandraBackend',
  26. 'couchbase': 'celery.backends.couchbase:CouchBaseBackend',
  27. 'couchdb': 'celery.backends.couchdb:CouchDBBackend',
  28. 'riak': 'celery.backends.riak:RiakBackend',
  29. 'file': 'celery.backends.filesystem:FilesystemBackend',
  30. 'disabled': 'celery.backends.base:DisabledBackend',
  31. }
  32. #: deprecated alias to ``current_app.backend``.
  33. default_backend = Proxy(lambda: current_app.backend)
  34. def get_backend_cls(backend=None, loader=None):
  35. """Get backend class by name/alias"""
  36. backend = backend or 'disabled'
  37. loader = loader or current_app.loader
  38. aliases = dict(BACKEND_ALIASES, **loader.override_backends)
  39. try:
  40. return symbol_by_name(backend, aliases)
  41. except ValueError as exc:
  42. reraise(ValueError, ValueError(UNKNOWN_BACKEND.format(
  43. backend, exc)), sys.exc_info()[2])
  44. def get_backend_by_url(backend=None, loader=None):
  45. url = None
  46. if backend and '://' in backend:
  47. url = backend
  48. scheme, _, _ = url.partition('://')
  49. if '+' in scheme:
  50. backend, url = url.split('+', 1)
  51. else:
  52. backend = scheme
  53. return get_backend_cls(backend, loader), url