mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-11-04 09:56:28 +00:00 
			
		
		
		
	Introduce the sort search parameter
This commit is contained in:
		@@ -1,15 +1,17 @@
 | 
			
		||||
use std::collections::{BTreeMap, BTreeSet, HashSet};
 | 
			
		||||
use std::str::FromStr;
 | 
			
		||||
use std::time::Instant;
 | 
			
		||||
 | 
			
		||||
use either::Either;
 | 
			
		||||
use heed::RoTxn;
 | 
			
		||||
use indexmap::IndexMap;
 | 
			
		||||
use meilisearch_tokenizer::{Analyzer, AnalyzerConfig, Token};
 | 
			
		||||
use milli::{FieldId, FieldsIdsMap, FilterCondition, MatchingWords};
 | 
			
		||||
use milli::{AscDesc, FieldId, FieldsIdsMap, FilterCondition, MatchingWords};
 | 
			
		||||
use serde::{Deserialize, Serialize};
 | 
			
		||||
use serde_json::Value;
 | 
			
		||||
 | 
			
		||||
use crate::index::error::FacetError;
 | 
			
		||||
use crate::index::IndexError;
 | 
			
		||||
 | 
			
		||||
use super::error::Result;
 | 
			
		||||
use super::Index;
 | 
			
		||||
@@ -49,6 +51,7 @@ pub struct SearchQuery {
 | 
			
		||||
    #[serde(default = "Default::default")]
 | 
			
		||||
    pub matches: bool,
 | 
			
		||||
    pub filter: Option<Value>,
 | 
			
		||||
    pub sort: Option<Vec<String>>,
 | 
			
		||||
    pub facets_distribution: Option<Vec<String>>,
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -104,6 +107,15 @@ impl Index {
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if let Some(ref sort) = query.sort {
 | 
			
		||||
            let sort = match sort.iter().map(|s| AscDesc::from_str(s)).collect() {
 | 
			
		||||
                Ok(sorts) => sorts,
 | 
			
		||||
                Err(err) => return Err(IndexError::Milli(err.into())),
 | 
			
		||||
            };
 | 
			
		||||
 | 
			
		||||
            search.sort_criteria(sort);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        let milli::SearchResult {
 | 
			
		||||
            documents_ids,
 | 
			
		||||
            matching_words,
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,3 @@
 | 
			
		||||
use std::collections::{BTreeSet, HashSet};
 | 
			
		||||
 | 
			
		||||
use actix_web::{web, HttpResponse};
 | 
			
		||||
use log::debug;
 | 
			
		||||
use serde::Deserialize;
 | 
			
		||||
@@ -31,6 +29,7 @@ pub struct SearchQueryGet {
 | 
			
		||||
    crop_length: usize,
 | 
			
		||||
    attributes_to_highlight: Option<String>,
 | 
			
		||||
    filter: Option<String>,
 | 
			
		||||
    sort: Option<String>,
 | 
			
		||||
    #[serde(default = "Default::default")]
 | 
			
		||||
    matches: bool,
 | 
			
		||||
    facets_distribution: Option<String>,
 | 
			
		||||
@@ -40,19 +39,19 @@ impl From<SearchQueryGet> for SearchQuery {
 | 
			
		||||
    fn from(other: SearchQueryGet) -> Self {
 | 
			
		||||
        let attributes_to_retrieve = other
 | 
			
		||||
            .attributes_to_retrieve
 | 
			
		||||
            .map(|attrs| attrs.split(',').map(String::from).collect::<BTreeSet<_>>());
 | 
			
		||||
            .map(|attrs| attrs.split(',').map(String::from).collect());
 | 
			
		||||
 | 
			
		||||
        let attributes_to_crop = other
 | 
			
		||||
            .attributes_to_crop
 | 
			
		||||
            .map(|attrs| attrs.split(',').map(String::from).collect::<Vec<_>>());
 | 
			
		||||
            .map(|attrs| attrs.split(',').map(String::from).collect());
 | 
			
		||||
 | 
			
		||||
        let attributes_to_highlight = other
 | 
			
		||||
            .attributes_to_highlight
 | 
			
		||||
            .map(|attrs| attrs.split(',').map(String::from).collect::<HashSet<_>>());
 | 
			
		||||
            .map(|attrs| attrs.split(',').map(String::from).collect());
 | 
			
		||||
 | 
			
		||||
        let facets_distribution = other
 | 
			
		||||
            .facets_distribution
 | 
			
		||||
            .map(|attrs| attrs.split(',').map(String::from).collect::<Vec<_>>());
 | 
			
		||||
            .map(|attrs| attrs.split(',').map(String::from).collect());
 | 
			
		||||
 | 
			
		||||
        let filter = match other.filter {
 | 
			
		||||
            Some(f) => match serde_json::from_str(&f) {
 | 
			
		||||
@@ -62,6 +61,10 @@ impl From<SearchQueryGet> for SearchQuery {
 | 
			
		||||
            None => None,
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        let sort = other
 | 
			
		||||
            .sort
 | 
			
		||||
            .map(|attrs| attrs.split(',').map(String::from).collect());
 | 
			
		||||
 | 
			
		||||
        Self {
 | 
			
		||||
            q: other.q,
 | 
			
		||||
            offset: other.offset,
 | 
			
		||||
@@ -71,6 +74,7 @@ impl From<SearchQueryGet> for SearchQuery {
 | 
			
		||||
            crop_length: other.crop_length,
 | 
			
		||||
            attributes_to_highlight,
 | 
			
		||||
            filter,
 | 
			
		||||
            sort,
 | 
			
		||||
            matches: other.matches,
 | 
			
		||||
            facets_distribution,
 | 
			
		||||
        }
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user