Kernel: Stricter path checking in validate_path_against_process_veil

This change enforces that paths passed to
VFS::validate_path_against_process_veil are absolute and do not contain
any '..' or '.' parts. We should VERIFY here instead of returning EINVAL
since the code that calls this should resolve non-canonical paths before
calling this function.
This commit is contained in:
Max Wipfli 2021-07-05 18:03:54 +02:00 committed by Andreas Kling
parent 82c25aad01
commit 502436f9fc
Notes: sideshowbarker 2024-07-18 10:22:31 +09:00

View File

@ -852,9 +852,9 @@ KResult VFS::validate_path_against_process_veil(StringView path, int options)
if (path == "/usr/lib/Loader.so")
return KSuccess;
// FIXME: Figure out a nicer way to do this.
if (String(path).contains("/.."))
return EINVAL;
VERIFY(path.starts_with('/'));
VERIFY(!path.contains("/../"sv) && !path.ends_with("/.."sv));
VERIFY(!path.contains("/./"sv) && !path.ends_with("/."sv));
auto& unveiled_path = find_matching_unveiled_path(path);
if (unveiled_path.permissions() == UnveilAccess::None) {