2 # - mod_caps uses uname -r for detection
3 # - don't use internal libltdl
4 # - package contrib/ftp* perl scripts.
7 %bcond_without pam # disable PAM support
8 %bcond_without ipv6 # disable IPv6 and TCPD support
9 %bcond_without ssl # disbale TLS/SSL support
10 %bcond_without ldap # disable LDAP support
11 %bcond_without mysql # disable MySQL support
12 %bcond_without pgsql # disable PostgreSQL support
13 %bcond_without quotafile # disable quota file support
14 %bcond_without quotaldap # disable quota ldap support
15 %bcond_without quotamysql # disable quota mysql support
16 %bcond_without quotapgsql # disable quota pgsql support
18 %define mod_clamav_version 0.11rc
20 Summary: PROfessional FTP Daemon with apache-like configuration syntax
21 Summary(es.UTF-8): Servidor FTP profesional, con sintaxis de configuración semejante a la del apache
22 Summary(pl.UTF-8): PROfesionalny serwer FTP
23 Summary(pt_BR.UTF-8): Servidor FTP profissional, com sintaxe de configuração semelhante à do apache
24 Summary(zh_CN.UTF-8): 易于管理的,安全的 FTP 服务器
30 Group: Networking/Daemons
31 Source0: ftp://ftp.proftpd.org/distrib/source/%{name}-%{version}.tar.gz
32 # Source0-md5: 4040f6a6b86173e2a03f4ccdb9b9af6e
33 # https://github.com/jbenden/mod_clamav
34 Source1: https://secure.thrallingpenguin.com/redmine/attachments/download/1/mod_clamav-%{mod_clamav_version}.tar.gz
35 # Source1-md5: 42e560ec0bd5964e13fad1b2bb7afe21
38 Source4: %{name}.inetd
39 Source5: %{name}.sysconfig
41 Source7: ftpusers.tar.bz2
42 # Source7-md5: 76c80b6ec9f4d079a1e27316edddbe16
43 Source9: %{name}-mod_pam.conf
44 Source10: %{name}-mod_tls.conf
45 Source11: %{name}-anonftp.conf
46 Source12: %{name}-mod_clamav.conf
47 Source13: %{name}.tmpfiles
48 Patch0: %{name}-paths.patch
49 Patch1: %{name}-noautopriv.patch
50 Patch2: %{name}-wtmp.patch
51 Patch3: %{name}-pool.patch
53 URL: http://www.proftpd.org/
54 BuildRequires: acl-devel
55 BuildRequires: autoconf
56 BuildRequires: automake
57 BuildRequires: libcap-devel
58 BuildRequires: libstdc++-devel
59 BuildRequires: libwrap-devel
60 %if %{with mysql} || %{with quotamysql}
61 BuildRequires: mysql-devel
63 BuildRequires: ncurses-devel
64 %if %{with ldap} || %{with quotaldap}
65 BuildRequires: openldap-devel
67 %{?with_ssl:BuildRequires: openssl-devel >= 0.9.7d}
68 %{?with_pam:BuildRequires: pam-devel}
69 %if %{with pgsql} || %{with quotapgsql}
70 BuildRequires: postgresql-devel
72 BuildRequires: rpmbuild(macros) >= 1.268
73 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
75 %define _sysconfdir /etc/ftpd
76 %define _localstatedir /var/run
77 %define _libexecdir %{_prefix}/%{_lib}/%{name}
79 %define filterout -flto
82 ProFTPD is a highly configurable FTP daemon for Unix and Unix-like
83 operating systems. ProFTPD is designed to be somewhat of a "drop-in"
84 replacement for wu-ftpd. Full online documentation is available at
85 <http://www.proftpd.org/>, including a server configuration directive
88 %description -l es.UTF-8
89 ProFTPD es un servidor FTP altamente configurable para sistemas
90 operativos Unix. Está proyectado para ser un substituto directo al
91 wu-ftpd. La documentación completa está disponible en
92 <http://www.proftpd.org/>, incluido el manual de referencia para las
93 directivas de configuración del servidor.
95 %description -l pl.UTF-8
96 ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
97 ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
98 dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
99 włącznie z dokumentacją dotyczącą konfigurowania.
101 %description -l pt_BR.UTF-8
102 O ProFTPD é um servidor FTP altamente configurável para sistemas
105 É projetado para ser um substituto direto para o wu-ftpd. A
106 documentação completa está disponível em <http://www.proftpd.org/>,
107 incluindo o manual de referência para as diretivas de configuração do
111 Summary: PROfessional FTP Daemon with apache-like configuration syntax - common files
112 Summary(pl.UTF-8): PROfesionalny serwer FTP - wspólne pliki
113 Group: Networking/Daemons
115 Requires(post): fileutils
116 Obsoletes: proftpd < 0:1.2.2rc1-3
119 ProFTPD is a highly configurable FTP daemon for Unix and Unix-like
120 operating systems. ProFTPD is designed to be somewhat of a "drop-in"
121 replacement for wu-ftpd. Full online documentation is available at
122 <http://www.proftpd.org/>, including a server configuration directive
125 %description common -l es.UTF-8
126 ProFTPD es un servidor FTP altamente configurable para sistemas
127 operativos Unix. Está proyectado para ser un substituto directo al
128 wu-ftpd. La documentación completa está disponible en
129 <http://www.proftpd.org/>, incluido el manual de referencia para las
130 directivas de configuración del servidor.
132 %description common -l pl.UTF-8
133 ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
134 ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
135 dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
136 włącznie z dokumentacją dotyczącą konfigurowania.
138 %description common -l pt_BR.UTF-8
139 O ProFTPD é um servidor FTP altamente configurável para sistemas
142 É projetado para ser um substituto direto para o wu-ftpd. A
143 documentação completa está disponível em <http://www.proftpd.org/>,
144 incluindo o manual de referência para as diretivas de configuração do
148 Summary: inetd configs for proftpd
149 Summary(pl.UTF-8): Pliki konfiguracyjne do użycia proftpd poprzez inetd
150 Group: Networking/Daemons
151 Requires(post): fileutils
153 Requires(post): sed >= 4.0
154 Requires(triggerpostun): sed >= 4.0
155 Requires: %{name}-common = %{epoch}:%{version}-%{release}
158 Provides: proftpd = %{epoch}:%{version}-%{release}
164 Obsoletes: heimdal-ftpd
166 Obsoletes: linux-ftpd
167 Obsoletes: muddleftpd
168 Obsoletes: proftpd-standalone
170 Obsoletes: troll-ftpd
173 Conflicts: man-pages < 1.51
174 Conflicts: rpm < 4.4.2-0.2
177 ProFTPD configs for running from inetd.
179 %description inetd -l pl.UTF-8
180 Pliki konfiguracyjna ProFTPD do startowania demona poprzez inetd.
183 Summary: Standalone daemon configs for proftpd
184 Summary(pl.UTF-8): Pliki konfiguracyjne do startowania proftpd w trybie standalone
185 Group: Networking/Daemons
186 Requires(post): fileutils
188 Requires(post): sed >= 4.0
189 Requires(post,preun): /sbin/chkconfig
190 Requires(triggerpostun): sed >= 4.0
191 Requires: %{name}-common = %{epoch}:%{version}-%{release}
194 Provides: proftpd = %{epoch}:%{version}-%{release}
200 Obsoletes: heimdal-ftpd
202 Obsoletes: linux-ftpd
203 Obsoletes: muddleftpd
204 Obsoletes: proftpd-inetd
206 Obsoletes: troll-ftpd
209 Conflicts: man-pages < 1.51
210 Conflicts: rpm < 4.4.2-0.2
212 %description standalone
213 ProFTPD configs for running as a standalone daemon.
215 %description standalone -l pl.UTF-8
216 Pliki konfiguracyjne ProFTPD do startowania demona w trybie
220 Summary: Header files ProFTPD
221 Summary(pl.UTF-8): Pliki nagłówkowe ProFTPD
222 Group: Development/Libraries
226 This is the package containing the header files for ProFTPD.
228 %description devel -l pl.UTF-8
229 Ten pakiet zawiera pliki nagłówkowe ProFTPD
232 Summary: Anonymous FTP config for ProFTPD
233 Summary(pl.UTF-8): Konfiguracja anonimowego FTP dla ProFTPD
234 Group: Networking/Daemons
235 Requires: %{name}-common = %{epoch}:%{version}-%{release}
238 Anonymous FTP config for ProFTPD.
240 %description anonftp -l pl.UTF-8
241 Konfiguracja anonimowego FTP dla ProFTPD.
243 %package mod_auth_pam
244 Summary: ProFTPD PAM auth module
245 Summary(pl.UTF-8): Moduł uwierzytelnienia PAM dla ProFTPD
246 Group: Networking/Daemons
247 Requires: %{name}-common = %{epoch}:%{version}-%{release}
248 Requires: pam >= 0.79.0
250 %description mod_auth_pam
251 PAM authentication method for ProFTPD.
253 %description mod_auth_pam -l pl.UTF-8
254 Metoda uwierzytelnienia PAM dla ProFTPD.
257 Summary: ProFTPD OpenLDAP module
258 Summary(pl.UTF-8): Moduł OpenLDAP dla ProFTPD
259 Group: Networking/Daemons
260 Requires: %{name}-common = %{epoch}:%{version}-%{release}
262 %description mod_ldap
263 mod_ldap provides LDAP authentication support for ProFTPD. It supports
264 many features useful in "toaster" environments such as default UID/GID
265 and autocreation/autogeneration of home directories.
267 %description mod_ldap -l pl.UTF-8
268 mod_ldap dodaje obsługę uwierzytelnienia LDAP do ProFTPD. Obsługuje
269 wiele cech przydatnych w środowiskach "tosterowych", takich jak
270 domyślny UID/GID i automatyczne tworzenie/generowanie katalogów
273 %package mod_quotatab
274 Summary: ProFTPD quotatab module
275 Summary(pl.UTF-8): Moduł quotatab dla ProFTPD
276 Group: Networking/Daemons
277 Requires: %{name}-common = %{epoch}:%{version}-%{release}
279 %description mod_quotatab
280 A module for managing FTP byte/file quotas via centralized tables.
282 %description mod_quotatab -l pl.UTF-8
283 Moduł do zarządzania ograniczeniami bajtów/plików FTP poprzez
284 scentralizowane tabele.
286 %package mod_quotatab_file
287 Summary: ProFTPD quotatab file module
288 Summary(pl.UTF-8): Moduł quotatab_file dla ProFTPD
289 Group: Networking/Daemons
290 Requires: %{name}-common = %{epoch}:%{version}-%{release}
291 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
293 %description mod_quotatab_file
294 A mod_quotatab sub-module for managing quota data via file-based
297 %description mod_quotatab_file -l pl.UTF-8
298 Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
299 tabele zapisane w pliku.
301 %package mod_quotatab_ldap
302 Summary: ProFTPD quotatab ldap module
303 Summary(pl.UTF-8): Moduł quotatab_ldap dla ProFTPD
304 Group: Networking/Daemons
305 Requires: %{name}-common = %{epoch}:%{version}-%{release}
306 Requires: %{name}-mod_ldap = %{epoch}:%{version}-%{release}
307 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
309 %description mod_quotatab_ldap
310 A mod_quotatab sub-module for obtaining quota information from an LDAP
313 %description mod_quotatab_ldap -l pl.UTF-8
314 Podmoduł mod_quotatab do pobierania informacji o ograniczeniach z
317 %package mod_quotatab_sql
318 Summary: ProFTPD quotatab sql module
319 Summary(pl.UTF-8): Moduł quotatab_sql dla ProFTPD
320 Group: Networking/Daemons
321 Requires: %{name}-common = %{epoch}:%{version}-%{release}
322 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
323 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
325 %description mod_quotatab_sql
326 A mod_quotatab sub-module for managing quota data via SQL-based
329 %description mod_quotatab_sql -l pl.UTF-8
330 Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
334 Summary: ProFTPD ratio module
335 Summary(pl.UTF-8): Moduł ratio dla ProFTPD
336 Group: Networking/Daemons
337 Requires: %{name}-common = %{epoch}:%{version}-%{release}
339 %description mod_ratio
340 Support upload/download ratios.
342 %description mod_ratio -l pl.UTF-8
343 Obsługa współczynników upload/download.
346 Summary: ProFTPD readme module
347 Summary(pl.UTF-8): Moduł readme dla ProFTPD
348 Group: Networking/Daemons
349 Requires: %{name}-common = %{epoch}:%{version}-%{release}
351 %description mod_readme
352 "README" file support.
354 %description mod_readme -l pl.UTF-8
355 Obsługa pliku "README".
358 Summary: ProFTPD rewrite module
359 Summary(pl.UTF-8): Moduł rewrite dla ProFTPD
360 Group: Networking/Daemons
361 Requires: %{name}-common = %{epoch}:%{version}-%{release}
363 %description mod_rewrite
364 Runtime rewrite engine.
366 %description mod_rewrite -l pl.UTF-8
367 Silnik przepisujący adresy w locie.
370 Summary: ProFTPD SQL support module
371 Summary(pl.UTF-8): Moduł obsługi SQL dla ProFTPD
372 Group: Networking/Daemons
373 Requires: %{name}-common = %{epoch}:%{version}-%{release}
376 This module provides the necessary support for SQL based
377 authentication, logging and other features as required.
379 %description mod_sql -l pl.UTF-8
380 Ten moduł dodaje obsługę SQL potrzebną do uwierzytelniania, logowania
381 i innych możliwości opartych o SQL.
383 %package mod_sql_mysql
384 Summary: ProFTPD sql mysql module
385 Summary(pl.UTF-8): Moduł sql_mysql dla ProFTPD
386 Group: Networking/Daemons
387 Requires: %{name}-common = %{epoch}:%{version}-%{release}
388 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
390 %description mod_sql_mysql
391 Support for connecting to MySQL databases.
393 %description mod_sql_mysql -l pl.UTF-8
394 Obsługa łączenia się z bazami danych MySQL.
396 %package mod_sql_postgres
397 Summary: ProFTPD sql postgres module
398 Summary(pl.UTF-8): Moduł sql_postgres dla ProFTPD
399 Group: Networking/Daemons
400 Requires: %{name}-common = %{epoch}:%{version}-%{release}
401 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
403 %description mod_sql_postgres
404 Support for connecting to PostgreSQL databases.
406 %description mod_sql_postgres -l pl.UTF-8
407 Obsługa łączenia się z bazami danych PostgreSQL.
410 Summary: ProFTPD TLS support
411 Summary(pl.UTF-8): Obsługa TLS dla ProFTPD
412 Group: Networking/Daemons
413 Requires: %{name}-common = %{epoch}:%{version}-%{release}
416 An RFC2228 SSL/TLS module for ProFTPD.
418 %description mod_tls -l pl.UTF-8
419 Moduł SSL/TLS zgodny z RFC2228 dla ProFTPD.
422 Summary: ProFTPD interface to libwrap
423 Summary(pl.UTF-8): Interfejs ProFTPD do libwrap
424 Group: Networking/Daemons
425 Requires: %{name}-common = %{epoch}:%{version}-%{release}
428 %description mod_wrap
429 It enables the daemon to use the common tcpwrappers access control
430 library while in standalone mode, and in a very configurable manner.
432 Many programs will automatically add entries in the common allow/deny
433 files, and use of this module will allow a ProFTPD daemon running in
434 standalone mode to adapt as these entries are added. The portsentry
435 program does this, for example: when illegal access is attempted, it
436 will add hosts to the /etc/hosts.deny file.
438 %description mod_wrap -l pl.UTF-8
439 Ten pakiet pozwala demonowi używać wspólnej biblioteki kontroli
440 dostępu tcpwrappers w trybie samodzielnym w bardzo wygodny sposób.
442 Wiele programów automatycznie dodaje wpisy we wspólnych plikach
443 allow/deny, a użycie tego modułu pozwala demonowi ProFTPD działającemu
444 w trybie samodzielnym adaptować te wpisy w miarę dodawania. Robi tak
445 na przykład program portsentry: przy próbie niedozwolonego dostępu
446 dodaje hosty do pliku /etc/hosts.deny.
449 %setup -q -n %{name}-%{version}%{?_rc} -a1
457 patch -p0 < mod_clamav-%{mod_clamav_version}/proftpd.patch
458 cp -a mod_clamav-%{mod_clamav_version}/*.{c,h} contrib/
460 cp -f /usr/share/automake/config.sub .
462 # cleanup backups after patching
463 find . '(' -name '*~' -o -name '*.orig' ')' -print0 | xargs -0 -r -l512 rm -f
465 sed -E -i -e '1s,#![[:space:]]*/usr/bin/env[[:space:]]+perl,#!%{__perl},' \
469 contrib/xferstats.holger-preiss \
485 %{?with_pam:mod_auth_pam}
486 %{?with_ldap:mod_ldap}
487 %{?with_quotafile:mod_quotatab mod_quotatab_file}
488 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
489 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
490 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
491 %{?with_mysql:mod_sql mod_sql_mysql}
492 %{?with_pgsql:mod_sql mod_sql_postgres}
495 MODARG=$(echo $MODULES | tr ' ' '\n' | sort -u | xargs | tr ' ' ':')
497 --with-includes=/usr/include/ncurses%{?with_mysql::%{_includedir}/mysql} \
499 --enable-buffer-size=4096 \
500 --disable-auth-file \
501 --enable-autoshadow \
505 %{?with_ipv6:--enable-ipv6} \
507 %{!?with_ssl:--disable-tls} \
508 --with-shared=$MODARG \
509 --with-modules=mod_clamav
514 rm -rf $RPM_BUILD_ROOT
515 install -d $RPM_BUILD_ROOT/etc/{pam.d,security,sysconfig/rc-inetd,rc.d/init.d} \
516 $RPM_BUILD_ROOT/var/{lib/ftp/pub/Incoming,log,run/proftpd} \
517 $RPM_BUILD_ROOT%{_sysconfdir}/conf.d \
518 $RPM_BUILD_ROOT%{_includedir}/%{name} \
519 $RPM_BUILD_ROOT/usr/lib/tmpfiles.d
522 DESTDIR=$RPM_BUILD_ROOT \
523 INSTALL_USER=%(id -u) \
524 INSTALL_GROUP=%(id -g)
526 rm $RPM_BUILD_ROOT%{_sbindir}/in.proftpd
528 install %{SOURCE2} $RPM_BUILD_ROOT%{_sysconfdir}
529 install %{SOURCE9} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_auth_pam.conf
537 %{?with_ldap:mod_ldap}
538 %{?with_quotafile:mod_quotatab mod_quotatab_file}
539 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
540 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
541 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
542 %{?with_mysql:mod_sql mod_sql_mysql}
543 %{?with_pgsql:mod_sql mod_sql_postgres}
545 for module in $MODULES; do
546 echo "LoadModule $module.c" > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/$module.conf
548 install %{SOURCE10} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_tls.conf
549 install %{SOURCE11} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/anonftp.conf
550 install %{SOURCE12} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_clamav.conf
552 %{?with_pam:install %{SOURCE3} $RPM_BUILD_ROOT/etc/pam.d/ftp}
553 install %{SOURCE4} $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/ftpd
554 install %{SOURCE5} $RPM_BUILD_ROOT/etc/sysconfig/proftpd
555 install %{SOURCE6} $RPM_BUILD_ROOT/etc/rc.d/init.d/proftpd
556 install contrib/xferstats.holger-preiss $RPM_BUILD_ROOT%{_bindir}/xferstat
558 bzip2 -dc %{SOURCE7} | tar xf - -C $RPM_BUILD_ROOT%{_mandir}
560 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers.default
561 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers
563 install %{SOURCE13} $RPM_BUILD_ROOT/usr/lib/tmpfiles.d/%{name}.conf
565 # only for -inetd package?
566 ln -sf proftpd $RPM_BUILD_ROOT%{_sbindir}/ftpd
568 :> $RPM_BUILD_ROOT/etc/security/blacklist.ftp
570 rm $RPM_BUILD_ROOT%{_libexecdir}/*.a
571 rm $RPM_BUILD_ROOT%{_libexecdir}/*.la
573 rm -f $RPM_BUILD_ROOT%{_mandir}/ftpusers-path.diff*
574 cp -aL include/* config.h $RPM_BUILD_ROOT%{_includedir}/%{name}
577 rm -rf $RPM_BUILD_ROOT
581 awk -F: '{ if (($3 < 500) && ($1 != "ftp")) print $1; }' < /etc/passwd >> %{_sysconfdir}/ftpusers.default
582 if [ ! -f %{_sysconfdir}/ftpusers ]; then
583 cp -f %{_sysconfdir}/ftpusers.default %{_sysconfdir}/ftpusers
587 if grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf ; then
588 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
589 sed -i -e 's/^ServerType[[:space:]]\+standalone/ServerType inetd/g' %{_sysconfdir}/proftpd.conf
591 %service -q rc-inetd reload
594 if [ "$1" = "0" ]; then
595 %service -q rc-inetd reload
598 %posttrans standalone
599 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf ; then
600 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
601 sed -i -e 's/^ServerType[[:space:]]\+inetd/ServerType standalone/g' %{_sysconfdir}/proftpd.conf
603 /sbin/chkconfig --add proftpd
604 %service proftpd restart "ProFTPD daemon"
607 if [ "$1" = "0" ]; then
608 %service proftpd stop
609 /sbin/chkconfig --del proftpd
612 %triggerin standalone -- pam
613 # restart proftpd if pam is upgraded
614 # (proftpd is linked with old libpam but tries to open modules linked with new libpam)
615 if [ "$2" != 1 ]; then
616 %service -q proftpd restart
619 # macro called at module post scriptlet
620 %define module_post \
621 if [ "$1" = "1" ]; then \
622 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
623 %service -q rc-inetd reload \
624 elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
625 %service -q proftpd restart \
629 # macro called at module postun scriptlet
630 %define module_postun \
631 if [ "$1" = "0" ]; then \
632 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
633 %service -q rc-inetd reload \
634 elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
635 %service -q proftpd restart \
639 # it's sooo annoying to write them
640 %define module_scripts() \
647 %module_scripts mod_auth_pam
648 %module_scripts mod_ldap
649 %module_scripts mod_quotatab
650 %module_scripts mod_quotatab_file
651 %module_scripts mod_quotatab_ldap
652 %module_scripts mod_quotatab_sql
653 %module_scripts mod_ratio
654 %module_scripts mod_readme
655 %module_scripts mod_rewrite
656 %module_scripts mod_sql
657 %module_scripts mod_sql_mysql
658 %module_scripts mod_sql_postgres
659 %module_scripts mod_tls
660 %module_scripts mod_wrap
663 %defattr(644,root,root,755)
664 %doc sample-configurations/*.conf CREDITS ChangeLog NEWS RELEASE_NOTES
665 %doc README.md README.capabilities README.classes README.controls README.IPv6
667 %doc doc/*.html doc/contrib doc/howto doc/modules
668 %dir %attr(750,root,ftp) %dir %{_sysconfdir}
669 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*.conf
670 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %ghost %{_sysconfdir}/ftpusers
671 %attr(640,root,root) %{_sysconfdir}/ftpusers.default
672 %dir %attr(750,root,root) %{_sysconfdir}/conf.d
673 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_file.conf
674 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ident.conf
675 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_clamav.conf
676 #%attr(640,root,root) %ghost /var/log/*
677 %attr(755,root,root) %{_bindir}/*
678 %attr(755,root,root) %{_sbindir}/*
680 %attr(755,root,root) %{_libexecdir}/mod_auth_file.so
681 %attr(755,root,root) %{_libexecdir}/mod_facl.so
682 %attr(755,root,root) %{_libexecdir}/mod_ident.so
683 %attr(755,root,root) %{_libexecdir}/mod_ifsession.so
684 %dir %{_localstatedir}/proftpd
685 /usr/lib/tmpfiles.d/%{name}.conf
687 %lang(ja) %{_mandir}/ja/man5/ftpusers*
688 %lang(pl) %{_mandir}/pl/man5/ftpusers*
689 %lang(pt_BR) %{_mandir}/pt_BR/man5/ftpusers*
690 %lang(ru) %{_mandir}/ru/man5/ftpusers*
693 %dir /var/lib/ftp/pub
694 %attr(711,ftp,ftp) %dir /var/lib/ftp/pub/Incoming
697 %defattr(644,root,root,755)
698 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/rc-inetd/ftpd
701 %defattr(644,root,root,755)
702 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/proftpd
703 %attr(754,root,root) /etc/rc.d/init.d/proftpd
706 %defattr(644,root,root,755)
707 %{_includedir}/%{name}
708 %{_pkgconfigdir}/%{name}.pc
711 %defattr(644,root,root,755)
712 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/anonftp.conf
716 %defattr(644,root,root,755)
718 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/pam.d/*
719 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/security/blacklist.ftp
720 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_pam.conf
721 %attr(755,root,root) %{_libexecdir}/mod_auth_pam.so
726 %defattr(644,root,root,755)
728 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ldap.conf
729 %attr(755,root,root) %{_libexecdir}/mod_ldap.so
733 %defattr(644,root,root,755)
734 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab.conf
735 %attr(755,root,root) %{_libexecdir}/mod_quotatab.so
737 %if %{with quotafile}
738 %files mod_quotatab_file
739 %defattr(644,root,root,755)
740 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_file.conf
741 %attr(755,root,root) %{_libexecdir}/mod_quotatab_file.so
744 %if %{with quotaldap}
745 %files mod_quotatab_ldap
746 %defattr(644,root,root,755)
747 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_ldap.conf
748 %attr(755,root,root) %{_libexecdir}/mod_quotatab_ldap.so
751 %if %{with quotamysql} || %{with quotapgsql}
752 %files mod_quotatab_sql
753 %defattr(644,root,root,755)
754 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_sql.conf
755 %attr(755,root,root) %{_libexecdir}/mod_quotatab_sql.so
759 %defattr(644,root,root,755)
760 %doc contrib/README.ratio
761 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ratio.conf
762 %attr(755,root,root) %{_libexecdir}/mod_ratio.so
765 %defattr(644,root,root,755)
766 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_readme.conf
767 %attr(755,root,root) %{_libexecdir}/mod_readme.so
770 %defattr(644,root,root,755)
771 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_rewrite.conf
772 %attr(755,root,root) %{_libexecdir}/mod_rewrite.so
774 %if %{with mysql} || %{with pgsql}
776 %defattr(644,root,root,755)
777 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql.conf
778 %attr(755,root,root) %{_libexecdir}/mod_sql.so
783 %defattr(644,root,root,755)
784 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_mysql.conf
785 %attr(755,root,root) %{_libexecdir}/mod_sql_mysql.so
789 %files mod_sql_postgres
790 %defattr(644,root,root,755)
791 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_postgres.conf
792 %attr(755,root,root) %{_libexecdir}/mod_sql_postgres.so
796 %defattr(644,root,root,755)
797 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_tls.conf
798 %attr(755,root,root) %{_libexecdir}/mod_tls.so
801 %defattr(644,root,root,755)
802 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_wrap.conf
803 %attr(755,root,root) %{_libexecdir}/mod_wrap.so