2022-10-21 21:39:04 +03:00
|
|
|
from drf_yasg import openapi
|
|
|
|
from drf_yasg.utils import swagger_auto_schema
|
|
|
|
from rest_framework import status
|
|
|
|
from rest_framework.response import Response
|
|
|
|
from rest_framework.views import APIView
|
2022-10-21 23:22:14 +03:00
|
|
|
from search.api.serializers import HintRequestSerializer
|
2022-10-21 21:39:04 +03:00
|
|
|
|
2022-10-21 23:22:14 +03:00
|
|
|
from search.api.serializers import SearchSerializer, ResponseSerializer, HintResponseSerializer
|
2022-10-21 21:39:04 +03:00
|
|
|
from search.services.search import process_string
|
|
|
|
|
|
|
|
user_response = openapi.Response("search results", ResponseSerializer)
|
2022-10-21 23:22:14 +03:00
|
|
|
hint_response = openapi.Response("hints", HintResponseSerializer)
|
2022-10-21 21:39:04 +03:00
|
|
|
|
|
|
|
class SearchApi(APIView):
|
|
|
|
@swagger_auto_schema(request_body=SearchSerializer, responses={200: user_response})
|
|
|
|
def post(self, request, format=None):
|
|
|
|
serializer = SearchSerializer(data=request.data)
|
|
|
|
serializer.is_valid(raise_exception=True)
|
|
|
|
return Response(
|
|
|
|
process_string(serializer.data["body"]), status=status.HTTP_200_OK
|
|
|
|
)
|
2022-10-21 23:22:14 +03:00
|
|
|
|
|
|
|
|
|
|
|
class HintApi(APIView):
|
|
|
|
@swagger_auto_schema(request_body=HintRequestSerializer, responses={200: hint_response})
|
|
|
|
def post(self, request, format=None):
|
|
|
|
serializer = HintRequestSerializer(data=request.data)
|
|
|
|
serializer.is_valid(raise_exception=True)
|
|
|
|
return Response(
|
|
|
|
{
|
|
|
|
'type': 'category',
|
|
|
|
'value': serializer.data['content']
|
|
|
|
},
|
|
|
|
status=status.HTTP_200_OK
|
|
|
|
)
|