Files
fastapi-cache/fastapi_cache/backends/inmemory.py

60 lines
1.5 KiB
Python
Raw Normal View History

2020-10-08 15:10:34 +08:00
import time
2020-11-10 10:34:52 +08:00
from asyncio import Lock
2020-10-08 15:10:34 +08:00
from dataclasses import dataclass
from typing import Dict, Optional, Tuple
from fastapi_cache.backends import Backend
@dataclass
class Value:
data: str
ttl_ts: int
class InMemoryBackend(Backend):
_store: Dict[str, Value] = {}
_lock = Lock()
@property
def _now(self) -> int:
return int(time.time())
def _get(self, key: str):
v = self._store.get(key)
if v:
if v.ttl_ts < self._now:
del self._store[key]
else:
return v
async def get_with_ttl(self, key: str) -> Tuple[int, Optional[str]]:
2020-11-10 10:34:52 +08:00
async with self._lock:
2020-10-08 15:10:34 +08:00
v = self._get(key)
if v:
return v.ttl_ts - self._now, v.data
return 0, None
async def get(self, key: str) -> str:
2020-11-10 10:34:52 +08:00
async with self._lock:
2020-10-08 15:10:34 +08:00
v = self._get(key)
if v:
return v.data
async def set(self, key: str, value: str, expire: int = None):
2020-11-10 10:34:52 +08:00
async with self._lock:
2021-09-29 16:14:28 +02:00
self._store[key] = Value(value, self._now + expire or 0)
2020-11-03 18:08:06 +08:00
async def clear(self, namespace: str = None, key: str = None) -> int:
count = 0
if namespace:
keys = list(self._store.keys())
for key in keys:
if key.startswith(namespace):
del self._store[key]
count += 1
elif key:
del self._store[key]
count += 1
return count