8 Commits

Author SHA1 Message Date
long2ice
767241be41 - Fix redis cache.
- Encode key builder.
2021-07-26 16:33:22 +08:00
long2ice
de1bde39fd update version 2021-07-23 09:38:47 +08:00
long2ice
8490ad36f0 Merge pull request #25 from dveleztx/master
This fixes #24.
2021-07-23 09:38:04 +08:00
David Velez
57fe4ce24b Updated changelog to 1.4 from 1.5 2021-07-22 10:54:10 -05:00
David Velez
3dc2b53e41 Updated changelog and version for the project. 2021-07-22 10:47:02 -05:00
David Velez
2dd37b09ab This fixes #24. Looking at aioredis library, the client.py keyword for set is now 'ex', not 'expire'. Tested this fix and fast-cache now works without issue. 2021-07-22 10:17:52 -05:00
long2ice
0bc8c6c20e Merge pull request #22 from heliumbrain/master
Adapt to aioredis 2.0
2021-07-16 10:02:10 +08:00
heliumbrain
9e3c9816c5 Update README.md
Updated readme to reflect the changes in aioredis 2.0
2021-07-15 23:15:01 +02:00
7 changed files with 23 additions and 12 deletions

View File

@@ -2,6 +2,16 @@
## 0.1 ## 0.1
### 0.1.6
- Fix redis cache.
- Encode key builder.
### 0.1.5
- Fix setting expire for redis (#24)
- Update expire key
### 0.1.4 ### 0.1.4
- Fix default expire for memcached. (#13) - Fix default expire for memcached. (#13)

View File

@@ -69,7 +69,7 @@ async def index(request: Request, response: Response):
@app.on_event("startup") @app.on_event("startup")
async def startup(): async def startup():
redis = await aioredis.create_redis_pool("redis://localhost", encoding="utf8") redis = aioredis.from_url("redis://localhost", encoding="utf8", decode_responses=True)
FastAPICache.init(RedisBackend(redis), prefix="fastapi-cache") FastAPICache.init(RedisBackend(redis), prefix="fastapi-cache")
``` ```

View File

@@ -1,3 +1,4 @@
import aioredis
import uvicorn import uvicorn
from fastapi import FastAPI from fastapi import FastAPI
from starlette.requests import Request from starlette.requests import Request
@@ -5,6 +6,7 @@ from starlette.responses import Response
from fastapi_cache import FastAPICache from fastapi_cache import FastAPICache
from fastapi_cache.backends.inmemory import InMemoryBackend from fastapi_cache.backends.inmemory import InMemoryBackend
from fastapi_cache.backends.redis import RedisBackend
from fastapi_cache.decorator import cache from fastapi_cache.decorator import cache
app = FastAPI() app = FastAPI()
@@ -20,7 +22,7 @@ async def get_ret():
@app.get("/") @app.get("/")
@cache(namespace="test", expire=2) @cache(namespace="test", expire=20)
async def index(request: Request, response: Response): async def index(request: Request, response: Response):
return dict(ret=await get_ret()) return dict(ret=await get_ret())
@@ -32,7 +34,8 @@ async def clear():
@app.on_event("startup") @app.on_event("startup")
async def startup(): async def startup():
FastAPICache.init(InMemoryBackend(), prefix="fastapi-cache") redis = aioredis.from_url(url="redis://localhost")
FastAPICache.init(RedisBackend(redis), prefix="fastapi-cache")
if __name__ == "__main__": if __name__ == "__main__":

View File

@@ -10,20 +10,18 @@ class RedisBackend(Backend):
self.redis = redis self.redis = redis
async def get_with_ttl(self, key: str) -> Tuple[int, str]: async def get_with_ttl(self, key: str) -> Tuple[int, str]:
p = self.redis.pipeline() async with self.redis.pipeline(transaction=True) as pipe:
p.ttl(key) return await (pipe.ttl(key).get(key).execute())
p.get(key)
return await p.execute()
async def get(self, key) -> str: async def get(self, key) -> str:
return await self.redis.get(key) return await self.redis.get(key)
async def set(self, key: str, value: str, expire: int = None): async def set(self, key: str, value: str, expire: int = None):
return await self.redis.set(key, value, expire=expire) return await self.redis.set(key, value, ex=expire)
async def clear(self, namespace: str = None, key: str = None) -> int: async def clear(self, namespace: str = None, key: str = None) -> int:
if namespace: if namespace:
lua = f"for i, name in ipairs(redis.call('KEYS', '{namespace}:*')) do redis.call('DEL', name); end" lua = f"for i, name in ipairs(redis.call('KEYS', '{namespace}:*')) do redis.call('DEL', name); end"
return await self.redis.eval(lua) return await self.redis.eval(lua, numkeys=0)
elif key: elif key:
return await self.redis.delete(key) return await self.redis.delete(key)

View File

@@ -3,9 +3,9 @@ import json
import pickle # nosec:B403 import pickle # nosec:B403
from decimal import Decimal from decimal import Decimal
from typing import Any from typing import Any
from fastapi.encoders import jsonable_encoder
import dateutil.parser import dateutil.parser
from fastapi.encoders import jsonable_encoder
CONVERTERS = { CONVERTERS = {
"date": dateutil.parser.parse, "date": dateutil.parser.parse,

View File

@@ -19,7 +19,7 @@ def default_key_builder(
cache_key = ( cache_key = (
prefix prefix
+ hashlib.md5( # nosec:B303 + hashlib.md5( # nosec:B303
f"{func.__module__}:{func.__name__}:{args}:{kwargs}" f"{func.__module__}:{func.__name__}:{args}:{kwargs}".encode()
).hexdigest() ).hexdigest()
) )
return cache_key return cache_key

View File

@@ -1,6 +1,6 @@
[tool.poetry] [tool.poetry]
name = "fastapi-cache2" name = "fastapi-cache2"
version = "0.1.4" version = "0.1.6"
description = "Cache for FastAPI" description = "Cache for FastAPI"
authors = ["long2ice <long2ice@gmail.com>"] authors = ["long2ice <long2ice@gmail.com>"]
license = "Apache-2.0" license = "Apache-2.0"