mirror of
https://github.com/deepset-ai/haystack.git
synced 2025-07-21 07:51:40 +00:00

* 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>
53 lines
1.7 KiB
Python
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
|