add validation for usernames and groupnames
This commit is contained in:
		
							parent
							
								
									7ec3bc3f0c
								
							
						
					
					
						commit
						d09f861ab0
					
				| @ -30,11 +30,7 @@ impl Display for Groupname { | |||||||
| impl TryFrom<String> for Groupname { | impl TryFrom<String> for Groupname { | ||||||
|     type Error = UserLibError; |     type Error = UserLibError; | ||||||
|     fn try_from(source: String) -> std::result::Result<Self, Self::Error> { |     fn try_from(source: String) -> std::result::Result<Self, Self::Error> { | ||||||
|         lazy_static! { |         if is_groupname_valid(&source) { | ||||||
|             static ref USERVALIDATION: Regex = |  | ||||||
|                 Regex::new("^[a-z_]([a-z0-9_\\-]{0,31}|[a-z0-9_\\-]{0,30}\\$)$").unwrap(); |  | ||||||
|         } |  | ||||||
|         if USERVALIDATION.is_match(&source) { |  | ||||||
|             Ok(Self { groupname: source }) |             Ok(Self { groupname: source }) | ||||||
|         } else if source == "Debian-exim" { |         } else if source == "Debian-exim" { | ||||||
|             warn!("username {} is not a valid username. This might cause problems. (It is default in Debian and Ubuntu)", source); |             warn!("username {} is not a valid username. This might cause problems. (It is default in Debian and Ubuntu)", source); | ||||||
| @ -48,6 +44,11 @@ impl TryFrom<String> for Groupname { | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | pub(crate) fn is_groupname_valid(name: &str) -> bool { | ||||||
|  |     // for now just use the username validation.
 | ||||||
|  |     crate::user::passwd_fields::is_username_valid(name) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /// A record(line) in the user database `/etc/shadow` found in most linux systems.
 | /// A record(line) in the user database `/etc/shadow` found in most linux systems.
 | ||||||
| #[derive(Debug, PartialEq, Eq)] | #[derive(Debug, PartialEq, Eq)] | ||||||
| pub struct Group { | pub struct Group { | ||||||
|  | |||||||
| @ -35,11 +35,7 @@ impl Display for Username { | |||||||
| impl TryFrom<String> for Username { | impl TryFrom<String> for Username { | ||||||
|     type Error = UserLibError; |     type Error = UserLibError; | ||||||
|     fn try_from(source: String) -> std::result::Result<Self, Self::Error> { |     fn try_from(source: String) -> std::result::Result<Self, Self::Error> { | ||||||
|         lazy_static! { |         if is_username_valid(&source) { | ||||||
|             static ref USERVALIDATION: Regex = |  | ||||||
|                 Regex::new("^[a-z_]([a-z0-9_\\-]{0,31}|[a-z0-9_\\-]{0,30}\\$)$").unwrap(); |  | ||||||
|         } |  | ||||||
|         if USERVALIDATION.is_match(&source) { |  | ||||||
|             Ok(Self { username: source }) |             Ok(Self { username: source }) | ||||||
|         } else if source == "Debian-exim" { |         } else if source == "Debian-exim" { | ||||||
|             warn!("username {} is not a valid username. This might cause problems. (It is default in Debian and Ubuntu)", source); |             warn!("username {} is not a valid username. This might cause problems. (It is default in Debian and Ubuntu)", source); | ||||||
| @ -53,6 +49,14 @@ impl TryFrom<String> for Username { | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | pub(crate) fn is_username_valid(name: &str) -> bool { | ||||||
|  |     lazy_static! { | ||||||
|  |         static ref USERVALIDATION: Regex = | ||||||
|  |             Regex::new("^[a-z_]([a-z0-9_\\-]{0,31}|[a-z0-9_\\-]{0,30}\\$)$").unwrap(); | ||||||
|  |     } | ||||||
|  |     USERVALIDATION.is_match(name) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| #[derive(Debug, PartialEq, Eq)] | #[derive(Debug, PartialEq, Eq)] | ||||||
| pub enum Password { | pub enum Password { | ||||||
|     Encrypted(crate::EncryptedPassword), |     Encrypted(crate::EncryptedPassword), | ||||||
|  | |||||||
| @ -124,12 +124,14 @@ use crate::api::UserDBValidation; | |||||||
| impl UserDBValidation for UserDBLocal { | impl UserDBValidation for UserDBLocal { | ||||||
|     fn is_uid_valid_and_free(&self, uid: u32) -> bool { |     fn is_uid_valid_and_free(&self, uid: u32) -> bool { | ||||||
|         warn!("No valid check, only free check"); |         warn!("No valid check, only free check"); | ||||||
|         self.users.iter().all(|(_, u)| u.get_uid() != uid) |         let free = self.users.iter().all(|(_, u)| u.get_uid() != uid); | ||||||
|  |         free | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     fn is_username_valid_and_free(&self, name: &str) -> bool { |     fn is_username_valid_and_free(&self, name: &str) -> bool { | ||||||
|         warn!("No valid check, only free check"); |         let valid = crate::user::passwd_fields::is_username_valid(name); | ||||||
|         self.get_user_by_name(name).is_none() |         let free = self.get_user_by_name(name).is_none(); | ||||||
|  |         valid && free | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     fn is_gid_valid_and_free(&self, gid: u32) -> bool { |     fn is_gid_valid_and_free(&self, gid: u32) -> bool { | ||||||
| @ -139,7 +141,9 @@ impl UserDBValidation for UserDBLocal { | |||||||
| 
 | 
 | ||||||
|     fn is_groupname_valid_and_free(&self, name: &str) -> bool { |     fn is_groupname_valid_and_free(&self, name: &str) -> bool { | ||||||
|         warn!("No valid check, only free check"); |         warn!("No valid check, only free check"); | ||||||
|         self.groups.iter().all(|x| x.get_groupname() != name) |         let valid = crate::group::is_groupname_valid(name); | ||||||
|  |         let free = self.groups.iter().all(|x| x.get_groupname() != name); | ||||||
|  |         valid && free | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user