2019-10-31 22:00:36 +08:00
|
|
|
use std::collections::HashMap;
|
|
|
|
|
|
|
|
use http::StatusCode;
|
|
|
|
use tide::response::IntoResponse;
|
|
|
|
use tide::{Context, Response};
|
2019-12-11 23:49:09 +08:00
|
|
|
use indexmap::IndexMap;
|
2019-10-31 22:00:36 +08:00
|
|
|
|
|
|
|
use crate::error::{ResponseError, SResult};
|
|
|
|
use crate::helpers::tide::ContextExt;
|
|
|
|
use crate::models::token::ACL::*;
|
|
|
|
use crate::routes::document::IndexUpdateResponse;
|
|
|
|
use crate::Data;
|
|
|
|
|
2019-12-11 23:49:09 +08:00
|
|
|
pub async fn get(ctx: Context<Data>) -> SResult<Response> {
|
2019-10-31 22:00:36 +08:00
|
|
|
ctx.is_allowed(SettingsRead)?;
|
|
|
|
let index = ctx.index()?;
|
|
|
|
|
2019-11-26 23:12:06 +08:00
|
|
|
let db = &ctx.state().db;
|
|
|
|
let reader = db.main_read_txn().map_err(ResponseError::internal)?;
|
2019-10-31 22:00:36 +08:00
|
|
|
|
|
|
|
let synonyms_fst = index
|
|
|
|
.main
|
|
|
|
.synonyms_fst(&reader)
|
|
|
|
.map_err(ResponseError::internal)?;
|
|
|
|
|
|
|
|
let synonyms_fst = synonyms_fst.unwrap_or_default();
|
2019-12-09 23:54:44 +08:00
|
|
|
let synonyms_list = synonyms_fst.stream().into_strs().map_err(ResponseError::internal)?;
|
2019-10-31 22:00:36 +08:00
|
|
|
|
2019-12-11 23:49:09 +08:00
|
|
|
let mut response = IndexMap::new();
|
2019-10-31 22:00:36 +08:00
|
|
|
|
|
|
|
let index_synonyms = &index.synonyms;
|
|
|
|
|
|
|
|
for synonym in synonyms_list {
|
|
|
|
let alternative_list = index_synonyms
|
|
|
|
.synonyms(&reader, synonym.as_bytes())
|
2019-12-09 23:54:44 +08:00
|
|
|
.map_err(ResponseError::internal)?;
|
|
|
|
|
|
|
|
if let Some(list) = alternative_list {
|
|
|
|
let list = list.stream().into_strs().map_err(ResponseError::internal)?;
|
|
|
|
response.insert(synonym, list);
|
|
|
|
}
|
2019-10-31 22:00:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
Ok(tide::response::json(response))
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn update(mut ctx: Context<Data>) -> SResult<Response> {
|
|
|
|
ctx.is_allowed(SettingsWrite)?;
|
|
|
|
|
2019-12-11 23:49:09 +08:00
|
|
|
let data: HashMap<String, Vec<String>> = ctx.body_json().await.map_err(ResponseError::bad_request)?;
|
2019-10-31 22:00:36 +08:00
|
|
|
|
|
|
|
let index = ctx.index()?;
|
|
|
|
|
2019-11-26 23:12:06 +08:00
|
|
|
let db = &ctx.state().db;
|
|
|
|
let mut writer = db.update_write_txn().map_err(ResponseError::internal)?;
|
2019-10-31 22:00:36 +08:00
|
|
|
|
2019-12-11 23:49:09 +08:00
|
|
|
let mut synonyms_update = index.synonyms_update();
|
2019-10-31 22:00:36 +08:00
|
|
|
|
2019-12-11 23:49:09 +08:00
|
|
|
for (input, synonyms) in data {
|
|
|
|
synonyms_update.add_synonym(input, synonyms.into_iter());
|
2019-10-31 22:00:36 +08:00
|
|
|
}
|
|
|
|
|
2019-12-11 23:49:09 +08:00
|
|
|
let update_id = synonyms_update
|
2019-10-31 22:00:36 +08:00
|
|
|
.finalize(&mut writer)
|
|
|
|
.map_err(ResponseError::internal)?;
|
|
|
|
|
|
|
|
writer.commit().map_err(ResponseError::internal)?;
|
|
|
|
|
|
|
|
let response_body = IndexUpdateResponse { update_id };
|
|
|
|
Ok(tide::response::json(response_body)
|
|
|
|
.with_status(StatusCode::ACCEPTED)
|
|
|
|
.into_response())
|
|
|
|
}
|
2020-01-03 00:10:49 +08:00
|
|
|
|
|
|
|
|
|
|
|
pub async fn delete(ctx: Context<Data>) -> SResult<Response> {
|
|
|
|
ctx.is_allowed(SettingsWrite)?;
|
|
|
|
|
|
|
|
let index = ctx.index()?;
|
|
|
|
|
|
|
|
let db = &ctx.state().db;
|
|
|
|
let mut writer = db.update_write_txn().map_err(ResponseError::internal)?;
|
|
|
|
|
2020-01-08 21:17:38 +08:00
|
|
|
let settings = SettingsUpdate {
|
|
|
|
synonyms: UpdateState::Clear,
|
|
|
|
.. SettingsUpdate::default()
|
|
|
|
};
|
|
|
|
|
2020-01-03 00:10:49 +08:00
|
|
|
let synonyms_update = index.synonyms_update();
|
|
|
|
|
|
|
|
let update_id = synonyms_update
|
|
|
|
.finalize(&mut writer)
|
|
|
|
.map_err(ResponseError::internal)?;
|
|
|
|
|
|
|
|
writer.commit().map_err(ResponseError::internal)?;
|
|
|
|
|
|
|
|
let response_body = IndexUpdateResponse { update_id };
|
|
|
|
Ok(tide::response::json(response_body)
|
|
|
|
.with_status(StatusCode::ACCEPTED)
|
|
|
|
.into_response())
|
|
|
|
}
|