mirror of
https://github.com/nushell/nushell.git
synced 2025-01-25 15:51:28 +01:00
Fix root directory traversal issue (#14747)
fixes : #13729 During dot expansion, the "parent" was added even if it was after the root (`/../../`). Added additional check that skips appending elements to the path representation if the parent folder is the root folder.
This commit is contained in:
parent
b5ff46db6a
commit
87a562e24b
@ -60,7 +60,13 @@ pub fn expand_dots(path: impl AsRef<Path>) -> PathBuf {
|
|||||||
Component::CurDir if last_component_is_normal(&result) => {
|
Component::CurDir if last_component_is_normal(&result) => {
|
||||||
// no-op
|
// no-op
|
||||||
}
|
}
|
||||||
_ => result.push(component),
|
_ => {
|
||||||
|
let prev_component = result.components().last();
|
||||||
|
if prev_component == Some(Component::RootDir) && component == Component::ParentDir {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
result.push(component)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -215,11 +221,7 @@ mod test_expand_dots {
|
|||||||
#[test]
|
#[test]
|
||||||
fn backtrack_to_root() {
|
fn backtrack_to_root() {
|
||||||
let path = Path::new("/foo/bar/../../../../baz");
|
let path = Path::new("/foo/bar/../../../../baz");
|
||||||
let expected = if cfg!(windows) {
|
let expected = if cfg!(windows) { r"\baz" } else { "/baz" };
|
||||||
r"\..\..\baz"
|
|
||||||
} else {
|
|
||||||
"/../../baz"
|
|
||||||
};
|
|
||||||
assert_path_eq!(expand_dots(path), expected);
|
assert_path_eq!(expand_dots(path), expected);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user