meilisearch/meilisearch-http/src/routes/settings/mod.rs

188 lines
6.0 KiB
Rust
Raw Normal View History

2021-03-16 01:11:10 +08:00
use actix_web::{delete, get, post, web, HttpResponse};
2021-01-05 07:21:42 +08:00
2021-05-10 23:30:09 +08:00
use crate::{error::ResponseError, index::Unchecked};
2021-01-05 07:21:42 +08:00
use crate::helpers::Authentication;
2021-03-16 01:11:10 +08:00
use crate::index::Settings;
use crate::Data;
2021-01-05 07:21:42 +08:00
#[macro_export]
macro_rules! make_setting_route {
($route:literal, $type:ty, $attr:ident) => {
mod $attr {
use actix_web::{web, HttpResponse};
use crate::data;
use crate::error::ResponseError;
use crate::helpers::Authentication;
2021-03-04 18:56:32 +08:00
use crate::index::Settings;
2021-01-05 07:21:42 +08:00
#[actix_web::delete($route, wrap = "Authentication::Private")]
pub async fn delete(
data: web::Data<data::Data>,
index_uid: web::Path<String>,
) -> Result<HttpResponse, ResponseError> {
2021-03-04 18:56:32 +08:00
use crate::index::Settings;
2021-01-05 07:21:42 +08:00
let settings = Settings {
$attr: Some(None),
..Default::default()
};
match data.update_settings(index_uid.into_inner(), settings, false).await {
2021-04-01 21:50:45 +08:00
Ok(update_status) => {
Ok(HttpResponse::Accepted().json(serde_json::json!({ "updateId": update_status.id() })))
}
2021-01-05 07:21:42 +08:00
Err(e) => {
2021-03-16 23:09:14 +08:00
Ok(HttpResponse::BadRequest().json(serde_json::json!({ "error": e.to_string() })))
2021-01-05 07:21:42 +08:00
}
}
}
#[actix_web::post($route, wrap = "Authentication::Private")]
pub async fn update(
data: actix_web::web::Data<data::Data>,
index_uid: actix_web::web::Path<String>,
body: actix_web::web::Json<Option<$type>>,
) -> std::result::Result<HttpResponse, ResponseError> {
let settings = Settings {
$attr: Some(body.into_inner()),
..Default::default()
};
match data.update_settings(index_uid.into_inner(), settings, true).await {
2021-04-01 21:50:45 +08:00
Ok(update_status) => {
Ok(HttpResponse::Accepted().json(serde_json::json!({ "updateId": update_status.id() })))
}
2021-01-05 07:21:42 +08:00
Err(e) => {
2021-03-16 23:09:14 +08:00
Ok(HttpResponse::BadRequest().json(serde_json::json!({ "error": e.to_string() })))
2021-01-05 07:21:42 +08:00
}
}
}
#[actix_web::get($route, wrap = "Authentication::Private")]
pub async fn get(
data: actix_web::web::Data<data::Data>,
index_uid: actix_web::web::Path<String>,
) -> std::result::Result<HttpResponse, ResponseError> {
2021-03-15 23:52:05 +08:00
match data.settings(index_uid.into_inner()).await {
2021-03-16 23:09:14 +08:00
Ok(settings) => Ok(HttpResponse::Ok().json(settings.$attr)),
2021-01-05 07:21:42 +08:00
Err(e) => {
2021-03-16 23:09:14 +08:00
Ok(HttpResponse::BadRequest().json(serde_json::json!({ "error": e.to_string() })))
2021-01-05 07:21:42 +08:00
}
}
}
}
};
}
make_setting_route!(
"/indexes/{index_uid}/settings/attributes-for-faceting",
std::collections::HashMap<String, String>,
attributes_for_faceting
2021-01-05 07:21:42 +08:00
);
make_setting_route!(
"/indexes/{index_uid}/settings/displayed-attributes",
Vec<String>,
displayed_attributes
);
make_setting_route!(
"/indexes/{index_uid}/settings/searchable-attributes",
Vec<String>,
searchable_attributes
);
make_setting_route!(
"/indexes/{index_uid}/settings/stop-words",
std::collections::BTreeSet<String>,
stop_words
);
make_setting_route!(
"/indexes/{index_uid}/settings/distinct-attribute",
String,
distinct_attribute
);
2021-01-05 07:21:42 +08:00
2021-04-27 21:29:00 +08:00
make_setting_route!(
"/indexes/{index_uid}/settings/ranking-rules",
Vec<String>,
ranking_rules
);
2021-01-05 07:21:42 +08:00
macro_rules! create_services {
($($mod:ident),*) => {
pub fn services(cfg: &mut web::ServiceConfig) {
cfg
.service(update_all)
.service(get_all)
.service(delete_all)
$(
.service($mod::get)
.service($mod::update)
.service($mod::delete)
)*;
}
};
}
create_services!(
attributes_for_faceting,
2021-01-05 07:21:42 +08:00
displayed_attributes,
searchable_attributes,
distinct_attribute,
2021-04-27 21:29:00 +08:00
stop_words,
ranking_rules
2021-01-05 07:21:42 +08:00
);
#[post("/indexes/{index_uid}/settings", wrap = "Authentication::Private")]
async fn update_all(
data: web::Data<Data>,
index_uid: web::Path<String>,
2021-05-10 23:30:09 +08:00
body: web::Json<Settings<Unchecked>>,
2021-01-05 07:21:42 +08:00
) -> Result<HttpResponse, ResponseError> {
2021-05-10 23:30:09 +08:00
let settings = body.into_inner().check();
2021-03-16 01:11:10 +08:00
match data
2021-05-10 23:30:09 +08:00
.update_settings(index_uid.into_inner(), settings, true)
2021-03-16 01:11:10 +08:00
.await
{
2021-04-14 23:53:12 +08:00
Ok(update_result) => Ok(
HttpResponse::Accepted().json(serde_json::json!({ "updateId": update_result.id() }))
),
2021-01-05 07:21:42 +08:00
Err(e) => {
2021-03-16 23:09:14 +08:00
Ok(HttpResponse::BadRequest().json(serde_json::json!({ "error": e.to_string() })))
2021-01-05 07:21:42 +08:00
}
}
}
#[get("/indexes/{index_uid}/settings", wrap = "Authentication::Private")]
async fn get_all(
data: web::Data<Data>,
index_uid: web::Path<String>,
) -> Result<HttpResponse, ResponseError> {
2021-03-15 23:52:05 +08:00
match data.settings(index_uid.into_inner()).await {
2021-03-16 23:09:14 +08:00
Ok(settings) => Ok(HttpResponse::Ok().json(settings)),
2021-01-05 07:21:42 +08:00
Err(e) => {
2021-03-16 23:09:14 +08:00
Ok(HttpResponse::BadRequest().json(serde_json::json!({ "error": e.to_string() })))
2021-01-05 07:21:42 +08:00
}
}
}
#[delete("/indexes/{index_uid}/settings", wrap = "Authentication::Private")]
async fn delete_all(
data: web::Data<Data>,
index_uid: web::Path<String>,
) -> Result<HttpResponse, ResponseError> {
let settings = Settings::cleared();
2021-03-16 01:11:10 +08:00
match data
.update_settings(index_uid.into_inner(), settings, false)
.await
{
2021-04-14 23:53:12 +08:00
Ok(update_result) => Ok(
HttpResponse::Accepted().json(serde_json::json!({ "updateId": update_result.id() }))
),
2021-01-05 07:21:42 +08:00
Err(e) => {
2021-03-16 23:09:14 +08:00
Ok(HttpResponse::BadRequest().json(serde_json::json!({ "error": e.to_string() })))
2021-01-05 07:21:42 +08:00
}
}
}