mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 21:46:27 +00:00 
			
		
		
		
	Merge branch 'main' into fix-3037
This commit is contained in:
		| @@ -20,7 +20,7 @@ use serde::Deserialize; | ||||
| use serde_cs::vec::CS; | ||||
| use serde_json::Value; | ||||
| use tempfile::NamedTempFile; | ||||
| use crate::analytics::Analytics; | ||||
| use crate::analytics::{Analytics, DocumentDeletionKind}; | ||||
| use crate::error::MeilisearchHttpError; | ||||
| use crate::error::PayloadError::ReceivePayloadErr; | ||||
| use crate::extractors::authentication::policies::*; | ||||
| @@ -95,7 +95,11 @@ pub async fn get_document( | ||||
| pub async fn delete_document( | ||||
|     index_scheduler: GuardedData<ActionPolicy<{ actions::DOCUMENTS_DELETE }>, Data<IndexScheduler>>, | ||||
|     path: web::Path<DocumentParam>, | ||||
|     req: HttpRequest, | ||||
|     analytics: web::Data<dyn Analytics>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     analytics.delete_documents(DocumentDeletionKind::PerDocumentId, &req); | ||||
|  | ||||
|     let DocumentParam { document_id, index_uid } = path.into_inner(); | ||||
|     let task = KindWithContent::DocumentDeletion { index_uid, documents_ids: vec![document_id] }; | ||||
|     let task: SummarizedTaskView = | ||||
| @@ -321,8 +325,13 @@ pub async fn delete_documents( | ||||
|     index_scheduler: GuardedData<ActionPolicy<{ actions::DOCUMENTS_DELETE }>, Data<IndexScheduler>>, | ||||
|     path: web::Path<String>, | ||||
|     body: web::Json<Vec<Value>>, | ||||
|     req: HttpRequest, | ||||
|     analytics: web::Data<dyn Analytics>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     debug!("called with params: {:?}", body); | ||||
|  | ||||
|     analytics.delete_documents(DocumentDeletionKind::PerBatch, &req); | ||||
|  | ||||
|     let ids = body | ||||
|         .iter() | ||||
|         .map(|v| v.as_str().map(String::from).unwrap_or_else(|| v.to_string())) | ||||
| @@ -340,7 +349,11 @@ pub async fn delete_documents( | ||||
| pub async fn clear_all_documents( | ||||
|     index_scheduler: GuardedData<ActionPolicy<{ actions::DOCUMENTS_DELETE }>, Data<IndexScheduler>>, | ||||
|     path: web::Path<String>, | ||||
|     req: HttpRequest, | ||||
|     analytics: web::Data<dyn Analytics>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     analytics.delete_documents(DocumentDeletionKind::ClearAll, &req); | ||||
|  | ||||
|     let task = KindWithContent::DocumentClear { index_uid: path.into_inner() }; | ||||
|     let task: SummarizedTaskView = | ||||
|         tokio::task::spawn_blocking(move || index_scheduler.register(task)).await??.into(); | ||||
|   | ||||
| @@ -123,17 +123,6 @@ macro_rules! make_setting_route { | ||||
|             } | ||||
|         } | ||||
|     }; | ||||
|     ($route:literal, $update_verb:ident, $type:ty, $attr:ident, $camelcase_attr:literal) => { | ||||
|         make_setting_route!( | ||||
|             $route, | ||||
|             $update_verb, | ||||
|             $type, | ||||
|             $attr, | ||||
|             $camelcase_attr, | ||||
|             _analytics, | ||||
|             |_, _| {} | ||||
|         ); | ||||
|     }; | ||||
| } | ||||
|  | ||||
| make_setting_route!( | ||||
| @@ -187,7 +176,22 @@ make_setting_route!( | ||||
|     put, | ||||
|     Vec<String>, | ||||
|     displayed_attributes, | ||||
|     "displayedAttributes" | ||||
|     "displayedAttributes", | ||||
|     analytics, | ||||
|     |displayed: &Option<Vec<String>>, req: &HttpRequest| { | ||||
|         use serde_json::json; | ||||
|  | ||||
|         analytics.publish( | ||||
|             "DisplayedAttributes Updated".to_string(), | ||||
|             json!({ | ||||
|                 "displayed_attributes": { | ||||
|                     "total": displayed.as_ref().map(|displayed| displayed.len()), | ||||
|                     "with_wildcard": displayed.as_ref().map(|displayed| displayed.iter().any(|displayed| displayed == "*")), | ||||
|                 }, | ||||
|             }), | ||||
|             Some(req), | ||||
|         ); | ||||
|     } | ||||
| ); | ||||
|  | ||||
| make_setting_route!( | ||||
| @@ -247,6 +251,7 @@ make_setting_route!( | ||||
|             json!({ | ||||
|                 "searchable_attributes": { | ||||
|                     "total": setting.as_ref().map(|searchable| searchable.len()), | ||||
|                     "with_wildcard": setting.as_ref().map(|searchable| searchable.iter().any(|searchable| searchable == "*")), | ||||
|                 }, | ||||
|             }), | ||||
|             Some(req), | ||||
| @@ -259,7 +264,21 @@ make_setting_route!( | ||||
|     put, | ||||
|     std::collections::BTreeSet<String>, | ||||
|     stop_words, | ||||
|     "stopWords" | ||||
|     "stopWords", | ||||
|     analytics, | ||||
|     |stop_words: &Option<std::collections::BTreeSet<String>>, req: &HttpRequest| { | ||||
|         use serde_json::json; | ||||
|  | ||||
|         analytics.publish( | ||||
|             "StopWords Updated".to_string(), | ||||
|             json!({ | ||||
|                 "stop_words": { | ||||
|                     "total": stop_words.as_ref().map(|stop_words| stop_words.len()), | ||||
|                 }, | ||||
|             }), | ||||
|             Some(req), | ||||
|         ); | ||||
|     } | ||||
| ); | ||||
|  | ||||
| make_setting_route!( | ||||
| @@ -267,10 +286,43 @@ make_setting_route!( | ||||
|     put, | ||||
|     std::collections::BTreeMap<String, Vec<String>>, | ||||
|     synonyms, | ||||
|     "synonyms" | ||||
|     "synonyms", | ||||
|     analytics, | ||||
|     |synonyms: &Option<std::collections::BTreeMap<String, Vec<String>>>, req: &HttpRequest| { | ||||
|         use serde_json::json; | ||||
|  | ||||
|         analytics.publish( | ||||
|             "Synonyms Updated".to_string(), | ||||
|             json!({ | ||||
|                 "synonyms": { | ||||
|                     "total": synonyms.as_ref().map(|synonyms| synonyms.len()), | ||||
|                 }, | ||||
|             }), | ||||
|             Some(req), | ||||
|         ); | ||||
|     } | ||||
| ); | ||||
|  | ||||
| make_setting_route!("/distinct-attribute", put, String, distinct_attribute, "distinctAttribute"); | ||||
| make_setting_route!( | ||||
|     "/distinct-attribute", | ||||
|     put, | ||||
|     String, | ||||
|     distinct_attribute, | ||||
|     "distinctAttribute", | ||||
|     analytics, | ||||
|     |distinct: &Option<String>, req: &HttpRequest| { | ||||
|         use serde_json::json; | ||||
|         analytics.publish( | ||||
|             "DistinctAttribute Updated".to_string(), | ||||
|             json!({ | ||||
|                 "distinct_attribute": { | ||||
|                     "set": distinct.is_some(), | ||||
|                 } | ||||
|             }), | ||||
|             Some(req), | ||||
|         ); | ||||
|     } | ||||
| ); | ||||
|  | ||||
| make_setting_route!( | ||||
|     "/ranking-rules", | ||||
| @@ -286,7 +338,13 @@ make_setting_route!( | ||||
|             "RankingRules Updated".to_string(), | ||||
|             json!({ | ||||
|                 "ranking_rules": { | ||||
|                     "sort_position": setting.as_ref().map(|sort| sort.iter().position(|s| s == "sort")), | ||||
|                     "words_position": setting.as_ref().map(|rr| rr.iter().position(|s| s == "words")), | ||||
|                     "typo_position": setting.as_ref().map(|rr| rr.iter().position(|s| s == "typo")), | ||||
|                     "proximity_position": setting.as_ref().map(|rr| rr.iter().position(|s| s == "proximity")), | ||||
|                     "attribute_position": setting.as_ref().map(|rr| rr.iter().position(|s| s == "attribute")), | ||||
|                     "sort_position": setting.as_ref().map(|rr| rr.iter().position(|s| s == "sort")), | ||||
|                     "exactness_position": setting.as_ref().map(|rr| rr.iter().position(|s| s == "exactness")), | ||||
|                     "values": setting.as_ref().map(|rr| rr.iter().filter(|s| !s.contains(':')).cloned().collect::<Vec<_>>().join(", ")), | ||||
|                 } | ||||
|             }), | ||||
|             Some(req), | ||||
| @@ -379,10 +437,21 @@ pub async fn update_all( | ||||
|         "Settings Updated".to_string(), | ||||
|         json!({ | ||||
|            "ranking_rules": { | ||||
|                 "sort_position": new_settings.ranking_rules.as_ref().set().map(|sort| sort.iter().position(|s| s == "sort")), | ||||
|                 "words_position": new_settings.ranking_rules.as_ref().set().map(|rr| rr.iter().position(|s| s == "words")), | ||||
|                 "typo_position": new_settings.ranking_rules.as_ref().set().map(|rr| rr.iter().position(|s| s == "typo")), | ||||
|                 "proximity_position": new_settings.ranking_rules.as_ref().set().map(|rr| rr.iter().position(|s| s == "proximity")), | ||||
|                 "attribute_position": new_settings.ranking_rules.as_ref().set().map(|rr| rr.iter().position(|s| s == "attribute")), | ||||
|                 "sort_position": new_settings.ranking_rules.as_ref().set().map(|rr| rr.iter().position(|s| s == "sort")), | ||||
|                 "exactness_position": new_settings.ranking_rules.as_ref().set().map(|rr| rr.iter().position(|s| s == "exactness")), | ||||
|                 "values": new_settings.ranking_rules.as_ref().set().map(|rr| rr.iter().filter(|s| !s.contains(':')).cloned().collect::<Vec<_>>().join(", ")), | ||||
|             }, | ||||
|             "searchable_attributes": { | ||||
|                 "total": new_settings.searchable_attributes.as_ref().set().map(|searchable| searchable.len()), | ||||
|                 "with_wildcard": new_settings.searchable_attributes.as_ref().set().map(|searchable| searchable.iter().any(|searchable| searchable == "*")), | ||||
|             }, | ||||
|             "displayed_attributes": { | ||||
|                 "total": new_settings.displayed_attributes.as_ref().set().map(|displayed| displayed.len()), | ||||
|                 "with_wildcard": new_settings.displayed_attributes.as_ref().set().map(|displayed| displayed.iter().any(|displayed| displayed == "*")), | ||||
|             }, | ||||
|            "sortable_attributes": { | ||||
|                 "total": new_settings.sortable_attributes.as_ref().set().map(|sort| sort.len()), | ||||
| @@ -392,6 +461,9 @@ pub async fn update_all( | ||||
|                 "total": new_settings.filterable_attributes.as_ref().set().map(|filter| filter.len()), | ||||
|                 "has_geo": new_settings.filterable_attributes.as_ref().set().map(|filter| filter.iter().any(|s| s == "_geo")), | ||||
|             }, | ||||
|             "distinct_attribute": { | ||||
|                 "set": new_settings.distinct_attribute.as_ref().set().is_some() | ||||
|             }, | ||||
|             "typo_tolerance": { | ||||
|                 "enabled": new_settings.typo_tolerance | ||||
|                     .as_ref() | ||||
| @@ -435,6 +507,12 @@ pub async fn update_all( | ||||
|                     .set() | ||||
|                     .and_then(|s| s.max_total_hits.as_ref().set()), | ||||
|             }, | ||||
|             "stop_words": { | ||||
|                 "total": new_settings.stop_words.as_ref().set().map(|stop_words| stop_words.len()), | ||||
|             }, | ||||
|             "synonyms": { | ||||
|                 "total": new_settings.synonyms.as_ref().set().map(|synonyms| synonyms.len()), | ||||
|             }, | ||||
|         }), | ||||
|         Some(&req), | ||||
|     ); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user