Quais permissões afetam a criação de links físicos? A propriedade do arquivo é importante?
Suponha que o usuário alice
deseje criar um link físico para o arquivo target.txt
em um diretório target-dir
.
- Quais permissões
alice
precisam nos doistarget.txt
etarget-dir
? - Se
target.txt
pertence ao usuáriobill
etarget-dir
pertence ao usuáriochad
, isso muda alguma coisa?
Tentei simular essa situação criando a seguinte estrutura de pastas / arquivos em um ext4
sistema de arquivos:
#> ls -lh . *
.:
drwxr-xr-x 2 bill bill 60 Oct 1 11:29 source-dir
drwxrwxrwx 2 chad chad 60 Oct 1 11:40 target-dir
source-dir:
-r--r--r-- 1 bill bill 0 Oct 1 11:29 target.txt
target-dir:
-rw-rw-r-- 1 alice alice 0 Oct 1 11:40 dummy
Embora alice
possa criar um link virtual para target.txt
, ela não pode criar um link físico:
#> ln source-dir/target.txt target-dir/
ln: failed to create hard link ‘target-dir/target.txt’ => ‘source-dir/target.txt’: Operation not permitted
Se alice
possuir target.txt
e nenhuma permissão for alterada, o link físico será bem-sucedido. O que estou perdendo aqui?
target.txt
e target-dir
permissões, a menos que eu sudo
como root.
alice
.Eu pode acessar o arquivo original e hard-link a ela (criado com sudo
), mas não pode criar o link como o usuário, alice
apesar de todos concordarmos com essas permissões, deve ser suficiente.