Source code for django_celery_results.backends.cache
"""Celery cache backend using the Django Cache Framework."""
from celery.backends.base import KeyValueStoreBackend
from django.core.cache import cache as default_cache
from django.core.cache import caches
from kombu.utils.encoding import bytes_to_str
[docs]class CacheBackend(KeyValueStoreBackend):
"""Backend using the Django cache framework to store task metadata."""
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
# Must make sure backend doesn't convert exceptions to dict.
self.serializer = 'pickle'
[docs] def get(self, key):
key = bytes_to_str(key)
return self.cache_backend.get(key)
[docs] def set(self, key, value):
key = bytes_to_str(key)
self.cache_backend.set(key, value, self.expires)
[docs] def delete(self, key):
key = bytes_to_str(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