Kernel: Don't allow non-root, non-owners to rmdir any child of sticky

We were not handling sticky parents properly in sys$rmdir(). Child
directories of a sticky parent should not be rmdir'able by just anyone.
Only the owner and root.

Fixes #4875.
This commit is contained in:
Andreas Kling 2021-01-10 10:12:15 +01:00
parent f35a723f61
commit 795bccbf69
Notes: sideshowbarker 2024-07-18 23:58:11 +09:00

View file

@ -750,10 +750,16 @@ KResult VFS::rmdir(StringView path, Custody& base)
return KResult(-EBUSY);
auto& parent_inode = parent_custody->inode();
auto parent_metadata = parent_inode.metadata();
if (!parent_inode.metadata().may_write(*Process::current()))
if (!parent_metadata.may_write(*Process::current()))
return KResult(-EACCES);
if (parent_metadata.is_sticky()) {
if (!Process::current()->is_superuser() && inode.metadata().uid != Process::current()->euid())
return KResult(-EACCES);
}
KResultOr<size_t> dir_count_result = inode.directory_entry_count();
if (dir_count_result.is_error())
return dir_count_result.result();