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

163 lines
5.0 KiB
Rust
Raw Normal View History

2021-03-15 18:11:10 +01:00
use actix_web::{delete, get, post, web, HttpResponse};
2021-01-05 00:21:42 +01:00
use crate::helpers::Authentication;
2021-03-15 18:11:10 +01:00
use crate::index::Settings;
use crate::Data;
2021-05-31 16:03:39 +02:00
use crate::{error::ResponseError, index::Unchecked};
2021-01-05 00:21:42 +01: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 11:56:32 +01:00
use crate::index::Settings;
2021-01-05 00:21:42 +01: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 11:56:32 +01:00
use crate::index::Settings;
2021-01-05 00:21:42 +01:00
let settings = Settings {
$attr: Some(None),
..Default::default()
};
let update_status = data.update_settings(index_uid.into_inner(), settings, false).await?;
Ok(HttpResponse::Accepted().json(serde_json::json!({ "updateId": update_status.id() })))
2021-01-05 00:21:42 +01: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()
};
let update_status = data.update_settings(index_uid.into_inner(), settings, true).await?;
Ok(HttpResponse::Accepted().json(serde_json::json!({ "updateId": update_status.id() })))
2021-01-05 00:21:42 +01: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> {
let settings = data.settings(index_uid.into_inner()).await?;
Ok(HttpResponse::Ok().json(settings.$attr))
2021-01-05 00:21:42 +01:00
}
}
};
}
make_setting_route!(
"/indexes/{index_uid}/settings/filterable-attributes",
2021-06-03 19:36:25 +02:00
std::collections::HashSet<String>,
filterable_attributes
2021-01-05 00:21:42 +01: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
);
2021-06-03 14:19:56 +02:00
make_setting_route!(
"/indexes/{index_uid}/settings/synonyms",
std::collections::BTreeMap<String, Vec<String>>,
synonyms
);
make_setting_route!(
"/indexes/{index_uid}/settings/distinct-attribute",
String,
distinct_attribute
);
2021-01-05 00:21:42 +01:00
2021-04-27 15:29:00 +02:00
make_setting_route!(
"/indexes/{index_uid}/settings/ranking-rules",
Vec<String>,
ranking_rules
);
2021-01-05 00:21:42 +01: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!(
filterable_attributes,
2021-01-05 00:21:42 +01:00
displayed_attributes,
searchable_attributes,
distinct_attribute,
2021-04-27 15:29:00 +02:00
stop_words,
2021-06-03 14:19:56 +02:00
synonyms,
2021-04-27 15:29:00 +02:00
ranking_rules
2021-01-05 00:21:42 +01: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 17:30:09 +02:00
body: web::Json<Settings<Unchecked>>,
2021-01-05 00:21:42 +01:00
) -> Result<HttpResponse, ResponseError> {
2021-05-10 17:30:09 +02:00
let settings = body.into_inner().check();
let update_result = data
2021-05-10 17:30:09 +02:00
.update_settings(index_uid.into_inner(), settings, true)
.await?;
let json = serde_json::json!({ "updateId": update_result.id() });
Ok(HttpResponse::Accepted().json(json))
2021-01-05 00:21:42 +01: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> {
let settings = data.settings(index_uid.into_inner()).await?;
Ok(HttpResponse::Ok().json(settings))
2021-01-05 00:21:42 +01: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();
let update_result = data
2021-03-15 18:11:10 +01:00
.update_settings(index_uid.into_inner(), settings, false)
.await?;
let json = serde_json::json!({ "updateId": update_result.id() });
Ok(HttpResponse::Accepted().json(json))
2021-01-05 00:21:42 +01:00
}