2023-04-27 16:24:22 +01:00
|
|
|
from typing import ClassVar, Optional, Type
|
2020-10-16 16:55:33 +08:00
|
|
|
|
2022-10-22 20:59:37 +04:00
|
|
|
from fastapi_cache.backends import Backend
|
2020-10-16 16:55:33 +08:00
|
|
|
from fastapi_cache.coder import Coder, JsonCoder
|
|
|
|
|
from fastapi_cache.key_builder import default_key_builder
|
2023-04-27 16:24:22 +01:00
|
|
|
from fastapi_cache.types import KeyBuilder
|
2020-10-16 16:55:33 +08:00
|
|
|
|
|
|
|
|
|
2020-08-26 18:04:57 +08:00
|
|
|
class FastAPICache:
|
2023-04-27 16:15:06 +01:00
|
|
|
_backend: ClassVar[Optional[Backend]] = None
|
|
|
|
|
_prefix: ClassVar[Optional[str]] = None
|
|
|
|
|
_expire: ClassVar[Optional[int]] = None
|
|
|
|
|
_init: ClassVar[bool] = False
|
|
|
|
|
_coder: ClassVar[Optional[Type[Coder]]] = None
|
2023-04-27 16:24:22 +01:00
|
|
|
_key_builder: ClassVar[Optional[KeyBuilder]] = None
|
2023-04-27 16:15:06 +01:00
|
|
|
_enable: ClassVar[bool] = True
|
2020-08-26 18:04:57 +08:00
|
|
|
|
|
|
|
|
@classmethod
|
2020-10-16 16:55:33 +08:00
|
|
|
def init(
|
|
|
|
|
cls,
|
2022-10-22 20:59:37 +04:00
|
|
|
backend: Backend,
|
2020-10-16 16:55:33 +08:00
|
|
|
prefix: str = "",
|
2022-10-22 20:59:37 +04:00
|
|
|
expire: Optional[int] = None,
|
|
|
|
|
coder: Type[Coder] = JsonCoder,
|
2023-04-27 16:24:22 +01:00
|
|
|
key_builder: KeyBuilder = default_key_builder,
|
2021-10-28 15:52:21 +08:00
|
|
|
enable: bool = True,
|
2022-10-22 20:59:37 +04:00
|
|
|
) -> None:
|
2020-10-08 15:10:34 +08:00
|
|
|
if cls._init:
|
|
|
|
|
return
|
|
|
|
|
cls._init = True
|
2020-08-26 18:04:57 +08:00
|
|
|
cls._backend = backend
|
|
|
|
|
cls._prefix = prefix
|
2020-10-08 15:10:34 +08:00
|
|
|
cls._expire = expire
|
2020-10-16 16:55:33 +08:00
|
|
|
cls._coder = coder
|
|
|
|
|
cls._key_builder = key_builder
|
2021-10-28 15:52:21 +08:00
|
|
|
cls._enable = enable
|
2020-08-26 18:04:57 +08:00
|
|
|
|
2022-10-22 21:12:04 +04:00
|
|
|
@classmethod
|
|
|
|
|
def reset(cls) -> None:
|
|
|
|
|
cls._init = False
|
|
|
|
|
cls._backend = None
|
|
|
|
|
cls._prefix = None
|
|
|
|
|
cls._expire = None
|
|
|
|
|
cls._coder = None
|
|
|
|
|
cls._key_builder = None
|
|
|
|
|
cls._enable = True
|
|
|
|
|
|
2020-08-26 18:04:57 +08:00
|
|
|
@classmethod
|
2022-10-22 20:59:37 +04:00
|
|
|
def get_backend(cls) -> Backend:
|
2020-08-26 18:04:57 +08:00
|
|
|
assert cls._backend, "You must call init first!" # nosec: B101
|
|
|
|
|
return cls._backend
|
|
|
|
|
|
|
|
|
|
@classmethod
|
2022-10-22 21:05:43 +04:00
|
|
|
def get_prefix(cls) -> str:
|
2022-10-22 21:12:04 +04:00
|
|
|
assert cls._prefix is not None, "You must call init first!" # nosec: B101
|
2020-08-26 18:04:57 +08:00
|
|
|
return cls._prefix
|
2020-10-08 15:10:34 +08:00
|
|
|
|
|
|
|
|
@classmethod
|
2022-10-22 20:59:37 +04:00
|
|
|
def get_expire(cls) -> Optional[int]:
|
2020-10-08 15:10:34 +08:00
|
|
|
return cls._expire
|
2020-10-16 16:55:33 +08:00
|
|
|
|
|
|
|
|
@classmethod
|
2022-10-22 21:05:43 +04:00
|
|
|
def get_coder(cls) -> Type[Coder]:
|
|
|
|
|
assert cls._coder, "You must call init first!" # nosec: B101
|
2020-10-16 16:55:33 +08:00
|
|
|
return cls._coder
|
|
|
|
|
|
|
|
|
|
@classmethod
|
2023-04-27 16:24:22 +01:00
|
|
|
def get_key_builder(cls) -> KeyBuilder:
|
2022-10-22 21:05:43 +04:00
|
|
|
assert cls._key_builder, "You must call init first!" # nosec: B101
|
2020-10-16 16:55:33 +08:00
|
|
|
return cls._key_builder
|
2020-11-03 18:08:06 +08:00
|
|
|
|
2021-10-28 15:52:21 +08:00
|
|
|
@classmethod
|
2022-10-22 20:59:37 +04:00
|
|
|
def get_enable(cls) -> bool:
|
2021-10-28 15:52:21 +08:00
|
|
|
return cls._enable
|
|
|
|
|
|
2020-11-03 18:08:06 +08:00
|
|
|
@classmethod
|
2022-10-22 20:59:37 +04:00
|
|
|
async def clear(cls, namespace: Optional[str] = None, key: Optional[str] = None) -> int:
|
2022-10-22 21:12:04 +04:00
|
|
|
assert cls._backend and cls._prefix is not None, "You must call init first!" # nosec: B101
|
2022-08-10 19:31:29 +02:00
|
|
|
namespace = cls._prefix + (":" + namespace if namespace else "")
|
2020-11-03 18:08:06 +08:00
|
|
|
return await cls._backend.clear(namespace, key)
|