collection.py: create

pull/72/head
Tal Leibman 3 years ago committed by Tom Hacohen
parent 4bd826b3be
commit be7b830804

@ -1,16 +1,16 @@
import typing as t import typing as t
from asgiref.sync import sync_to_async
from django.contrib.auth import get_user_model from django.contrib.auth import get_user_model
from django.db.models import Q from django.db.models import Q
from django.db.models import QuerySet from django.db.models import QuerySet
from fastapi import APIRouter, Depends from fastapi import APIRouter, Depends, status
from pydantic import BaseModel from pydantic import BaseModel
from asgiref.sync import sync_to_async
from django_etebase.models import Collection, Stoken, AccessLevels, CollectionMember from django_etebase.models import Collection, AccessLevels, CollectionMember
from .authentication import get_authenticated_user from .authentication import get_authenticated_user
from .msgpack import MsgpackRoute, MsgpackResponse from .msgpack import MsgpackRoute, MsgpackResponse
from .stoken_handler import filter_by_stoken_and_limit, filter_by_stoken, get_queryset_stoken from .stoken_handler import filter_by_stoken_and_limit
User = get_user_model() User = get_user_model()
collection_router = APIRouter(route_class=MsgpackRoute) collection_router = APIRouter(route_class=MsgpackRoute)
@ -75,3 +75,29 @@ async def list_multi(
) )
response = await list_common(queryset, user, stoken, limit) response = await list_common(queryset, user, stoken, limit)
return response return response
class CollectionItemContent(BaseModel):
uid: str
meta: bytes
deleted: bool
chunks: t.List[t.List[t.Union[str, bytes]]]
class Item(BaseModel):
uid: str
version: int
etag: t.Optional[str]
content: CollectionItemContent
class CollectionItemIn(BaseModel):
collectionType: bytes
collectionKey: bytes
item: Item
@collection_router.post("/")
def create(data: CollectionItemIn):
# FIXME save actual item
return MsgpackResponse({}, status_code=status.HTTP_201_CREATED)

Loading…
Cancel
Save