save ab password to recent PeerConfig when connected with it
Signed-off-by: 21pages <pages21@163.com>
This commit is contained in:
		
							parent
							
								
									ee8510cec7
								
							
						
					
					
						commit
						7ec462737b
					
				| @ -1074,6 +1074,7 @@ pub struct LoginConfigHandler { | |||||||
|     pub direct: Option<bool>, |     pub direct: Option<bool>, | ||||||
|     pub received: bool, |     pub received: bool, | ||||||
|     switch_uuid: Option<String>, |     switch_uuid: Option<String>, | ||||||
|  |     pub save_ab_password_to_recent: bool, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl Deref for LoginConfigHandler { | impl Deref for LoginConfigHandler { | ||||||
| @ -1647,7 +1648,10 @@ impl LoginConfigHandler { | |||||||
|                 log::debug!("remember password of {}", self.id); |                 log::debug!("remember password of {}", self.id); | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             if !password0.is_empty() { |             if self.save_ab_password_to_recent { | ||||||
|  |                 config.password = password; | ||||||
|  |                 log::debug!("save ab password of {} to recent", self.id); | ||||||
|  |             } else if !password0.is_empty() { | ||||||
|                 config.password = Default::default(); |                 config.password = Default::default(); | ||||||
|                 log::debug!("remove password of {}", self.id); |                 log::debug!("remove password of {}", self.id); | ||||||
|             } |             } | ||||||
| @ -2173,6 +2177,7 @@ pub fn handle_login_error( | |||||||
|     err: &str, |     err: &str, | ||||||
|     interface: &impl Interface, |     interface: &impl Interface, | ||||||
| ) -> bool { | ) -> bool { | ||||||
|  |     lc.write().unwrap().save_ab_password_to_recent = false; | ||||||
|     if err == LOGIN_MSG_PASSWORD_EMPTY { |     if err == LOGIN_MSG_PASSWORD_EMPTY { | ||||||
|         lc.write().unwrap().password = Default::default(); |         lc.write().unwrap().password = Default::default(); | ||||||
|         interface.msgbox("input-password", "Password Required", "", ""); |         interface.msgbox("input-password", "Password Required", "", ""); | ||||||
| @ -2252,7 +2257,11 @@ pub async fn handle_hash( | |||||||
|                 .find_map(|p| if p.id == id { Some(p) } else { None }) |                 .find_map(|p| if p.id == id { Some(p) } else { None }) | ||||||
|             { |             { | ||||||
|                 if let Ok(hash) = base64::decode(p.hash.clone(), base64::Variant::Original) { |                 if let Ok(hash) = base64::decode(p.hash.clone(), base64::Variant::Original) { | ||||||
|  |                     if !hash.is_empty() { | ||||||
|                         password = hash; |                         password = hash; | ||||||
|  |                         lc.write().unwrap().save_ab_password_to_recent = true; | ||||||
|  |                         lc.write().unwrap().password = password.clone(); | ||||||
|  |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user