mirror of
https://github.com/long2ice/fastapi-cache.git
synced 2026-03-25 04:57:54 +00:00
fix #509: fix up linting and tests due to aiobotocore 2.18.0 changes
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
import datetime
|
||||
from typing import TYPE_CHECKING, Optional, Tuple
|
||||
from typing import TYPE_CHECKING, Optional, Tuple, Union
|
||||
|
||||
from aiobotocore.client import AioBaseClient
|
||||
from aiobotocore.session import AioSession, get_session
|
||||
@@ -30,7 +30,7 @@ class DynamoBackend(Backend):
|
||||
>> FastAPICache.init(dynamodb)
|
||||
"""
|
||||
|
||||
client: DynamoDBClient
|
||||
client: Union[DynamoDBClient, None]
|
||||
session: AioSession
|
||||
table_name: str
|
||||
region: Optional[str]
|
||||
@@ -46,9 +46,12 @@ class DynamoBackend(Backend):
|
||||
).__aenter__()
|
||||
|
||||
async def close(self) -> None:
|
||||
self.client = await self.client.__aexit__(None, None, None)
|
||||
if self.client:
|
||||
await self.client.__aexit__(None, None, None)
|
||||
self.client = None
|
||||
|
||||
async def get_with_ttl(self, key: str) -> Tuple[int, Optional[bytes]]:
|
||||
if self.client:
|
||||
response = await self.client.get_item(TableName=self.table_name, Key={"key": {"S": key}})
|
||||
|
||||
if "Item" in response:
|
||||
@@ -66,12 +69,14 @@ class DynamoBackend(Backend):
|
||||
return 0, None
|
||||
|
||||
async def get(self, key: str) -> Optional[bytes]:
|
||||
if self.client:
|
||||
response = await self.client.get_item(TableName=self.table_name, Key={"key": {"S": key}})
|
||||
if "Item" in response:
|
||||
return response["Item"].get("value", {}).get("B")
|
||||
return None
|
||||
|
||||
async def set(self, key: str, value: bytes, expire: Optional[int] = None) -> None:
|
||||
if self.client:
|
||||
ttl = (
|
||||
{
|
||||
"ttl": {
|
||||
|
||||
Reference in New Issue
Block a user