Source code for libbot.cache.classes.cache_memcached

import logging
from logging import Logger
from typing import Dict, Any, Optional

from pymemcache import Client

from .cache import Cache
from ..utils._objects import _json_to_string, _string_to_json

logger: Logger = logging.getLogger(__name__)


[docs] class CacheMemcached(Cache): client: Client def __init__( self, client: Client, prefix: Optional[str] = None, default_ttl_seconds: Optional[int] = None ) -> None: self.client: Client = client self.prefix: str | None = prefix self.default_ttl_seconds: int = default_ttl_seconds if default_ttl_seconds is not None else 0 logger.info("Initialized Memcached for caching")
[docs] @classmethod def from_config(cls, engine_config: Dict[str, Any], prefix: Optional[str] = None) -> "CacheMemcached": if "uri" not in engine_config: raise KeyError( "Cache configuration is invalid. Please check if all keys are set (engine: memcached)" ) return cls(Client(engine_config["uri"], default_noreply=True), prefix=prefix)
def _get_prefixed_key(self, key: str) -> str: return key if self.prefix is None else f"{self.prefix}_{key}"
[docs] def get_json(self, key: str) -> Any | None: key = self._get_prefixed_key(key) try: result: Any | None = self.client.get(key, None) logger.debug( "Got json cache key '%s'%s", key, "" if result is not None else " (not found)", ) except Exception as exc: logger.error("Could not get json cache key '%s' due to: %s", key, exc) return None return None if result is None else _string_to_json(result)
[docs] def get_string(self, key: str) -> str | None: key = self._get_prefixed_key(key) try: result: str | None = self.client.get(key, None) logger.debug( "Got string cache key '%s'%s", key, "" if result is not None else " (not found)", ) return result except Exception as exc: logger.error("Could not get string cache key '%s' due to: %s", key, exc) return None
# TODO Implement binary deserialization
[docs] def get_object(self, key: str) -> Any | None: raise NotImplementedError()
[docs] def set_json(self, key: str, value: Any, ttl_seconds: Optional[int] = None) -> None: key = self._get_prefixed_key(key) try: self.client.set( key, _json_to_string(value), expire=self.default_ttl_seconds if ttl_seconds is None else ttl_seconds, ) logger.debug("Set json cache key '%s'", key) except Exception as exc: logger.error("Could not set json cache key '%s' due to: %s", key, exc) return None
[docs] def set_string(self, key: str, value: str, ttl_seconds: Optional[int] = None) -> None: key = self._get_prefixed_key(key) try: self.client.set( key, value, expire=self.default_ttl_seconds if ttl_seconds is None else ttl_seconds ) logger.debug("Set string cache key '%s'", key) except Exception as exc: logger.error("Could not set string cache key '%s' due to: %s", key, exc) return None
# TODO Implement binary serialization
[docs] def set_object(self, key: str, value: Any, ttl_seconds: Optional[int] = None) -> None: raise NotImplementedError()
[docs] def delete(self, key: str) -> None: key = self._get_prefixed_key(key) try: self.client.delete(key) logger.debug("Deleted cache key '%s'", key) except Exception as exc: logger.error("Could not delete cache key '%s' due to: %s", key, exc)