Source code for django_celery_results.backends.cache

"""Celery cache backend using the Django Cache Framework."""
from __future__ import absolute_import, unicode_literals

from django.core.cache import cache as default_cache, caches

from celery.backends.base import KeyValueStoreBackend


[docs]class CacheBackend(KeyValueStoreBackend): """Backend using the Django cache framework to store task metadata.""" def __init__(self, *args, **kwargs): super(CacheBackend, self).__init__(*args, **kwargs) # Must make sure backend doesn't convert exceptions to dict. self.serializer = 'pickle'
[docs] def get(self, key): return self.cache_backend.get(key)
[docs] def set(self, key, value): self.cache_backend.set(key, value, self.expires)
[docs] def delete(self, key): self.cache_backend.delete(key)
[docs] def encode(self, data): return data
[docs] def decode(self, data): return data
@property def cache_backend(self): backend = self.app.conf.cache_backend return caches[backend] if backend else default_cache