mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	last review edits + fmt
This commit is contained in:
		| @@ -7,10 +7,10 @@ use milli::update::{IndexDocumentsMethod, UpdateFormat}; | ||||
| use serde::Deserialize; | ||||
| use serde_json::Value; | ||||
|  | ||||
| use crate::Data; | ||||
| use crate::error::ResponseError; | ||||
| use crate::helpers::Authentication; | ||||
| use crate::routes::IndexParam; | ||||
| use crate::Data; | ||||
|  | ||||
| const DEFAULT_RETRIEVE_DOCUMENTS_OFFSET: usize = 0; | ||||
| const DEFAULT_RETRIEVE_DOCUMENTS_LIMIT: usize = 20; | ||||
| @@ -19,7 +19,10 @@ macro_rules! guard_content_type { | ||||
|     ($fn_name:ident, $guard_value:literal) => { | ||||
|         fn $fn_name(head: &actix_web::dev::RequestHead) -> bool { | ||||
|             if let Some(content_type) = head.headers.get("Content-Type") { | ||||
|                 content_type.to_str().map(|v| v.contains($guard_value)).unwrap_or(false) | ||||
|                 content_type | ||||
|                     .to_str() | ||||
|                     .map(|v| v.contains($guard_value)) | ||||
|                     .unwrap_or(false) | ||||
|             } else { | ||||
|                 false | ||||
|             } | ||||
| @@ -57,7 +60,10 @@ async fn get_document( | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let index = path.index_uid.clone(); | ||||
|     let id = path.document_id.clone(); | ||||
|     match data.retrieve_document(index, id, None as Option<Vec<String>>).await { | ||||
|     match data | ||||
|         .retrieve_document(index, id, None as Option<Vec<String>>) | ||||
|         .await | ||||
|     { | ||||
|         Ok(document) => { | ||||
|             let json = serde_json::to_string(&document).unwrap(); | ||||
|             Ok(HttpResponse::Ok().body(json)) | ||||
| @@ -76,7 +82,10 @@ async fn delete_document( | ||||
|     data: web::Data<Data>, | ||||
|     path: web::Path<DocumentParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     match data.delete_documents(path.index_uid.clone(), vec![path.document_id.clone()]).await { | ||||
|     match data | ||||
|         .delete_documents(path.index_uid.clone(), vec![path.document_id.clone()]) | ||||
|         .await | ||||
|     { | ||||
|         Ok(result) => { | ||||
|             let json = serde_json::to_string(&result).unwrap(); | ||||
|             Ok(HttpResponse::Ok().body(json)) | ||||
| @@ -104,16 +113,17 @@ async fn get_all_documents( | ||||
|     let attributes_to_retrieve = params | ||||
|         .attributes_to_retrieve | ||||
|         .as_ref() | ||||
|         .map(|attrs| attrs | ||||
|             .split(',') | ||||
|             .map(String::from) | ||||
|             .collect::<Vec<_>>()); | ||||
|         .map(|attrs| attrs.split(',').map(String::from).collect::<Vec<_>>()); | ||||
|  | ||||
|     match data.retrieve_documents( | ||||
|         path.index_uid.clone(), | ||||
|         params.offset.unwrap_or(DEFAULT_RETRIEVE_DOCUMENTS_OFFSET), | ||||
|         params.limit.unwrap_or(DEFAULT_RETRIEVE_DOCUMENTS_LIMIT), | ||||
|         attributes_to_retrieve).await { | ||||
|     match data | ||||
|         .retrieve_documents( | ||||
|             path.index_uid.clone(), | ||||
|             params.offset.unwrap_or(DEFAULT_RETRIEVE_DOCUMENTS_OFFSET), | ||||
|             params.limit.unwrap_or(DEFAULT_RETRIEVE_DOCUMENTS_LIMIT), | ||||
|             attributes_to_retrieve, | ||||
|         ) | ||||
|         .await | ||||
|     { | ||||
|         Ok(docs) => { | ||||
|             let json = serde_json::to_string(&docs).unwrap(); | ||||
|             Ok(HttpResponse::Ok().body(json)) | ||||
| @@ -149,7 +159,8 @@ async fn add_documents_json( | ||||
|             UpdateFormat::Json, | ||||
|             body, | ||||
|             params.primary_key.clone(), | ||||
|         ).await; | ||||
|         ) | ||||
|         .await; | ||||
|  | ||||
|     match addition_result { | ||||
|         Ok(update) => { | ||||
| @@ -163,7 +174,6 @@ async fn add_documents_json( | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| /// Default route for adding documents, this should return an error and redirect to the documentation | ||||
| #[post("/indexes/{index_uid}/documents", wrap = "Authentication::Private")] | ||||
| async fn add_documents_default( | ||||
| @@ -191,7 +201,7 @@ async fn update_documents_default( | ||||
| #[put( | ||||
|     "/indexes/{index_uid}/documents", | ||||
|     wrap = "Authentication::Private", | ||||
|     guard = "guard_json", | ||||
|     guard = "guard_json" | ||||
| )] | ||||
| async fn update_documents( | ||||
|     data: web::Data<Data>, | ||||
| @@ -206,7 +216,8 @@ async fn update_documents( | ||||
|             UpdateFormat::Json, | ||||
|             body, | ||||
|             params.primary_key.clone(), | ||||
|         ).await; | ||||
|         ) | ||||
|         .await; | ||||
|  | ||||
|     match addition_result { | ||||
|         Ok(update) => { | ||||
| @@ -231,7 +242,11 @@ async fn delete_documents( | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let ids = body | ||||
|         .iter() | ||||
|         .map(|v| v.as_str().map(String::from).unwrap_or_else(|| v.to_string())) | ||||
|         .map(|v| { | ||||
|             v.as_str() | ||||
|                 .map(String::from) | ||||
|                 .unwrap_or_else(|| v.to_string()) | ||||
|         }) | ||||
|         .collect(); | ||||
|  | ||||
|     match data.delete_documents(path.index_uid.clone(), ids).await { | ||||
|   | ||||
| @@ -3,10 +3,10 @@ use actix_web::{web, HttpResponse}; | ||||
| use chrono::{DateTime, Utc}; | ||||
| use serde::{Deserialize, Serialize}; | ||||
|  | ||||
| use crate::Data; | ||||
| use crate::error::ResponseError; | ||||
| use crate::helpers::Authentication; | ||||
| use crate::routes::IndexParam; | ||||
| use crate::Data; | ||||
|  | ||||
| pub fn services(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service(list_indexes) | ||||
| @@ -18,7 +18,6 @@ pub fn services(cfg: &mut web::ServiceConfig) { | ||||
|         .service(get_all_updates_status); | ||||
| } | ||||
|  | ||||
|  | ||||
| #[get("/indexes", wrap = "Authentication::Private")] | ||||
| async fn list_indexes(data: web::Data<Data>) -> Result<HttpResponse, ResponseError> { | ||||
|     match data.list_indexes().await { | ||||
| @@ -96,7 +95,10 @@ async fn update_index( | ||||
|     body: web::Json<UpdateIndexRequest>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let body = body.into_inner(); | ||||
|     match data.update_index(path.into_inner().index_uid, body.primary_key,  body.uid).await { | ||||
|     match data | ||||
|         .update_index(path.into_inner().index_uid, body.primary_key, body.uid) | ||||
|         .await | ||||
|     { | ||||
|         Ok(meta) => { | ||||
|             let json = serde_json::to_string(&meta).unwrap(); | ||||
|             Ok(HttpResponse::Ok().body(json)) | ||||
| @@ -135,7 +137,9 @@ async fn get_update_status( | ||||
|     path: web::Path<UpdateParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let params = path.into_inner(); | ||||
|     let result = data.get_update_status(params.index_uid, params.update_id).await; | ||||
|     let result = data | ||||
|         .get_update_status(params.index_uid, params.update_id) | ||||
|         .await; | ||||
|     match result { | ||||
|         Ok(meta) => { | ||||
|             let json = serde_json::to_string(&meta).unwrap(); | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| use actix_web::get; | ||||
| use actix_web::web; | ||||
| use actix_web::HttpResponse; | ||||
| use actix_web::get; | ||||
| use serde::Serialize; | ||||
|  | ||||
| use crate::helpers::Authentication; | ||||
|   | ||||
| @@ -6,9 +6,9 @@ use serde::Deserialize; | ||||
|  | ||||
| use crate::error::ResponseError; | ||||
| use crate::helpers::Authentication; | ||||
| use crate::index::{SearchQuery, DEFAULT_SEARCH_LIMIT}; | ||||
| use crate::routes::IndexParam; | ||||
| use crate::Data; | ||||
| use crate::index::{SearchQuery, DEFAULT_SEARCH_LIMIT}; | ||||
|  | ||||
| pub fn services(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service(search_with_post).service(search_with_url_query); | ||||
| @@ -80,7 +80,9 @@ async fn search_with_url_query( | ||||
|     let query: SearchQuery = match params.into_inner().try_into() { | ||||
|         Ok(q) => q, | ||||
|         Err(e) => { | ||||
|             return Ok(HttpResponse::BadRequest().body(serde_json::json!({ "error": e.to_string() }))) | ||||
|             return Ok( | ||||
|                 HttpResponse::BadRequest().body(serde_json::json!({ "error": e.to_string() })) | ||||
|             ) | ||||
|         } | ||||
|     }; | ||||
|     let search_result = data.search(path.into_inner().index_uid, query).await; | ||||
| @@ -101,7 +103,9 @@ async fn search_with_post( | ||||
|     path: web::Path<IndexParam>, | ||||
|     params: web::Json<SearchQuery>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let search_result = data.search(path.into_inner().index_uid, params.into_inner()).await; | ||||
|     let search_result = data | ||||
|         .search(path.into_inner().index_uid, params.into_inner()) | ||||
|         .await; | ||||
|     match search_result { | ||||
|         Ok(docs) => { | ||||
|             let docs = serde_json::to_string(&docs).unwrap(); | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| use actix_web::{web, HttpResponse, delete, get, post}; | ||||
| use actix_web::{delete, get, post, web, HttpResponse}; | ||||
|  | ||||
| use crate::Data; | ||||
| use crate::error::ResponseError; | ||||
| use crate::index::Settings; | ||||
| use crate::helpers::Authentication; | ||||
| use crate::index::Settings; | ||||
| use crate::Data; | ||||
|  | ||||
| #[macro_export] | ||||
| macro_rules! make_setting_route { | ||||
| @@ -98,15 +98,15 @@ make_setting_route!( | ||||
| ); | ||||
|  | ||||
| //make_setting_route!( | ||||
|     //"/indexes/{index_uid}/settings/distinct-attribute", | ||||
|     //String, | ||||
|     //distinct_attribute | ||||
| //"/indexes/{index_uid}/settings/distinct-attribute", | ||||
| //String, | ||||
| //distinct_attribute | ||||
| //); | ||||
|  | ||||
| //make_setting_route!( | ||||
|     //"/indexes/{index_uid}/settings/ranking-rules", | ||||
|     //Vec<String>, | ||||
|     //ranking_rules | ||||
| //"/indexes/{index_uid}/settings/ranking-rules", | ||||
| //Vec<String>, | ||||
| //ranking_rules | ||||
| //); | ||||
|  | ||||
| macro_rules! create_services { | ||||
| @@ -137,7 +137,10 @@ async fn update_all( | ||||
|     index_uid: web::Path<String>, | ||||
|     body: web::Json<Settings>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     match data.update_settings(index_uid.into_inner(), body.into_inner(), true).await { | ||||
|     match data | ||||
|         .update_settings(index_uid.into_inner(), body.into_inner(), true) | ||||
|         .await | ||||
|     { | ||||
|         Ok(update_result) => { | ||||
|             let json = serde_json::to_string(&update_result).unwrap(); | ||||
|             Ok(HttpResponse::Ok().body(json)) | ||||
| @@ -170,7 +173,10 @@ async fn delete_all( | ||||
|     index_uid: web::Path<String>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let settings = Settings::cleared(); | ||||
|     match data.update_settings(index_uid.into_inner(), settings, false).await { | ||||
|     match data | ||||
|         .update_settings(index_uid.into_inner(), settings, false) | ||||
|         .await | ||||
|     { | ||||
|         Ok(update_result) => { | ||||
|             let json = serde_json::to_string(&update_result).unwrap(); | ||||
|             Ok(HttpResponse::Ok().body(json)) | ||||
| @@ -180,4 +186,3 @@ async fn delete_all( | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| use std::collections::{HashMap, BTreeMap}; | ||||
| use std::collections::{BTreeMap, HashMap}; | ||||
|  | ||||
| use actix_web::get; | ||||
| use actix_web::web; | ||||
| use actix_web::HttpResponse; | ||||
| use actix_web::get; | ||||
| use chrono::{DateTime, Utc}; | ||||
| use serde::Serialize; | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| use actix_web::{web, HttpResponse}; | ||||
| use actix_web::{delete, get, post}; | ||||
| use actix_web::{web, HttpResponse}; | ||||
| use std::collections::BTreeSet; | ||||
|  | ||||
| use crate::error::ResponseError; | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| use std::collections::BTreeMap; | ||||
|  | ||||
| use actix_web::{web, HttpResponse}; | ||||
| use actix_web::{delete, get, post}; | ||||
| use actix_web::{web, HttpResponse}; | ||||
|  | ||||
| use crate::error::ResponseError; | ||||
| use crate::helpers::Authentication; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user