MeiliSearch/meilisearch-http/src/routes/synonym.rs

83 lines
2.2 KiB
Rust
Raw Normal View History

2020-01-10 18:20:30 +01:00
use std::collections::BTreeMap;
2019-10-31 15:00:36 +01:00
2019-12-11 16:49:09 +01:00
use indexmap::IndexMap;
2020-01-10 18:20:30 +01:00
use meilisearch_core::settings::{SettingsUpdate, UpdateState};
2020-01-23 11:30:18 +01:00
use tide::{Request, Response};
2019-10-31 15:00:36 +01:00
use crate::error::{ResponseError, SResult};
2020-01-15 17:10:33 +01:00
use crate::helpers::tide::RequestExt;
2020-02-06 15:41:11 +01:00
use crate::helpers::tide::ACL::*;
2019-10-31 15:00:36 +01:00
use crate::routes::document::IndexUpdateResponse;
use crate::Data;
2020-01-15 17:10:33 +01:00
pub async fn get(ctx: Request<Data>) -> SResult<Response> {
2020-02-06 15:41:11 +01:00
ctx.is_allowed(Private)?;
2019-10-31 15:00:36 +01:00
let index = ctx.index()?;
let db = &ctx.state().db;
2020-01-16 16:58:57 +01:00
let reader = db.main_read_txn()?;
2019-10-31 15:00:36 +01:00
2020-01-16 19:19:44 +01:00
let synonyms_fst = index.main.synonyms_fst(&reader)?.unwrap_or_default();
2020-01-16 16:58:57 +01:00
let synonyms_list = synonyms_fst.stream().into_strs()?;
2019-10-31 15:00:36 +01:00
2020-01-16 19:19:44 +01:00
let mut synonyms = IndexMap::new();
2019-10-31 15:00:36 +01:00
let index_synonyms = &index.synonyms;
for synonym in synonyms_list {
2020-01-16 16:58:57 +01:00
let alternative_list = index_synonyms.synonyms(&reader, synonym.as_bytes())?;
if let Some(list) = alternative_list {
2020-01-16 16:58:57 +01:00
let list = list.stream().into_strs()?;
2020-01-16 19:19:44 +01:00
synonyms.insert(synonym, list);
}
2019-10-31 15:00:36 +01:00
}
2020-01-16 19:19:44 +01:00
Ok(tide::Response::new(200).body_json(&synonyms).unwrap())
2019-10-31 15:00:36 +01:00
}
2020-01-15 17:10:33 +01:00
pub async fn update(mut ctx: Request<Data>) -> SResult<Response> {
2020-02-06 15:41:11 +01:00
ctx.is_allowed(Private)?;
2019-10-31 15:00:36 +01:00
2020-01-23 11:30:18 +01:00
let data: BTreeMap<String, Vec<String>> =
ctx.body_json().await.map_err(ResponseError::bad_request)?;
2019-10-31 15:00:36 +01:00
let index = ctx.index()?;
let db = &ctx.state().db;
2020-01-16 16:58:57 +01:00
let mut writer = db.update_write_txn()?;
2019-10-31 15:00:36 +01:00
2020-01-10 18:20:30 +01:00
let settings = SettingsUpdate {
synonyms: UpdateState::Update(data),
2020-01-23 11:30:18 +01:00
..SettingsUpdate::default()
2020-01-10 18:20:30 +01:00
};
2019-10-31 15:00:36 +01:00
2020-01-16 16:58:57 +01:00
let update_id = index.settings_update(&mut writer, settings)?;
2019-10-31 15:00:36 +01:00
2020-01-16 16:58:57 +01:00
writer.commit()?;
2019-10-31 15:00:36 +01:00
let response_body = IndexUpdateResponse { update_id };
2020-01-29 18:30:21 +01:00
Ok(tide::Response::new(202).body_json(&response_body)?)
2019-10-31 15:00:36 +01:00
}
2020-01-15 17:10:33 +01:00
pub async fn delete(ctx: Request<Data>) -> SResult<Response> {
2020-02-06 15:41:11 +01:00
ctx.is_allowed(Private)?;
let index = ctx.index()?;
let db = &ctx.state().db;
2020-01-16 16:58:57 +01:00
let mut writer = db.update_write_txn()?;
2020-01-08 14:17:38 +01:00
let settings = SettingsUpdate {
synonyms: UpdateState::Clear,
2020-01-23 11:30:18 +01:00
..SettingsUpdate::default()
2020-01-08 14:17:38 +01:00
};
2020-01-16 16:58:57 +01:00
let update_id = index.settings_update(&mut writer, settings)?;
2020-01-16 16:58:57 +01:00
writer.commit()?;
let response_body = IndexUpdateResponse { update_id };
2020-01-29 18:30:21 +01:00
Ok(tide::Response::new(202).body_json(&response_body)?)
}