mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	refactor routes
This commit is contained in:
		| @@ -6,9 +6,9 @@ use crate::error::ResponseError; | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::Data; | ||||
|  | ||||
| pub fn services(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service(web::resource("/dumps").route(web::post().to(create_dump))) | ||||
|         .service(web::resource("/dumps/{dump_uid}/status").route(web::get().to(get_dump_status))); | ||||
| 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))); | ||||
| } | ||||
|  | ||||
| async fn create_dump(data: GuardedData<Private, Data>) -> Result<HttpResponse, ResponseError> { | ||||
|   | ||||
| @@ -1,11 +0,0 @@ | ||||
| use actix_web::{web, HttpResponse}; | ||||
|  | ||||
| use crate::error::ResponseError; | ||||
|  | ||||
| pub fn services(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service(web::resource("/health").route(web::get().to(get_health))); | ||||
| } | ||||
|  | ||||
| async fn get_health() -> Result<HttpResponse, ResponseError> { | ||||
|     Ok(HttpResponse::Ok().json(serde_json::json!({ "status": "available" }))) | ||||
| } | ||||
| @@ -54,23 +54,20 @@ struct DocumentParam { | ||||
|     document_id: String, | ||||
| } | ||||
| 
 | ||||
| pub fn services(cfg: &mut web::ServiceConfig) { | ||||
| pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service( | ||||
|         web::scope("/indexes/{index_uid}/documents") | ||||
|             .service( | ||||
|                 web::resource("") | ||||
|                     .route(web::get().to(get_all_documents)) | ||||
|                     .route(web::post().guard(guard_json).to(add_documents)) | ||||
|                     .route(web::put().guard(guard_json).to(update_documents)) | ||||
|                     .route(web::delete().to(clear_all_documents)), | ||||
|             ) | ||||
|             // this route needs to be before the /documents/{document_id} to match properly
 | ||||
|             .service(web::resource("/delete-batch").route(web::post().to(delete_documents))) | ||||
|             .service( | ||||
|                 web::resource("/{document_id}") | ||||
|                     .route(web::get().to(get_document)) | ||||
|                     .route(web::delete().to(delete_document)), | ||||
|             ), | ||||
|         web::resource("") | ||||
|             .route(web::get().to(get_all_documents)) | ||||
|             .route(web::post().guard(guard_json).to(add_documents)) | ||||
|             .route(web::put().guard(guard_json).to(update_documents)) | ||||
|             .route(web::delete().to(clear_all_documents)), | ||||
|     ) | ||||
|     // this route needs to be before the /documents/{document_id} to match properly
 | ||||
|     .service(web::resource("/delete-batch").route(web::post().to(delete_documents))) | ||||
|     .service( | ||||
|         web::resource("/{document_id}") | ||||
|             .route(web::get().to(get_document)) | ||||
|             .route(web::delete().to(delete_document)), | ||||
|     ); | ||||
| } | ||||
| 
 | ||||
| @@ -3,32 +3,44 @@ use chrono::{DateTime, Utc}; | ||||
| use log::debug; | ||||
| use serde::{Deserialize, Serialize}; | ||||
| 
 | ||||
| use super::{IndexParam, UpdateStatusResponse}; | ||||
| use crate::error::ResponseError; | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::routes::IndexParam; | ||||
| use crate::Data; | ||||
| 
 | ||||
| pub fn services(cfg: &mut web::ServiceConfig) { | ||||
| mod documents; | ||||
| mod search; | ||||
| mod settings; | ||||
| mod updates; | ||||
| 
 | ||||
| pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service( | ||||
|         web::resource("indexes") | ||||
|         web::resource("") | ||||
|             .route(web::get().to(list_indexes)) | ||||
|             .route(web::post().to(create_index)), | ||||
|     ) | ||||
|     .service( | ||||
|         web::resource("/indexes/{index_uid}") | ||||
|             .route(web::get().to(get_index)) | ||||
|             .route(web::put().to(update_index)) | ||||
|             .route(web::delete().to(delete_index)), | ||||
|     ) | ||||
|     .service( | ||||
|         web::resource("/indexes/{index_uid}/updates").route(web::get().to(get_all_updates_status)), | ||||
|     ) | ||||
|     .service( | ||||
|         web::resource("/indexes/{index_uid}/updates/{update_id}") | ||||
|             .route(web::get().to(get_update_status)), | ||||
|         web::scope("/{index_uid}") | ||||
|             .service( | ||||
|                 web::resource("") | ||||
|                     .route(web::get().to(get_index)) | ||||
|                     .route(web::put().to(update_index)) | ||||
|                     .route(web::delete().to(delete_index)), | ||||
|             ) | ||||
|             .service(web::resource("/stats").route(web::get().to(get_index_stats))) | ||||
|             .service(web::scope("/documents").configure(documents::configure)) | ||||
|             .service(web::scope("/search").configure(search::configure)) | ||||
|             .service(web::scope("/updates").configure(updates::configure)) | ||||
|             .service(web::scope("/settings").configure(settings::configure)), | ||||
|     ); | ||||
| } | ||||
| 
 | ||||
| async fn list_indexes(data: GuardedData<Private, Data>) -> Result<HttpResponse, ResponseError> { | ||||
|     let indexes = data.list_indexes().await?; | ||||
|     debug!("returns: {:?}", indexes); | ||||
|     Ok(HttpResponse::Ok().json(indexes)) | ||||
| } | ||||
| 
 | ||||
| #[derive(Debug, Deserialize)] | ||||
| #[serde(rename_all = "camelCase", deny_unknown_fields)] | ||||
| struct IndexCreateRequest { | ||||
| @@ -36,6 +48,15 @@ struct IndexCreateRequest { | ||||
|     primary_key: Option<String>, | ||||
| } | ||||
| 
 | ||||
| async fn create_index( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     body: web::Json<IndexCreateRequest>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let body = body.into_inner(); | ||||
|     let meta = data.create_index(body.uid, body.primary_key).await?; | ||||
|     Ok(HttpResponse::Ok().json(meta)) | ||||
| } | ||||
| 
 | ||||
| #[derive(Debug, Deserialize)] | ||||
| #[serde(rename_all = "camelCase", deny_unknown_fields)] | ||||
| struct UpdateIndexRequest { | ||||
| @@ -52,22 +73,6 @@ pub struct UpdateIndexResponse { | ||||
|     updated_at: DateTime<Utc>, | ||||
|     primary_key: Option<String>, | ||||
| } | ||||
| 
 | ||||
| async fn list_indexes(data: GuardedData<Private, Data>) -> Result<HttpResponse, ResponseError> { | ||||
|     let indexes = data.list_indexes().await?; | ||||
|     debug!("returns: {:?}", indexes); | ||||
|     Ok(HttpResponse::Ok().json(indexes)) | ||||
| } | ||||
| 
 | ||||
| async fn create_index( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     body: web::Json<IndexCreateRequest>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let body = body.into_inner(); | ||||
|     let meta = data.create_index(body.uid, body.primary_key).await?; | ||||
|     Ok(HttpResponse::Ok().json(meta)) | ||||
| } | ||||
| 
 | ||||
| async fn get_index( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     path: web::Path<IndexParam>, | ||||
| @@ -99,35 +104,12 @@ async fn delete_index( | ||||
|     Ok(HttpResponse::NoContent().finish()) | ||||
| } | ||||
| 
 | ||||
| #[derive(Deserialize)] | ||||
| struct UpdateParam { | ||||
|     index_uid: String, | ||||
|     update_id: u64, | ||||
| } | ||||
| 
 | ||||
| async fn get_update_status( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     path: web::Path<UpdateParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let params = path.into_inner(); | ||||
|     let meta = data | ||||
|         .get_update_status(params.index_uid, params.update_id) | ||||
|         .await?; | ||||
|     let meta = UpdateStatusResponse::from(meta); | ||||
|     debug!("returns: {:?}", meta); | ||||
|     Ok(HttpResponse::Ok().json(meta)) | ||||
| } | ||||
| 
 | ||||
| async fn get_all_updates_status( | ||||
| async fn get_index_stats( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     path: web::Path<IndexParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let metas = data.get_updates_status(path.into_inner().index_uid).await?; | ||||
|     let metas = metas | ||||
|         .into_iter() | ||||
|         .map(UpdateStatusResponse::from) | ||||
|         .collect::<Vec<_>>(); | ||||
|     let response = data.get_index_stats(path.index_uid.clone()).await?; | ||||
| 
 | ||||
|     debug!("returns: {:?}", metas); | ||||
|     Ok(HttpResponse::Ok().json(metas)) | ||||
|     debug!("returns: {:?}", response); | ||||
|     Ok(HttpResponse::Ok().json(response)) | ||||
| } | ||||
| @@ -11,9 +11,9 @@ use crate::index::{default_crop_length, SearchQuery, DEFAULT_SEARCH_LIMIT}; | ||||
| use crate::routes::IndexParam; | ||||
| use crate::Data; | ||||
| 
 | ||||
| pub fn services(cfg: &mut web::ServiceConfig) { | ||||
| pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service( | ||||
|         web::resource("/indexes/{index_uid}/search") | ||||
|         web::resource("") | ||||
|             .route(web::get().to(search_with_url_query)) | ||||
|             .route(web::post().to(search_with_post)), | ||||
|     ); | ||||
| @@ -69,68 +69,63 @@ macro_rules! make_setting_route { | ||||
| } | ||||
| 
 | ||||
| make_setting_route!( | ||||
|     "/indexes/{index_uid}/settings/filterable-attributes", | ||||
|     "/filterable-attributes", | ||||
|     std::collections::HashSet<String>, | ||||
|     filterable_attributes, | ||||
|     "filterableAttributes" | ||||
| ); | ||||
| 
 | ||||
| make_setting_route!( | ||||
|     "/indexes/{index_uid}/settings/displayed-attributes", | ||||
|     "/displayed-attributes", | ||||
|     Vec<String>, | ||||
|     displayed_attributes, | ||||
|     "displayedAttributes" | ||||
| ); | ||||
| 
 | ||||
| make_setting_route!( | ||||
|     "/indexes/{index_uid}/settings/searchable-attributes", | ||||
|     "/searchable-attributes", | ||||
|     Vec<String>, | ||||
|     searchable_attributes, | ||||
|     "searchableAttributes" | ||||
| ); | ||||
| 
 | ||||
| make_setting_route!( | ||||
|     "/indexes/{index_uid}/settings/stop-words", | ||||
|     "/stop-words", | ||||
|     std::collections::BTreeSet<String>, | ||||
|     stop_words, | ||||
|     "stopWords" | ||||
| ); | ||||
| 
 | ||||
| make_setting_route!( | ||||
|     "/indexes/{index_uid}/settings/synonyms", | ||||
|     "/synonyms", | ||||
|     std::collections::BTreeMap<String, Vec<String>>, | ||||
|     synonyms, | ||||
|     "synonyms" | ||||
| ); | ||||
| 
 | ||||
| make_setting_route!( | ||||
|     "/indexes/{index_uid}/settings/distinct-attribute", | ||||
|     "/distinct-attribute", | ||||
|     String, | ||||
|     distinct_attribute, | ||||
|     "distinctAttribute" | ||||
| ); | ||||
| 
 | ||||
| make_setting_route!( | ||||
|     "/indexes/{index_uid}/settings/ranking-rules", | ||||
|     Vec<String>, | ||||
|     ranking_rules, | ||||
|     "rankingRules" | ||||
| ); | ||||
| make_setting_route!("/ranking-rules", Vec<String>, ranking_rules, "rankingRules"); | ||||
| 
 | ||||
| macro_rules! create_services { | ||||
| macro_rules! generate_configure { | ||||
|     ($($mod:ident),*) => { | ||||
|         pub fn services(cfg: &mut web::ServiceConfig) { | ||||
|             cfg | ||||
|                 .service(web::resource("/indexes/{index_uid}/settings") | ||||
|                     .route(web::post().to(update_all)) | ||||
|                     .route(web::get().to(get_all)) | ||||
|                     .route(web::delete().to(delete_all))) | ||||
|         pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
|             cfg.service( | ||||
|                 web::resource("") | ||||
|                 .route(web::post().to(update_all)) | ||||
|                 .route(web::get().to(get_all)) | ||||
|                 .route(web::delete().to(delete_all))) | ||||
|                 $(.service($mod::resources()))*; | ||||
|         } | ||||
|     }; | ||||
| } | ||||
| 
 | ||||
| create_services!( | ||||
| generate_configure!( | ||||
|     filterable_attributes, | ||||
|     displayed_attributes, | ||||
|     searchable_attributes, | ||||
							
								
								
									
										64
									
								
								meilisearch-http/src/routes/indexes/updates.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								meilisearch-http/src/routes/indexes/updates.rs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | ||||
| use actix_web::{web, HttpResponse}; | ||||
| use chrono::{DateTime, Utc}; | ||||
| use log::debug; | ||||
| 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))) | ||||
|         .service(web::resource("{update_id}").route(web::get().to(get_update_status))); | ||||
| } | ||||
|  | ||||
| #[derive(Debug, Deserialize)] | ||||
| #[serde(rename_all = "camelCase", deny_unknown_fields)] | ||||
| struct UpdateIndexRequest { | ||||
|     uid: Option<String>, | ||||
|     primary_key: Option<String>, | ||||
| } | ||||
|  | ||||
| #[derive(Debug, Serialize)] | ||||
| #[serde(rename_all = "camelCase")] | ||||
| pub struct UpdateIndexResponse { | ||||
|     name: String, | ||||
|     uid: String, | ||||
|     created_at: DateTime<Utc>, | ||||
|     updated_at: DateTime<Utc>, | ||||
|     primary_key: Option<String>, | ||||
| } | ||||
|  | ||||
| #[derive(Deserialize)] | ||||
| struct UpdateParam { | ||||
|     index_uid: String, | ||||
|     update_id: u64, | ||||
| } | ||||
|  | ||||
| async fn get_update_status( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     path: web::Path<UpdateParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let params = path.into_inner(); | ||||
|     let meta = data | ||||
|         .get_update_status(params.index_uid, params.update_id) | ||||
|         .await?; | ||||
|     let meta = UpdateStatusResponse::from(meta); | ||||
|     debug!("returns: {:?}", meta); | ||||
|     Ok(HttpResponse::Ok().json(meta)) | ||||
| } | ||||
|  | ||||
| async fn get_all_updates_status( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     path: web::Path<IndexParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let metas = data.get_updates_status(path.into_inner().index_uid).await?; | ||||
|     let metas = metas | ||||
|         .into_iter() | ||||
|         .map(UpdateStatusResponse::from) | ||||
|         .collect::<Vec<_>>(); | ||||
|  | ||||
|     debug!("returns: {:?}", metas); | ||||
|     Ok(HttpResponse::Ok().json(metas)) | ||||
| } | ||||
| @@ -1,23 +0,0 @@ | ||||
| use actix_web::{web, HttpResponse}; | ||||
| use serde::Serialize; | ||||
|  | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::Data; | ||||
|  | ||||
| pub fn services(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service(web::resource("/keys").route(web::get().to(list))); | ||||
| } | ||||
|  | ||||
| #[derive(Serialize)] | ||||
| struct KeysResponse { | ||||
|     private: Option<String>, | ||||
|     public: Option<String>, | ||||
| } | ||||
|  | ||||
| async fn list(data: GuardedData<Admin, Data>) -> HttpResponse { | ||||
|     let api_keys = data.api_keys.clone(); | ||||
|     HttpResponse::Ok().json(&KeysResponse { | ||||
|         private: api_keys.private, | ||||
|         public: api_keys.public, | ||||
|     }) | ||||
| } | ||||
| @@ -1,21 +1,27 @@ | ||||
| use std::time::Duration; | ||||
|  | ||||
| use actix_web::HttpResponse; | ||||
| use actix_web::{web, HttpResponse}; | ||||
| use chrono::{DateTime, Utc}; | ||||
| use log::debug; | ||||
| use serde::{Deserialize, Serialize}; | ||||
|  | ||||
| use crate::error::ResponseError; | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::index::{Settings, Unchecked}; | ||||
| use crate::index_controller::{UpdateMeta, UpdateResult, UpdateStatus}; | ||||
| use crate::Data; | ||||
|  | ||||
| pub mod document; | ||||
| pub mod dump; | ||||
| pub mod health; | ||||
| pub mod index; | ||||
| pub mod key; | ||||
| pub mod search; | ||||
| pub mod settings; | ||||
| pub mod stats; | ||||
| mod dump; | ||||
| mod indexes; | ||||
|  | ||||
| pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service(web::resource("/health").route(web::get().to(get_health))) | ||||
|         .service(web::scope("/dumps").configure(dump::configure)) | ||||
|         .service(web::resource("/keys").route(web::get().to(list_keys))) | ||||
|         .service(web::resource("/stats").route(web::get().to(get_stats))) | ||||
|         .service(web::resource("/version").route(web::get().to(get_version))) | ||||
|         .service(web::scope("/indexes").configure(indexes::configure)); | ||||
| } | ||||
|  | ||||
| #[derive(Debug, Clone, Serialize, Deserialize)] | ||||
| #[allow(clippy::large_enum_variant)] | ||||
| @@ -43,7 +49,6 @@ pub enum UpdateType { | ||||
| impl From<&UpdateStatus> for UpdateType { | ||||
|     fn from(other: &UpdateStatus) -> Self { | ||||
|         use milli::update::IndexDocumentsMethod::*; | ||||
|  | ||||
|         match other.meta() { | ||||
|             UpdateMeta::DocumentsAddition { method, .. } => { | ||||
|                 let number = match other { | ||||
| @@ -223,3 +228,53 @@ impl IndexUpdateResponse { | ||||
| 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> { | ||||
|     let response = data.get_all_stats().await?; | ||||
|  | ||||
|     debug!("returns: {:?}", response); | ||||
|     Ok(HttpResponse::Ok().json(response)) | ||||
| } | ||||
|  | ||||
| #[derive(Serialize)] | ||||
| #[serde(rename_all = "camelCase")] | ||||
| struct VersionResponse { | ||||
|     commit_sha: String, | ||||
|     commit_date: String, | ||||
|     pkg_version: String, | ||||
| } | ||||
|  | ||||
| async fn get_version(_data: GuardedData<Private, Data>) -> HttpResponse { | ||||
|     let commit_sha = match option_env!("COMMIT_SHA") { | ||||
|         Some("") | None => env!("VERGEN_SHA"), | ||||
|         Some(commit_sha) => commit_sha, | ||||
|     }; | ||||
|     let commit_date = match option_env!("COMMIT_DATE") { | ||||
|         Some("") | None => env!("VERGEN_COMMIT_DATE"), | ||||
|         Some(commit_date) => commit_date, | ||||
|     }; | ||||
|  | ||||
|     HttpResponse::Ok().json(VersionResponse { | ||||
|         commit_sha: commit_sha.to_string(), | ||||
|         commit_date: commit_date.to_string(), | ||||
|         pkg_version: env!("CARGO_PKG_VERSION").to_string(), | ||||
|     }) | ||||
| } | ||||
|  | ||||
| #[derive(Serialize)] | ||||
| struct KeysResponse { | ||||
|     private: Option<String>, | ||||
|     public: Option<String>, | ||||
| } | ||||
|  | ||||
| pub async fn list_keys(data: GuardedData<Admin, Data>) -> HttpResponse { | ||||
|     let api_keys = data.api_keys.clone(); | ||||
|     HttpResponse::Ok().json(&KeysResponse { | ||||
|         private: api_keys.private, | ||||
|         public: api_keys.public, | ||||
|     }) | ||||
| } | ||||
|  | ||||
| pub async fn get_health() -> Result<HttpResponse, ResponseError> { | ||||
|     Ok(HttpResponse::Ok().json(serde_json::json!({ "status": "available" }))) | ||||
| } | ||||
|   | ||||
| @@ -1,56 +0,0 @@ | ||||
| use actix_web::{web, HttpResponse}; | ||||
| use log::debug; | ||||
| use serde::Serialize; | ||||
|  | ||||
| use crate::error::ResponseError; | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::routes::IndexParam; | ||||
| use crate::Data; | ||||
|  | ||||
| pub fn services(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service(web::resource("/indexes/{index_uid}/stats").route(web::get().to(get_index_stats))) | ||||
|         .service(web::resource("/stats").route(web::get().to(get_stats))) | ||||
|         .service(web::resource("/version").route(web::get().to(get_version))); | ||||
| } | ||||
|  | ||||
| async fn get_index_stats( | ||||
|     data: GuardedData<Private, Data>, | ||||
|     path: web::Path<IndexParam>, | ||||
| ) -> Result<HttpResponse, ResponseError> { | ||||
|     let response = data.get_index_stats(path.index_uid.clone()).await?; | ||||
|  | ||||
|     debug!("returns: {:?}", response); | ||||
|     Ok(HttpResponse::Ok().json(response)) | ||||
| } | ||||
|  | ||||
| async fn get_stats(data: GuardedData<Private, Data>) -> Result<HttpResponse, ResponseError> { | ||||
|     let response = data.get_all_stats().await?; | ||||
|  | ||||
|     debug!("returns: {:?}", response); | ||||
|     Ok(HttpResponse::Ok().json(response)) | ||||
| } | ||||
|  | ||||
| #[derive(Serialize)] | ||||
| #[serde(rename_all = "camelCase")] | ||||
| struct VersionResponse { | ||||
|     commit_sha: String, | ||||
|     commit_date: String, | ||||
|     pkg_version: String, | ||||
| } | ||||
|  | ||||
| async fn get_version(_data: GuardedData<Private, Data>) -> HttpResponse { | ||||
|     let commit_sha = match option_env!("COMMIT_SHA") { | ||||
|         Some("") | None => env!("VERGEN_SHA"), | ||||
|         Some(commit_sha) => commit_sha, | ||||
|     }; | ||||
|     let commit_date = match option_env!("COMMIT_DATE") { | ||||
|         Some("") | None => env!("VERGEN_COMMIT_DATE"), | ||||
|         Some(commit_date) => commit_date, | ||||
|     }; | ||||
|  | ||||
|     HttpResponse::Ok().json(VersionResponse { | ||||
|         commit_sha: commit_sha.to_string(), | ||||
|         commit_date: commit_date.to_string(), | ||||
|         pkg_version: env!("CARGO_PKG_VERSION").to_string(), | ||||
|     }) | ||||
| } | ||||
		Reference in New Issue
	
	Block a user