Sara Zan a59bca3661
Apply black formatting (#2115)
* Testing black on ui/

* Applying black on docstores

* Add latest docstring and tutorial changes

* Create a single GH action for Black and docs to reduce commit noise to the minimum, slightly refactor the OpenAPI action too

* Remove comments

* Relax constraints on pydoc-markdown

* Split temporary black from the docs. Pydoc-markdown was obsolete and needs a separate PR to upgrade

* Fix a couple of bugs

* Add a type: ignore that was missing somehow

* Give path to black

* Apply Black

* Apply Black

* Relocate a couple of type: ignore

* Update documentation

* Make Linux CI run after applying Black

* Triggering Black

* Apply Black

* Remove dependency, does not work well

* Remove manually double trailing commas

* Update documentation

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
2022-02-03 13:43:18 +01:00

53 lines
1.7 KiB
Python

from typing import List
import logging
from fastapi import APIRouter
from rest_api.controller.search import DOCUMENT_STORE
from rest_api.config import LOG_LEVEL
from rest_api.schema import FilterRequest, DocumentSerialized
logging.getLogger("haystack").setLevel(LOG_LEVEL)
logger = logging.getLogger("haystack")
router = APIRouter()
@router.post("/documents/get_by_filters", response_model=List[DocumentSerialized], response_model_exclude_none=True)
def get_documents(filters: FilterRequest):
"""
This endpoint allows you to retrieve documents contained in your document store.
You can filter the documents to delete by metadata (like the document's name),
or provide an empty JSON object to clear the document store.
Example of filters:
`'{"filters": {{"name": ["some", "more"], "category": ["only_one"]}}'`
To get all documents you should provide an empty dict, like:
`'{"filters": {}}'`
"""
docs = [doc.to_dict() for doc in DOCUMENT_STORE.get_all_documents(filters=filters.filters)]
for doc in docs:
doc["embedding"] = None
return docs
@router.post("/documents/delete_by_filters", response_model=bool)
def delete_documents(filters: FilterRequest):
"""
This endpoint allows you to delete documents contained in your document store.
You can filter the documents to delete by metadata (like the document's name),
or provide an empty JSON object to clear the document store.
Example of filters:
`'{"filters": {{"name": ["some", "more"], "category": ["only_one"]}}'`
To get all documents you should provide an empty dict, like:
`'{"filters": {}}'`
"""
DOCUMENT_STORE.delete_documents(filters=filters.filters)
return True