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