# TODO
# - mod_caps uses uname -r for detection
+# - don't use internal libltdl
+# - package contrib/ftp* perl scripts.
+#
# Conditional build:
%bcond_without pam # disable PAM support
%bcond_without ipv6 # disable IPv6 and TCPD support
%bcond_without ssl # disbale TLS/SSL support
-%bcond_without ldap # enable LDAP support
-%bcond_without mysql # enable MySQL support
-%bcond_without pgsql # enable PostgreSQL support
-%bcond_without quotafile # enable quota file support
-%bcond_without quotaldap # enable quota ldap support
-%bcond_without quotamysql # enable quota mysql support
-%bcond_without quotapgsql # enable quota pgsql support
+%bcond_without ldap # disable LDAP support
+%bcond_without mysql # disable MySQL support
+%bcond_without pgsql # disable PostgreSQL support
+%bcond_without quotafile # disable quota file support
+%bcond_without quotaldap # disable quota ldap support
+%bcond_without quotamysql # disable quota mysql support
+%bcond_without quotapgsql # disable quota pgsql support
#
+%define mod_clamav_version 0.11rc
+
Summary: PROfessional FTP Daemon with apache-like configuration syntax
-Summary(es): Servidor FTP profesional, con sintaxis de configuración semejante a la del apache
-Summary(pl): PROfesionalny serwer FTP
-Summary(pt_BR): Servidor FTP profissional, com sintaxe de configuração semelhante à do apache
-Summary(zh_CN): Ò×ÓÚ¹ÜÀíµÄ,°²È«µÄ FTP ·þÎñÆ÷
+Summary(es.UTF-8): Servidor FTP profesional, con sintaxis de configuración semejante a la del apache
+Summary(pl.UTF-8): PROfesionalny serwer FTP
+Summary(pt_BR.UTF-8): Servidor FTP profissional, com sintaxe de configuração semelhante à do apache
+Summary(zh_CN.UTF-8): 易于管理的,安全的 FTP 服务器
Name: proftpd
-Version: 1.3.0
+Version: 1.3.4
Release: 1
-Epoch: 1
+Epoch: 2
License: GPL v2+
-Group: Daemons
+Group: Networking/Daemons
Source0: ftp://ftp.proftpd.org/distrib/source/%{name}-%{version}.tar.bz2
-# Source0-md5: fae47d01b52e035eb6b7190e74c17722
-Source1: %{name}.conf
+# Source0-md5: 7734142c7fa7212ab9f188a617a4be87
+Source1: https://secure.thrallingpenguin.com/redmine/attachments/download/1/mod_clamav-%{mod_clamav_version}.tar.gz
+# Source1-md5: 42e560ec0bd5964e13fad1b2bb7afe21
+Source2: %{name}.conf
Source3: ftp.pamd
Source4: %{name}.inetd
Source5: %{name}.sysconfig
Source9: %{name}-mod_pam.conf
Source10: %{name}-mod_tls.conf
Source11: %{name}-anonftp.conf
-Patch0: %{name}-umode_t.patch
-Patch1: %{name}-glibc.patch
-Patch2: %{name}-paths.patch
-Patch3: %{name}-noautopriv.patch
-Patch4: %{name}-wtmp.patch
-Patch5: %{name}-sendfile64.patch
-Patch6: %{name}-configure.patch
+Source12: %{name}-mod_clamav.conf
+Patch0: %{name}-paths.patch
+Patch1: %{name}-noautopriv.patch
+Patch2: %{name}-wtmp.patch
+Patch3: %{name}-pool.patch
+Patch4: %{name}-link.patch
URL: http://www.proftpd.org/
+BuildRequires: acl-devel
BuildRequires: autoconf
BuildRequires: automake
+BuildRequires: libcap-devel
+BuildRequires: libstdc++-devel
BuildRequires: libwrap-devel
%if %{with mysql} || %{with quotamysql}
BuildRequires: mysql-devel
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
%define _sysconfdir /etc/ftpd
-%define _localstatedir /var/run
+%define _localstatedir /var/run
%define _libexecdir %{_prefix}/%{_lib}/%{name}
%description
-ProFTPD is a highly configurable FTP daemon for unix and unix-like
+ProFTPD is a highly configurable FTP daemon for Unix and Unix-like
operating systems. ProFTPD is designed to be somewhat of a "drop-in"
replacement for wu-ftpd. Full online documentation is available at
<http://www.proftpd.org/>, including a server configuration directive
reference manual.
-%description -l es
+%description -l es.UTF-8
ProFTPD es un servidor FTP altamente configurable para sistemas
-operativos unix. Está proyectado para ser un substituto directo al
-wu-ftpd. La documentación completa está disponible en
+operativos Unix. Está proyectado para ser un substituto directo al
+wu-ftpd. La documentación completa está disponible en
<http://www.proftpd.org/>, incluido el manual de referencia para las
-directivas de configuración del servidor.
+directivas de configuración del servidor.
-%description -l pl
-ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
-ProFTPD jest robiony jako bezpo¶redni zamiennik wu-ftpd. Pe³na
-dokumentacja jest dostêpna on-line pod <http://www.proftpd.org/>
-w³±cznie z dokumentacj± dotycz±c± konfigurowania.
+%description -l pl.UTF-8
+ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
+ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
+dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
+włącznie z dokumentacją dotyczącą konfigurowania.
-%description -l pt_BR
-O ProFTPD é um servidor FTP altamente configurável para sistemas
-operacionais unix.
+%description -l pt_BR.UTF-8
+O ProFTPD é um servidor FTP altamente configurável para sistemas
+operacionais Unix.
-É projetado para ser um substituto direto para o wu-ftpd. A
-documentação completa está disponível em <http://www.proftpd.org/>,
-incluindo o manual de referência para as diretivas de configuração do
+É projetado para ser um substituto direto para o wu-ftpd. A
+documentação completa está disponível em <http://www.proftpd.org/>,
+incluindo o manual de referência para as diretivas de configuração do
servidor.
%package common
Summary: PROfessional FTP Daemon with apache-like configuration syntax - common files
-Summary(pl): PROfesionalny serwer FTP - wspólne pliki
-Group: Daemons
+Summary(pl.UTF-8): PROfesionalny serwer FTP - wspólne pliki
+Group: Networking/Daemons
Requires(post): awk
Requires(post): fileutils
Obsoletes: proftpd < 0:1.2.2rc1-3
%description common
-ProFTPD is a highly configurable FTP daemon for unix and unix-like
+ProFTPD is a highly configurable FTP daemon for Unix and Unix-like
operating systems. ProFTPD is designed to be somewhat of a "drop-in"
replacement for wu-ftpd. Full online documentation is available at
<http://www.proftpd.org/>, including a server configuration directive
reference manual.
-%description common -l es
+%description common -l es.UTF-8
ProFTPD es un servidor FTP altamente configurable para sistemas
-operativos unix. Está proyectado para ser un substituto directo al
-wu-ftpd. La documentación completa está disponible en
+operativos Unix. Está proyectado para ser un substituto directo al
+wu-ftpd. La documentación completa está disponible en
<http://www.proftpd.org/>, incluido el manual de referencia para las
-directivas de configuración del servidor.
+directivas de configuración del servidor.
-%description common -l pl
-ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
-ProFTPD jest robiony jako bezpo¶redni zamiennik wu-ftpd. Pe³na
-dokumentacja jest dostêpna on-line pod <http://www.proftpd.org/>
-w³±cznie z dokumentacj± dotycz±c± konfigurowania.
+%description common -l pl.UTF-8
+ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
+ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
+dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
+włącznie z dokumentacją dotyczącą konfigurowania.
-%description common -l pt_BR
-O ProFTPD é um servidor FTP altamente configurável para sistemas
-operacionais unix.
+%description common -l pt_BR.UTF-8
+O ProFTPD é um servidor FTP altamente configurável para sistemas
+operacionais Unix.
-É projetado para ser um substituto direto para o wu-ftpd. A
-documentação completa está disponível em <http://www.proftpd.org/>,
-incluindo o manual de referência para as diretivas de configuração do
+É projetado para ser um substituto direto para o wu-ftpd. A
+documentação completa está disponível em <http://www.proftpd.org/>,
+incluindo o manual de referência para as diretivas de configuração do
servidor.
%package inetd
Summary: inetd configs for proftpd
-Summary(pl): Pliki konfiguracyjne do u¿ycia proftpd poprzez inetd
-Group: Daemons
+Summary(pl.UTF-8): Pliki konfiguracyjne do użycia proftpd poprzez inetd
+Group: Networking/Daemons
Requires(post): fileutils
Requires(post): grep
Requires(post): sed >= 4.0
Obsoletes: ftpserver
Obsoletes: glftpd
Obsoletes: heimdal-ftpd
+Obsoletes: krb5-ftpd
Obsoletes: linux-ftpd
Obsoletes: muddleftpd
Obsoletes: proftpd-standalone
%description inetd
ProFTPD configs for running from inetd.
-%description inetd -l pl
+%description inetd -l pl.UTF-8
Pliki konfiguracyjna ProFTPD do startowania demona poprzez inetd.
%package standalone
Summary: Standalone daemon configs for proftpd
-Summary(pl): Pliki konfiguracyjne do startowania proftpd w trybie standalone
-Group: Daemons
+Summary(pl.UTF-8): Pliki konfiguracyjne do startowania proftpd w trybie standalone
+Group: Networking/Daemons
Requires(post): fileutils
Requires(post): grep
Requires(post): sed >= 4.0
Obsoletes: ftpserver
Obsoletes: glftpd
Obsoletes: heimdal-ftpd
+Obsoletes: krb5-ftpd
Obsoletes: linux-ftpd
Obsoletes: muddleftpd
Obsoletes: proftpd-inetd
%description standalone
ProFTPD configs for running as a standalone daemon.
-%description standalone -l pl
+%description standalone -l pl.UTF-8
Pliki konfiguracyjne ProFTPD do startowania demona w trybie
standalone.
%package devel
Summary: Header files ProFTPD
-Summary(pl): Pliki nag³ówkowe ProFTPD
+Summary(pl.UTF-8): Pliki nagłówkowe ProFTPD
Group: Development/Libraries
+Requires: acl-devel
%description devel
This is the package containing the header files for ProFTPD.
-%description devel -l pl
-Ten pakiet zawiera pliki nag³ówkowe ProFTPD
+%description devel -l pl.UTF-8
+Ten pakiet zawiera pliki nagłówkowe ProFTPD
%package anonftp
Summary: Anonymous FTP config for ProFTPD
-Summary(pl): Konfiguracja anonimowego FTP dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Konfiguracja anonimowego FTP dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
%description anonftp
Anonymous FTP config for ProFTPD.
-%description anonftp -l pl
+%description anonftp -l pl.UTF-8
Konfiguracja anonimowego FTP dla ProFTPD.
%package mod_auth_pam
Summary: ProFTPD PAM auth module
-Summary(pl): Modu³ uwierzytelnienia PAM dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Moduł uwierzytelnienia PAM dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
Requires: pam >= 0.79.0
%description mod_auth_pam
PAM authentication method for ProFTPD.
-%description mod_auth_pam -l pl
+%description mod_auth_pam -l pl.UTF-8
Metoda uwierzytelnienia PAM dla ProFTPD.
%package mod_ldap
Summary: ProFTPD OpenLDAP module
-Summary(pl): Modu³ OpenLDAP dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Moduł OpenLDAP dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
%description mod_ldap
many features useful in "toaster" environments such as default UID/GID
and autocreation/autogeneration of home directories.
-%description mod_ldap -l pl
-mod_ldap dodaje obs³ugê uwierzytelnienia LDAP do ProFTPD. Obs³uguje
-wiele cech przydatnych w ¶rodowiskach "tosterowych", takich jak
-domy¶lny UID/GID i automatyczne tworzenie/generowanie katalogów
+%description mod_ldap -l pl.UTF-8
+mod_ldap dodaje obsługę uwierzytelnienia LDAP do ProFTPD. Obsługuje
+wiele cech przydatnych w środowiskach "tosterowych", takich jak
+domyślny UID/GID i automatyczne tworzenie/generowanie katalogów
domowych.
%package mod_quotatab
Summary: ProFTPD quotatab module
-Summary(pl): Modu³ quotatab dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Moduł quotatab dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
%description mod_quotatab
A module for managing FTP byte/file quotas via centralized tables.
-%description mod_quotatab -l pl
-Modu³ do zarz±dzania ograniczeniami bajtów/plików FTP poprzez
+%description mod_quotatab -l pl.UTF-8
+Moduł do zarządzania ograniczeniami bajtów/plików FTP poprzez
scentralizowane tabele.
%package mod_quotatab_file
Summary: ProFTPD quotatab file module
-Summary(pl): Modu³ quotatab_file dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Moduł quotatab_file dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
A mod_quotatab sub-module for managing quota data via file-based
tables.
-%description mod_quotatab_file -l pl
-Podmodu³ mod_quotatab do zarz±dzania danymi o ograniczeniach poprzez
+%description mod_quotatab_file -l pl.UTF-8
+Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
tabele zapisane w pliku.
%package mod_quotatab_ldap
Summary: ProFTPD quotatab ldap module
-Summary(pl): Modu³ quotatab_ldap dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Moduł quotatab_ldap dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
Requires: %{name}-mod_ldap = %{epoch}:%{version}-%{release}
Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
A mod_quotatab sub-module for obtaining quota information from an LDAP
directory.
-%description mod_quotatab_ldap -l pl
-Podmodu³ mod_quotatab do pobierania informacji o ograniczeniach z
+%description mod_quotatab_ldap -l pl.UTF-8
+Podmoduł mod_quotatab do pobierania informacji o ograniczeniach z
katalogu LDAP.
%package mod_quotatab_sql
Summary: ProFTPD quotatab sql module
-Summary(pl): Modu³ quotatab_sql dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Moduł quotatab_sql dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
A mod_quotatab sub-module for managing quota data via SQL-based
tables.
-%description mod_quotatab_sql -l pl
-Podmodu³ mod_quotatab do zarz±dzania danymi o ograniczeniach poprzez
+%description mod_quotatab_sql -l pl.UTF-8
+Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
tabele SQL.
%package mod_ratio
Summary: ProFTPD ratio module
-Summary(pl): Modu³ ratio dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Moduł ratio dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
%description mod_ratio
Support upload/download ratios.
-%description mod_ratio -l pl
-Obs³uga wspó³czynników upload/download.
+%description mod_ratio -l pl.UTF-8
+Obsługa współczynników upload/download.
%package mod_readme
Summary: ProFTPD readme module
-Summary(pl): Modu³ readme dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Moduł readme dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
%description mod_readme
"README" file support.
-%description mod_readme -l pl
-Obs³uga pliku "README".
+%description mod_readme -l pl.UTF-8
+Obsługa pliku "README".
+
+%package mod_rewrite
+Summary: ProFTPD rewrite module
+Summary(pl.UTF-8): Moduł rewrite dla ProFTPD
+Group: Networking/Daemons
+Requires: %{name}-common = %{epoch}:%{version}-%{release}
+
+%description mod_rewrite
+Runtime rewrite engine.
+
+%description mod_rewrite -l pl.UTF-8
+Silnik przepisujący adresy w locie.
%package mod_sql
Summary: ProFTPD SQL support module
-Summary(pl): Modu³ obs³ugi SQL dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Moduł obsługi SQL dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
%description mod_sql
This module provides the necessary support for SQL based
authentication, logging and other features as required.
-%description mod_sql -l pl
-Ten modu³ dodaje obs³ugê SQL potrzebn± do uwierzytelniania, logowania
-i innych mo¿liwo¶ci opartych o SQL.
+%description mod_sql -l pl.UTF-8
+Ten moduł dodaje obsługę SQL potrzebną do uwierzytelniania, logowania
+i innych możliwości opartych o SQL.
%package mod_sql_mysql
Summary: ProFTPD sql mysql module
-Summary(pl): Modu³ sql_mysql dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Moduł sql_mysql dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
%description mod_sql_mysql
Support for connecting to MySQL databases.
-%description mod_sql_mysql -l pl
-Obs³uga ³±czenia siê z bazami danych MySQL.
+%description mod_sql_mysql -l pl.UTF-8
+Obsługa łączenia się z bazami danych MySQL.
%package mod_sql_postgres
Summary: ProFTPD sql postgres module
-Summary(pl): Modu³ sql_postgres dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Moduł sql_postgres dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
%description mod_sql_postgres
Support for connecting to PostgreSQL databases.
-%description mod_sql_postgres -l pl
-Obs³uga ³±czenia siê z bazami danych PostgreSQL.
+%description mod_sql_postgres -l pl.UTF-8
+Obsługa łączenia się z bazami danych PostgreSQL.
%package mod_tls
Summary: ProFTPD TLS support
-Summary(pl): Obs³uga TLS dla ProFTPD
-Group: Daemons
+Summary(pl.UTF-8): Obsługa TLS dla ProFTPD
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
%description mod_tls
An RFC2228 SSL/TLS module for ProFTPD.
-%description mod_tls -l pl
-Modu³ SSL/TLS zgodny z RFC2228 dla ProFTPD.
+%description mod_tls -l pl.UTF-8
+Moduł SSL/TLS zgodny z RFC2228 dla ProFTPD.
%package mod_wrap
Summary: ProFTPD interface to libwrap
-Summary(pl): Interfejs ProFTPD do libwrap
-Group: Daemons
+Summary(pl.UTF-8): Interfejs ProFTPD do libwrap
+Group: Networking/Daemons
Requires: %{name}-common = %{epoch}:%{version}-%{release}
Requires: libwrap
program does this, for example: when illegal access is attempted, it
will add hosts to the /etc/hosts.deny file.
-%description mod_wrap -l pl
-Ten pakiet pozwala demonowi u¿ywaæ wspólnej biblioteki kontroli
-dostêpu tcpwrappers w trybie samodzielnym w bardzo wygodny sposób.
+%description mod_wrap -l pl.UTF-8
+Ten pakiet pozwala demonowi używać wspólnej biblioteki kontroli
+dostępu tcpwrappers w trybie samodzielnym w bardzo wygodny sposób.
-Wiele programów automatycznie dodaje wpisy we wspólnych plikach
-allow/deny, a u¿ycie tego modu³u pozwala demonowi ProFTPD dzia³aj±cemu
-w trybie samodzielnym adaptowaæ te wpisy w miarê dodawania. Robi tak
-na przyk³ad program portsentry: przy próbie niedozwolonego dostêpu
+Wiele programów automatycznie dodaje wpisy we wspólnych plikach
+allow/deny, a użycie tego modułu pozwala demonowi ProFTPD działającemu
+w trybie samodzielnym adaptować te wpisy w miarę dodawania. Robi tak
+na przykład program portsentry: przy próbie niedozwolonego dostępu
dodaje hosty do pliku /etc/hosts.deny.
%prep
-%setup -q -n %{name}-%{version}%{?_rc}
+%setup -q -n %{name}-%{version}%{?_rc} -a1
%patch0 -p1
-#%patch1 -p1 CONFUSES mod_ls.c
+%patch1 -p1
%patch2 -p1
%patch3 -p1
%patch4 -p1
-#%patch5 -p1 NEEDS UPDATE
-%patch6 -p1
+
+# mod_clamav
+patch -p0 < mod_clamav-%{mod_clamav_version}/proftpd.patch
+cp -a mod_clamav-%{mod_clamav_version}/*.{c,h} contrib/
cp -f /usr/share/automake/config.sub .
%{__autoconf}
MODULES="
+mod_auth_file
+mod_ident
mod_ratio
mod_readme
+mod_rewrite
mod_wrap
+mod_facl
+mod_ifsession
+mod_lang
%{?with_ssl:mod_tls}
%{?with_pam:mod_auth_pam}
%{?with_ldap:mod_ldap}
%{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
%{?with_quotamysql:mod_quotatab mod_quotatab_sql}
%{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
-%{?with_linuxprivs:mod_linuxprivs}
%{?with_mysql:mod_sql mod_sql_mysql}
%{?with_pgsql:mod_sql mod_sql_postgres}
"
MODARG=$(echo $MODULES | tr ' ' '\n' | sort -u | xargs | tr ' ' ':')
%configure \
--with-includes=/usr/include/ncurses%{?with_mysql::%{_includedir}/mysql} \
+ --disable-strip \
+ --enable-buffer-size=4096 \
+ --disable-auth-file \
--enable-autoshadow \
--enable-ctrls \
--enable-dso \
- --enable-facl \
%{?with_ipv6:--enable-ipv6} \
--enable-sendfile \
%{!?with_ssl:--disable-tls} \
--with-shared=$MODARG \
+ --with-modules=mod_clamav
-%{__make}
+%{__make} -j1
%install
rm -rf $RPM_BUILD_ROOT
install -d $RPM_BUILD_ROOT/etc/{pam.d,security,sysconfig/rc-inetd,rc.d/init.d} \
- $RPM_BUILD_ROOT/var/{lib/ftp/pub/Incoming,log} \
+ $RPM_BUILD_ROOT/var/{lib/ftp/pub/Incoming,log,run/proftpd} \
$RPM_BUILD_ROOT%{_sysconfdir}/conf.d \
$RPM_BUILD_ROOT%{_includedir}/%{name}
rm $RPM_BUILD_ROOT%{_sbindir}/in.proftpd
-install %{SOURCE1} $RPM_BUILD_ROOT%{_sysconfdir}
+install %{SOURCE2} $RPM_BUILD_ROOT%{_sysconfdir}
install %{SOURCE9} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_auth_pam.conf
-%{?with_ldap:echo 'LoadModule mod_ldap.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_ldap.conf}
-echo 'LoadModule mod_quotatab.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab.conf
-echo 'LoadModule mod_quotatab_file.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab_file.conf
-%{?with_quotaldap:echo 'LoadModule mod_quotatab_ldap.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab_ldap.conf}
-echo 'LoadModule mod_ratio.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_ratio.conf
-echo 'LoadModule mod_readme.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_readme.conf
-%if %{with mysql} || %{with pgsql}
-echo 'LoadModule mod_quotatab_sql.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab_sql.conf
-echo 'LoadModule mod_sql.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_sql.conf
-%endif
-%{?with_mysql:echo 'LoadModule mod_sql_mysql.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_sql_mysql.conf}
-%{?with_pgsql:echo 'LoadModule mod_sql_postgres.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_sql_postgres.conf}
+MODULES="
+mod_auth_file
+mod_ident
+mod_ratio
+mod_readme
+mod_rewrite
+mod_wrap
+%{?with_ldap:mod_ldap}
+%{?with_quotafile:mod_quotatab mod_quotatab_file}
+%{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
+%{?with_quotamysql:mod_quotatab mod_quotatab_sql}
+%{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
+%{?with_mysql:mod_sql mod_sql_mysql}
+%{?with_pgsql:mod_sql mod_sql_postgres}
+"
+for module in $MODULES; do
+ echo "LoadModule $module.c" > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/$module.conf
+done
install %{SOURCE10} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_tls.conf
-echo 'LoadModule mod_wrap.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_wrap.conf
install %{SOURCE11} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/anonftp.conf
+install %{SOURCE12} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_clamav.conf
%{?with_pam:install %{SOURCE3} $RPM_BUILD_ROOT/etc/pam.d/ftp}
install %{SOURCE4} $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/ftpd
:> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers.default
:> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers
-:> $RPM_BUILD_ROOT/var/log/xferlog
# only for -inetd package?
ln -sf proftpd $RPM_BUILD_ROOT%{_sbindir}/ftpd
:> $RPM_BUILD_ROOT/etc/security/blacklist.ftp
-rm $RPM_BUILD_ROOT%{_libdir}/%{name}/*.a
-rm $RPM_BUILD_ROOT%{_libdir}/%{name}/*.la
+rm $RPM_BUILD_ROOT%{_libexecdir}/*.a
+rm $RPM_BUILD_ROOT%{_libexecdir}/*.la
rm -f $RPM_BUILD_ROOT%{_mandir}/ftpusers-path.diff*
cp -aL include/* config.h $RPM_BUILD_ROOT%{_includedir}/%{name}
%post common
umask 027
-touch /var/log/xferlog
awk -F: '{ if (($3 < 500) && ($1 != "ftp")) print $1; }' < /etc/passwd >> %{_sysconfdir}/ftpusers.default
if [ ! -f %{_sysconfdir}/ftpusers ]; then
cp -f %{_sysconfdir}/ftpusers.default %{_sysconfdir}/ftpusers
/sbin/chkconfig --del proftpd
fi
+%triggerin standalone -- pam
+# restart proftpd if pam is upgraded
+# (proftpd is linked with old libpam but tries to open modules linked with new libpam)
+if [ "$2" != 1 ]; then
+ %service -q proftpd restart
+fi
+
# macro called at module post scriptlet
%define module_post \
if [ "$1" = "1" ]; then \
%module_scripts mod_quotatab_sql
%module_scripts mod_ratio
%module_scripts mod_readme
+%module_scripts mod_rewrite
%module_scripts mod_sql
%module_scripts mod_sql_mysql
%module_scripts mod_sql_postgres
%module_scripts mod_tls
%module_scripts mod_wrap
-%triggerpostun inetd -- %{name}-inetd <= 1:1.2.10
-echo "Changing deprecated config options"
-cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
-sed -i -e '
- s/AuthPAMAuthoritative\b/AuthPAM/
- s/TCPDServiceName/TCPServiceName/
- s/TlsRsaCertFile/TLSRSACertificateFile/
- s/TlsRsaKeyFile/TLSRSACertificateKeyFile/
- s/TlsDsaCertFile/TLSDSACertificateFile/
- s/TlsDsaKeyFile/TLSDSACertificateKeyFile/
- s/TlsCrlFile/TLSCARevocationFile/
- s/TlsDhParamFile/TLSDHParamFile/
- s/TlsCipherList/TLSCipherSuite/
- s/TlsCertsOk/TLSVerifyClient/
- /UseTCPD/d
-' %{_sysconfdir}/proftpd.conf
-
-%triggerpostun standalone -- %{name}-standalone <= 1:1.2.10
-echo "Changing deprecated config options"
-cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
-sed -i -e '
- s/AuthPAMAuthoritative\b/AuthPAM/
- s/TCPDServiceName/TCPServiceName/
- s/TlsRsaCertFile/TLSRSACertificateFile/
- s/TlsRsaKeyFile/TLSRSACertificateKeyFile/
- s/TlsDsaCertFile/TLSDSACertificateFile/
- s/TlsDsaKeyFile/TLSDSACertificateKeyFile/
- s/TlsCrlFile/TLSCARevocationFile/
- s/TlsDhParamFile/TLSDHParamFile/
- s/TlsCipherList/TLSCipherSuite/
- s/TlsCertsOk/TLSVerifyClient/
- /UseTCPD/d
-' %{_sysconfdir}/proftpd.conf
-
%files common
%defattr(644,root,root,755)
%doc sample-configurations/*.conf CREDITS ChangeLog NEWS RELEASE_NOTES
%doc README README.capabilities README.classes README.controls README.IPv6
%doc README.modules
-%doc doc/*html
+%doc doc/*.html doc/contrib doc/howto doc/modules
%dir %attr(750,root,ftp) %dir %{_sysconfdir}
%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*.conf
%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %ghost %{_sysconfdir}/ftpusers
%attr(640,root,root) %{_sysconfdir}/ftpusers.default
%dir %attr(750,root,root) %{_sysconfdir}/conf.d
-%attr(640,root,root) %ghost /var/log/*
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_file.conf
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ident.conf
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_clamav.conf
+#%attr(640,root,root) %ghost /var/log/*
%attr(755,root,root) %{_bindir}/*
%attr(755,root,root) %{_sbindir}/*
-%dir %{_libdir}/%{name}
-%dir /var/run/proftpd
+%dir %{_libexecdir}
+%attr(755,root,root) %{_libexecdir}/mod_auth_file.so
+%attr(755,root,root) %{_libexecdir}/mod_facl.so
+%attr(755,root,root) %{_libexecdir}/mod_ident.so
+%attr(755,root,root) %{_libexecdir}/mod_ifsession.so
+%attr(755,root,root) %{_libexecdir}/mod_lang.so
+%dir %{_localstatedir}/proftpd
%{_mandir}/man[18]/*
%dir /var/lib/ftp
%dir /var/lib/ftp/pub
%files devel
%defattr(644,root,root,755)
%{_includedir}/%{name}
+%{_pkgconfigdir}/%{name}.pc
%files anonftp
%defattr(644,root,root,755)
%files mod_ratio
%defattr(644,root,root,755)
+%doc contrib/README.ratio
%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ratio.conf
%attr(755,root,root) %{_libexecdir}/mod_ratio.so
%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_readme.conf
%attr(755,root,root) %{_libexecdir}/mod_readme.so
+%files mod_rewrite
+%defattr(644,root,root,755)
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_rewrite.conf
+%attr(755,root,root) %{_libexecdir}/mod_rewrite.so
+
%if %{with mysql} || %{with pgsql}
%files mod_sql
%defattr(644,root,root,755)