Add file name validation.

This commit is contained in:
Rafał Harabień 2017-11-07 23:17:52 +01:00
parent 288da370b3
commit 1576c4d697

View File

@ -419,7 +419,7 @@ impl <'a, 'b> DirEntry<'a, 'b> {
} }
pub(crate) fn first_cluster(&self) -> Option<u32> { pub(crate) fn first_cluster(&self) -> Option<u32> {
self.data.first_cluster() self.data.first_cluster(self.fs.fat_type)
} }
fn entry_info(&self) -> FileEntryInfo { fn entry_info(&self) -> FileEntryInfo {
@ -677,10 +677,26 @@ impl <'a, 'b> Dir<'a, 'b> {
short_name short_name
} }
fn create_entry(&mut self, name: &str, attrs: FileAttributes, first_cluster: Option<u32>) -> io::Result<DirEntry<'a, 'b>> { fn validate_name(name: &str) -> io::Result<()> {
if name.len() > 255 { if name.len() == 0 {
return Err(io::Error::new(ErrorKind::InvalidInput, "filename too long")); return Err(io::Error::new(ErrorKind::InvalidInput, "filename cannot be empty"));
} }
if name.len() > 255 {
return Err(io::Error::new(ErrorKind::InvalidInput, "filename is too long"));
}
for c in name.chars() {
match c {
'a'...'z' | 'A'...'Z' | '0'...'9' | '\u{80}'...'\u{FFFF}' |
'$' | '%' | '\'' | '-' | '_' | '@' | '~' | '`' | '!' | '(' | ')' | '{' | '}' |
'.' | ' ' | '+' | ',' | ';' | '=' | '[' | ']' => {},
_ => return Err(io::Error::new(ErrorKind::InvalidInput, "invalid character in filename")),
}
}
Ok(())
}
fn create_entry(&mut self, name: &str, attrs: FileAttributes, first_cluster: Option<u32>) -> io::Result<DirEntry<'a, 'b>> {
Self::validate_name(name)?;
let num_lfn_entries = (name.len() + LFN_PART_LEN - 1) / LFN_PART_LEN; let num_lfn_entries = (name.len() + LFN_PART_LEN - 1) / LFN_PART_LEN;
let num_entries = num_lfn_entries + 1; // multiple lfn entries + one file entry let num_entries = num_lfn_entries + 1; // multiple lfn entries + one file entry
let mut stream = self.find_free_entries(num_entries)?; let mut stream = self.find_free_entries(num_entries)?;