From fa27e84f68ca6bd969d40795aabd9b95c44b748c Mon Sep 17 00:00:00 2001 From: Xin Liu Date: Tue, 12 Mar 2024 19:55:38 +0900 Subject: [PATCH] refactor!: update `search_points` Signed-off-by: Xin Liu --- src/lib.rs | 38 ++++++++++++++++++++++++++------------ 1 file changed, 26 insertions(+), 12 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 13b3bcc..3454bb2 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1,4 +1,4 @@ -use anyhow::{anyhow, Error}; +use anyhow::{anyhow, bail, Error}; use serde::{Deserialize, Serialize}; use serde_json::json; use serde_json::{Map, Value}; @@ -98,7 +98,7 @@ impl Qdrant { point: Vec, limit: u64, score_threshold: Option, - ) -> Vec { + ) -> Result, Error> { let score_threshold = match score_threshold { Some(v) => v, None => 0.0, @@ -112,17 +112,31 @@ impl Qdrant { "score_threshold": score_threshold, }); - let v = self - .search_points_api(collection_name, ¶ms) - .await - .unwrap(); - let rs: &Vec = v.get("result").unwrap().as_array().unwrap(); - let mut sps: Vec = Vec::::new(); - for r in rs { - let sp: ScoredPoint = serde_json::from_value(r.clone()).unwrap(); - sps.push(sp); + let v = match self.search_points_api(collection_name, ¶ms).await { + Ok(v) => v, + Err(e) => { + return Err(e); + } + }; + + match v.get("result") { + Some(v) => match v.as_array() { + Some(rs) => { + let mut sps: Vec = Vec::::new(); + for r in rs { + let sp: ScoredPoint = serde_json::from_value(r.clone()).unwrap(); + sps.push(sp); + } + return Ok(sps); + } + None => { + bail!("The value corresponding to the 'result' key is not an array."); + } + }, + None => { + bail!("The given key 'result' does not exist."); + } } - sps } pub async fn get_points(&self, collection_name: &str, ids: Vec) -> Vec {