mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	Fix some issues
This commit is contained in:
		
				
					committed by
					
						 Kerollmops
						Kerollmops
					
				
			
			
				
	
			
			
			
						parent
						
							662c5d9871
						
					
				
				
					commit
					1a9dbd364e
				
			| @@ -8,7 +8,7 @@ pub const DEFAULT_CHAT_SYSTEM_PROMPT: &str = "You are a highly capable research | |||||||
| pub const DEFAULT_CHAT_SEARCH_DESCRIPTION_PROMPT: &str = | pub const DEFAULT_CHAT_SEARCH_DESCRIPTION_PROMPT: &str = | ||||||
|     "Search the database for relevant JSON documents using an optional query."; |     "Search the database for relevant JSON documents using an optional query."; | ||||||
| pub const DEFAULT_CHAT_SEARCH_Q_PARAM_PROMPT: &str = "The search query string used to find relevant documents in the index. This should contain keywords or phrases that best represent what the user is looking for. More specific queries will yield more precise results."; | pub const DEFAULT_CHAT_SEARCH_Q_PARAM_PROMPT: &str = "The search query string used to find relevant documents in the index. This should contain keywords or phrases that best represent what the user is looking for. More specific queries will yield more precise results."; | ||||||
| pub const DEFAULT_CHAT_SEARCH_FILTER_PARAM_PROMPT: &str = "The search filter string used to find relevant documents in the index. It supports parentheses, AND, OR, NOT, EXISTS, IS EMPTY, IS NOT EMPTY. Here is an example: \"price > 100 AND category = 'electronics'\""; | pub const DEFAULT_CHAT_SEARCH_FILTER_PARAM_PROMPT: &str = "The search filter string used to find relevant documents in the index. It supports parentheses, `=`, `!=`, `>=`, `>`, `<=`, `<`, `IN`, `NOT IN`, `TO`, `EXISTS`, `NOT EXISTS`, `IS NULL`, `IS NOT NULL`, `IS EMPTY`, `IS NOT EMPTY`, `CONTAINS`, `NOT CONTAINS`, `STARTS WITH`, `NOT STARTS WITH`, `_geoRadius`, or `_geoBoundingBox`. Here is an example: \"price > 100 AND category = 'electronics'\""; | ||||||
| pub const DEFAULT_CHAT_SEARCH_INDEX_UID_PARAM_PROMPT: &str = "The name of the index to search within. An index is a collection of documents organized for search. Selecting the right index ensures the most relevant results for the user query."; | pub const DEFAULT_CHAT_SEARCH_INDEX_UID_PARAM_PROMPT: &str = "The name of the index to search within. An index is a collection of documents organized for search. Selecting the right index ensures the most relevant results for the user query."; | ||||||
|  |  | ||||||
| #[derive(Serialize, Deserialize, Debug, Clone, Copy, Default, PartialEq, Eq)] | #[derive(Serialize, Deserialize, Debug, Clone, Copy, Default, PartialEq, Eq)] | ||||||
|   | |||||||
| @@ -209,7 +209,7 @@ fn setup_search_tool( | |||||||
|                             "description": prompts.search_filter_param, |                             "description": prompts.search_filter_param, | ||||||
|                         } |                         } | ||||||
|                     }, |                     }, | ||||||
|                     "required": ["index_uid", "q"], |                     "required": ["index_uid", "q", "filter"], | ||||||
|                     "additionalProperties": false, |                     "additionalProperties": false, | ||||||
|                 })) |                 })) | ||||||
|                 .strict(true) |                 .strict(true) | ||||||
| @@ -251,11 +251,16 @@ async fn process_search_request( | |||||||
|     auth_token: &str, |     auth_token: &str, | ||||||
|     index_uid: String, |     index_uid: String, | ||||||
|     q: Option<String>, |     q: Option<String>, | ||||||
|  |     filter: Option<String>, | ||||||
| ) -> Result<(Index, Vec<Document>, String), ResponseError> { | ) -> Result<(Index, Vec<Document>, String), ResponseError> { | ||||||
|     let index = index_scheduler.index(&index_uid)?; |     let index = index_scheduler.index(&index_uid)?; | ||||||
|     let rtxn = index.static_read_txn()?; |     let rtxn = index.static_read_txn()?; | ||||||
|     let ChatConfig { description: _, prompt: _, search_parameters } = index.chat_config(&rtxn)?; |     let ChatConfig { description: _, prompt: _, search_parameters } = index.chat_config(&rtxn)?; | ||||||
|     let mut query = SearchQuery { q, ..SearchQuery::from(search_parameters) }; |     let mut query = SearchQuery { | ||||||
|  |         q, | ||||||
|  |         filter: filter.map(serde_json::Value::from), | ||||||
|  |         ..SearchQuery::from(search_parameters) | ||||||
|  |     }; | ||||||
|     let auth_filter = ActionPolicy::<{ actions::SEARCH }>::authenticate( |     let auth_filter = ActionPolicy::<{ actions::SEARCH }>::authenticate( | ||||||
|         auth_ctrl, |         auth_ctrl, | ||||||
|         auth_token, |         auth_token, | ||||||
| @@ -399,16 +404,19 @@ async fn non_streamed_chat( | |||||||
|  |  | ||||||
|                 for call in meili_calls { |                 for call in meili_calls { | ||||||
|                     let result = match serde_json::from_str(&call.function.arguments) { |                     let result = match serde_json::from_str(&call.function.arguments) { | ||||||
|                         Ok(SearchInIndexParameters { index_uid, q }) => process_search_request( |                         Ok(SearchInIndexParameters { index_uid, q, filter }) => { | ||||||
|                             &index_scheduler, |                             process_search_request( | ||||||
|                             auth_ctrl.clone(), |                                 &index_scheduler, | ||||||
|                             &search_queue, |                                 auth_ctrl.clone(), | ||||||
|                             auth_token, |                                 &search_queue, | ||||||
|                             index_uid, |                                 auth_token, | ||||||
|                             q, |                                 index_uid, | ||||||
|                         ) |                                 q, | ||||||
|                         .await |                                 filter, | ||||||
|                         .map_err(|e| e.to_string()), |                             ) | ||||||
|  |                             .await | ||||||
|  |                             .map_err(|e| e.to_string()) | ||||||
|  |                         } | ||||||
|                         Err(err) => Err(err.to_string()), |                         Err(err) => Err(err.to_string()), | ||||||
|                     }; |                     }; | ||||||
|  |  | ||||||
| @@ -722,14 +730,15 @@ async fn handle_meili_tools( | |||||||
|  |  | ||||||
|         let mut error = None; |         let mut error = None; | ||||||
|  |  | ||||||
|         let result = match serde_json::from_str(&call.function.arguments) { |         let answer = match serde_json::from_str(&call.function.arguments) { | ||||||
|             Ok(SearchInIndexParameters { index_uid, q }) => match process_search_request( |             Ok(SearchInIndexParameters { index_uid, q, filter }) => match process_search_request( | ||||||
|                 index_scheduler, |                 index_scheduler, | ||||||
|                 auth_ctrl.clone(), |                 auth_ctrl.clone(), | ||||||
|                 search_queue, |                 search_queue, | ||||||
|                 auth_token, |                 auth_token, | ||||||
|                 index_uid, |                 index_uid, | ||||||
|                 q, |                 q, | ||||||
|  |                 filter, | ||||||
|             ) |             ) | ||||||
|             .await |             .await | ||||||
|             { |             { | ||||||
| @@ -805,4 +814,6 @@ struct SearchInIndexParameters { | |||||||
|     index_uid: String, |     index_uid: String, | ||||||
|     /// The query parameter to use. |     /// The query parameter to use. | ||||||
|     q: Option<String>, |     q: Option<String>, | ||||||
|  |     /// The filter parameter to use. | ||||||
|  |     filter: Option<String>, | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user