2 # - mod_caps uses uname -r for detection
3 # - don't use internal libltdl
6 %bcond_without pam # disable PAM support
7 %bcond_without ipv6 # disable IPv6 and TCPD support
8 %bcond_without ssl # disbale TLS/SSL support
9 %bcond_without ldap # disable LDAP support
10 %bcond_without mysql # disable MySQL support
11 %bcond_without pgsql # disable PostgreSQL support
12 %bcond_without quotafile # disable quota file support
13 %bcond_without quotaldap # disable quota ldap support
14 %bcond_without quotamysql # disable quota mysql support
15 %bcond_without quotapgsql # disable quota pgsql support
17 %define mod_clamav_version 0.11rc
19 Summary: PROfessional FTP Daemon with apache-like configuration syntax
20 Summary(es.UTF-8): Servidor FTP profesional, con sintaxis de configuración semejante a la del apache
21 Summary(pl.UTF-8): PROfesionalny serwer FTP
22 Summary(pt_BR.UTF-8): Servidor FTP profissional, com sintaxe de configuração semelhante à do apache
23 Summary(zh_CN.UTF-8): 易于管理的,安全的 FTP 服务器
29 Group: Networking/Daemons
30 Source0: ftp://ftp.proftpd.org/distrib/source/%{name}-%{version}.tar.bz2
31 # Source0-md5: 721b8232fcac36317a6a1d29fa86250e
32 Source1: https://secure.thrallingpenguin.com/redmine/attachments/download/1/mod_clamav-%{mod_clamav_version}.tar.gz
33 # Source1-md5: 42e560ec0bd5964e13fad1b2bb7afe21
36 Source4: %{name}.inetd
37 Source5: %{name}.sysconfig
39 Source7: ftpusers.tar.bz2
40 # Source7-md5: 76c80b6ec9f4d079a1e27316edddbe16
41 Source9: %{name}-mod_pam.conf
42 Source10: %{name}-mod_tls.conf
43 Source11: %{name}-anonftp.conf
44 Source12: %{name}-mod_clamav.conf
45 Patch0: %{name}-paths.patch
46 Patch1: %{name}-noautopriv.patch
47 Patch2: %{name}-wtmp.patch
48 Patch3: %{name}-pool.patch
49 Patch4: %{name}-nostrip.patch
50 Patch5: %{name}-link.patch
51 URL: http://www.proftpd.org/
52 BuildRequires: acl-devel
53 BuildRequires: autoconf
54 BuildRequires: automake
55 BuildRequires: libcap-devel
56 BuildRequires: libstdc++-devel
57 BuildRequires: libwrap-devel
58 %if %{with mysql} || %{with quotamysql}
59 BuildRequires: mysql-devel
61 BuildRequires: ncurses-devel
62 %if %{with ldap} || %{with quotaldap}
63 BuildRequires: openldap-devel
65 %{?with_ssl:BuildRequires: openssl-devel >= 0.9.7d}
66 %{?with_pam:BuildRequires: pam-devel}
67 %if %{with pgsql} || %{with quotapgsql}
68 BuildRequires: postgresql-devel
70 BuildRequires: rpmbuild(macros) >= 1.268
71 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
73 %define _sysconfdir /etc/ftpd
74 %define _localstatedir /var/run
75 %define _libexecdir %{_prefix}/%{_lib}/%{name}
78 ProFTPD is a highly configurable FTP daemon for Unix and Unix-like
79 operating systems. ProFTPD is designed to be somewhat of a "drop-in"
80 replacement for wu-ftpd. Full online documentation is available at
81 <http://www.proftpd.org/>, including a server configuration directive
84 %description -l es.UTF-8
85 ProFTPD es un servidor FTP altamente configurable para sistemas
86 operativos Unix. Está proyectado para ser un substituto directo al
87 wu-ftpd. La documentación completa está disponible en
88 <http://www.proftpd.org/>, incluido el manual de referencia para las
89 directivas de configuración del servidor.
91 %description -l pl.UTF-8
92 ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
93 ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
94 dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
95 włącznie z dokumentacją dotyczącą konfigurowania.
97 %description -l pt_BR.UTF-8
98 O ProFTPD é um servidor FTP altamente configurável para sistemas
101 É projetado para ser um substituto direto para o wu-ftpd. A
102 documentação completa está disponível em <http://www.proftpd.org/>,
103 incluindo o manual de referência para as diretivas de configuração do
107 Summary: PROfessional FTP Daemon with apache-like configuration syntax - common files
108 Summary(pl.UTF-8): PROfesionalny serwer FTP - wspólne pliki
109 Group: Networking/Daemons
111 Requires(post): fileutils
112 Obsoletes: proftpd < 0:1.2.2rc1-3
115 ProFTPD is a highly configurable FTP daemon for Unix and Unix-like
116 operating systems. ProFTPD is designed to be somewhat of a "drop-in"
117 replacement for wu-ftpd. Full online documentation is available at
118 <http://www.proftpd.org/>, including a server configuration directive
121 %description common -l es.UTF-8
122 ProFTPD es un servidor FTP altamente configurable para sistemas
123 operativos Unix. Está proyectado para ser un substituto directo al
124 wu-ftpd. La documentación completa está disponible en
125 <http://www.proftpd.org/>, incluido el manual de referencia para las
126 directivas de configuración del servidor.
128 %description common -l pl.UTF-8
129 ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
130 ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
131 dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
132 włącznie z dokumentacją dotyczącą konfigurowania.
134 %description common -l pt_BR.UTF-8
135 O ProFTPD é um servidor FTP altamente configurável para sistemas
138 É projetado para ser um substituto direto para o wu-ftpd. A
139 documentação completa está disponível em <http://www.proftpd.org/>,
140 incluindo o manual de referência para as diretivas de configuração do
144 Summary: inetd configs for proftpd
145 Summary(pl.UTF-8): Pliki konfiguracyjne do użycia proftpd poprzez inetd
146 Group: Networking/Daemons
147 Requires(post): fileutils
149 Requires(post): sed >= 4.0
150 Requires(triggerpostun): sed >= 4.0
151 Requires: %{name}-common = %{epoch}:%{version}-%{release}
154 Provides: proftpd = %{epoch}:%{version}-%{release}
160 Obsoletes: heimdal-ftpd
162 Obsoletes: linux-ftpd
163 Obsoletes: muddleftpd
164 Obsoletes: proftpd-standalone
166 Obsoletes: troll-ftpd
169 Conflicts: man-pages < 1.51
170 Conflicts: rpm < 4.4.2-0.2
173 ProFTPD configs for running from inetd.
175 %description inetd -l pl.UTF-8
176 Pliki konfiguracyjna ProFTPD do startowania demona poprzez inetd.
179 Summary: Standalone daemon configs for proftpd
180 Summary(pl.UTF-8): Pliki konfiguracyjne do startowania proftpd w trybie standalone
181 Group: Networking/Daemons
182 Requires(post): fileutils
184 Requires(post): sed >= 4.0
185 Requires(post,preun): /sbin/chkconfig
186 Requires(triggerpostun): sed >= 4.0
187 Requires: %{name}-common = %{epoch}:%{version}-%{release}
190 Provides: proftpd = %{epoch}:%{version}-%{release}
196 Obsoletes: heimdal-ftpd
198 Obsoletes: linux-ftpd
199 Obsoletes: muddleftpd
200 Obsoletes: proftpd-inetd
202 Obsoletes: troll-ftpd
205 Conflicts: man-pages < 1.51
206 Conflicts: rpm < 4.4.2-0.2
208 %description standalone
209 ProFTPD configs for running as a standalone daemon.
211 %description standalone -l pl.UTF-8
212 Pliki konfiguracyjne ProFTPD do startowania demona w trybie
216 Summary: Header files ProFTPD
217 Summary(pl.UTF-8): Pliki nagłówkowe ProFTPD
218 Group: Development/Libraries
222 This is the package containing the header files for ProFTPD.
224 %description devel -l pl.UTF-8
225 Ten pakiet zawiera pliki nagłówkowe ProFTPD
228 Summary: Anonymous FTP config for ProFTPD
229 Summary(pl.UTF-8): Konfiguracja anonimowego FTP dla ProFTPD
230 Group: Networking/Daemons
231 Requires: %{name}-common = %{epoch}:%{version}-%{release}
234 Anonymous FTP config for ProFTPD.
236 %description anonftp -l pl.UTF-8
237 Konfiguracja anonimowego FTP dla ProFTPD.
239 %package mod_auth_pam
240 Summary: ProFTPD PAM auth module
241 Summary(pl.UTF-8): Moduł uwierzytelnienia PAM dla ProFTPD
242 Group: Networking/Daemons
243 Requires: %{name}-common = %{epoch}:%{version}-%{release}
244 Requires: pam >= 0.79.0
246 %description mod_auth_pam
247 PAM authentication method for ProFTPD.
249 %description mod_auth_pam -l pl.UTF-8
250 Metoda uwierzytelnienia PAM dla ProFTPD.
253 Summary: ProFTPD OpenLDAP module
254 Summary(pl.UTF-8): Moduł OpenLDAP dla ProFTPD
255 Group: Networking/Daemons
256 Requires: %{name}-common = %{epoch}:%{version}-%{release}
258 %description mod_ldap
259 mod_ldap provides LDAP authentication support for ProFTPD. It supports
260 many features useful in "toaster" environments such as default UID/GID
261 and autocreation/autogeneration of home directories.
263 %description mod_ldap -l pl.UTF-8
264 mod_ldap dodaje obsługę uwierzytelnienia LDAP do ProFTPD. Obsługuje
265 wiele cech przydatnych w środowiskach "tosterowych", takich jak
266 domyślny UID/GID i automatyczne tworzenie/generowanie katalogów
269 %package mod_quotatab
270 Summary: ProFTPD quotatab module
271 Summary(pl.UTF-8): Moduł quotatab dla ProFTPD
272 Group: Networking/Daemons
273 Requires: %{name}-common = %{epoch}:%{version}-%{release}
275 %description mod_quotatab
276 A module for managing FTP byte/file quotas via centralized tables.
278 %description mod_quotatab -l pl.UTF-8
279 Moduł do zarządzania ograniczeniami bajtów/plików FTP poprzez
280 scentralizowane tabele.
282 %package mod_quotatab_file
283 Summary: ProFTPD quotatab file module
284 Summary(pl.UTF-8): Moduł quotatab_file dla ProFTPD
285 Group: Networking/Daemons
286 Requires: %{name}-common = %{epoch}:%{version}-%{release}
287 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
289 %description mod_quotatab_file
290 A mod_quotatab sub-module for managing quota data via file-based
293 %description mod_quotatab_file -l pl.UTF-8
294 Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
295 tabele zapisane w pliku.
297 %package mod_quotatab_ldap
298 Summary: ProFTPD quotatab ldap module
299 Summary(pl.UTF-8): Moduł quotatab_ldap dla ProFTPD
300 Group: Networking/Daemons
301 Requires: %{name}-common = %{epoch}:%{version}-%{release}
302 Requires: %{name}-mod_ldap = %{epoch}:%{version}-%{release}
303 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
305 %description mod_quotatab_ldap
306 A mod_quotatab sub-module for obtaining quota information from an LDAP
309 %description mod_quotatab_ldap -l pl.UTF-8
310 Podmoduł mod_quotatab do pobierania informacji o ograniczeniach z
313 %package mod_quotatab_sql
314 Summary: ProFTPD quotatab sql module
315 Summary(pl.UTF-8): Moduł quotatab_sql dla ProFTPD
316 Group: Networking/Daemons
317 Requires: %{name}-common = %{epoch}:%{version}-%{release}
318 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
319 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
321 %description mod_quotatab_sql
322 A mod_quotatab sub-module for managing quota data via SQL-based
325 %description mod_quotatab_sql -l pl.UTF-8
326 Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
330 Summary: ProFTPD ratio module
331 Summary(pl.UTF-8): Moduł ratio dla ProFTPD
332 Group: Networking/Daemons
333 Requires: %{name}-common = %{epoch}:%{version}-%{release}
335 %description mod_ratio
336 Support upload/download ratios.
338 %description mod_ratio -l pl.UTF-8
339 Obsługa współczynników upload/download.
342 Summary: ProFTPD readme module
343 Summary(pl.UTF-8): Moduł readme dla ProFTPD
344 Group: Networking/Daemons
345 Requires: %{name}-common = %{epoch}:%{version}-%{release}
347 %description mod_readme
348 "README" file support.
350 %description mod_readme -l pl.UTF-8
351 Obsługa pliku "README".
354 Summary: ProFTPD rewrite module
355 Summary(pl.UTF-8): Moduł rewrite dla ProFTPD
356 Group: Networking/Daemons
357 Requires: %{name}-common = %{epoch}:%{version}-%{release}
359 %description mod_rewrite
360 Runtime rewrite engine.
362 %description mod_rewrite -l pl.UTF-8
363 Silnik przepisujący adresy w locie.
366 Summary: ProFTPD SQL support module
367 Summary(pl.UTF-8): Moduł obsługi SQL dla ProFTPD
368 Group: Networking/Daemons
369 Requires: %{name}-common = %{epoch}:%{version}-%{release}
372 This module provides the necessary support for SQL based
373 authentication, logging and other features as required.
375 %description mod_sql -l pl.UTF-8
376 Ten moduł dodaje obsługę SQL potrzebną do uwierzytelniania, logowania
377 i innych możliwości opartych o SQL.
379 %package mod_sql_mysql
380 Summary: ProFTPD sql mysql module
381 Summary(pl.UTF-8): Moduł sql_mysql dla ProFTPD
382 Group: Networking/Daemons
383 Requires: %{name}-common = %{epoch}:%{version}-%{release}
384 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
386 %description mod_sql_mysql
387 Support for connecting to MySQL databases.
389 %description mod_sql_mysql -l pl.UTF-8
390 Obsługa łączenia się z bazami danych MySQL.
392 %package mod_sql_postgres
393 Summary: ProFTPD sql postgres module
394 Summary(pl.UTF-8): Moduł sql_postgres dla ProFTPD
395 Group: Networking/Daemons
396 Requires: %{name}-common = %{epoch}:%{version}-%{release}
397 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
399 %description mod_sql_postgres
400 Support for connecting to PostgreSQL databases.
402 %description mod_sql_postgres -l pl.UTF-8
403 Obsługa łączenia się z bazami danych PostgreSQL.
406 Summary: ProFTPD TLS support
407 Summary(pl.UTF-8): Obsługa TLS dla ProFTPD
408 Group: Networking/Daemons
409 Requires: %{name}-common = %{epoch}:%{version}-%{release}
412 An RFC2228 SSL/TLS module for ProFTPD.
414 %description mod_tls -l pl.UTF-8
415 Moduł SSL/TLS zgodny z RFC2228 dla ProFTPD.
418 Summary: ProFTPD interface to libwrap
419 Summary(pl.UTF-8): Interfejs ProFTPD do libwrap
420 Group: Networking/Daemons
421 Requires: %{name}-common = %{epoch}:%{version}-%{release}
424 %description mod_wrap
425 It enables the daemon to use the common tcpwrappers access control
426 library while in standalone mode, and in a very configurable manner.
428 Many programs will automatically add entries in the common allow/deny
429 files, and use of this module will allow a ProFTPD daemon running in
430 standalone mode to adapt as these entries are added. The portsentry
431 program does this, for example: when illegal access is attempted, it
432 will add hosts to the /etc/hosts.deny file.
434 %description mod_wrap -l pl.UTF-8
435 Ten pakiet pozwala demonowi używać wspólnej biblioteki kontroli
436 dostępu tcpwrappers w trybie samodzielnym w bardzo wygodny sposób.
438 Wiele programów automatycznie dodaje wpisy we wspólnych plikach
439 allow/deny, a użycie tego modułu pozwala demonowi ProFTPD działającemu
440 w trybie samodzielnym adaptować te wpisy w miarę dodawania. Robi tak
441 na przykład program portsentry: przy próbie niedozwolonego dostępu
442 dodaje hosty do pliku /etc/hosts.deny.
445 %setup -q -n %{name}-%{version}%{?_rc} -a1
454 patch -p0 < mod_clamav-%{mod_clamav_version}/proftpd.patch
455 cp -a mod_clamav-%{mod_clamav_version}/*.{c,h} contrib/
457 cp -f /usr/share/automake/config.sub .
459 # cleanup backups after patching
460 find . '(' -name '*~' -o -name '*.orig' ')' -print0 | xargs -0 -r -l512 rm -f
476 %{?with_pam:mod_auth_pam}
477 %{?with_ldap:mod_ldap}
478 %{?with_quotafile:mod_quotatab mod_quotatab_file}
479 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
480 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
481 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
482 %{?with_mysql:mod_sql mod_sql_mysql}
483 %{?with_pgsql:mod_sql mod_sql_postgres}
486 MODARG=$(echo $MODULES | tr ' ' '\n' | sort -u | xargs | tr ' ' ':')
488 --with-includes=/usr/include/ncurses%{?with_mysql::%{_includedir}/mysql} \
489 --disable-auth-file \
490 --enable-autoshadow \
493 %{?with_ipv6:--enable-ipv6} \
495 %{!?with_ssl:--disable-tls} \
496 --with-shared=$MODARG \
497 --with-modules=mod_clamav
502 rm -rf $RPM_BUILD_ROOT
503 install -d $RPM_BUILD_ROOT/etc/{pam.d,security,sysconfig/rc-inetd,rc.d/init.d} \
504 $RPM_BUILD_ROOT/var/{lib/ftp/pub/Incoming,log,run/proftpd} \
505 $RPM_BUILD_ROOT%{_sysconfdir}/conf.d \
506 $RPM_BUILD_ROOT%{_includedir}/%{name}
509 DESTDIR=$RPM_BUILD_ROOT \
510 INSTALL_USER=%(id -u) \
511 INSTALL_GROUP=%(id -g)
513 rm $RPM_BUILD_ROOT%{_sbindir}/in.proftpd
515 install %{SOURCE2} $RPM_BUILD_ROOT%{_sysconfdir}
516 install %{SOURCE9} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_auth_pam.conf
524 %{?with_ldap:mod_ldap}
525 %{?with_quotafile:mod_quotatab mod_quotatab_file}
526 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
527 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
528 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
529 %{?with_mysql:mod_sql mod_sql_mysql}
530 %{?with_pgsql:mod_sql mod_sql_postgres}
532 for module in $MODULES; do
533 echo "LoadModule $module.c" > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/$module.conf
535 install %{SOURCE10} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_tls.conf
536 install %{SOURCE11} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/anonftp.conf
537 install %{SOURCE12} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_clamav.conf
539 %{?with_pam:install %{SOURCE3} $RPM_BUILD_ROOT/etc/pam.d/ftp}
540 install %{SOURCE4} $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/ftpd
541 install %{SOURCE5} $RPM_BUILD_ROOT/etc/sysconfig/proftpd
542 install %{SOURCE6} $RPM_BUILD_ROOT/etc/rc.d/init.d/proftpd
543 install contrib/xferstats.holger-preiss $RPM_BUILD_ROOT%{_bindir}/xferstat
545 bzip2 -dc %{SOURCE7} | tar xf - -C $RPM_BUILD_ROOT%{_mandir}
547 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers.default
548 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers
550 # only for -inetd package?
551 ln -sf proftpd $RPM_BUILD_ROOT%{_sbindir}/ftpd
553 :> $RPM_BUILD_ROOT/etc/security/blacklist.ftp
555 rm $RPM_BUILD_ROOT%{_libexecdir}/*.a
556 rm $RPM_BUILD_ROOT%{_libexecdir}/*.la
558 rm -f $RPM_BUILD_ROOT%{_mandir}/ftpusers-path.diff*
559 cp -aL include/* config.h $RPM_BUILD_ROOT%{_includedir}/%{name}
562 rm -rf $RPM_BUILD_ROOT
566 awk -F: '{ if (($3 < 500) && ($1 != "ftp")) print $1; }' < /etc/passwd >> %{_sysconfdir}/ftpusers.default
567 if [ ! -f %{_sysconfdir}/ftpusers ]; then
568 cp -f %{_sysconfdir}/ftpusers.default %{_sysconfdir}/ftpusers
572 if grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf ; then
573 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
574 sed -i -e 's/^ServerType[[:space:]]\+standalone/ServerType inetd/g' %{_sysconfdir}/proftpd.conf
576 %service -q rc-inetd reload
579 if [ "$1" = "0" ]; then
580 %service -q rc-inetd reload
583 %posttrans standalone
584 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf ; then
585 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
586 sed -i -e 's/^ServerType[[:space:]]\+inetd/ServerType standalone/g' %{_sysconfdir}/proftpd.conf
588 /sbin/chkconfig --add proftpd
589 %service proftpd restart "ProFTPD daemon"
592 if [ "$1" = "0" ]; then
593 %service proftpd stop
594 /sbin/chkconfig --del proftpd
597 # macro called at module post scriptlet
598 %define module_post \
599 if [ "$1" = "1" ]; then \
600 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
601 %service -q rc-inetd reload \
602 elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
603 %service -q proftpd restart \
607 # macro called at module postun scriptlet
608 %define module_postun \
609 if [ "$1" = "0" ]; then \
610 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
611 %service -q rc-inetd reload \
612 elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
613 %service -q proftpd restart \
617 # it's sooo annoying to write them
618 %define module_scripts() \
625 %module_scripts mod_auth_pam
626 %module_scripts mod_ldap
627 %module_scripts mod_quotatab
628 %module_scripts mod_quotatab_file
629 %module_scripts mod_quotatab_ldap
630 %module_scripts mod_quotatab_sql
631 %module_scripts mod_ratio
632 %module_scripts mod_readme
633 %module_scripts mod_rewrite
634 %module_scripts mod_sql
635 %module_scripts mod_sql_mysql
636 %module_scripts mod_sql_postgres
637 %module_scripts mod_tls
638 %module_scripts mod_wrap
641 %defattr(644,root,root,755)
642 %doc sample-configurations/*.conf CREDITS ChangeLog NEWS RELEASE_NOTES
643 %doc README README.capabilities README.classes README.controls README.IPv6
645 %doc doc/*.html doc/contrib doc/howto doc/modules
646 %dir %attr(750,root,ftp) %dir %{_sysconfdir}
647 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*.conf
648 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %ghost %{_sysconfdir}/ftpusers
649 %attr(640,root,root) %{_sysconfdir}/ftpusers.default
650 %dir %attr(750,root,root) %{_sysconfdir}/conf.d
651 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_file.conf
652 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ident.conf
653 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_clamav.conf
654 #%attr(640,root,root) %ghost /var/log/*
655 %attr(755,root,root) %{_bindir}/*
656 %attr(755,root,root) %{_sbindir}/*
658 %attr(755,root,root) %{_libexecdir}/mod_auth_file.so
659 %attr(755,root,root) %{_libexecdir}/mod_facl.so
660 %attr(755,root,root) %{_libexecdir}/mod_ident.so
661 %attr(755,root,root) %{_libexecdir}/mod_ifsession.so
662 %attr(755,root,root) %{_libexecdir}/mod_lang.so
663 %dir %{_localstatedir}/proftpd
666 %dir /var/lib/ftp/pub
667 %attr(711,ftp,ftp) %dir /var/lib/ftp/pub/Incoming
670 %defattr(644,root,root,755)
671 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/rc-inetd/ftpd
673 %lang(ja) %{_mandir}/ja/man5/ftpusers*
674 %lang(pl) %{_mandir}/pl/man5/ftpusers*
675 %lang(pt_BR) %{_mandir}/pt_BR/man5/ftpusers*
676 %lang(ru) %{_mandir}/ru/man5/ftpusers*
679 %defattr(644,root,root,755)
680 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/proftpd
681 %attr(754,root,root) /etc/rc.d/init.d/proftpd
683 %lang(ja) %{_mandir}/ja/man5/ftpusers*
684 %lang(pl) %{_mandir}/pl/man5/ftpusers*
685 %lang(pt_BR) %{_mandir}/pt_BR/man5/ftpusers*
686 %lang(ru) %{_mandir}/ru/man5/ftpusers*
689 %defattr(644,root,root,755)
690 %{_includedir}/%{name}
691 %{_pkgconfigdir}/%{name}.pc
694 %defattr(644,root,root,755)
695 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/anonftp.conf
699 %defattr(644,root,root,755)
701 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/pam.d/*
702 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/security/blacklist.ftp
703 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_pam.conf
704 %attr(755,root,root) %{_libexecdir}/mod_auth_pam.so
709 %defattr(644,root,root,755)
711 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ldap.conf
712 %attr(755,root,root) %{_libexecdir}/mod_ldap.so
716 %defattr(644,root,root,755)
717 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab.conf
718 %attr(755,root,root) %{_libexecdir}/mod_quotatab.so
720 %if %{with quotafile}
721 %files mod_quotatab_file
722 %defattr(644,root,root,755)
723 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_file.conf
724 %attr(755,root,root) %{_libexecdir}/mod_quotatab_file.so
727 %if %{with quotaldap}
728 %files mod_quotatab_ldap
729 %defattr(644,root,root,755)
730 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_ldap.conf
731 %attr(755,root,root) %{_libexecdir}/mod_quotatab_ldap.so
734 %if %{with quotamysql} || %{with quotapgsql}
735 %files mod_quotatab_sql
736 %defattr(644,root,root,755)
737 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_sql.conf
738 %attr(755,root,root) %{_libexecdir}/mod_quotatab_sql.so
742 %defattr(644,root,root,755)
743 %doc contrib/README.ratio
744 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ratio.conf
745 %attr(755,root,root) %{_libexecdir}/mod_ratio.so
748 %defattr(644,root,root,755)
749 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_readme.conf
750 %attr(755,root,root) %{_libexecdir}/mod_readme.so
753 %defattr(644,root,root,755)
754 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_rewrite.conf
755 %attr(755,root,root) %{_libexecdir}/mod_rewrite.so
757 %if %{with mysql} || %{with pgsql}
759 %defattr(644,root,root,755)
760 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql.conf
761 %attr(755,root,root) %{_libexecdir}/mod_sql.so
766 %defattr(644,root,root,755)
767 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_mysql.conf
768 %attr(755,root,root) %{_libexecdir}/mod_sql_mysql.so
772 %files mod_sql_postgres
773 %defattr(644,root,root,755)
774 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_postgres.conf
775 %attr(755,root,root) %{_libexecdir}/mod_sql_postgres.so
779 %defattr(644,root,root,755)
780 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_tls.conf
781 %attr(755,root,root) %{_libexecdir}/mod_tls.so
784 %defattr(644,root,root,755)
785 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_wrap.conf
786 %attr(755,root,root) %{_libexecdir}/mod_wrap.so