Eu passei por alguns guias de configuração, mas não consegui descobrir como configurar o VSFTPD para acesso somente LAN e restringir o acesso a um único diretório (por exemplo: ~/Downloads).
Se possível, nem quero expor sua presença na Internet. Qualquer ajuda é muito apreciada.
PC: Ubuntu Mate 19.04 64 bits.
Acesso somente LAN
Isso é feito melhor com regras de firewall. Usaremos
ufw
o firewall descomplicado para isso.Primeiro, verificamos o status de
ufw
Se você vir
Status: inactive
, use o seguinte comando para ativarufw
:Conforme descrito no link abaixo, permitiremos as portas 20 e 21 para o acesso básico do VSFTPD. Não usaremos a regra ufw simples como:
pois isso permitirá o acesso de qualquer lugar. Para permitir o acesso somente LAN, usaremos a sintaxe avançada:
A
from 192.168.0.0/24
é a parte somente LAN. O seu pode ser diferente. Alguns roteadores domésticos atribuem endereços IP no intervalo 192.168.0.xe outros no intervalo 192.168.1.x, onde x está entre 2-255. A/24
máscara de sub-rede diz que qualquer valor de x nesse intervalo é permitido.Isso
to any
significa que qualquer endereço IP atribuído a este computador está correto. Como este computador não está atuando como roteador, essa configuração está correta.O
port 20
(ou21
) é a porta que esta regra abre.O
proto tcp
é o únicotcp
protocolo (não oudp
protocolo) que pode ser usado.Se quisermos adicionar as portas 990 e 40.000 a 50.000 portas ao firewall como no tutorial abaixo, podemos usar um comando para fazer isso:
Uma nota sobre o IPv6
Eu não sei o suficiente sobre endereços locais IPv6 e máscaras de sub-rede para escrever uma resposta que inclua regras IPv6 ufw. Sem nenhuma regra de permissão IPv6, qualquer tentativa de usar endereços IPv6 para acessar o
ftp
site será negada.As respostas a esta pergunta sugerem que pode não haver uma solução fácil para o IPv6: Como permitir sub-redes IPv6 locais no ufw?
Pelo que vale a pena, a seguinte sintaxe de regra de permissão (com base em uma resposta à pergunta acima) é aceita por
ufw
:Isso deve permitir o acesso ftp do intervalo IPv6 de link local que começa com
fe80
.Restringir o usuário a um único diretório
Isso está muito bem descrito no Tutorial do Oceano Digital . As principais etapas são reproduzidas abaixo:
Neste exemplo, o nome de usuário é
sammy
. O conceito básico é que o usuáriosammy
não deve ter acesso de gravação ao diretório base do diretório acessível ao usuário. Crie aftp
pasta, defina sua propriedade e remova as permissões de gravação com os seguintes comandos:Em seguida, criamos o diretório onde os arquivos podem ser carregados e atribuímos a propriedade ao usuário:
Em seguida, editamos o arquivo de configuração do VSFTPD no nano:
e faça as seguintes alterações/adições:
Quando terminarmos de fazer a alteração, salve e saia do arquivo.
Em seguida, criamos e adicionamos nosso usuário ao arquivo. Usaremos o sinalizador -a para anexar ao arquivo:
Por fim, reiniciamos o daemon para carregar as alterações de configuração:
Espero que isto ajude