mirror of
				https://git.proxmox.com/git/proxmox
				synced 2025-10-26 21:26:20 +00:00 
			
		
		
		
	 3182df96c0
			
		
	
	
		3182df96c0
		
	
	
	
	
		
			
			The CLI part itself needs much less info now as we'll take as much as we can from the api methods themselves. Note that we may still want to be able to add extra info to a cli command in particular, for instance, for the completion callbacks. For now this is all part of the method itself. Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
| #![feature(async_await)]
 | |
| 
 | |
| use bytes::Bytes;
 | |
| 
 | |
| use proxmox_api::cli;
 | |
| 
 | |
| #[test]
 | |
| fn simple() {
 | |
|     let simple_method: &proxmox_api::ApiMethod<Bytes> = &methods::SIMPLE_METHOD;
 | |
| 
 | |
|     let cli = cli::App::new("simple")
 | |
|         .subcommand("new", cli::Command::method(simple_method, &[]))
 | |
|         .subcommand("newfoo", cli::Command::method(simple_method, &["foo"]))
 | |
|         .subcommand("newbar", cli::Command::method(simple_method, &["bar"]))
 | |
|         .subcommand(
 | |
|             "newboth",
 | |
|             cli::Command::method(simple_method, &["foo", "bar"]),
 | |
|         );
 | |
| }
 | |
| 
 | |
| mod methods {
 | |
|     use bytes::Bytes;
 | |
|     use failure::{bail, Error};
 | |
|     use http::Response;
 | |
|     use lazy_static::lazy_static;
 | |
|     use serde_derive::{Deserialize, Serialize};
 | |
|     use serde_json::Value;
 | |
| 
 | |
|     use proxmox_api::{
 | |
|         get_type_info, ApiFuture, ApiMethod, ApiOutput, ApiType, Parameter, TypeInfo,
 | |
|     };
 | |
| 
 | |
|     pub async fn simple_method(value: Value) -> ApiOutput<Bytes> {
 | |
|         let foo = value["foo"].as_str().unwrap();
 | |
| 
 | |
|         let bar = value["bar"].as_str().unwrap();
 | |
| 
 | |
|         let baz = value.get("baz").map(|value| value.as_str().unwrap());
 | |
| 
 | |
|         let output = match baz {
 | |
|             Some(baz) => format!("{}:{}:{}", foo, bar, baz),
 | |
|             None => format!("{}:{}", foo, bar),
 | |
|         };
 | |
| 
 | |
|         Ok(Response::builder()
 | |
|             .status(200)
 | |
|             .header("content-type", "application/json")
 | |
|             .body(output.into())?)
 | |
|     }
 | |
| 
 | |
|     lazy_static! {
 | |
|         static ref SIMPLE_PARAMS: Vec<Parameter> = {
 | |
|             vec![
 | |
|                 Parameter {
 | |
|                     name: "foo",
 | |
|                     description: "a test parameter",
 | |
|                     type_info: String::type_info,
 | |
|                 },
 | |
|                 Parameter {
 | |
|                     name: "bar",
 | |
|                     description: "another test parameter",
 | |
|                     type_info: String::type_info,
 | |
|                 },
 | |
|                 Parameter {
 | |
|                     name: "baz",
 | |
|                     description: "another test parameter",
 | |
|                     type_info: Option::<String>::type_info,
 | |
|                 },
 | |
|             ]
 | |
|         };
 | |
|         pub static ref SIMPLE_METHOD: ApiMethod<Bytes> = {
 | |
|             ApiMethod {
 | |
|                 description: "get some parameters back",
 | |
|                 parameters: &SIMPLE_PARAMS,
 | |
|                 return_type: get_type_info::<String>(),
 | |
|                 protected: false,
 | |
|                 reload_timezone: false,
 | |
|                 handler: |value: Value| -> ApiFuture<Bytes> { Box::pin(simple_method(value)) },
 | |
|             }
 | |
|         };
 | |
|     }
 | |
| }
 |