mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	split meilisearch-http and meilisearch-lib
This commit is contained in:
		| @@ -1,17 +1,17 @@ | ||||
| use actix_web::{web, HttpResponse}; | ||||
| use log::debug; | ||||
| use meilisearch_lib::MeiliSearch; | ||||
| use serde::{Deserialize, Serialize}; | ||||
|  | ||||
| use crate::error::ResponseError; | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::Data; | ||||
|  | ||||
| pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service(web::resource("").route(web::post().to(create_dump))) | ||||
|         .service(web::resource("/{dump_uid}/status").route(web::get().to(get_dump_status))); | ||||
| } | ||||
|  | ||||
| pub async fn create_dump(data: GuardedData<Private, Data>) -> Result<HttpResponse, ResponseError> { | ||||
| pub async fn create_dump(data: GuardedData<Private, MeiliSearch>) -> Result<HttpResponse, ResponseError> { | ||||
|     let res = data.create_dump().await?; | ||||
|  | ||||
|     debug!("returns: {:?}", res); | ||||
| @@ -30,10 +30,10 @@ struct DumpParam { | ||||
| } | ||||
|  | ||||
| async fn get_dump_status( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     data: GuardedData<Private, MeiliSearch>, | ||||
|     path: web::Path<DumpParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let res = data.dump_status(path.dump_uid.clone()).await?; | ||||
|     let res = data.dump_info(path.dump_uid.clone()).await?; | ||||
|  | ||||
|     debug!("returns: {:?}", res); | ||||
|     Ok(HttpResponse::Ok().json(res)) | ||||
|   | ||||
| @@ -3,6 +3,8 @@ use actix_web::{web, HttpResponse}; | ||||
| use actix_web::web::Bytes; | ||||
| use futures::{Stream, StreamExt}; | ||||
| use log::debug; | ||||
| use meilisearch_lib::MeiliSearch; | ||||
| use meilisearch_lib::index_controller::{DocumentAdditionFormat, Update}; | ||||
| use milli::update::IndexDocumentsMethod; | ||||
| use serde::Deserialize; | ||||
| //use serde_json::Value; | ||||
| @@ -11,9 +13,7 @@ use tokio::sync::mpsc; | ||||
| use crate::error::ResponseError; | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::extractors::payload::Payload; | ||||
| use crate::index_controller::{DocumentAdditionFormat, Update}; | ||||
| use crate::routes::IndexParam; | ||||
| use crate::Data; | ||||
|  | ||||
| const DEFAULT_RETRIEVE_DOCUMENTS_OFFSET: usize = 0; | ||||
| const DEFAULT_RETRIEVE_DOCUMENTS_LIMIT: usize = 20; | ||||
| @@ -88,20 +88,20 @@ pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
| } | ||||
|  | ||||
| pub async fn get_document( | ||||
|     data: GuardedData<Public, Data>, | ||||
|     data: GuardedData<Public, MeiliSearch>, | ||||
|     path: web::Path<DocumentParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let index = path.index_uid.clone(); | ||||
|     let id = path.document_id.clone(); | ||||
|     let document = data | ||||
|         .retrieve_document(index, id, None as Option<Vec<String>>) | ||||
|         .document(index, id, None as Option<Vec<String>>) | ||||
|         .await?; | ||||
|     debug!("returns: {:?}", document); | ||||
|     Ok(HttpResponse::Ok().json(document)) | ||||
| } | ||||
|  | ||||
| //pub async fn delete_document( | ||||
|     //data: GuardedData<Private, Data>, | ||||
|     //data: GuardedData<Private, MeiliSearch>, | ||||
|     //path: web::Path<DocumentParam>, | ||||
| //) -> Result<HttpResponse, ResponseError> { | ||||
|     //let update_status = data | ||||
| @@ -120,7 +120,7 @@ pub struct BrowseQuery { | ||||
| } | ||||
|  | ||||
| pub async fn get_all_documents( | ||||
|     data: GuardedData<Public, Data>, | ||||
|     data: GuardedData<Public, MeiliSearch>, | ||||
|     path: web::Path<IndexParam>, | ||||
|     params: web::Query<BrowseQuery>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
| @@ -137,7 +137,7 @@ pub async fn get_all_documents( | ||||
|     }); | ||||
|  | ||||
|     let documents = data | ||||
|         .retrieve_documents( | ||||
|         .documents( | ||||
|             path.index_uid.clone(), | ||||
|             params.offset.unwrap_or(DEFAULT_RETRIEVE_DOCUMENTS_OFFSET), | ||||
|             params.limit.unwrap_or(DEFAULT_RETRIEVE_DOCUMENTS_LIMIT), | ||||
| @@ -157,7 +157,7 @@ pub struct UpdateDocumentsQuery { | ||||
| /// Route used when the payload type is "application/json" | ||||
| /// Used to add or replace documents | ||||
| pub async fn add_documents( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     data: GuardedData<Private, MeiliSearch>, | ||||
|     path: web::Path<IndexParam>, | ||||
|     params: web::Query<UpdateDocumentsQuery>, | ||||
|     body: Payload, | ||||
| @@ -180,7 +180,7 @@ pub async fn add_documents( | ||||
| /// Route used when the payload type is "application/json" | ||||
| /// Used to add or replace documents | ||||
| pub async fn update_documents( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     data: GuardedData<Private, MeiliSearch>, | ||||
|     path: web::Path<IndexParam>, | ||||
|     params: web::Query<UpdateDocumentsQuery>, | ||||
|     body: Payload, | ||||
| @@ -201,7 +201,7 @@ pub async fn update_documents( | ||||
| } | ||||
|  | ||||
| //pub async fn delete_documents( | ||||
|     //data: GuardedData<Private, Data>, | ||||
|     //data: GuardedData<Private, MeiliSearch>, | ||||
|     //path: web::Path<IndexParam>, | ||||
|     //body: web::Json<Vec<Value>>, | ||||
| //) -> Result<HttpResponse, ResponseError> { | ||||
| @@ -221,7 +221,7 @@ pub async fn update_documents( | ||||
| //} | ||||
|  | ||||
| //pub async fn clear_all_documents( | ||||
|     //data: GuardedData<Private, Data>, | ||||
|     //data: GuardedData<Private, MeiliSearch>, | ||||
|     //path: web::Path<IndexParam>, | ||||
| //) -> Result<HttpResponse, ResponseError> { | ||||
|     //let update_status = data.clear_documents(path.index_uid.clone()).await?; | ||||
|   | ||||
| @@ -1,12 +1,13 @@ | ||||
| use actix_web::{web, HttpResponse}; | ||||
| use chrono::{DateTime, Utc}; | ||||
| use log::debug; | ||||
| use meilisearch_lib::MeiliSearch; | ||||
| use meilisearch_lib::index_controller::IndexSettings; | ||||
| use serde::{Deserialize, Serialize}; | ||||
|  | ||||
| use crate::error::ResponseError; | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::routes::IndexParam; | ||||
| use crate::Data; | ||||
|  | ||||
| pub mod documents; | ||||
| pub mod search; | ||||
| @@ -35,7 +36,7 @@ pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
|     ); | ||||
| } | ||||
|  | ||||
| pub async fn list_indexes(data: GuardedData<Private, Data>) -> Result<HttpResponse, ResponseError> { | ||||
| pub async fn list_indexes(data: GuardedData<Private, MeiliSearch>) -> Result<HttpResponse, ResponseError> { | ||||
|     let indexes = data.list_indexes().await?; | ||||
|     debug!("returns: {:?}", indexes); | ||||
|     Ok(HttpResponse::Ok().json(indexes)) | ||||
| @@ -49,7 +50,7 @@ pub struct IndexCreateRequest { | ||||
| } | ||||
|  | ||||
| //pub async fn create_index( | ||||
|     //data: GuardedData<Private, Data>, | ||||
|     //data: GuardedData<Private, MeiliSearch>, | ||||
|     //body: web::Json<IndexCreateRequest>, | ||||
| //) -> Result<HttpResponse, ResponseError> { | ||||
|     //let body = body.into_inner(); | ||||
| @@ -75,30 +76,34 @@ pub struct UpdateIndexResponse { | ||||
| } | ||||
|  | ||||
| pub async fn get_index( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     data: GuardedData<Private, MeiliSearch>, | ||||
|     path: web::Path<IndexParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let meta = data.index(path.index_uid.clone()).await?; | ||||
|     let meta = data.get_index(path.index_uid.clone()).await?; | ||||
|     debug!("returns: {:?}", meta); | ||||
|     Ok(HttpResponse::Ok().json(meta)) | ||||
| } | ||||
|  | ||||
| pub async fn update_index( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     data: GuardedData<Private, MeiliSearch>, | ||||
|     path: web::Path<IndexParam>, | ||||
|     body: web::Json<UpdateIndexRequest>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     debug!("called with params: {:?}", body); | ||||
|     let body = body.into_inner(); | ||||
|     let settings = IndexSettings { | ||||
|         uid: body.uid, | ||||
|         primary_key: body.primary_key, | ||||
|     }; | ||||
|     let meta = data | ||||
|         .update_index(path.into_inner().index_uid, body.primary_key, body.uid) | ||||
|         .update_index(path.into_inner().index_uid, settings) | ||||
|         .await?; | ||||
|     debug!("returns: {:?}", meta); | ||||
|     Ok(HttpResponse::Ok().json(meta)) | ||||
| } | ||||
|  | ||||
| //pub async fn delete_index( | ||||
|     //data: GuardedData<Private, Data>, | ||||
|     //data: GuardedData<Private, MeiliSearch>, | ||||
|     //path: web::Path<IndexParam>, | ||||
| //) -> Result<HttpResponse, ResponseError> { | ||||
|     //data.delete_index(path.index_uid.clone()).await?; | ||||
| @@ -106,7 +111,7 @@ pub async fn update_index( | ||||
| //} | ||||
|  | ||||
| pub async fn get_index_stats( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     data: GuardedData<Private, MeiliSearch>, | ||||
|     path: web::Path<IndexParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let response = data.get_index_stats(path.index_uid.clone()).await?; | ||||
|   | ||||
| @@ -1,13 +1,13 @@ | ||||
| use actix_web::{web, HttpResponse}; | ||||
| use log::debug; | ||||
| use meilisearch_lib::MeiliSearch; | ||||
| use  meilisearch_lib::index::{default_crop_length, SearchQuery, DEFAULT_SEARCH_LIMIT}; | ||||
| use serde::Deserialize; | ||||
| use serde_json::Value; | ||||
|  | ||||
| use crate::error::ResponseError; | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::index::{default_crop_length, SearchQuery, DEFAULT_SEARCH_LIMIT}; | ||||
| use crate::routes::IndexParam; | ||||
| use crate::Data; | ||||
|  | ||||
| pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service( | ||||
| @@ -82,7 +82,7 @@ impl From<SearchQueryGet> for SearchQuery { | ||||
| } | ||||
|  | ||||
| pub async fn search_with_url_query( | ||||
|     data: GuardedData<Public, Data>, | ||||
|     data: GuardedData<Public, MeiliSearch>, | ||||
|     path: web::Path<IndexParam>, | ||||
|     params: web::Query<SearchQueryGet>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
| @@ -99,7 +99,7 @@ pub async fn search_with_url_query( | ||||
| } | ||||
|  | ||||
| pub async fn search_with_post( | ||||
|     data: GuardedData<Public, Data>, | ||||
|     data: GuardedData<Public, MeiliSearch>, | ||||
|     path: web::Path<IndexParam>, | ||||
|     params: web::Json<SearchQuery>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|   | ||||
| @@ -148,7 +148,7 @@ | ||||
| //); | ||||
|  | ||||
| //pub async fn update_all( | ||||
|     //data: GuardedData<Private, Data>, | ||||
|     //data: GuardedData<Private, MeiliSearch>, | ||||
|     //index_uid: web::Path<String>, | ||||
|     //body: web::Json<Settings<Unchecked>>, | ||||
| //) -> Result<HttpResponse, ResponseError> { | ||||
| @@ -162,7 +162,7 @@ | ||||
| //} | ||||
|  | ||||
| //pub async fn get_all( | ||||
|     //data: GuardedData<Private, Data>, | ||||
|     //data: GuardedData<Private, MeiliSearch>, | ||||
|     //index_uid: web::Path<String>, | ||||
| //) -> Result<HttpResponse, ResponseError> { | ||||
|     //let settings = data.settings(index_uid.into_inner()).await?; | ||||
| @@ -171,7 +171,7 @@ | ||||
| //} | ||||
|  | ||||
| //pub async fn delete_all( | ||||
|     //data: GuardedData<Private, Data>, | ||||
|     //data: GuardedData<Private, MeiliSearch>, | ||||
|     //index_uid: web::Path<String>, | ||||
| //) -> Result<HttpResponse, ResponseError> { | ||||
|     //let settings = Settings::cleared(); | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| use actix_web::{web, HttpResponse}; | ||||
| use chrono::{DateTime, Utc}; | ||||
| use log::debug; | ||||
| use meilisearch_lib::MeiliSearch; | ||||
| use serde::{Deserialize, Serialize}; | ||||
|  | ||||
| use crate::error::ResponseError; | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::routes::{IndexParam, UpdateStatusResponse}; | ||||
| use crate::Data; | ||||
|  | ||||
| pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service(web::resource("").route(web::get().to(get_all_updates_status))) | ||||
| @@ -37,12 +37,12 @@ pub struct UpdateParam { | ||||
| } | ||||
|  | ||||
| pub async fn get_update_status( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     data: GuardedData<Private, MeiliSearch>, | ||||
|     path: web::Path<UpdateParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let params = path.into_inner(); | ||||
|     let meta = data | ||||
|         .get_update_status(params.index_uid, params.update_id) | ||||
|         .update_status(params.index_uid, params.update_id) | ||||
|         .await?; | ||||
|     let meta = UpdateStatusResponse::from(meta); | ||||
|     debug!("returns: {:?}", meta); | ||||
| @@ -50,10 +50,10 @@ pub async fn get_update_status( | ||||
| } | ||||
|  | ||||
| pub async fn get_all_updates_status( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     data: GuardedData<Private, MeiliSearch>, | ||||
|     path: web::Path<IndexParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let metas = data.get_updates_status(path.into_inner().index_uid).await?; | ||||
|     let metas = data.all_update_status(path.into_inner().index_uid).await?; | ||||
|     let metas = metas | ||||
|         .into_iter() | ||||
|         .map(UpdateStatusResponse::from) | ||||
|   | ||||
| @@ -5,12 +5,12 @@ use chrono::{DateTime, Utc}; | ||||
| use log::debug; | ||||
| use serde::{Deserialize, Serialize}; | ||||
|  | ||||
| use meilisearch_lib::{MeiliSearch, UpdateResult, UpdateStatus, RegisterUpdate}; | ||||
| use meilisearch_lib::index::{Settings, Unchecked}; | ||||
|  | ||||
| use crate::error::ResponseError; | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::index::{Settings, Unchecked}; | ||||
| use crate::index_controller::update_actor::RegisterUpdate; | ||||
| use crate::index_controller::{UpdateResult, UpdateStatus}; | ||||
| use crate::{ApiKeys, Data}; | ||||
| use crate::ApiKeys; | ||||
|  | ||||
| mod dump; | ||||
| mod indexes; | ||||
| @@ -187,15 +187,17 @@ impl From<UpdateStatus> for UpdateStatusResponse { | ||||
|                 let duration = Duration::from_millis(duration as u64).as_secs_f64(); | ||||
|  | ||||
|                 let update_id = failed.id(); | ||||
|                 let response = failed.error; | ||||
|                 let processed_at = failed.failed_at; | ||||
|                 let enqueued_at = failed.from.from.enqueued_at; | ||||
|                 let response = failed.into(); | ||||
|  | ||||
|                 let content = FailedUpdateResult { | ||||
|                     update_id, | ||||
|                     update_type, | ||||
|                     response, | ||||
|                     duration, | ||||
|                     enqueued_at: failed.from.from.enqueued_at, | ||||
|                     processed_at: failed.failed_at, | ||||
|                     enqueued_at, | ||||
|                     processed_at, | ||||
|                 }; | ||||
|                 UpdateStatusResponse::Failed { content } | ||||
|             } | ||||
| @@ -230,7 +232,7 @@ pub async fn running() -> HttpResponse { | ||||
|     HttpResponse::Ok().json(serde_json::json!({ "status": "MeiliSearch is running" })) | ||||
| } | ||||
|  | ||||
| async fn get_stats(data: GuardedData<Private, Data>) -> Result<HttpResponse, ResponseError> { | ||||
| async fn get_stats(data: GuardedData<Private, MeiliSearch>) -> Result<HttpResponse, ResponseError> { | ||||
|     let response = data.get_all_stats().await?; | ||||
|  | ||||
|     debug!("returns: {:?}", response); | ||||
| @@ -245,7 +247,7 @@ struct VersionResponse { | ||||
|     pkg_version: String, | ||||
| } | ||||
|  | ||||
| async fn get_version(_data: GuardedData<Private, Data>) -> HttpResponse { | ||||
| async fn get_version(_data: GuardedData<Private, MeiliSearch>) -> HttpResponse { | ||||
|     let commit_sha = option_env!("VERGEN_GIT_SHA").unwrap_or("unknown"); | ||||
|     let commit_date = option_env!("VERGEN_GIT_COMMIT_TIMESTAMP").unwrap_or("unknown"); | ||||
|  | ||||
| @@ -288,7 +290,7 @@ mod test { | ||||
|     macro_rules! impl_is_policy { | ||||
|         ($($param:ident)*) => { | ||||
|             impl<Policy, Func, $($param,)* Res> Is<Policy, (($($param,)*), Res)> for Func | ||||
|                 where Func: Fn(GuardedData<Policy, Data>, $($param,)*) -> Res {} | ||||
|                 where Func: Fn(GuardedData<Policy, MeiliSearch>, $($param,)*) -> Res {} | ||||
|  | ||||
|         }; | ||||
|     } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user