34 lines
968 B
Python
34 lines
968 B
Python
import asyncio
|
|
import json
|
|
from services.redis import redis
|
|
from db.shout import Shout
|
|
from schema.zine.load import load_shouts_by
|
|
|
|
|
|
class SearchService:
|
|
lock = asyncio.Lock()
|
|
cache = {}
|
|
|
|
@staticmethod
|
|
async def init(session):
|
|
async with SearchService.lock:
|
|
print("[search.service] did nothing")
|
|
SearchService.cache = {}
|
|
|
|
@staticmethod
|
|
async def search(text, limit, offset) -> [Shout]:
|
|
cached = await redis.execute("GET", text)
|
|
if not cached:
|
|
async with SearchService.lock:
|
|
options = {
|
|
"title": text,
|
|
"body": text,
|
|
"limit": limit,
|
|
"offset": offset,
|
|
}
|
|
payload = await load_shouts_by(None, None, options)
|
|
await redis.execute("SET", text, json.dumps(payload))
|
|
return payload
|
|
else:
|
|
return json.loads(cached)
|