| 
                        123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 | 
                        - #
 - #  Copyright 2025 The InfiniFlow Authors. All Rights Reserved.
 - #
 - #  Licensed under the Apache License, Version 2.0 (the "License");
 - #  you may not use this file except in compliance with the License.
 - #  You may obtain a copy of the License at
 - #
 - #      http://www.apache.org/licenses/LICENSE-2.0
 - #
 - #  Unless required by applicable law or agreed to in writing, software
 - #  distributed under the License is distributed on an "AS IS" BASIS,
 - #  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 - #  See the License for the specific language governing permissions and
 - #  limitations under the License.
 - #
 - from pathlib import Path
 - 
 - import requests
 - from configs import HOST_ADDRESS, VERSION
 - from requests_toolbelt import MultipartEncoder
 - from utils.file_utils import create_txt_file
 - 
 - HEADERS = {"Content-Type": "application/json"}
 - 
 - KB_APP_URL = f"/{VERSION}/kb"
 - DOCUMENT_APP_URL = f"/{VERSION}/document"
 - CHUNK_API_URL = f"/{VERSION}/chunk"
 - DIALOG_APP_URL = f"/{VERSION}/dialog"
 - # SESSION_WITH_CHAT_ASSISTANT_API_URL = "/api/v1/chats/{chat_id}/sessions"
 - # SESSION_WITH_AGENT_API_URL = "/api/v1/agents/{agent_id}/sessions"
 - 
 - 
 - # KB APP
 - def create_kb(auth, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{KB_APP_URL}/create", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def list_kbs(auth, params=None, payload=None, *, headers=HEADERS, data=None):
 -     if payload is None:
 -         payload = {}
 -     res = requests.post(url=f"{HOST_ADDRESS}{KB_APP_URL}/list", headers=headers, auth=auth, params=params, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def update_kb(auth, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{KB_APP_URL}/update", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def rm_kb(auth, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{KB_APP_URL}/rm", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def detail_kb(auth, params=None, *, headers=HEADERS):
 -     res = requests.get(url=f"{HOST_ADDRESS}{KB_APP_URL}/detail", headers=headers, auth=auth, params=params)
 -     return res.json()
 - 
 - 
 - def list_tags_from_kbs(auth, params=None, *, headers=HEADERS):
 -     res = requests.get(url=f"{HOST_ADDRESS}{KB_APP_URL}/tags", headers=headers, auth=auth, params=params)
 -     return res.json()
 - 
 - 
 - def list_tags(auth, dataset_id, params=None, *, headers=HEADERS):
 -     res = requests.get(url=f"{HOST_ADDRESS}{KB_APP_URL}/{dataset_id}/tags", headers=headers, auth=auth, params=params)
 -     return res.json()
 - 
 - 
 - def rm_tags(auth, dataset_id, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{KB_APP_URL}/{dataset_id}/rm_tags", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def rename_tags(auth, dataset_id, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{KB_APP_URL}/{dataset_id}/rename_tags", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def knowledge_graph(auth, dataset_id, params=None, *, headers=HEADERS):
 -     res = requests.get(url=f"{HOST_ADDRESS}{KB_APP_URL}/{dataset_id}/knowledge_graph", headers=headers, auth=auth, params=params)
 -     return res.json()
 - 
 - 
 - def delete_knowledge_graph(auth, dataset_id, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.delete(url=f"{HOST_ADDRESS}{KB_APP_URL}/{dataset_id}/delete_knowledge_graph", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def batch_create_datasets(auth, num):
 -     ids = []
 -     for i in range(num):
 -         res = create_kb(auth, {"name": f"kb_{i}"})
 -         ids.append(res["data"]["kb_id"])
 -     return ids
 - 
 - 
 - # DOCUMENT APP
 - def upload_documents(auth, payload=None, files_path=None):
 -     url = f"{HOST_ADDRESS}{DOCUMENT_APP_URL}/upload"
 - 
 -     if files_path is None:
 -         files_path = []
 - 
 -     fields = []
 -     file_objects = []
 -     try:
 -         if payload:
 -             for k, v in payload.items():
 -                 fields.append((k, str(v)))
 - 
 -         for fp in files_path:
 -             p = Path(fp)
 -             f = p.open("rb")
 -             fields.append(("file", (p.name, f)))
 -             file_objects.append(f)
 -         m = MultipartEncoder(fields=fields)
 - 
 -         res = requests.post(
 -             url=url,
 -             headers={"Content-Type": m.content_type},
 -             auth=auth,
 -             data=m,
 -         )
 -         return res.json()
 -     finally:
 -         for f in file_objects:
 -             f.close()
 - 
 - 
 - def create_document(auth, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{DOCUMENT_APP_URL}/create", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def list_documents(auth, params=None, payload=None, *, headers=HEADERS, data=None):
 -     if payload is None:
 -         payload = {}
 -     res = requests.post(url=f"{HOST_ADDRESS}{DOCUMENT_APP_URL}/list", headers=headers, auth=auth, params=params, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def delete_document(auth, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{DOCUMENT_APP_URL}/rm", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def parse_documents(auth, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{DOCUMENT_APP_URL}/run", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def bulk_upload_documents(auth, kb_id, num, tmp_path):
 -     fps = []
 -     for i in range(num):
 -         fp = create_txt_file(tmp_path / f"ragflow_test_upload_{i}.txt")
 -         fps.append(fp)
 - 
 -     res = upload_documents(auth, {"kb_id": kb_id}, fps)
 -     document_ids = []
 -     for document in res["data"]:
 -         document_ids.append(document["id"])
 -     return document_ids
 - 
 - 
 - # CHUNK APP
 - def add_chunk(auth, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{CHUNK_API_URL}/create", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def list_chunks(auth, payload=None, *, headers=HEADERS):
 -     res = requests.post(url=f"{HOST_ADDRESS}{CHUNK_API_URL}/list", headers=headers, auth=auth, json=payload)
 -     return res.json()
 - 
 - 
 - def get_chunk(auth, params=None, *, headers=HEADERS):
 -     res = requests.get(url=f"{HOST_ADDRESS}{CHUNK_API_URL}/get", headers=headers, auth=auth, params=params)
 -     return res.json()
 - 
 - 
 - def update_chunk(auth, payload=None, *, headers=HEADERS):
 -     res = requests.post(url=f"{HOST_ADDRESS}{CHUNK_API_URL}/set", headers=headers, auth=auth, json=payload)
 -     return res.json()
 - 
 - 
 - def delete_chunks(auth, payload=None, *, headers=HEADERS):
 -     res = requests.post(url=f"{HOST_ADDRESS}{CHUNK_API_URL}/rm", headers=headers, auth=auth, json=payload)
 -     return res.json()
 - 
 - 
 - def retrieval_chunks(auth, payload=None, *, headers=HEADERS):
 -     res = requests.post(url=f"{HOST_ADDRESS}{CHUNK_API_URL}/retrieval_test", headers=headers, auth=auth, json=payload)
 -     return res.json()
 - 
 - 
 - def batch_add_chunks(auth, doc_id, num):
 -     chunk_ids = []
 -     for i in range(num):
 -         res = add_chunk(auth, {"doc_id": doc_id, "content_with_weight": f"chunk test {i}"})
 -         chunk_ids.append(res["data"]["chunk_id"])
 -     return chunk_ids
 - 
 - 
 - # DIALOG APP
 - def create_dialog(auth, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{DIALOG_APP_URL}/set", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def update_dialog(auth, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{DIALOG_APP_URL}/set", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def get_dialog(auth, params=None, *, headers=HEADERS):
 -     res = requests.get(url=f"{HOST_ADDRESS}{DIALOG_APP_URL}/get", headers=headers, auth=auth, params=params)
 -     return res.json()
 - 
 - 
 - def list_dialogs(auth, *, headers=HEADERS):
 -     res = requests.get(url=f"{HOST_ADDRESS}{DIALOG_APP_URL}/list", headers=headers, auth=auth)
 -     return res.json()
 - 
 - 
 - def delete_dialog(auth, payload=None, *, headers=HEADERS, data=None):
 -     res = requests.post(url=f"{HOST_ADDRESS}{DIALOG_APP_URL}/rm", headers=headers, auth=auth, json=payload, data=data)
 -     return res.json()
 - 
 - 
 - def batch_create_dialogs(auth, num, kb_ids=None):
 -     if kb_ids is None:
 -         kb_ids = []
 - 
 -     dialog_ids = []
 -     for i in range(num):
 -         payload = {
 -             "name": f"dialog_{i}",
 -             "description": f"Test dialog {i}",
 -             "kb_ids": kb_ids,
 -             "prompt_config": {"system": "You are a helpful assistant. Use the following knowledge to answer questions: {knowledge}", "parameters": [{"key": "knowledge", "optional": False}]},
 -             "top_n": 6,
 -             "top_k": 1024,
 -             "similarity_threshold": 0.1,
 -             "vector_similarity_weight": 0.3,
 -             "llm_setting": {"model": "gpt-3.5-turbo", "temperature": 0.7},
 -         }
 -         res = create_dialog(auth, payload)
 -         if res["code"] == 0:
 -             dialog_ids.append(res["data"]["id"])
 -     return dialog_ids
 - 
 - 
 - def delete_dialogs(auth):
 -     res = list_dialogs(auth)
 -     if res["code"] == 0 and res["data"]:
 -         dialog_ids = [dialog["id"] for dialog in res["data"]]
 -         if dialog_ids:
 -             delete_dialog(auth, {"dialog_ids": dialog_ids})
 
 
  |