| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220 |
- #
- # Copyright 2024 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 flask import request
-
- from api.db import StatusEnum, FileSource
- from api.db.db_models import File
- from api.db.services.document_service import DocumentService
- from api.db.services.file2document_service import File2DocumentService
- from api.db.services.file_service import FileService
- from api.db.services.knowledgebase_service import KnowledgebaseService
- from api.db.services.user_service import TenantService
- from api.settings import RetCode
- from api.utils import get_uuid
- from api.utils.api_utils import get_json_result, token_required, get_data_error_result
-
-
- @manager.route('/save', methods=['POST'])
- @token_required
- def save(tenant_id):
- req = request.json
- e, t = TenantService.get_by_id(tenant_id)
- if "id" not in req:
- if "tenant_id" in req or "embedding_model" in req:
- return get_data_error_result(
- retmsg="Tenant_id or embedding_model must not be provided")
- if "name" not in req:
- return get_data_error_result(
- retmsg="Name is not empty!")
- req['id'] = get_uuid()
- req["name"] = req["name"].strip()
- if req["name"] == "":
- return get_data_error_result(
- retmsg="Name is not empty string!")
- if KnowledgebaseService.query(name=req["name"], tenant_id=tenant_id, status=StatusEnum.VALID.value):
- return get_data_error_result(
- retmsg="Duplicated knowledgebase name in creating dataset.")
- req["tenant_id"] = req['created_by'] = tenant_id
- req['embedding_model'] = t.embd_id
- key_mapping = {
- "chunk_num": "chunk_count",
- "doc_num": "document_count",
- "parser_id": "parse_method",
- "embd_id": "embedding_model"
- }
- mapped_keys = {new_key: req[old_key] for new_key, old_key in key_mapping.items() if old_key in req}
- req.update(mapped_keys)
- if not KnowledgebaseService.save(**req):
- return get_data_error_result(retmsg="Create dataset error.(Database error)")
- renamed_data={}
- e, k = KnowledgebaseService.get_by_id(req["id"])
- for key, value in k.to_dict().items():
- new_key = key_mapping.get(key, key)
- renamed_data[new_key] = value
- return get_json_result(data=renamed_data)
- else:
- invalid_keys = {"embd_id", "chunk_num", "doc_num", "parser_id"}
- if any(key in req for key in invalid_keys):
- return get_data_error_result(retmsg="The input parameters are invalid.")
-
- if "tenant_id" in req:
- if req["tenant_id"] != tenant_id:
- return get_data_error_result(
- retmsg="Can't change tenant_id.")
-
- if "embedding_model" in req:
- if req["embedding_model"] != t.embd_id:
- return get_data_error_result(
- retmsg="Can't change embedding_model.")
- req.pop("embedding_model")
-
- if not KnowledgebaseService.query(
- created_by=tenant_id, id=req["id"]):
- return get_json_result(
- data=False, retmsg='You do not own the dataset.',
- retcode=RetCode.OPERATING_ERROR)
-
- e, kb = KnowledgebaseService.get_by_id(req["id"])
-
- if "chunk_count" in req:
- if req["chunk_count"] != kb.chunk_num:
- return get_data_error_result(
- retmsg="Can't change chunk_count.")
- req.pop("chunk_count")
-
- if "document_count" in req:
- if req['document_count'] != kb.doc_num:
- return get_data_error_result(
- retmsg="Can't change document_count.")
- req.pop("document_count")
-
- if "parse_method" in req:
- if kb.chunk_num != 0 and req['parse_method'] != kb.parser_id:
- return get_data_error_result(
- retmsg="If chunk count is not 0, parse method is not changable.")
- req['parser_id'] = req.pop('parse_method')
- if "name" in req:
- if req["name"].lower() != kb.name.lower() \
- and len(KnowledgebaseService.query(name=req["name"], tenant_id=tenant_id,
- status=StatusEnum.VALID.value)) > 0:
- return get_data_error_result(
- retmsg="Duplicated knowledgebase name in updating dataset.")
-
- del req["id"]
- if not KnowledgebaseService.update_by_id(kb.id, req):
- return get_data_error_result(retmsg="Update dataset error.(Database error)")
- return get_json_result(data=True)
-
-
- @manager.route('/delete', methods=['DELETE'])
- @token_required
- def delete(tenant_id):
- req = request.args
- if "id" not in req:
- return get_data_error_result(
- retmsg="id is required")
- kbs = KnowledgebaseService.query(
- created_by=tenant_id, id=req["id"])
- if not kbs:
- return get_json_result(
- data=False, retmsg='You do not own the dataset',
- retcode=RetCode.OPERATING_ERROR)
-
- for doc in DocumentService.query(kb_id=req["id"]):
- if not DocumentService.remove_document(doc, kbs[0].tenant_id):
- return get_data_error_result(
- retmsg="Remove document error.(Database error)")
- f2d = File2DocumentService.get_by_document_id(doc.id)
- FileService.filter_delete([File.source_type == FileSource.KNOWLEDGEBASE, File.id == f2d[0].file_id])
- File2DocumentService.delete_by_document_id(doc.id)
-
- if not KnowledgebaseService.delete_by_id(req["id"]):
- return get_data_error_result(
- retmsg="Delete dataset error.(Database serror)")
- return get_json_result(data=True)
-
-
- @manager.route('/list', methods=['GET'])
- @token_required
- def list_datasets(tenant_id):
- page_number = int(request.args.get("page", 1))
- items_per_page = int(request.args.get("page_size", 1024))
- orderby = request.args.get("orderby", "create_time")
- desc = bool(request.args.get("desc", True))
- tenants = TenantService.get_joined_tenants_by_user_id(tenant_id)
- kbs = KnowledgebaseService.get_by_tenant_ids(
- [m["tenant_id"] for m in tenants], tenant_id, page_number, items_per_page, orderby, desc)
- renamed_list = []
- for kb in kbs:
- key_mapping = {
- "chunk_num": "chunk_count",
- "doc_num": "document_count",
- "parser_id": "parse_method",
- "embd_id": "embedding_model"
- }
- renamed_data = {}
- for key, value in kb.items():
- new_key = key_mapping.get(key, key)
- renamed_data[new_key] = value
- renamed_list.append(renamed_data)
- return get_json_result(data=renamed_list)
-
-
- @manager.route('/detail', methods=['GET'])
- @token_required
- def detail(tenant_id):
- req = request.args
- key_mapping = {
- "chunk_num": "chunk_count",
- "doc_num": "document_count",
- "parser_id": "parse_method",
- "embd_id": "embedding_model"
- }
- renamed_data = {}
- if "id" in req:
- id = req["id"]
- kb = KnowledgebaseService.query(created_by=tenant_id, id=req["id"])
- if not kb:
- return get_json_result(
- data=False, retmsg='You do not own the dataset.',
- retcode=RetCode.OPERATING_ERROR)
- if "name" in req:
- name = req["name"]
- if kb[0].name != name:
- return get_json_result(
- data=False, retmsg='You do not own the dataset.',
- retcode=RetCode.OPERATING_ERROR)
- e, k = KnowledgebaseService.get_by_id(id)
- for key, value in k.to_dict().items():
- new_key = key_mapping.get(key, key)
- renamed_data[new_key] = value
- return get_json_result(data=renamed_data)
- else:
- if "name" in req:
- name = req["name"]
- e, k = KnowledgebaseService.get_by_name(kb_name=name, tenant_id=tenant_id)
- if not e:
- return get_json_result(
- data=False, retmsg='You do not own the dataset.',
- retcode=RetCode.OPERATING_ERROR)
- for key, value in k.to_dict().items():
- new_key = key_mapping.get(key, key)
- renamed_data[new_key] = value
- return get_json_result(data=renamed_data)
- else:
- return get_data_error_result(
- retmsg="At least one of `id` or `name` must be provided.")
|