mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	add error on search with empty facets
This commit is contained in:
		| @@ -183,6 +183,7 @@ pub enum FacetError { | ||||
|     AttributeNotFound(String), | ||||
|     AttributeNotSet { expected: Vec<String>, found: String }, | ||||
|     InvalidDocumentAttribute(String), | ||||
|     NoAttributesForFaceting, | ||||
| } | ||||
|  | ||||
| impl FacetError { | ||||
| @@ -207,6 +208,7 @@ impl fmt::Display for FacetError { | ||||
|             AttributeNotFound(attr) => write!(f, "unknown {:?} attribute", attr), | ||||
|             AttributeNotSet { found, expected } => write!(f, "`{}` is not set as a faceted attribute. available facet attributes: {}", found, expected.join(", ")), | ||||
|             InvalidDocumentAttribute(attr) => write!(f, "invalid document attribute {}, accepted types: String and [String]", attr), | ||||
|             NoAttributesForFaceting => write!(f, "impossible to perform faceted search, no attributes for faceting are set"), | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -35,6 +35,9 @@ impl FacetFilter { | ||||
|         schema: &Schema, | ||||
|         attributes_for_faceting: &[FieldId], | ||||
|     ) -> MResult<FacetFilter> { | ||||
|         if attributes_for_faceting.is_empty() { | ||||
|             return Err(FacetError::NoAttributesForFaceting.into()); | ||||
|         } | ||||
|         let parsed = serde_json::from_str::<Value>(s).map_err(|e| FacetError::ParsingError(e.to_string()))?; | ||||
|         let mut filter = Vec::new(); | ||||
|         match parsed { | ||||
|   | ||||
| @@ -87,11 +87,9 @@ async fn search_with_url_query( | ||||
|     } | ||||
|  | ||||
|     if let Some(ref facet_filters) = params.facet_filters { | ||||
|         let attrs = index.main.attributes_for_faceting(&reader)?; | ||||
|         if let Some(attrs) = attrs { | ||||
|         let attrs = index.main.attributes_for_faceting(&reader)?.unwrap_or_default(); | ||||
|         search_builder.add_facet_filters(FacetFilter::from_str(facet_filters, &schema, &attrs)?); | ||||
|     } | ||||
|     } | ||||
|  | ||||
|     if let Some(facets) = ¶ms.facets_distribution { | ||||
|         match index.main.attributes_for_faceting(&reader)? { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user