Merge pull request #724 from Kingtous/master
fix: cli compilation error when using cli feature
This commit is contained in:
		
						commit
						a7c84722d0
					
				
							
								
								
									
										11
									
								
								src/cli.rs
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								src/cli.rs
									
									
									
									
									
								
							| @ -21,7 +21,7 @@ impl Session { | |||||||
|     pub fn new(id: &str, sender: mpsc::UnboundedSender<Data>) -> Self { |     pub fn new(id: &str, sender: mpsc::UnboundedSender<Data>) -> Self { | ||||||
|         let mut password = "".to_owned(); |         let mut password = "".to_owned(); | ||||||
|         if PeerConfig::load(id).password.is_empty() { |         if PeerConfig::load(id).password.is_empty() { | ||||||
|             password = rpassword::read_password_from_tty(Some("Enter password: ")).unwrap(); |             password = rpassword::prompt_password("Enter password: ").unwrap(); | ||||||
|         } |         } | ||||||
|         let session = Self { |         let session = Self { | ||||||
|             id: id.to_owned(), |             id: id.to_owned(), | ||||||
| @ -47,7 +47,7 @@ impl Interface for Session { | |||||||
|                 .ok(); |                 .ok(); | ||||||
|         } else if msgtype == "re-input-password" { |         } else if msgtype == "re-input-password" { | ||||||
|             log::error!("{}: {}", title, text); |             log::error!("{}: {}", title, text); | ||||||
|             let pass = rpassword::read_password_from_tty(Some("Enter password: ")).unwrap(); |             let pass = rpassword::prompt_password("Enter password: ").unwrap(); | ||||||
|             self.sender.send(Data::Login((pass, true))).ok(); |             self.sender.send(Data::Login((pass, true))).ok(); | ||||||
|         } else if msgtype.contains("error") { |         } else if msgtype.contains("error") { | ||||||
|             log::error!("{}: {}: {}", msgtype, title, text); |             log::error!("{}: {}: {}", msgtype, title, text); | ||||||
| @ -76,6 +76,10 @@ impl Interface for Session { | |||||||
|     async fn handle_test_delay(&mut self, t: TestDelay, peer: &mut Stream) { |     async fn handle_test_delay(&mut self, t: TestDelay, peer: &mut Stream) { | ||||||
|         handle_test_delay(t, peer).await; |         handle_test_delay(t, peer).await; | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     fn send(&self, data: Data) { | ||||||
|  |         self.sender.send(data).ok(); | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #[tokio::main(flavor = "current_thread")] | #[tokio::main(flavor = "current_thread")] | ||||||
| @ -85,6 +89,7 @@ pub async fn start_one_port_forward( | |||||||
|     remote_host: String, |     remote_host: String, | ||||||
|     remote_port: i32, |     remote_port: i32, | ||||||
|     key: String, |     key: String, | ||||||
|  |     token: String, | ||||||
| ) { | ) { | ||||||
|     crate::common::test_rendezvous_server(); |     crate::common::test_rendezvous_server(); | ||||||
|     crate::common::test_nat_type(); |     crate::common::test_nat_type(); | ||||||
| @ -92,7 +97,7 @@ pub async fn start_one_port_forward( | |||||||
|     let handler = Session::new(&id, sender); |     let handler = Session::new(&id, sender); | ||||||
|     handler.lc.write().unwrap().port_forward = (remote_host, remote_port); |     handler.lc.write().unwrap().port_forward = (remote_host, remote_port); | ||||||
|     if let Err(err) = |     if let Err(err) = | ||||||
|         crate::port_forward::listen(handler.id.clone(), port, handler.clone(), receiver, &key).await |         crate::port_forward::listen(handler.id.clone(), port, handler.clone(), receiver, &key, &token).await | ||||||
|     { |     { | ||||||
|         log::error!("Failed to listen on {}: {}", port, err); |         log::error!("Failed to listen on {}: {}", port, err); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -9,7 +9,7 @@ pub trait FileManager: Interface { | |||||||
|         fs::get_home_as_string() |         fs::get_home_as_string() | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     #[cfg(not(any(target_os = "android", target_os = "ios")))] |     #[cfg(not(any(target_os = "android", target_os = "ios", feature = "cli")))] | ||||||
|     fn read_dir(&self,path: String, include_hidden: bool) -> sciter::Value { |     fn read_dir(&self,path: String, include_hidden: bool) -> sciter::Value { | ||||||
|         match fs::read_dir(&fs::get_path(&path), include_hidden) { |         match fs::read_dir(&fs::get_path(&path), include_hidden) { | ||||||
|             Err(_) => sciter::Value::null(), |             Err(_) => sciter::Value::null(), | ||||||
| @ -22,9 +22,9 @@ pub trait FileManager: Interface { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     #[cfg(any(target_os = "android", target_os = "ios"))] |     #[cfg(any(target_os = "android", target_os = "ios", feature = "cli"))] | ||||||
|     fn read_dir(&self,path: &str, include_hidden: bool) -> String { |     fn read_dir(&self,path: &str, include_hidden: bool) -> String { | ||||||
|         use crate::mobile::make_fd_to_json; |         use crate::common::make_fd_to_json; | ||||||
|         match fs::read_dir(&fs::get_path(path), include_hidden){ |         match fs::read_dir(&fs::get_path(path), include_hidden){ | ||||||
|             Ok(fd) => make_fd_to_json(fd), |             Ok(fd) => make_fd_to_json(fd), | ||||||
|             Err(_)=>"".into() |             Err(_)=>"".into() | ||||||
|  | |||||||
| @ -605,3 +605,22 @@ pub fn make_privacy_mode_msg(state: back_notification::PrivacyModeState) -> Mess | |||||||
|     msg_out.set_misc(misc); |     msg_out.set_misc(misc); | ||||||
|     msg_out |     msg_out | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | pub fn make_fd_to_json(fd: FileDirectory) -> String { | ||||||
|  |     use serde_json::json; | ||||||
|  |     let mut fd_json = serde_json::Map::new(); | ||||||
|  |     fd_json.insert("id".into(), json!(fd.id)); | ||||||
|  |     fd_json.insert("path".into(), json!(fd.path)); | ||||||
|  | 
 | ||||||
|  |     let mut entries = vec![]; | ||||||
|  |     for entry in fd.entries { | ||||||
|  |         let mut entry_map = serde_json::Map::new(); | ||||||
|  |         entry_map.insert("entry_type".into(), json!(entry.entry_type.value())); | ||||||
|  |         entry_map.insert("name".into(), json!(entry.name)); | ||||||
|  |         entry_map.insert("size".into(), json!(entry.size)); | ||||||
|  |         entry_map.insert("modified_time".into(), json!(entry.modified_time)); | ||||||
|  |         entries.push(entry_map); | ||||||
|  |     } | ||||||
|  |     fd_json.insert("entries".into(), json!(entries)); | ||||||
|  |     serde_json::to_string(&fd_json).unwrap_or("".into()) | ||||||
|  | } | ||||||
| @ -186,7 +186,7 @@ fn main() { | |||||||
|         .about("RustDesk command line tool") |         .about("RustDesk command line tool") | ||||||
|         .args_from_usage(&args) |         .args_from_usage(&args) | ||||||
|         .get_matches(); |         .get_matches(); | ||||||
|     use hbb_common::env_logger::*; |     use hbb_common::{env_logger::*, config::LocalConfig}; | ||||||
|     init_from_env(Env::default().filter_or(DEFAULT_FILTER_ENV, "info")); |     init_from_env(Env::default().filter_or(DEFAULT_FILTER_ENV, "info")); | ||||||
|     if let Some(p) = matches.value_of("port-forward") { |     if let Some(p) = matches.value_of("port-forward") { | ||||||
|         let options: Vec<String> = p.split(":").map(|x| x.to_owned()).collect(); |         let options: Vec<String> = p.split(":").map(|x| x.to_owned()).collect(); | ||||||
| @ -213,6 +213,7 @@ fn main() { | |||||||
|             remote_host = options[3].clone(); |             remote_host = options[3].clone(); | ||||||
|         } |         } | ||||||
|         let key = matches.value_of("key").unwrap_or("").to_owned(); |         let key = matches.value_of("key").unwrap_or("").to_owned(); | ||||||
|         cli::start_one_port_forward(options[0].clone(), port, remote_host, remote_port, key); |         let token = LocalConfig::get_option("access_token"); | ||||||
|  |         cli::start_one_port_forward(options[0].clone(), port, remote_host, remote_port, key, token); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,4 +1,5 @@ | |||||||
| use crate::client::*; | use crate::client::*; | ||||||
|  | use crate::common::{make_fd_to_json}; | ||||||
| use flutter_rust_bridge::{StreamSink, ZeroCopyBuffer}; | use flutter_rust_bridge::{StreamSink, ZeroCopyBuffer}; | ||||||
| use hbb_common::{ | use hbb_common::{ | ||||||
|     allow_err, |     allow_err, | ||||||
| @ -1144,25 +1145,6 @@ impl Connection { | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| pub fn make_fd_to_json(fd: FileDirectory) -> String { |  | ||||||
|     use serde_json::json; |  | ||||||
|     let mut fd_json = serde_json::Map::new(); |  | ||||||
|     fd_json.insert("id".into(), json!(fd.id)); |  | ||||||
|     fd_json.insert("path".into(), json!(fd.path)); |  | ||||||
| 
 |  | ||||||
|     let mut entries = vec![]; |  | ||||||
|     for entry in fd.entries { |  | ||||||
|         let mut entry_map = serde_json::Map::new(); |  | ||||||
|         entry_map.insert("entry_type".into(), json!(entry.entry_type.value())); |  | ||||||
|         entry_map.insert("name".into(), json!(entry.name)); |  | ||||||
|         entry_map.insert("size".into(), json!(entry.size)); |  | ||||||
|         entry_map.insert("modified_time".into(), json!(entry.modified_time)); |  | ||||||
|         entries.push(entry_map); |  | ||||||
|     } |  | ||||||
|     fd_json.insert("entries".into(), json!(entries)); |  | ||||||
|     serde_json::to_string(&fd_json).unwrap_or("".into()) |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // Server Side
 | // Server Side
 | ||||||
| // TODO connection_manager need use struct and trait,impl default method
 | // TODO connection_manager need use struct and trait,impl default method
 | ||||||
| #[cfg(target_os = "android")] | #[cfg(target_os = "android")] | ||||||
|  | |||||||
| @ -1,6 +1,7 @@ | |||||||
| use crate::client::file_trait::FileManager; | use crate::client::file_trait::FileManager; | ||||||
| use crate::mobile::connection_manager::{self, get_clients_length, get_clients_state}; | use crate::mobile::connection_manager::{self, get_clients_length, get_clients_state}; | ||||||
| use crate::mobile::{self, make_fd_to_json, Session}; | use crate::mobile::{self, Session}; | ||||||
|  | use crate::common::{make_fd_to_json}; | ||||||
| use flutter_rust_bridge::{StreamSink, ZeroCopyBuffer}; | use flutter_rust_bridge::{StreamSink, ZeroCopyBuffer}; | ||||||
| use hbb_common::ResultType; | use hbb_common::ResultType; | ||||||
| use hbb_common::{ | use hbb_common::{ | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user