mirror of
				https://github.com/infiniflow/ragflow.git
				synced 2025-10-31 17:59:43 +00:00 
			
		
		
		
	fix doc number miss-match issue (#822)
### What problem does this PR solve? #620 ### Type of change - [x] Bug Fix (non-breaking change which fixes an issue)
This commit is contained in:
		
							parent
							
								
									9e5d501e83
								
							
						
					
					
						commit
						a2a6a35e94
					
				| @ -250,13 +250,9 @@ def rm(): | |||||||
|             if not tenant_id: |             if not tenant_id: | ||||||
|                 return get_data_error_result(retmsg="Tenant not found!") |                 return get_data_error_result(retmsg="Tenant not found!") | ||||||
| 
 | 
 | ||||||
|             ELASTICSEARCH.deleteByQuery( |  | ||||||
|                 Q("match", doc_id=doc.id), idxnm=search.index_name(tenant_id)) |  | ||||||
| 
 |  | ||||||
|             DocumentService.clear_chunk_num(doc_id) |  | ||||||
|             b, n = File2DocumentService.get_minio_address(doc_id=doc_id) |             b, n = File2DocumentService.get_minio_address(doc_id=doc_id) | ||||||
| 
 | 
 | ||||||
|             if not DocumentService.delete(doc): |             if not DocumentService.remove_document(doc, tenant_id): | ||||||
|                 return get_data_error_result( |                 return get_data_error_result( | ||||||
|                     retmsg="Database error (Document removal)!") |                     retmsg="Database error (Document removal)!") | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -58,11 +58,7 @@ def convert(): | |||||||
|                     tenant_id = DocumentService.get_tenant_id(doc_id) |                     tenant_id = DocumentService.get_tenant_id(doc_id) | ||||||
|                     if not tenant_id: |                     if not tenant_id: | ||||||
|                         return get_data_error_result(retmsg="Tenant not found!") |                         return get_data_error_result(retmsg="Tenant not found!") | ||||||
|                     ELASTICSEARCH.deleteByQuery( |                     if not DocumentService.remove_document(doc, tenant_id): | ||||||
|                         Q("match", doc_id=doc.id), idxnm=search.index_name(tenant_id)) |  | ||||||
|                     DocumentService.increment_chunk_num( |  | ||||||
|                         doc.id, doc.kb_id, doc.token_num * -1, doc.chunk_num * -1, 0) |  | ||||||
|                     if not DocumentService.delete(doc): |  | ||||||
|                         return get_data_error_result( |                         return get_data_error_result( | ||||||
|                             retmsg="Database error (Document removal)!") |                             retmsg="Database error (Document removal)!") | ||||||
|                 File2DocumentService.delete_by_file_id(id) |                 File2DocumentService.delete_by_file_id(id) | ||||||
| @ -125,11 +121,7 @@ def rm(): | |||||||
|                 tenant_id = DocumentService.get_tenant_id(doc_id) |                 tenant_id = DocumentService.get_tenant_id(doc_id) | ||||||
|                 if not tenant_id: |                 if not tenant_id: | ||||||
|                     return get_data_error_result(retmsg="Tenant not found!") |                     return get_data_error_result(retmsg="Tenant not found!") | ||||||
|                 ELASTICSEARCH.deleteByQuery( |                 if not DocumentService.remove_document(doc, tenant_id): | ||||||
|                     Q("match", doc_id=doc.id), idxnm=search.index_name(tenant_id)) |  | ||||||
|                 DocumentService.increment_chunk_num( |  | ||||||
|                     doc.id, doc.kb_id, doc.token_num * -1, doc.chunk_num * -1, 0) |  | ||||||
|                 if not DocumentService.delete(doc): |  | ||||||
|                     return get_data_error_result( |                     return get_data_error_result( | ||||||
|                         retmsg="Database error (Document removal)!") |                         retmsg="Database error (Document removal)!") | ||||||
|         return get_json_result(data=True) |         return get_json_result(data=True) | ||||||
|  | |||||||
| @ -277,11 +277,7 @@ def rm(): | |||||||
|                 tenant_id = DocumentService.get_tenant_id(doc_id) |                 tenant_id = DocumentService.get_tenant_id(doc_id) | ||||||
|                 if not tenant_id: |                 if not tenant_id: | ||||||
|                     return get_data_error_result(retmsg="Tenant not found!") |                     return get_data_error_result(retmsg="Tenant not found!") | ||||||
|                 ELASTICSEARCH.deleteByQuery( |                 if not DocumentService.remove_document(doc, tenant_id): | ||||||
|                     Q("match", doc_id=doc.id), idxnm=search.index_name(tenant_id)) |  | ||||||
|                 DocumentService.increment_chunk_num( |  | ||||||
|                     doc.id, doc.kb_id, doc.token_num * -1, doc.chunk_num * -1, 0) |  | ||||||
|                 if not DocumentService.delete(doc): |  | ||||||
|                     return get_data_error_result( |                     return get_data_error_result( | ||||||
|                         retmsg="Database error (Document removal)!") |                         retmsg="Database error (Document removal)!") | ||||||
|             File2DocumentService.delete_by_file_id(file_id) |             File2DocumentService.delete_by_file_id(file_id) | ||||||
|  | |||||||
| @ -136,12 +136,7 @@ def rm(): | |||||||
|                 data=False, retmsg=f'Only owner of knowledgebase authorized for this operation.', retcode=RetCode.OPERATING_ERROR) |                 data=False, retmsg=f'Only owner of knowledgebase authorized for this operation.', retcode=RetCode.OPERATING_ERROR) | ||||||
| 
 | 
 | ||||||
|         for doc in DocumentService.query(kb_id=req["kb_id"]): |         for doc in DocumentService.query(kb_id=req["kb_id"]): | ||||||
|             ELASTICSEARCH.deleteByQuery( |             if not DocumentService.remove_document(doc, kbs[0].tenant_id): | ||||||
|                 Q("match", doc_id=doc.id), idxnm=search.index_name(kbs[0].tenant_id)) |  | ||||||
| 
 |  | ||||||
|             DocumentService.increment_chunk_num( |  | ||||||
|                 doc.id, doc.kb_id, doc.token_num * -1, doc.chunk_num * -1, 0) |  | ||||||
|             if not DocumentService.delete(doc): |  | ||||||
|                 return get_data_error_result( |                 return get_data_error_result( | ||||||
|                     retmsg="Database error (Document removal)!") |                     retmsg="Database error (Document removal)!") | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -70,27 +70,12 @@ class DocumentService(CommonService): | |||||||
|             raise RuntimeError("Database error (Knowledgebase)!") |             raise RuntimeError("Database error (Knowledgebase)!") | ||||||
|         return doc |         return doc | ||||||
| 
 | 
 | ||||||
|     @classmethod |  | ||||||
|     @DB.connection_context() |  | ||||||
|     def delete(cls, doc): |  | ||||||
|         e, kb = KnowledgebaseService.get_by_id(doc.kb_id) |  | ||||||
|         if not KnowledgebaseService.update_by_id( |  | ||||||
|                 kb.id, {"doc_num": max(0, kb.doc_num - 1)}): |  | ||||||
|             raise RuntimeError("Database error (Knowledgebase)!") |  | ||||||
|         return cls.delete_by_id(doc.id) |  | ||||||
| 
 |  | ||||||
|     @classmethod |     @classmethod | ||||||
|     @DB.connection_context() |     @DB.connection_context() | ||||||
|     def remove_document(cls, doc, tenant_id): |     def remove_document(cls, doc, tenant_id): | ||||||
|         ELASTICSEARCH.deleteByQuery( |         ELASTICSEARCH.deleteByQuery( | ||||||
|                 Q("match", doc_id=doc.id), idxnm=search.index_name(tenant_id)) |                 Q("match", doc_id=doc.id), idxnm=search.index_name(tenant_id)) | ||||||
| 
 |         cls.clear_chunk_num(doc.id) | ||||||
|         cls.increment_chunk_num( |  | ||||||
|             doc.id, doc.kb_id, doc.token_num * -1, doc.chunk_num * -1, 0) |  | ||||||
|         if not cls.delete(doc): |  | ||||||
|             raise RuntimeError("Database error (Document removal)!") |  | ||||||
| 
 |  | ||||||
|         MINIO.rm(doc.kb_id, doc.location) |  | ||||||
|         return cls.delete_by_id(doc.id) |         return cls.delete_by_id(doc.id) | ||||||
| 
 | 
 | ||||||
|     @classmethod |     @classmethod | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 KevinHuSh
						KevinHuSh