FTPS – VsFTPd / Debian 11

Mémento 9.21 - Serveur VsFTPd

Le serveur VsFTPd sera installé sur la VM srvlan.

Le FTP est un protocole de communication dédié au transfert de fichiers sur un réseau TCP/IP.

Les utilisateurs des VM debian11-vm* (clients) utiliseront la VM srvlan (serveur) pour déposer ou s'échanger des fichiers.

Selon le paramétrage FTP, un utilisateur pourra ou non Déposer, Télécharger, Lire, Modifier ou Supprimer des dossiers/fichiers.

1 - Préambule

Outils utilisés :
- Serveur VsFTPd (Very secure FTP daemon).
- Console client lftp à la place de ftp.

Configurations proposées :
- Usage du FTPS (FTP via SSL).
- Usage du mode passif.

1.1 - Rôle d'un serveur FTP

Il permet le transfert de dossiers/fichiers avec un client distant, par Internet ou par le réseau informatique local. Le transfert, selon un modèle client/serveur, peut se faire dans les 2 sens.

Le serveur FTP d'un hébergeur permet par exemple à un client distant de déposer ou télécharger les fichiers de son site web.

En général, deux modes de connexion sont utilisés :
Le mode anonyme qui autorise l'accès au dossier public du serveur sans fournir de nom d'utilisateur ni de MDP. Les fichiers de ce dossier sont souvent en lecteur seule.

Le mode authentifié qui permet à un utilisateur local ou virtuel, après contrôle de son nom et de son MDP, d'accéder en lecture/écriture à ses propres fichiers.

2 - Installation

2.1 - Serveur vsftpd

Au préalable, mettez à jour la distribution Debian 11 :

[srvlan@srvlan:~$] sudo apt update
[srvlan@srvlan:~$] sudo apt upgrade
[srvlan@srvlan:~$] sudo reboot

et installez vsftpd pour son côté léger et sécurisé :

[srvlan@srvlan:~$] sudo apt install vsftpd

Vérifiez le bon démarrage de celui-ci :

[srvlan@srvlan:~$] sudo systemctl status vsftpd

Retour :

 vsftpd.service - vsftpd FTP server
   Loaded: loaded (/lib/systemd/system/vsftpd...
   Active: active (running) since Mon 2022-... ago
  Process: 1575 ExecStartPre=/bin/mkdir -p /var...
 Main PID: 1576 (vsftpd)
    Tasks: 1 (limit: 1116)
   Memory: 948.0K
      CPU: 33ms
   CGroup: /system.slice/vsftpd.service
             └─1576 /usr/sbin/vsftpd /etc/vsftd...

mai 02 ... srvlan systemd[1]: Starting vsftpd ...
mai 02 ... srvlan systemd[1]: Started vsftpd ...

Un utilisateur de nom ftp a été créé lors de l'installation.
Un dossier personnel /srv/ftp/ lui a été associé.
Il s'agit du dossier public FTP par défaut du serveur.

Pour les tests, copiez ces 2 fichiers dans ce dossier :

[srvlan@srvlan:~$] cd /usr/share/doc/vsftpd
[srvlan@srvlan:~$] sudo cp README /srv/ftp/README
[srvlan@srvlan:~$] sudo cp TODO /srv/ftp/TODO

2.2 - Sécurisation des échanges FTP via SSL

De base le serveur vsftpd ne chiffre rien mais il peut utiliser le protocole FTPS (FTP via SSL) pour chiffrer ses communications avec les clients.

Pour information, différences entre le SFTP et le FTPS :
- SFTP plus récent utilise par défaut le port 22 pour traiter l’authentification, les Cdes FTP et le transfert de données.

La gestion d'un pare-feu est facilitée, un seul port.

- FTPS utilise par défaut le port 21 pour traiter l'authentification et les Cdes FTP ainsi que le port 20 (en mode actif) ou une tranche de ports (en mode passif) pour le transfert de données.

Un pare-feu sera donc plus compliqué à gérer.

Pour le FTPS, installez si absent le paquet openssl :

[srvlan@srvlan:~$] sudo apt install openssl

Puis connectez-vous en tant que root et créez un certificat CA (Certificate Authority) auto-signé :

[srvlan@srvlan:~$] su root
[root@srvlan:~#] cd /etc/ssl/private
[root@srvlan:~#] openssl req -x509 -nodes -newkey rsa:2048 -keyout vsftpd.pem -out vsftpd.pem -days 3650

en répondant aux questions posées comme suit :

Country Name (2 letter code) [AU]:FR
State or Prov... Name (full name) [Some-State]:Paris
Locality Name (eg, city) []:Paris
Organization Name (e...) [Interne...]:Intra-InfoLoup            
Organizational Uni... (eg...) []:Intra-Labo-FTPS
Common Name (... server FQDN or YOUR name) []:srvlan
Email Address []:Rien > Touche Entrée

Editez ensuite le fichier de configuration vsftpd.conf :

[root@srvlan:~#] exit

[srvlan@srvlan:~$] sudo nano /etc/vsftpd.conf

et ajustez vers la ligne 147 les paramètres SSL :

# This option specifies the location of the RSA certificate ...
# encrypted connections.
rsa_cert_file=/etc/ssl/private/vsftpd.pem
rsa_private_key_file=/etc/ssl/private/vsftpd.pem
ssl_enable=YES

ssl_ciphers=HIGH
ssl_tlsv1=YES
ssl_sslv2=NO
ssl_sslv3=NO
force_local_data_ssl=YES
force_local_logins_ssl=YES
allow_anon_ssl=NO

Le contenu des 7 dernières lignes ajoutées signifie :
- Niveau de chiffrement élevé imposé.
- Protocole ssl_tlsv1 autorisé.
- Protocole ssl_sslv2 refusé car moins sécurisé.
- Protocole ssl_sslv3 refusé car moins sécurisé.
- Login non anonyme forcé SSL pour l'envoi des Data.
- Login non anonyme forcé SSL pour l'envoi du MDP.
- Login anonyme non forcé SSL.

2.3 - Activation du mode FTP passif

Le serveur fonctionne par défaut en mode actif. Il vaut mieux, pour éventuellement éviter que le pare-feu d'un client distant situé sur Internet ne bloque la liaison FTPS, passer celui-ci en mode passif.

Ouvrez le synoptique du mémento pour découvrir la différence entre les 2 modes.

Activez l'usage du mode passif en fin de vsftpd.conf :

# Activation du mode passif
pasv_enable=YES
pasv_min_port=12500         # La tranche de ports  aléatoires 
pasv_max_port=12550        # doit-être > à 1024

et redémarrez le serveur FTP :

[srvlan@srvlan:~$] sudo systemctl restart vsftpd
[srvlan@srvlan:~$] sudo systemctl status vsftpd

3 - Connexions anonymes

3.1 - Configuration de base

Par défaut, vsftpd refuse les connexions anonymes.
Pour changer cela, éditez son fichier de configuration :

[srvlan@srvlan:~$] sudo nano /etc/vsftpd.conf

et réglez les valeurs de ces 3 paramètres comme suit :

anonymous_enable=YES                    # Accès anonyme autorisé
anon_upload_enable=NO                         # Dépôt fichiers interdit
anon_mkdir_write_enable=NO        # Création dossiers interdite

N'oubliez pas de retirer si besoin le # de début de ligne.

Redémarrez le serveur FTP :

[srvlan@srvlan:~$] sudo systemctl restart vsftpd

3.2 - Connexion distante depuis une console

Installez le client FTP de nom lftp sur debian11-vm2 :

[client-linux@debian11-vm2:~$] sudo apt install lftp

Ce programme permet d'envoyer des lignes de Cdes vers un serveur FTP/FTPS/SFTP.

Créez un fichier caché .lftprc qui sera utilisé par lftp :

[client-linux@debian11-vm2:~$] cd /home/client-linux
[client-linux@debian11-vm2:~$] nano .lftprc

et entrez la configuration suivante :

# Configuration traitée au démarrage du client lftp
set ftp:passive-mode true
set ftp:ssl-auth TLS
set ftp:ssl-force true
set ftp:ssl-protect-data true
set ftp:ssl-protect-list true
set ssl:verify-certificate no

Enfin, connectez-vous sur le serveur vsftpd de srvlan :

[client-linux@debian11-vm2:~$] lftp srvlan
lftp srvlan:~> ls

La Cde ls renvoie le contenu du dossier public /srv/ftp/ :

lftp srvlan:~> ls
-rw-r--r--    1 0      0  1361 May 02 13:54 README
-rw-r--r--    1 0      0  1833 May 02 13:54 TODO
lftp srvlan:/> quit

Utilisez la Cde quit pour fermer la connexion distante.

Testez ensuite un téléchargement FTP :

[client-linux@debian11-vm2:~$] cd Documents
[client-linux@debian11-vm2:~$] lftp srvlan
lftp srvlan:~> get TODO

Retour :

lftp srvlan:~> get TODO
1833 octets transférés                        
lftp srvlan:/> quit

Créez enfin un fichier de test test-ftp-vm2 comme suit :

[client-linux@debian11-vm2:~$] touch test-ftp-vm2
[client-linux@debian11-vm2:~$] echo "Test Upload FTP" > test-ftp-vm2

et testez un envoi FTP dans le dossier public de srvlan :

[client-linux@debian11-vm2:~$] lftp srvlan
lftp srvlan:~> put test-ftp-vm2

Retour :

lftp srvlan:~> put test-ftp-vm2
put: L'accès a échoué : 550 Permission denied. (te...
lftp srvlan:/> quit

Echec normal puisque nous avons plus haut interdit le dépôt anonyme de fichiers.

3.3 - Connexion distante depuis FileZilla

Installez sur debian11-vm2 le client FTP/SFTP FileZilla :

[client-linux@debian11-vm2:~$] sudo apt install filezilla

FileZilla fonctionne en mode passif par défaut.

Ouvrez ensuite l'application graphique :
- Menu Applications > Internet > Icône FileZilla

Cliquez sur l'icône située la plus à gauche de la barre des icônes afin d'ouvrir le Gestionnaire de Sites et cliquez sur le bouton Nouveau site.

Créez un site de nom srvlan-anonymous comme suit :
- Onglet Général

Capture - FileZilla : Réglages généraux FTP Anonymous
FileZilla : Réglages généraux FTP Anonymous

- Onglet Avancé

Capture - FileZilla : Réglages avancés FTP Anonymous
FileZilla : Réglages avancés FTP Anonymous

Une fenêtre Se souvenir des mots de passe ? s'ouvre :
> Cochez Sauvegarder les mots de passe > Valider

Le site srvlan-anonymous est à présent créé. Cliquez sur la flèche située à droite de l'icône du Gestionnaire de Sites et sélectionnez celui-ci.

Une fenêtre Connexion FTP non sécurisée s'ouvre :
> Cochez Toujours autoriser FTP non sécurisé pour ...
> Valider

La connexion s'établit et la zone Site distant doit montrer le contenu du dossier public de srvlan.

Capture - FileZilla : Connexion FTP Anonymous établie
FileZilla : Connexion FTP Anonymous établie

Pour Afficher/Editer les fichiers texte, procédez ainsi :
> Menu Edition de FileZilla > Paramètres...
> Edition des fichiers
> Cochez Utiliser l'éditeur person... > /usr/bin/mousepad
> Cochez Toujours utiliser l'éditeur par défaut
> Valider

Vérifiez à présent que vous pouvez :
- En zone Site local
Télécharger un fichier mais non en Envoyer (Upload).

- En zone Site distant
Afficher/Editer un fichier mais non le Renommer ni le Supprimer.

Cliquez sur l'icône serveur/croix-rouge pour fermer la connexion.

3.4 - Configuration ouvrant l'Upload de fichiers

Choix déconseillé pour raison de sécurité, un anonyme pouvant déposer un fichier infecté.

Créez et affectez un dossier uploads à l'utilisateur ftp :

[srvlan@srvlan:~$] sudo mkdir /srv/ftp/uploads
[srvlan@srvlan:~$] sudo chown ftp:ftp /srv/ftp/uploads

Donnez à l'utilisateur ftp le droit d'écriture sur celui-ci :

[srvlan@srvlan:~$] sudo chmod 755 /srv/ftp/uploads

et retirez lui ce droit sur le dossier racine /srv/ftp/ :

[srvlan@srvlan:~$] sudo chmod 555 /srv/ftp

Editez ensuite le fichier de configuration vsftpd.conf :

[srvlan@srvlan:~$] sudo nano /etc/vsftpd.conf

puis ajustez les paramètres ci-dessous comme suit :

write_enable=YES                                         # Ecriture autorisée
anon_upload_enable=YES                  # Dépôt fichiers autorisé
anon_mkdir_write_enable=YES # Création dossiers autorisée

et ajoutez les 2 lignes suivantes en fin de fichier :

# Permissions affectées au contenu du dossier uploads 
anon_umask=022               # 644 fichiers et 755 dossiers

Pour finir, redémarrez le serveur FTP :

[srvlan@srvlan:~$] sudo systemctl restart vsftpd

3.5 - Test de bon fonctionnement de l'Upload

Accédez au dossier suivant de la VM debian11-vm2 :

client-linux@debian11-vm2:~$] cd /home/client-linux
client-linux@debian11-vm2:~$] cd Documents

et testez le dépôt (upload) suivant avec la Cde lftp :

client-linux@debian11-vm2:~/Documents$ lftp srvlan
lftp srvlan:~> ls
-rw-r--r--    1 0    0      1361 May 02 13:54 README
-rw-r--r--    1 0    0      1833 May 02 13:54 TODO
drwxr-xr-x    2 117  125    4096 May 07 ... uploads
lftp srvlan:/> cd uploads
lftp srvlan:/uploads> put test-ftp-vm2
16 octets transférés
lftp srvlan:/uploads> ls
-rw-r--r--    1 117  125    16 May... test-ftp-vm2
lftp srvlan:/uploads> quit
client-linux@debian11-vm2:~/Documents$

Testez ensuite le dépôt avec l'outil graphique FileZilla.

Vérifiez l'impossibilité de Supprimer, Renommer et Modifier un fichier/dossier déposé dans le dossier uploads.

Vérifiez également l'impossibilité maintenant de réaliser un envoi FTP en dehors du dossier uploads (droits du dossier racine /srv/ftp/ fixés ci-dessus à 555).

4 - Connexions authentifiées d'utilisateurs locaux

4.1 - Accès FTP limité à un dossier commun

C'est par défaut l'utilisateur nobody de Linux qui permet au démon vsftpd d'exécuter ses processus enfants non privilégiés. L'inconvénient est que d'autres démons peuvent également travailler avec cet utilisateur.

Il est donc, par sécurité, conseillé de créer un utilisateur non privilégié dédié au démon vsftpd et de le déclarer dans vsftpd.conf à l'aide du paramètre nopriv_user.

Pour cela, vous allez créer un utilisateur local de nom userftps sans MDP associé, ce qui interdira toute tentative de connexion avec ce nom sur srvlan.

Un dossier /home/ftp/ affecté à cet utilisateur et au groupe grftps servira de racine aux utilisateurs locaux et plus tard aux utilisateurs virtuels.

Créez le dossier/groupe/utilisateur et les permissions :

[srvlan@srvlan:~$] sudo mkdir -p /home/ftp
[srvlan@srvlan:~$] sudo groupadd grftps

[srvlan@srvlan:~$] sudo useradd -g grftps -d /home/ftp userftps

[srvlan@srvlan:~$] sudo chown userftps:grftps /home/ftp
[srvlan@srvlan:~$] sudo chmod 555 /home/ftp

Créez ensuite les utilisateurs locaux clientvm* suivants :

[srvlan@srvlan:~$] sudo adduser clientvm1
[srvlan@srvlan:~$] sudo adduser clientvm2

Un MDP UNIX sera demandé pour chacun d'eux. Vous pouvez utiliser ceux des VM debian11-vm* mais ce n'est pas obligatoire. Vous êtes également libre de répondre ou non aux demandes d'information qui apparaîtront.

Ajoutez les 2 utilisateurs au groupe grftps :

[srvlan@srvlan:~$] sudo adduser clientvm1 grftps
[srvlan@srvlan:~$] sudo adduser clientvm2 grftps

et créez pour ceux-ci le dossier commun_locaux :

[srvlan@srvlan:~$] cd /home/ftp
[srvlan@srvlan:~$] sudo mkdir commun_locaux

[srvlan@srvlan:~$] sudo chown userftps:grftps commun_locaux

[srvlan@srvlan:~$] sudo chmod 775 commun_locaux
[srvlan@srvlan:~$] sudo chmod +t commun_locaux # sticky bit

L'activation du stiky bit interdira aux utilisateurs locaux de Supprimer/Modifier les fichiers situés dans le dossier commun_locaux dont ils ne sont pas propriétaires.

Vérifiez toutes les créations dans /home/ ainsi que le contenu de ces 3 fichiers :

[srvlan@srvlan:~$] sudo cat /etc/group
[srvlan@srvlan:~$] sudo cat /etc/passwd
[srvlan@srvlan:~$] sudo cat /etc/shadow

Editez à présent le fichier de configuration vsftpd.conf :

[srvlan@srvlan:~$] sudo nano /etc/vsftpd.conf

puis ajustez les paramètres suivants comme affichés :

local_enable=YES                          # Accès utilisateur local=YES
write_enable=YES                       # Ecriture utilisateur local=YES
local_umask=022       # 644 fichiers reçus, 755 dossiers reçus
nopriv_user=userftps        # Utilisateur non privilégié de vsftpd
ftpd_banner=Serveur FTP de ...                    # Accueil de vsftpd
chroot_local_user=YES      # Utilisateur local limité à sa racine
secure_chroot_dir=/home/ftp  # Racine utilisateur de userftps

- ftpd_banner : Permet de cacher la version de vsftpd.

et ajoutez ces 3 lignes en fin de fichier :

# Gestion des utilisateurs locaux
local_root=/home/ftp/commun_locaux      # Racine utilisateurs
allow_writeable_chroot=YES     # Ecriture dans racine autorisée

Redémarrez le serveur FTP :

[srvlan@srvlan:~$] sudo systemctl restart vsftpd

Créez la note suivante dans le dossier commun_locaux :

[srvlan@srvlan:~$] cd /home/ftp/commun_locaux
[srvlan@srvlan:~$] sudo nano note-ftps-utilisateurs-locaux

et entrez ce contenu précisant le rôle du dossier :

Ici, dossier FTP dédié aux utilisateurs locaux.

4.2 - Connexion sur le dossier commun

Créez sur le client FileZilla de debian11-vm2 un site de nom srvlan-commun.

Paramétrez celui-ci comme montré ci-dessous :
- Onglet Général

Capture - FileZilla : Création du site FTPS srvlan-commun
FileZilla : Création du site FTPS srvlan-commun

- Onglet Avancé
> Dossier local par défaut > Parcourir...
> Sélectionnez /home/client-linux/Documents
> Valider

Lancez ensuite une connexion FTPS sur le site.

1 ) Traitez le certificat SSL présenté comme suit :

Capture - FileZilla : Certificat SSL émis par le serveur vsftpd
FileZilla : Certificat SSL émis par le serveur vsftpd

2 ) La connexion est établie :

Capture - FileZilla : Connexion sécurisée FTPS établie
FileZilla : Connexion sécurisée FTPS établie

Le transfert FTP doit fonctionner dans les 2 sens.

Mais vous ne devez pas pouvoir, zone Site distant, Supprimer, Renommer et Modifier les fichiers déposés sur srvlan par d'autres utilisateurs, cas du fichier note-ftps-utilisateurs-locaux.

Vous devez en revanche pouvoir lire leur contenu.

Pour finir, créez sur le client FileZilla de debian11-vm1 le site srvlan-commun avec comme utilisateur local clientvm1 et contrôlez après connexion que vous retrouvez bien les mêmes permissions que ci-dessus.

4.3 - Accès FTP à tous les dossiers

Choix déconseillé, l'utilisateur du FTP pouvant accéder à des fichiers sensibles.

La configuration actuelle enferme les utilisateurs locaux tels clientvm* dans le dossier racine commun_locaux, ceux-ci ne peuvent donc pas accéder au dossier parent donc à l'arborescence complète de srvlan.

Ce comportement sécurisé vient de ces paramètres :

chroot_local_user=YES       # Utilisateur local limité à sa racine 
local_root=/home/ftp/commun_locaux                         # Racine

Mais vous pouvez avoir besoin qu'un utilisateur local accède à toute l'arborescence de srvlan ceci avec des permissions différentes de celles de son dossier personnel et du dossier racine commun_locaux.

Editez pour cela le fichier vsftpd.conf :

[srvlan@srvlan:~$] sudo nano /etc/vsftpd.conf

puis décommentez les 2 lignes suivantes :

chroot_list_enable=YES
chroot_list_file=/etc/vsftpd.chroot_list

et redémarrez le serveur FTP :

[srvlan@srvlan:~$] sudo systemctl restart vsftpd

Créez maintenant un utilisateur local de nom indiscret :

[srvlan@srvlan:~$] sudo adduser indiscret

Pour simplifier, donnez lui le MDP indiscret.

Affectez ensuite celui-ci au groupe grftps :

[srvlan@srvlan:~$] sudo adduser indiscret grftps

Pour finir, créez le fichier vsftpd.chroot_list :

[srvlan@srvlan:~$] sudo nano /etc/vsftpd.chroot_list

et entrez l'utilisateur indiscret en début de celui-ci :

indiscret

Si d'autres noms, placez ceux-ci les uns sous les autres.

Créez sur le FileZilla de debian11-vm1 le site srvlan-complet et attribuez lui ces paramètres :

- Onglet Général
> Hôte > srvlan
> Chiffrement > Connexion FTP explicite sur TLS si dis...
> Type d'authentification > Normale
> Identifiant > indiscret
> Mot de passe > indiscret

- Onglet Avancé
> Dossier local par défaut > Parcourir...
> Sélectionnez /home/client-linux/Documents
> Dossier distant par défaut
> Entrez /home/indiscret
> Valider

Lancez une connexion sur le site srvlan-complet :

Capture - FileZilla : Accès complet aux dossiers/fichiers de srvlan
FileZilla : Accès complet aux dossiers/fichiers de srvlan

et vérifiez que rien, en dehors de /home/indiscret/ et /home/ftp/commun_locaux/, ne peut être supprimé ou modifié mais le droit de lire et télécharger tous les fichiers de srvlan représente un risque de sécurité.

5 - Connexions authentifiées d'utilisateurs virtuels

Choix conseillé pour raison de sécurité.

Les utilisateurs virtuels non déclarés avec la Cde adduser seront comme l'utilisateur local userftps inconnus du système mais verront leurs demandes de connexion mappées vers celui-ci, chacun dans leur dossier respectif.

Il s’agit là d’une protection plus efficace que la création d'utilisateurs locaux.

La configuration s’opère en 4 étapes :
- Création d’une Bdd Berkeley utilisateurs virtuels
- Liaison de la Bdd avec le module PAM de vsftpd
- Création des permissions et dossiers des utilisateurs
- Configuration de vsftpd et test de connexion

5.1 - Bdd Berkeley des utilisateurs virtuels

Installez au préalable le paquet db5.3-util :

[srvlan@srvlan:~$] sudo apt install db5.3-util

puis créez ensuite le dossier et le fichier suivants :

[srvlan@srvlan:~$] sudo mkdir /etc/vsftpd
[srvlan@srvlan:~$] sudo touch /etc/vsftpd/virtuels.txt 

Editez le fichier créé virtuels.txt :

[srvlan@srvlan:~$] sudo nano /etc/vsftpd/virtuels.txt

et entrez, l'un sous l'autre, ces utilisateurs et MDP :

clientvm1-virtuel                            # Utilisateur inconnu de srvlan
MDP de clientvm1-virtuel  # ≠ ou non de celui de debian11-vm1
clientvm2-virtuel                            # Utilisateur inconnu de srvlan
MDP de clientvm2-virtuel  # ≠ ou non de celui de debian11-vm2

Terminez la liste par un retour de chariot.

Créez enfin la Bdd virtuels.db pour le module PAM :

[srvlan@srvlan:~$] cd /etc/vsftpd
[srvlan@srvlan:~$] sudo db5.3_load -T -t hash -f virtuels.txt virtuels.db 

et autorisez la lecture des 2 fichiers à root uniquement :

[srvlan@srvlan:~$] sudo chmod 600 /etc/vsftpd/virtuels.db
[srvlan@srvlan:~$] sudo chmod 600 /etc/vsftpd/virtuels.txt 

5.2 - Liaison Bdd avec le module PAM vsftpd

Editez le fichier de configuration PAM suivant :

[srvlan@srvlan:~$] sudo nano /etc/pam.d/vsftpd

et ajoutez, sous # Note : vsftpd..., ces 2 instructions :

auth sufficient /lib/x86_64-linux-gnu/security/pam_userdb.so db=/etc/vsftpd/virtuels

account sufficient /lib/x86_64-linux-gnu/security/pam_userdb.so db=/etc/vsftpd/virtuels

Mettre i386-linux-gnu à la place de x86_64-linux-gnu pour un système 32 bits.

Le module pam_userdb (Pluggable Authentication Modules) vérifiera les authentifications utilisateurs virtuels/MDP avec les valeurs stockées dans la Bdd Berkeley.

5.3 - Permissions et dossiers des utilisateurs

Créez le dossier qui contiendra les permissions :

[srvlan@srvlan:~$] cd /etc/vsftpd
[srvlan@srvlan:~$] sudo mkdir vsftpd_user_conf

Créez le fichier des permissions pour clientvm1-virtuel :

[srvlan@srvlan:~$] cd vsftpd_user_conf
[srvlan@srvlan:~$] sudo nano clientvm1-virtuel

et entrez pour cet utilisateur les permissions suivantes :

# Configuration vsftpd pour l'utilisateur "clientvm1-virtuel"
# Paramétrage pour les mêmes droits qu'un utilisateur local

# Activation de l'utilisateur comme utilisateur virtuel
guest_enable=YES

# Ecriture autorisée
write_enable=YES

# Modification et suppression autorisées
anon_other_write_enable=YES

# Download autorisé même si un fichier
# n'est pas en lecture pour tous
anon_world_readable_only=NO

# Dossier dans lequel sera enfermé l'utilisateur
local_root=/home/ftp/clientvm1-virtuel 

Créez maintenant son dossier personnel :

[srvlan@... ~$] cd /home/ftp
[srvlan@... ~$] sudo mkdir clientvm1-virtuel

[srvlan@... ~$] sudo chown userftps:grftps clientvm1-virtuel
[srvlan@... ~$] sudo chmod 755 clientvm1-virtuel 

Créez une note qui permettra d'identifier le dossier :

[srvlan@srvlan:~$] cd /home/ftp/clientvm1-virtuel
[srvlan@srvlan:~$] sudo nano note-clientvm1-virtuel 

et entrez le texte suivant :

Ici, dossier FTP personnel de "clientvm1-virtuel".

Effectuez les mêmes opérations que ci-dessus pour l'utilisateur virtuel clientvm2-virtuel.

5.4 - Réglage de vsftpd et test de connexion

Editez le fichier de configuration de serveur FTP :

[srvlan@srvlan:~$] sudo nano /etc/vsftpd.conf

et ajoutez les lignes suivantes à la fin de celui-ci :

# Gestion des utilisateurs virtuels
guest_username=userftps     # Valide le mappage vers userftps
user_config_dir=/etc/vsftpd/vsftpd_user_conf # Configurations
virtual_use_local_privs=YES # Mêmes droits utilisateurs locaux

Redémarrez le serveur :

[srvlan@srvlan:~$] sudo systemctl restart vsftpd

Créez depuis FileZilla les sites srvlan-clientvm*-virtuel sur les VM debian11-vm* comme suit :

- Onglet Général
> Hôte > srvlan
> Chiffrement > Connexion FTP explicite sur TLS si dis...
> Type d'authentification > Normale
> Identifiant > clientvm1-virtuel ou clientvm2-virtuel
> Mot de passe > MDP de clientvm1-virtuel ou clientv...

Pour les MDP, voir le § 5.1.

- Onglet Avancé
> Dossier local par défaut > Parcourir...
> Sélectionnez /home/client-linux/Documents
> Valider

Vérifiez après connexion que chaque utilisateur virtuel :
- Peut Transférer des fichiers dans les 2 sens.
- Peut Supprimer/Modifier ses dépôts sur srvlan.
- Reste bien enfermé dans son dossier personnel.

Vérifiez que chaque dossier/fichier déposé sur srvlan est bien mappé sur l'utilisateur userftps :

[srvlan@srvlan:~$] ls -l /home/ftp/clientvm1-virtuel
[srvlan@srvlan:~$] ls -l /home/ftp/clientvm2-virtuel

6 - Configuration préférentielle

En l'état, le serveur FTP accepte les connexions d'utilisateurs anonymes, locaux et virtuels.

Vous l'avez compris, la connexion authentifiée d'utilisateurs virtuels est la plus sécurisée des 3.

Pour ne traiter que celle-ci, appliquez dans vsftpd.conf :

anonymous_enable=NO              # Accès anonyme interdit

Editez ensuite le fichier de configuration PAM :

[srvlan@srvlan:~$] sudo nano /etc/pam.d/vsftpd

et commentez ces 4 lignes dédiées utilisateurs locaux :

# @include common-account
# @include common-session
# @include common-auth
# auth      required      pam_shells.so

La 2ème ligne de ce fichier fait référence au fichier /etc/ftpusers. Pour info, celui-ci contient une liste par défaut d'utilisateurs locaux n'ayant pas le droit de se connecter sur le service FTP.

On pourrait encore augmenter la sécurité (changement de n° de port FTP, filtrage IP, adresses IP virtuelles, etc...) mais la connexion authentifiée d'utilisateurs virtuels est un bon début.

Image - Rédacteur satisfait


Repos mérité, respirez !
Le mémento 10.11 propose de rendre
le réseau plus cohérent avec entre
autres la création d'un DNS split.

Laisser un commentaire