Voy a comentar cuatro sencillos pasos para montar el ya archiconocido ProFTPd con autenticación y quotas de espacio por MySQL. La verdad es que tenía el gusanillo de montarlo como prueba, para uso personal y quizá como un servicio que poder ofrecer. Cada vez vamos más hacia servicios permanentes, de no depender en exceso de hardware propio y más de servicios externos, como podría ser un FTP.
Primero, para bajarnos el software de ProFTPd necesitamos un repositorio adicional para CentOS, editamos el fichero de yum y añadimos lo siguiente:
1 | <strong># vim /etc/yum.repos.d/CentOS-Base.repo</strong> |
1 2 3 4 5 6 7 8 9 10 11 | # Name: RPMforge RPM Repository for Red Hat Enterprise 5 - dag # URL: http://rpmforge.net/ [RHEL5-rpmforge] name = Red Hat Enterprise 5 - RPMforge.net - dag #baseurl = http://apt.sw.be/redhat/el5/en/i386/dag mirrorlist = http://apt.sw.be/redhat/el5/en/mirrors-rpmforge #mirrorlist = file:///etc/yum.repos.d/mirrors-rpmforge enabled = 1 protect = 0 #gpgkey = file:///etc/pki/rpm-gpg/RPM-GPG-KEY-rpmforge-dag gpgcheck = 0 |
Instalamos mysql y mysq-server. También necesitamos apache y php para la gestión de la BD con phpmyAdimin
1 2 | <strong># yum install mysql mysql-server php php-mysql httpd proftpd-mysql </strong> |
Bajamos el software de phpmyadmin y ya lo tenemos todo.
1 2 | <strong># wget http://heanet.dl.sourceforge.net/sourceforge/phpmyadmin/ phpMyAdmin-2.11.9.2-all-languages.tar.gz</strong> |
Añadimos usuario y grupo de sistema
1 2 3 4 5 | <strong> # groupadd -g 2008 ftpgroup # useradd -u 2008 -s /bin/false -d /bin/null -c "usuario proftpd" -g ftpgroup ftpuser </strong> |
Damos un password de root a la BD
1 | <strong># mysqladmin -u root password tupassworderoooot</strong> |
Accedemos por shell a la BD
1 2 3 4 5 6 7 8 9 | # mysql -uroot -p # mysql> create database ftp; # mysql> GRANT SELECT, INSERT, UPDATE, DELETE ON ftp.* TO 'proftpd'@'localhost' IDENTIFIED BY 'password'; # mysql> use ftp; # mysql> CREATE TABLE ftpgroup ( groupname varchar(16) NOT NULL default '', gid smallint(6) NOT NULL default '5500', members varchar(16) NOT NULL default '', KEY groupname (groupname)) TYPE=MyISAM COMMENT='ProFTP group table'; |
1 2 3 4 5 6 7 8 9 10 | # mysql> CREATE TABLE ftpquotalimits ( name varchar(30) default NULL, quota_type enum('user','group','class','all') NOT NULL default 'user', per_session enum('false','true') NOT NULL default 'false', limit_type enum('soft','hard') NOT NULL default 'soft', bytes_in_avail int(10) unsigned NOT NULL default '0', bytes_out_avail int(10) unsigned NOT NULL default '0', bytes_xfer_avail int(10) unsigned NOT NULL default '0', files_in_avail int(10) unsigned NOT NULL default '0', files_out_avail int(10) unsigned NOT NULL default '0', files_xfer_avail int(10) unsigned NOT NULL default '0') TYPE=MyISAM; |
1 2 3 4 5 6 7 8 | # mysql> CREATE TABLE ftpquotatallies ( name varchar(30) NOT NULL default '', quota_type enum('user','group','class','all') NOT NULL default 'user', bytes_in_used int(10) unsigned NOT NULL default '0', bytes_out_used int(10) unsigned NOT NULL default '0', bytes_xfer_used int(10) unsigned NOT NULL default '0', files_in_used int(10) unsigned NOT NULL default '0', files_out_used int(10) unsigned NOT NULL default '0', files_xfer_used int(10) unsigned NOT NULL default '0') TYPE=MyISAM; |
1 2 3 4 5 6 7 8 9 10 11 | # mysql> CREATE TABLE ftpuser ( id int(10) unsigned NOT NULL auto_increment, userid varchar(32) NOT NULL default '', passwd varchar(32) NOT NULL default '', uid smallint(6) NOT NULL default '5500', gid smallint(6) NOT NULL default '5500', homedir varchar(255) NOT NULL default '', shell varchar(16) NOT NULL default '/sbin/nologin', count int(11) NOT NULL default '0', accessed datetime NOT NULL default '0000-00-00 00:00:00', modified datetime NOT NULL default '0000-00-00 00:00:00', PRIMARY KEY (id),UNIQUE KEY userid (userid)) TYPE=MyISAM COMMENT='ProFTP user table'; |
Ya tenemos preparada la BD para la gestión de los usuarios FTP, ahora hay que configurar ProFTPd. Editamos el fichero de configuracion de Proftpd, hemos de cambiar el password por el password del usurio mysql que hemos creado.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | [...] # SQL authentication Dynamic Shared Object (DSO) loading # See README.DSO and howto/DSO.html for more details. LoadModule mod_sql.c LoadModule mod_sql_mysql.c LoadModule mod_quotatab.c LoadModule mod_quotatab_sql.c # The passwords in MySQL are encrypted using CRYPT SQLAuthTypes Plaintext Crypt SQLAuthenticate users groups # used to connect to the database # databasename@host database_user user_password SQLConnectInfo ftp@localhost proftpd password < --- cambiar!! # Here we tell ProFTPd the names of the database columns in the "usertable" # we want it to interact with. Match the names with those in the db SQLUserInfo ftpuser userid passwd uid gid homedir shell # Here we tell ProFTPd the names of the database columns in the "grouptable" # we want it to interact with. Again the names match with those in the db SQLGroupInfo ftpgroup groupname gid members # set min UID and GID - otherwise these are 999 each SQLMinID 500 # create a user's home directory on demand if it doesn't exist SQLHomedirOnDemand on # Update count every time user logs in SQLLog PASS updatecount SQLNamedQuery updatecount UPDATE "count=count+1, accessed=now() WHERE userid='%u'" ftpuser # Update modified everytime user uploads or deletes a file SQLLog STOR,DELE modified SQLNamedQuery modified UPDATE "modified=now() WHERE userid='%u'" ftpuser # User quotas # =========== QuotaEngine on QuotaDirectoryTally on QuotaDisplayUnits Mb QuotaShowQuotas on SQLNamedQuery get-quota-limit SELECT "name, quota_type, per_session, limit_type, bytes_in_avail, bytes_out_avail, bytes_xfer_avail, files_in_avail, files_out_avail, files_xfer_avail FROM ftpquotalimits WHERE name = '%{0}' AND quota_type = '%{1}'" SQLNamedQuery get-quota-tally SELECT "name, quota_type, bytes_in_used, bytes_out_used, bytes_xfer_used, files_in_used, files_out_used, files_xfer_used FROM ftpquotatallies WHERE name = '%{0}' AND quota_type = '%{1}'" SQLNamedQuery update-quota-tally UPDATE "bytes_in_used = bytes_in_used + %{0}, bytes_out_used = bytes_out_used + %{1}, bytes_xfer_used = bytes_xfer_used + %{2}, files_in_used = files_in_used + %{3}, files_out_used = files_out_used + %{4}, files_xfer_used = files_xfer_used + %{5} WHERE name = '%{6}' AND quota_type = '%{7}'" ftpquotatallies SQLNamedQuery insert-quota-tally INSERT "%{0}, %{1}, %{2}, %{3}, %{4}, %{5}, %{6}, %{7}" ftpquotatallies QuotaLimitTable sql:/get-quota-limit QuotaTallyTable sql:/get-quota-tally/update-quota-tally/insert-quota-tally RootLogin off RequireValidShell off [...] |
He tenido que poner saltos de línea en las variables de SQL, tenlo en cuenta. Ahora toca reiniciar el servicio para hacer efectivos los cambios
1 | <strong># /etc/init.d/proftpd restart</strong> |
Añadimos ahora un usuario de ejemplo, para añadirlo, hemos de conectarnos al MySQL por shell o phpmyadmin ![]()
1 | # mysql -u root -p |
# USE ftp;
Primero creamos una fila en la tabla ftpgroup. Esta contiene el nombre del grupo, el id del grupo y el usuario ftp de sistema que hemos creado anteriormente.
1 2 | # INSERT INTO `ftpgroup` (`groupname`, `gid`, `members`) VALUES ('ftpgroup', 2008, 'ftpuser'); |
Ahora, siempre que queramos añadir un nuevo usuario, sólo habremos de modificar dos tablas, ftpquotalimits y ftpuser. El usuario de ejemplo se llama pepe y tiene una restricción de 1 GB(en bytes).
1 2 3 4 | # mysql> INSERT INTO `ftpquotalimits` (`name`, `quota_type`, `per_session`, `limit_type`, `bytes_in_avail`, `bytes_out_avail`, `bytes_xfer_avail`, `files_in_avail`, `files_out_avail`, `files_xfer_avail`) VALUES ('pepe', 'user', 'true', 'hard', 1073741824, 0, 0, 0, 0, 0); |
1 2 3 4 | # mysql> INSERT INTO `ftpuser` (`id`, `userid`, `passwd`, `uid`, `gid`, `homedir`, `shell`, `count`, `accessed`, `modified`) VALUES (1, 'pepe', 'secret', 2008, 2008, '/home/pepe', '/sbin/nologin', 0, '', ''); |
1 | #mysql> quit; |
Hola.
Muchísimas gracias por este post, gracias a ti he podido instalar el maldito proftpd en un CentOs 5 después de 3 horas buscando la última versión.
Gracias, mil gracias.
Javier.
Saludos gracias por el tuto, lei que había un problema al momento de arrancar el PROFTPD por esto ‘SQLHomedirOnDemand’ on line 93 of ‘/etc/proftpd.conf’ queria saber si puedes hacer un mini manual para crear el directorio home porque por mas que leo la solucion del fabricante (asi es creo) no le entiendo y estoy barado con este ftp
muchas gracias
Quisiera añadir la ruta /etc/www/html para subir los archivos de un sitio Web, pero los usuarios creados no me dejan acceder a tal directorio, y no lo veo desde ftp. ¿Alguna sugerencia?