I made a directory called "shadi" and set this permission for it
sinoosh@ubuntu:/home$ ls -ld shadi
drwxr-xrwx 2 root root 4096 Jul 1 01:58 shadi
In this situation I have "others" permissions, but why can I not delete it?
sinoosh@ubuntu:/home$ rm -r shadi/
rm: cannot remove ‘shadi/’: Permission denied
Here the problem is you do not have "w" permission on the
/home
directory. While deleting a file note that you are not writing to that file but you are changing the contents of the directory that contains the file, so having "w" permission on the directory is a must if you want to delete any file from the directory.If I am in a directory with "w" permission, I can delete any of its files without being worried about the file permission itself. Note that my present directory is
/home/rohith
which has "w" permission and hence I can delete any of its files irrespective of the file permissions.If the same file is created in the '/home' directory which has no "w" permission I get the same output as yours ! :)
This happens because you don't own the directory, it is owned by 'root' and the 'root' group. So to delete it you can either changing the ownership and then delete it (here you elevate your rights and become 'root' for taking the ownership):
Or you skip taking the ownership and make a
sudo rm
to elevate your rights and become 'root' for the deletion:Try this:
The permissions show owner root and group root, so you have to use sudo.
It's different accounts.
How would you expect safety from your account, if everyone had the permission to delete your home directory?
You do not have the
w
permission to delete someone other's home directory by default, except if theychmod +w
it.Here are the different permissions, and an example (
It goes like this:-rwxr-x---
/rwxrx
):1 + 2 + 4 = 7
,1 + 4 = 5
,0 = 0
, so750
, i.e. an ideal permission system. The owner (u
in this case) can read, write and execute the file, the owner's group (g
in this case) can read and execute, and anyone other (o
in this case) cannot do anything. This is the legendary: .you must get root access first by:
then force deleting the file