commit
0e1dd5d44e
@ -1,3 +1,5 @@
|
|||||||
|
import asyncio
|
||||||
|
import collections
|
||||||
import fastapi
|
import fastapi
|
||||||
import pydantic
|
import pydantic
|
||||||
import typing
|
import typing
|
||||||
@ -5,6 +7,7 @@ import typing
|
|||||||
from app.storage.mongo import tasks
|
from app.storage.mongo import tasks
|
||||||
|
|
||||||
|
|
||||||
|
locks = collections.defaultdict(asyncio.Lock)
|
||||||
router = fastapi.APIRouter()
|
router = fastapi.APIRouter()
|
||||||
|
|
||||||
|
|
||||||
@ -20,6 +23,7 @@ class Response(pydantic.BaseModel):
|
|||||||
|
|
||||||
@router.get('/api/v1/take', responses={404: {'description': 'Not found'}})
|
@router.get('/api/v1/take', responses={404: {'description': 'Not found'}})
|
||||||
async def execute(queue: typing.Annotated[str, fastapi.Header()]) -> Response:
|
async def execute(queue: typing.Annotated[str, fastapi.Header()]) -> Response:
|
||||||
|
async with locks[queue]:
|
||||||
task = await tasks.take_task(queue)
|
task = await tasks.take_task(queue)
|
||||||
if not task:
|
if not task:
|
||||||
return Response(task=None)
|
return Response(task=None)
|
||||||
|
Loading…
Reference in New Issue
Block a user