code cleanup
This commit is contained in:
		| @ -4,10 +4,24 @@ use crate::api::schema::*; | ||||
| use serde_json::{Value}; | ||||
| use std::collections::HashMap; | ||||
|  | ||||
| type ApiHandlerFn = fn(Value, &ApiMethod) -> Result<Value, Error>; | ||||
|  | ||||
| pub struct ApiMethod { | ||||
|     pub parameters: ObjectSchema, | ||||
|     pub returns: Schema, | ||||
|     pub handler: fn(Value, &ApiMethod) -> Result<Value, Error>, | ||||
|     pub handler: ApiHandlerFn, | ||||
| } | ||||
|  | ||||
| impl ApiMethod { | ||||
|  | ||||
|     pub fn new(handler: ApiHandlerFn, parameters: ObjectSchema) -> Self { | ||||
|         Self { | ||||
|             parameters, | ||||
|             handler, | ||||
|             returns: Schema::Null, | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
| pub enum SubRoute { | ||||
| @ -36,13 +50,30 @@ impl Router { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     pub fn subdir<S: Into<String>>(mut self, subdir: S, router: Router) -> Self { | ||||
|         if let SubRoute::None = self.subroute { | ||||
|             self.subroute = SubRoute::Hash(HashMap::new()); | ||||
|         } | ||||
|         match self.subroute { | ||||
|             SubRoute::Hash(ref mut map) => { | ||||
|                 map.insert(subdir.into(), router); | ||||
|             } | ||||
|             _ => panic!("unexpected subroute type"), | ||||
|         } | ||||
|         self | ||||
|     } | ||||
|  | ||||
|     pub fn subdirs(mut self, map: HashMap<String, Router>) -> Self { | ||||
|         self.subroute = SubRoute::Hash(map); | ||||
|         self | ||||
|     } | ||||
|  | ||||
|     pub fn match_all<S>(mut self, param_name: S, router: Router) -> Self where S: Into<String> { | ||||
|         self.subroute = SubRoute::MatchAll { router: Box::new(router), param_name: param_name.into() }; | ||||
|     pub fn match_all<S: Into<String>>(mut self, param_name: S, router: Router) -> Self { | ||||
|         if let SubRoute::None = self.subroute { | ||||
|             self.subroute = SubRoute::MatchAll { router: Box::new(router), param_name: param_name.into() }; | ||||
|         } else { | ||||
|             panic!("unexpected subroute type"); | ||||
|         } | ||||
|         self | ||||
|     } | ||||
|  | ||||
| @ -50,17 +81,17 @@ impl Router { | ||||
|         self.get = Some(m); | ||||
|         self | ||||
|     } | ||||
|      | ||||
|  | ||||
|     pub fn put(mut self, m: ApiMethod) -> Self { | ||||
|         self.put = Some(m); | ||||
|         self | ||||
|     } | ||||
|      | ||||
|  | ||||
|     pub fn post(mut self, m: ApiMethod) -> Self { | ||||
|         self.post = Some(m); | ||||
|         self | ||||
|     } | ||||
|      | ||||
|  | ||||
|     pub fn delete(mut self, m: ApiMethod) -> Self { | ||||
|         self.delete = Some(m); | ||||
|         self | ||||
|  | ||||
							
								
								
									
										33
									
								
								src/api3.rs
									
									
									
									
									
								
							
							
						
						
									
										33
									
								
								src/api3.rs
									
									
									
									
									
								
							| @ -54,27 +54,20 @@ pub fn router() -> Router { | ||||
|  | ||||
|  | ||||
|     let nodeinfo = Router::new() | ||||
|         .get(ApiMethod { | ||||
|             handler: test_sync_api_handler, | ||||
|             parameters: ObjectSchema::new("This is a simple test.") | ||||
|                 .optional("force", BooleanSchema::new("Test for boolean options")), | ||||
|             returns: Schema::Null, | ||||
|         }) | ||||
|         .subdirs({ | ||||
|             let mut map = HashMap::new(); | ||||
|             map.insert("subdir3".into(), route4); | ||||
|             map | ||||
|         }); | ||||
|         .get(ApiMethod::new( | ||||
|             test_sync_api_handler, | ||||
|             ObjectSchema::new("This is a simple test.") | ||||
|                 .optional("force", BooleanSchema::new("Test for boolean options"))) | ||||
|         ) | ||||
|         .subdir("subdir3", route4); | ||||
|  | ||||
|     let nodes = Router::new() | ||||
|         .match_all("node", nodeinfo); | ||||
|  | ||||
|     let version = Router::new() | ||||
|         .get(ApiMethod { | ||||
|             handler: get_version, | ||||
|             parameters: ObjectSchema::new("Proxmox Backup Server API version."), | ||||
|             returns: Schema::Null, | ||||
|         }); | ||||
|         .get(ApiMethod::new( | ||||
|             get_version, | ||||
|             ObjectSchema::new("Proxmox Backup Server API version."))); | ||||
|  | ||||
|      let route = Router::new() | ||||
|         .get(ApiMethod { | ||||
| @ -82,12 +75,8 @@ pub fn router() -> Router { | ||||
|             parameters: ObjectSchema::new("Directory index."), | ||||
|             returns: Schema::Null, | ||||
|         }) | ||||
|         .subdirs({ | ||||
|             let mut map = HashMap::new(); | ||||
|             map.insert("version".into(), version); | ||||
|             map.insert("nodes".into(), nodes); | ||||
|            map | ||||
|         }); | ||||
|         .subdir("version", version) | ||||
|         .subdir("nodes", nodes); | ||||
|  | ||||
|     route | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user