mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	remove unecessary settings routes
This commit is contained in:
		
				
					committed by
					
						 qdequele
						qdequele
					
				
			
			
				
	
			
			
			
						parent
						
							a5b0e468ee
						
					
				
				
					commit
					ea2a64a504
				
			| @@ -76,35 +76,26 @@ pub fn load_routes(app: &mut tide::Server<Data>) { | |||||||
|         .get(|ctx| into_response(setting::get_all(ctx))) |         .get(|ctx| into_response(setting::get_all(ctx))) | ||||||
|         .post(|ctx| into_response(setting::update_all(ctx))) |         .post(|ctx| into_response(setting::update_all(ctx))) | ||||||
|         .delete(|ctx| into_response(setting::delete_all(ctx))); |         .delete(|ctx| into_response(setting::delete_all(ctx))); | ||||||
|     app.at("/indexes/:index/settings/ranking") |  | ||||||
|         .get(|ctx| into_response(setting::get_ranking(ctx))) |  | ||||||
|         .post(|ctx| into_response(setting::update_ranking(ctx))) |  | ||||||
|         .delete(|ctx| into_response(setting::delete_ranking(ctx))); |  | ||||||
|  |  | ||||||
|     app.at("/indexes/:index/settings/ranking/rules") |     app.at("/indexes/:index/settings/ranking-rules") | ||||||
|         .get(|ctx| into_response(setting::get_rules(ctx))) |         .get(|ctx| into_response(setting::get_rules(ctx))) | ||||||
|         .post(|ctx| into_response(setting::update_rules(ctx))) |         .post(|ctx| into_response(setting::update_rules(ctx))) | ||||||
|         .delete(|ctx| into_response(setting::delete_rules(ctx))); |         .delete(|ctx| into_response(setting::delete_rules(ctx))); | ||||||
|  |  | ||||||
|     app.at("/indexes/:index/settings/ranking/distinct") |     app.at("/indexes/:index/settings/ranking-distinct") | ||||||
|         .get(|ctx| into_response(setting::get_distinct(ctx))) |         .get(|ctx| into_response(setting::get_distinct(ctx))) | ||||||
|         .post(|ctx| into_response(setting::update_distinct(ctx))) |         .post(|ctx| into_response(setting::update_distinct(ctx))) | ||||||
|         .delete(|ctx| into_response(setting::delete_distinct(ctx))); |         .delete(|ctx| into_response(setting::delete_distinct(ctx))); | ||||||
|  |  | ||||||
|     app.at("/indexes/:index/settings/attributes") |     app.at("/indexes/:index/settings/identifier") | ||||||
|         .get(|ctx| into_response(setting::get_attributes(ctx))) |  | ||||||
|         .post(|ctx| into_response(setting::update_attributes(ctx))) |  | ||||||
|         .delete(|ctx| into_response(setting::delete_attributes(ctx))); |  | ||||||
|  |  | ||||||
|     app.at("/indexes/:index/settings/attributes/identifier") |  | ||||||
|         .get(|ctx| into_response(setting::get_identifier(ctx))); |         .get(|ctx| into_response(setting::get_identifier(ctx))); | ||||||
|  |  | ||||||
|     app.at("/indexes/:index/settings/attributes/searchable") |     app.at("/indexes/:index/settings/searchable-attributes") | ||||||
|         .get(|ctx| into_response(setting::get_searchable(ctx))) |         .get(|ctx| into_response(setting::get_searchable(ctx))) | ||||||
|         .post(|ctx| into_response(setting::update_searchable(ctx))) |         .post(|ctx| into_response(setting::update_searchable(ctx))) | ||||||
|         .delete(|ctx| into_response(setting::delete_searchable(ctx))); |         .delete(|ctx| into_response(setting::delete_searchable(ctx))); | ||||||
|  |  | ||||||
|     app.at("/indexes/:index/settings/attributes/displayed") |     app.at("/indexes/:index/settings/displayed-attribute") | ||||||
|         .get(|ctx| into_response(setting::displayed(ctx))) |         .get(|ctx| into_response(setting::displayed(ctx))) | ||||||
|         .post(|ctx| into_response(setting::update_displayed(ctx))) |         .post(|ctx| into_response(setting::update_displayed(ctx))) | ||||||
|         .delete(|ctx| into_response(setting::delete_displayed(ctx))); |         .delete(|ctx| into_response(setting::delete_displayed(ctx))); | ||||||
|   | |||||||
| @@ -141,73 +141,6 @@ pub async fn delete_all(ctx: Request<Data>) -> SResult<Response> { | |||||||
|     Ok(tide::Response::new(202).body_json(&response_body)?) |     Ok(tide::Response::new(202).body_json(&response_body)?) | ||||||
| } | } | ||||||
|  |  | ||||||
| #[derive(Default, Clone, Serialize, Deserialize)] |  | ||||||
| #[serde(rename_all = "camelCase", deny_unknown_fields)] |  | ||||||
| pub struct RankingSettings { |  | ||||||
|     pub ranking_rules: Option<Vec<String>>, |  | ||||||
|     pub ranking_distinct: Option<String>, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| pub async fn get_ranking(ctx: Request<Data>) -> SResult<Response> { |  | ||||||
|     ctx.is_allowed(SettingsRead)?; |  | ||||||
|     let index = ctx.index()?; |  | ||||||
|     let db = &ctx.state().db; |  | ||||||
|     let reader = db.main_read_txn()?; |  | ||||||
|  |  | ||||||
|     let ranking_rules = match index.main.ranking_rules(&reader)? { |  | ||||||
|         Some(rules) => Some(rules.iter().map(|r| r.to_string()).collect()), |  | ||||||
|         None => None, |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     let ranking_distinct = index.main.ranking_distinct(&reader)?; |  | ||||||
|     let settings = RankingSettings { |  | ||||||
|         ranking_rules, |  | ||||||
|         ranking_distinct, |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     Ok(tide::Response::new(200).body_json(&settings).unwrap()) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| pub async fn update_ranking(mut ctx: Request<Data>) -> SResult<Response> { |  | ||||||
|     ctx.is_allowed(SettingsWrite)?; |  | ||||||
|     let index = ctx.index()?; |  | ||||||
|     let settings: RankingSettings = ctx.body_json().await.map_err(ResponseError::bad_request)?; |  | ||||||
|     let db = &ctx.state().db; |  | ||||||
|  |  | ||||||
|     let settings = Settings { |  | ||||||
|         ranking_rules: Some(settings.ranking_rules), |  | ||||||
|         ranking_distinct: Some(settings.ranking_distinct), |  | ||||||
|         ..Settings::default() |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     let mut writer = db.update_write_txn()?; |  | ||||||
|     let update_id = index.settings_update(&mut writer, settings.into_update()?)?; |  | ||||||
|     writer.commit()?; |  | ||||||
|  |  | ||||||
|     let response_body = IndexUpdateResponse { update_id }; |  | ||||||
|     Ok(tide::Response::new(202).body_json(&response_body)?) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| pub async fn delete_ranking(ctx: Request<Data>) -> SResult<Response> { |  | ||||||
|     ctx.is_allowed(SettingsWrite)?; |  | ||||||
|     let index = ctx.index()?; |  | ||||||
|     let db = &ctx.state().db; |  | ||||||
|     let mut writer = db.update_write_txn()?; |  | ||||||
|  |  | ||||||
|     let settings = SettingsUpdate { |  | ||||||
|         ranking_rules: UpdateState::Clear, |  | ||||||
|         ranking_distinct: UpdateState::Clear, |  | ||||||
|         ..SettingsUpdate::default() |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     let update_id = index.settings_update(&mut writer, settings)?; |  | ||||||
|  |  | ||||||
|     writer.commit()?; |  | ||||||
|  |  | ||||||
|     let response_body = IndexUpdateResponse { update_id }; |  | ||||||
|     Ok(tide::Response::new(202).body_json(&response_body)?) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| pub async fn get_rules(ctx: Request<Data>) -> SResult<Response> { | pub async fn get_rules(ctx: Request<Data>) -> SResult<Response> { | ||||||
|     ctx.is_allowed(SettingsRead)?; |     ctx.is_allowed(SettingsRead)?; | ||||||
|     let index = ctx.index()?; |     let index = ctx.index()?; | ||||||
| @@ -313,79 +246,6 @@ pub async fn delete_distinct(ctx: Request<Data>) -> SResult<Response> { | |||||||
|     Ok(tide::Response::new(202).body_json(&response_body)?) |     Ok(tide::Response::new(202).body_json(&response_body)?) | ||||||
| } | } | ||||||
|  |  | ||||||
| #[derive(Default, Clone, Serialize, Deserialize)] |  | ||||||
| #[serde(rename_all = "camelCase", deny_unknown_fields)] |  | ||||||
| pub struct AttributesSettings { |  | ||||||
|     pub identifier: Option<String>, |  | ||||||
|     pub searchable_attributes: Option<Vec<String>>, |  | ||||||
|     pub displayed_attributes: Option<HashSet<String>>, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| pub async fn get_attributes(ctx: Request<Data>) -> SResult<Response> { |  | ||||||
|     ctx.is_allowed(SettingsRead)?; |  | ||||||
|     let index = ctx.index()?; |  | ||||||
|     let db = &ctx.state().db; |  | ||||||
|     let reader = db.main_read_txn()?; |  | ||||||
|  |  | ||||||
|     let schema = index.main.schema(&reader)?; |  | ||||||
|  |  | ||||||
|     let identifier = schema.clone().map(|s| s.identifier().to_string()); |  | ||||||
|     let searchable_attributes = schema |  | ||||||
|         .clone() |  | ||||||
|         .map(|s| s.indexed_name().iter().map(|s| s.to_string()).collect()); |  | ||||||
|     let displayed_attributes = schema |  | ||||||
|         .clone() |  | ||||||
|         .map(|s| s.displayed_name().iter().map(|s| s.to_string()).collect()); |  | ||||||
|  |  | ||||||
|     let settings = AttributesSettings { |  | ||||||
|         identifier, |  | ||||||
|         searchable_attributes, |  | ||||||
|         displayed_attributes, |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     Ok(tide::Response::new(200).body_json(&settings).unwrap()) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| pub async fn update_attributes(mut ctx: Request<Data>) -> SResult<Response> { |  | ||||||
|     ctx.is_allowed(SettingsWrite)?; |  | ||||||
|     let index = ctx.index()?; |  | ||||||
|     let settings: AttributesSettings = ctx.body_json().await.map_err(ResponseError::bad_request)?; |  | ||||||
|     let db = &ctx.state().db; |  | ||||||
|  |  | ||||||
|     let settings = Settings { |  | ||||||
|         identifier: Some(settings.identifier), |  | ||||||
|         searchable_attributes: Some(settings.searchable_attributes), |  | ||||||
|         displayed_attributes: Some(settings.displayed_attributes), |  | ||||||
|         ..Settings::default() |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     let mut writer = db.update_write_txn()?; |  | ||||||
|     let update_id = index.settings_update(&mut writer, settings.into_update()?)?; |  | ||||||
|     writer.commit()?; |  | ||||||
|  |  | ||||||
|     let response_body = IndexUpdateResponse { update_id }; |  | ||||||
|     Ok(tide::Response::new(202).body_json(&response_body)?) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| pub async fn delete_attributes(ctx: Request<Data>) -> SResult<Response> { |  | ||||||
|     ctx.is_allowed(SettingsWrite)?; |  | ||||||
|     let index = ctx.index()?; |  | ||||||
|     let db = &ctx.state().db; |  | ||||||
|  |  | ||||||
|     let settings = SettingsUpdate { |  | ||||||
|         searchable_attributes: UpdateState::Clear, |  | ||||||
|         displayed_attributes: UpdateState::Clear, |  | ||||||
|         ..SettingsUpdate::default() |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     let mut writer = db.update_write_txn()?; |  | ||||||
|     let update_id = index.settings_update(&mut writer, settings)?; |  | ||||||
|     writer.commit()?; |  | ||||||
|  |  | ||||||
|     let response_body = IndexUpdateResponse { update_id }; |  | ||||||
|     Ok(tide::Response::new(202).body_json(&response_body)?) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| pub async fn get_identifier(ctx: Request<Data>) -> SResult<Response> { | pub async fn get_identifier(ctx: Request<Data>) -> SResult<Response> { | ||||||
|     ctx.is_allowed(SettingsRead)?; |     ctx.is_allowed(SettingsRead)?; | ||||||
|     let index = ctx.index()?; |     let index = ctx.index()?; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user