Outils pour utilisateurs

Outils du site


informatique:linux:proftpd

Ceci est une ancienne révision du document !


PROFTPD

Installation

Installer les paquetages pré-requis à la compilation de proftpd :

  • gcc-4.1.2-44.el5.i386.rpm
  • cpp-4.1.2-44.el5.i386.rpm
  • glibc-devel-2.5-34.i386.rpm
  • glibc-headers-2.5-34.i386.rpm
  • libgomp-4.3.2-7.el5.i386.rpm
  • kernel-headers-2.6.18-128.el5.i386.rpm
  • gcc-c++-4.1.2-44.el5.i386.rpm
  • libstdc++-devel-4.1.2-44.el5.i386.rpm
  • openssl-devel-0.9.8e-7.el5.i386.rpm
  • krb5-devel-1.6.1-31.el5.i386.rpm
  • zlib-devel-1.2.3-3.i386.rpm
  • e2fsprogs-devel-1.39-20.el5.i386.rpm
  • keyutils-libs-devel-1.2-1.el5.i386.rpm
  • libselinux-devel-1.33.4-5.1.el5.i386.rpm
  • libsepol-devel-1.15.2-1.el5.i386.rpm
  • mysql-5.0.45-7.el5.i386.rpm
  • perl-DBI-1.52-2.el5.i386.rpm
  • mysql-devel-5.0.45-7.el5.i386.rpm

Récupérer l'archive de proftpd sur http://www.proftpd.org

Décompresser l'archive :

cd /root
tar xzf proftpd-1.3.2rc4.tar.gz

Installation et compilation de proftpd :

cd /ap01/ftpserver/src/proftpd-1.3.2rc4
CFLAGS=-DHAVE_OPENSSL LIBS=-lcrypto
./configure --prefix=/ap01/ftpserver/appl/proftpd --sysconfdir=/ap01/ftpserver/appl/proftpd/etc --localstatedir=/ap01/ftpserver/appl/proftpd/var  --with-modules=mod_tls:mod_sql:mod_sql_mysql --with-includes=/usr/include/mysql:/usr/include/openssl --with-libraries=/usr/lib/mysql:/usr/lib/openssl
make clean
make
make install

Configuration

Configuration basic

Exemple d'options pour sécuriser et optimiser le serveur FTP

# Permet de cloisonner les utilisateurs dans leur répertoire :
DefaultRoot ~
# L'utilisateur FTP n'est pas obligé d'avoir un SHELL valide (telque bash, ksh etc...) pour se connecter 
RequireValidShell               no
# Evite les requetes DNS du serveur et permet donc une authentification plus rapide
IdentLookups                    off
UseReverseDNS                   off
# Permet de définir la plage de ports pour les connexion passive
# Plage de port à laisser passer par le FireWall
PassivePorts 49152 49500

Configuration avec SSL

Générer le certificat

Se positionner dans le répertoire de configuration de proftpd :

cd /usr/local/proftpd/etc

Pour générer le certificat voir : Créer un certificat SSL avec OpenSSL

Configuration

Ajouter les lignes suivantes dans le fichier de configuration /usr/local/proftpd/etc/proftpd.conf :

<IfModule mod_tls.c>
  TLSEngine on
  TLSLog /var/ftpd/tls.log

  # Support both SSLv3 and TLSv1
  TLSProtocol SSLv3 TLSv1

  # Are clients required to use FTP over TLS when talking to this server?
  TLSRequired on
  
  # Mettre TLSRequired off pour autoriser également les connexions non sécurisées.

  # Server's certificate
  TLSRSACertificateFile /usr/local/proftpd/etc/server.crt
  TLSRSACertificateKeyFile /usr/local/proftpd/etc/server.key

  # CA the server trusts
  #TLSCACertificateFile /etc/ftpd/root.cert.pem

  # Authenticate clients that want to use FTP over TLS?
  TLSVerifyClient off

  # Allow SSL/TLS renegotiations when the client requests them, but
  # do not force the renegotations.  Some clients do not support
  # SSL/TLS renegotiations; when mod_tls forces a renegotiation, these
  # clients will close the data connection, or there will be a timeout
  # on an idle data connection.
  TLSRenegotiate required off

</IfModule>

Cette configuration oblige une connexion sécurisée au client.

Tester

Lancer la commande suivante pour tester :

openssl s_client -connect 127.0.0.1:21 -starttls ftp

Pour tester avec un client sous linux :

# lftp 127.0.0.1
lftp 127.0.0.1:~> set ftp:ssl-force true
lftp 127.0.0.1:~> user userftp
Mot de passe:

Liste des client FTPS et FTPES

Configuration avec Mysql

Pour activer proftpd avec Mysql et authentifier les utilisateurs avec un compte de la base de données

AuthOrder       mod_sql.c mod_auth_unix.c
SQLEngine on
SQLBackend mysql
SQLAuthenticate user

# Indique le type de mot de passe s'il est clair ou chiffré choix : Plaintext Crypt OpenSSL
SQLAuthTypes OpenSSL

# Auth base Mysql
SQLConnectInfo proftpd@mysqlserver:4020 proftpd password

# SQLUserInfo [ user-table user-name passwd uid gid home-dir shell]
SQLUserInfo users username password uid gid homedir shell

# Activation ou non du compte
#SQLUserWhereClause "LoginAllowed = 'true'"

# Evite affichage nom compte systeme
SQLMinUserUID 700
SQLMinUserGID 700

# Mise a jour droits pendant la session
SQLNegativeCache on

Si le mode OpenSSL est choisi pour la directive SQLAuthTypes le chiffrement du mot de passe se fera par exemple ainsi :

/bin/echo "{sha256}"$(/bin/echo -n "secret" | openssl dgst -binary -sha256 | openssl enc -base64)

Le résultat de la commande doit être inséré dans le champs mot de passe de la base.

Exemple de configuration pour logguer l'activité dans la base :

SQLNamedQuery R SELECT "max(NbReboot) from reboot"
SQLLog PASS,ERR_PASS updatecount
SQLNamedQuery updatecount UPDATE "count=count+1 WHERE username='%u'" users
SQLLog RETR,ERR_RETR emissions
SQLNamedQuery emissions INSERT "'','%u',now(),now(), '%h','%f', %b,'%r','%s',%P,%R" emissions
SQLLog STOR,ERR_STOR receptions
SQLNamedQuery receptions INSERT "'','%u',now(),now(), '%h','%f', %b,'%r','%s',%P,%R" receptions
SQLLog PASS,ERR_PASS debutconnexions
SQLNamedQuery debutconnexions INSERT "'','%u',now(),now(),NULL,NULL, '%h','%r','%s',%P,%R" connexions
SQLLog EXIT,ERR_EXIT finconnexions
SQLNamedQuery finconnexions UPDATE "DateFinConn=now(),HFinConn=now(), CommandConn='%r', CodeConn='%s' WHERE IdFtpd='%P' AND NbReboot='%R'"   connexions
SQLLog MKD,ERR_MKD creationsr
SQLNamedQuery creationsr INSERT "'','%u',now(),now(), '%h','%f','%r','%s',%P,%R" creationsr
SQLLog RMD,ERR_RMD suppressionsr
SQLNamedQuery suppressionsr INSERT "'','%u',now(),now(), '%h','%f','%r','%s',%P,%R" suppressionsr
SQLLog DELE,ERR_DELE suppressionsf
SQLNamedQuery suppressionsf INSERT "'','%u',now(),now(), '%h','%f','%r','%s',%P,%R" suppressionsf
SQLLog RNTO,ERR_RNTO renames
SQLNamedQuery renames INSERT "'','%u',now(),now(), '%h','%f','%r','%s',%P,%R" renames
informatique/linux/proftpd.1237456761.txt.gz · Dernière modification: 2018/09/06 18:59 (modification externe)