mirror of
https://github.com/long2ice/fastapi-cache.git
synced 2026-03-24 20:47:54 +00:00
This is, for the majority of backends, the native format anyway, and so we save encoding and decoding when using the PickleCodec or if (in future) a orjson Coder was to be added. For the JsonCodec, the only thing that changed is the location where the JSON data is encoded to bytes and decoded back again to a string.
23 lines
725 B
Python
23 lines
725 B
Python
from typing import Optional, Tuple
|
|
|
|
from aiomcache import Client
|
|
|
|
from fastapi_cache.backends import Backend
|
|
|
|
|
|
class MemcachedBackend(Backend):
|
|
def __init__(self, mcache: Client):
|
|
self.mcache = mcache
|
|
|
|
async def get_with_ttl(self, key: str) -> Tuple[int, Optional[bytes]]:
|
|
return 3600, await self.get(key)
|
|
|
|
async def get(self, key: str) -> Optional[bytes]:
|
|
return await self.mcache.get(key.encode())
|
|
|
|
async def set(self, key: str, value: bytes, expire: Optional[int] = None) -> None:
|
|
await self.mcache.set(key.encode(), value, exptime=expire or 0)
|
|
|
|
async def clear(self, namespace: Optional[str] = None, key: Optional[str] = None) -> int:
|
|
raise NotImplementedError
|