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

30 lines
1.1 KiB
Python
Raw Normal View History

2022-11-07 16:39:17 +08:00
from typing import Optional, Tuple
2020-08-26 18:04:57 +08:00
2023-01-15 21:54:16 +00:00
from redis.asyncio.client import AbstractRedis
from redis.asyncio.cluster import AbstractRedisCluster
2020-08-26 18:04:57 +08:00
from fastapi_cache.backends import Backend
class RedisBackend(Backend):
2023-01-15 21:54:16 +00:00
def __init__(self, redis: AbstractRedis):
2020-08-26 18:04:57 +08:00
self.redis = redis
2023-01-15 21:54:16 +00:00
self.is_cluster = isinstance(redis, AbstractRedisCluster)
2020-08-26 18:04:57 +08:00
async def get_with_ttl(self, key: str) -> Tuple[int, str]:
2023-01-15 21:54:16 +00:00
async with self.redis.pipeline(transaction=not self.is_cluster) as pipe:
return await (pipe.ttl(key).get(key).execute())
2020-08-26 18:04:57 +08:00
2022-10-22 20:59:37 +04:00
async def get(self, key: str) -> Optional[str]:
2020-08-26 18:04:57 +08:00
return await self.redis.get(key)
2022-10-22 20:59:37 +04:00
async def set(self, key: str, value: str, expire: Optional[int] = None) -> None:
return await self.redis.set(key, value, ex=expire)
2020-11-03 18:08:06 +08:00
2022-10-22 20:59:37 +04:00
async def clear(self, namespace: Optional[str] = None, key: Optional[str] = None) -> int:
2020-11-03 18:08:06 +08:00
if namespace:
lua = f"for i, name in ipairs(redis.call('KEYS', '{namespace}:*')) do redis.call('DEL', name); end"
return await self.redis.eval(lua, numkeys=0)
2020-11-03 18:08:06 +08:00
elif key:
return await self.redis.delete(key)
2023-01-15 21:54:16 +00:00
return 0