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: f7b8e3a383b34a894c2502db74ccccde
33 Source1: https://secure.thrallingpenguin.com/redmine/attachments/download/1/mod_clamav-%{mod_clamav_version}.tar.gz
34 # Source1-md5: 42e560ec0bd5964e13fad1b2bb7afe21
37 Source4: %{name}.inetd
38 Source5: %{name}.sysconfig
40 Source7: ftpusers.tar.bz2
41 # Source7-md5: 76c80b6ec9f4d079a1e27316edddbe16
42 Source9: %{name}-mod_pam.conf
43 Source10: %{name}-mod_tls.conf
44 Source11: %{name}-anonftp.conf
45 Source12: %{name}-mod_clamav.conf
46 Source13: %{name}.tmpfiles
47 Patch0: %{name}-paths.patch
48 Patch1: %{name}-noautopriv.patch
49 Patch2: %{name}-wtmp.patch
50 Patch3: %{name}-pool.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}
77 %define filterout -flto
80 ProFTPD is a highly configurable FTP daemon for Unix and Unix-like
81 operating systems. ProFTPD is designed to be somewhat of a "drop-in"
82 replacement for wu-ftpd. Full online documentation is available at
83 <http://www.proftpd.org/>, including a server configuration directive
86 %description -l es.UTF-8
87 ProFTPD es un servidor FTP altamente configurable para sistemas
88 operativos Unix. Está proyectado para ser un substituto directo al
89 wu-ftpd. La documentación completa está disponible en
90 <http://www.proftpd.org/>, incluido el manual de referencia para las
91 directivas de configuración del servidor.
93 %description -l pl.UTF-8
94 ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
95 ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
96 dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
97 włącznie z dokumentacją dotyczącą konfigurowania.
99 %description -l pt_BR.UTF-8
100 O ProFTPD é um servidor FTP altamente configurável para sistemas
103 É projetado para ser um substituto direto para o wu-ftpd. A
104 documentação completa está disponível em <http://www.proftpd.org/>,
105 incluindo o manual de referência para as diretivas de configuração do
109 Summary: PROfessional FTP Daemon with apache-like configuration syntax - common files
110 Summary(pl.UTF-8): PROfesionalny serwer FTP - wspólne pliki
111 Group: Networking/Daemons
113 Requires(post): fileutils
114 Obsoletes: proftpd < 0:1.2.2rc1-3
117 ProFTPD is a highly configurable FTP daemon for Unix and Unix-like
118 operating systems. ProFTPD is designed to be somewhat of a "drop-in"
119 replacement for wu-ftpd. Full online documentation is available at
120 <http://www.proftpd.org/>, including a server configuration directive
123 %description common -l es.UTF-8
124 ProFTPD es un servidor FTP altamente configurable para sistemas
125 operativos Unix. Está proyectado para ser un substituto directo al
126 wu-ftpd. La documentación completa está disponible en
127 <http://www.proftpd.org/>, incluido el manual de referencia para las
128 directivas de configuración del servidor.
130 %description common -l pl.UTF-8
131 ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
132 ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
133 dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
134 włącznie z dokumentacją dotyczącą konfigurowania.
136 %description common -l pt_BR.UTF-8
137 O ProFTPD é um servidor FTP altamente configurável para sistemas
140 É projetado para ser um substituto direto para o wu-ftpd. A
141 documentação completa está disponível em <http://www.proftpd.org/>,
142 incluindo o manual de referência para as diretivas de configuração do
146 Summary: inetd configs for proftpd
147 Summary(pl.UTF-8): Pliki konfiguracyjne do użycia proftpd poprzez inetd
148 Group: Networking/Daemons
149 Requires(post): fileutils
151 Requires(post): sed >= 4.0
152 Requires(triggerpostun): sed >= 4.0
153 Requires: %{name}-common = %{epoch}:%{version}-%{release}
156 Provides: proftpd = %{epoch}:%{version}-%{release}
162 Obsoletes: heimdal-ftpd
164 Obsoletes: linux-ftpd
165 Obsoletes: muddleftpd
166 Obsoletes: proftpd-standalone
168 Obsoletes: troll-ftpd
171 Conflicts: man-pages < 1.51
172 Conflicts: rpm < 4.4.2-0.2
175 ProFTPD configs for running from inetd.
177 %description inetd -l pl.UTF-8
178 Pliki konfiguracyjna ProFTPD do startowania demona poprzez inetd.
181 Summary: Standalone daemon configs for proftpd
182 Summary(pl.UTF-8): Pliki konfiguracyjne do startowania proftpd w trybie standalone
183 Group: Networking/Daemons
184 Requires(post): fileutils
186 Requires(post): sed >= 4.0
187 Requires(post,preun): /sbin/chkconfig
188 Requires(triggerpostun): sed >= 4.0
189 Requires: %{name}-common = %{epoch}:%{version}-%{release}
192 Provides: proftpd = %{epoch}:%{version}-%{release}
198 Obsoletes: heimdal-ftpd
200 Obsoletes: linux-ftpd
201 Obsoletes: muddleftpd
202 Obsoletes: proftpd-inetd
204 Obsoletes: troll-ftpd
207 Conflicts: man-pages < 1.51
208 Conflicts: rpm < 4.4.2-0.2
210 %description standalone
211 ProFTPD configs for running as a standalone daemon.
213 %description standalone -l pl.UTF-8
214 Pliki konfiguracyjne ProFTPD do startowania demona w trybie
218 Summary: Header files ProFTPD
219 Summary(pl.UTF-8): Pliki nagłówkowe ProFTPD
220 Group: Development/Libraries
224 This is the package containing the header files for ProFTPD.
226 %description devel -l pl.UTF-8
227 Ten pakiet zawiera pliki nagłówkowe ProFTPD
230 Summary: Anonymous FTP config for ProFTPD
231 Summary(pl.UTF-8): Konfiguracja anonimowego FTP dla ProFTPD
232 Group: Networking/Daemons
233 Requires: %{name}-common = %{epoch}:%{version}-%{release}
236 Anonymous FTP config for ProFTPD.
238 %description anonftp -l pl.UTF-8
239 Konfiguracja anonimowego FTP dla ProFTPD.
241 %package mod_auth_pam
242 Summary: ProFTPD PAM auth module
243 Summary(pl.UTF-8): Moduł uwierzytelnienia PAM dla ProFTPD
244 Group: Networking/Daemons
245 Requires: %{name}-common = %{epoch}:%{version}-%{release}
246 Requires: pam >= 0.79.0
248 %description mod_auth_pam
249 PAM authentication method for ProFTPD.
251 %description mod_auth_pam -l pl.UTF-8
252 Metoda uwierzytelnienia PAM dla ProFTPD.
255 Summary: ProFTPD OpenLDAP module
256 Summary(pl.UTF-8): Moduł OpenLDAP dla ProFTPD
257 Group: Networking/Daemons
258 Requires: %{name}-common = %{epoch}:%{version}-%{release}
260 %description mod_ldap
261 mod_ldap provides LDAP authentication support for ProFTPD. It supports
262 many features useful in "toaster" environments such as default UID/GID
263 and autocreation/autogeneration of home directories.
265 %description mod_ldap -l pl.UTF-8
266 mod_ldap dodaje obsługę uwierzytelnienia LDAP do ProFTPD. Obsługuje
267 wiele cech przydatnych w środowiskach "tosterowych", takich jak
268 domyślny UID/GID i automatyczne tworzenie/generowanie katalogów
271 %package mod_quotatab
272 Summary: ProFTPD quotatab module
273 Summary(pl.UTF-8): Moduł quotatab dla ProFTPD
274 Group: Networking/Daemons
275 Requires: %{name}-common = %{epoch}:%{version}-%{release}
277 %description mod_quotatab
278 A module for managing FTP byte/file quotas via centralized tables.
280 %description mod_quotatab -l pl.UTF-8
281 Moduł do zarządzania ograniczeniami bajtów/plików FTP poprzez
282 scentralizowane tabele.
284 %package mod_quotatab_file
285 Summary: ProFTPD quotatab file module
286 Summary(pl.UTF-8): Moduł quotatab_file dla ProFTPD
287 Group: Networking/Daemons
288 Requires: %{name}-common = %{epoch}:%{version}-%{release}
289 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
291 %description mod_quotatab_file
292 A mod_quotatab sub-module for managing quota data via file-based
295 %description mod_quotatab_file -l pl.UTF-8
296 Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
297 tabele zapisane w pliku.
299 %package mod_quotatab_ldap
300 Summary: ProFTPD quotatab ldap module
301 Summary(pl.UTF-8): Moduł quotatab_ldap dla ProFTPD
302 Group: Networking/Daemons
303 Requires: %{name}-common = %{epoch}:%{version}-%{release}
304 Requires: %{name}-mod_ldap = %{epoch}:%{version}-%{release}
305 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
307 %description mod_quotatab_ldap
308 A mod_quotatab sub-module for obtaining quota information from an LDAP
311 %description mod_quotatab_ldap -l pl.UTF-8
312 Podmoduł mod_quotatab do pobierania informacji o ograniczeniach z
315 %package mod_quotatab_sql
316 Summary: ProFTPD quotatab sql module
317 Summary(pl.UTF-8): Moduł quotatab_sql dla ProFTPD
318 Group: Networking/Daemons
319 Requires: %{name}-common = %{epoch}:%{version}-%{release}
320 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
321 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
323 %description mod_quotatab_sql
324 A mod_quotatab sub-module for managing quota data via SQL-based
327 %description mod_quotatab_sql -l pl.UTF-8
328 Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
332 Summary: ProFTPD ratio module
333 Summary(pl.UTF-8): Moduł ratio dla ProFTPD
334 Group: Networking/Daemons
335 Requires: %{name}-common = %{epoch}:%{version}-%{release}
337 %description mod_ratio
338 Support upload/download ratios.
340 %description mod_ratio -l pl.UTF-8
341 Obsługa współczynników upload/download.
344 Summary: ProFTPD readme module
345 Summary(pl.UTF-8): Moduł readme dla ProFTPD
346 Group: Networking/Daemons
347 Requires: %{name}-common = %{epoch}:%{version}-%{release}
349 %description mod_readme
350 "README" file support.
352 %description mod_readme -l pl.UTF-8
353 Obsługa pliku "README".
356 Summary: ProFTPD rewrite module
357 Summary(pl.UTF-8): Moduł rewrite dla ProFTPD
358 Group: Networking/Daemons
359 Requires: %{name}-common = %{epoch}:%{version}-%{release}
361 %description mod_rewrite
362 Runtime rewrite engine.
364 %description mod_rewrite -l pl.UTF-8
365 Silnik przepisujący adresy w locie.
368 Summary: ProFTPD SQL support module
369 Summary(pl.UTF-8): Moduł obsługi SQL dla ProFTPD
370 Group: Networking/Daemons
371 Requires: %{name}-common = %{epoch}:%{version}-%{release}
374 This module provides the necessary support for SQL based
375 authentication, logging and other features as required.
377 %description mod_sql -l pl.UTF-8
378 Ten moduł dodaje obsługę SQL potrzebną do uwierzytelniania, logowania
379 i innych możliwości opartych o SQL.
381 %package mod_sql_mysql
382 Summary: ProFTPD sql mysql module
383 Summary(pl.UTF-8): Moduł sql_mysql dla ProFTPD
384 Group: Networking/Daemons
385 Requires: %{name}-common = %{epoch}:%{version}-%{release}
386 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
388 %description mod_sql_mysql
389 Support for connecting to MySQL databases.
391 %description mod_sql_mysql -l pl.UTF-8
392 Obsługa łączenia się z bazami danych MySQL.
394 %package mod_sql_postgres
395 Summary: ProFTPD sql postgres module
396 Summary(pl.UTF-8): Moduł sql_postgres dla ProFTPD
397 Group: Networking/Daemons
398 Requires: %{name}-common = %{epoch}:%{version}-%{release}
399 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
401 %description mod_sql_postgres
402 Support for connecting to PostgreSQL databases.
404 %description mod_sql_postgres -l pl.UTF-8
405 Obsługa łączenia się z bazami danych PostgreSQL.
408 Summary: ProFTPD TLS support
409 Summary(pl.UTF-8): Obsługa TLS dla ProFTPD
410 Group: Networking/Daemons
411 Requires: %{name}-common = %{epoch}:%{version}-%{release}
414 An RFC2228 SSL/TLS module for ProFTPD.
416 %description mod_tls -l pl.UTF-8
417 Moduł SSL/TLS zgodny z RFC2228 dla ProFTPD.
420 Summary: ProFTPD interface to libwrap
421 Summary(pl.UTF-8): Interfejs ProFTPD do libwrap
422 Group: Networking/Daemons
423 Requires: %{name}-common = %{epoch}:%{version}-%{release}
426 %description mod_wrap
427 It enables the daemon to use the common tcpwrappers access control
428 library while in standalone mode, and in a very configurable manner.
430 Many programs will automatically add entries in the common allow/deny
431 files, and use of this module will allow a ProFTPD daemon running in
432 standalone mode to adapt as these entries are added. The portsentry
433 program does this, for example: when illegal access is attempted, it
434 will add hosts to the /etc/hosts.deny file.
436 %description mod_wrap -l pl.UTF-8
437 Ten pakiet pozwala demonowi używać wspólnej biblioteki kontroli
438 dostępu tcpwrappers w trybie samodzielnym w bardzo wygodny sposób.
440 Wiele programów automatycznie dodaje wpisy we wspólnych plikach
441 allow/deny, a użycie tego modułu pozwala demonowi ProFTPD działającemu
442 w trybie samodzielnym adaptować te wpisy w miarę dodawania. Robi tak
443 na przykład program portsentry: przy próbie niedozwolonego dostępu
444 dodaje hosty do pliku /etc/hosts.deny.
447 %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
475 %{?with_pam:mod_auth_pam}
476 %{?with_ldap:mod_ldap}
477 %{?with_quotafile:mod_quotatab mod_quotatab_file}
478 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
479 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
480 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
481 %{?with_mysql:mod_sql mod_sql_mysql}
482 %{?with_pgsql:mod_sql mod_sql_postgres}
485 MODARG=$(echo $MODULES | tr ' ' '\n' | sort -u | xargs | tr ' ' ':')
487 --with-includes=/usr/include/ncurses%{?with_mysql::%{_includedir}/mysql} \
489 --enable-buffer-size=4096 \
490 --disable-auth-file \
491 --enable-autoshadow \
495 %{?with_ipv6:--enable-ipv6} \
497 %{!?with_ssl:--disable-tls} \
498 --with-shared=$MODARG \
499 --with-modules=mod_clamav
504 rm -rf $RPM_BUILD_ROOT
505 install -d $RPM_BUILD_ROOT/etc/{pam.d,security,sysconfig/rc-inetd,rc.d/init.d} \
506 $RPM_BUILD_ROOT/var/{lib/ftp/pub/Incoming,log,run/proftpd} \
507 $RPM_BUILD_ROOT%{_sysconfdir}/conf.d \
508 $RPM_BUILD_ROOT%{_includedir}/%{name} \
509 $RPM_BUILD_ROOT/usr/lib/tmpfiles.d
512 DESTDIR=$RPM_BUILD_ROOT \
513 INSTALL_USER=%(id -u) \
514 INSTALL_GROUP=%(id -g)
516 rm $RPM_BUILD_ROOT%{_sbindir}/in.proftpd
518 install %{SOURCE2} $RPM_BUILD_ROOT%{_sysconfdir}
519 install %{SOURCE9} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_auth_pam.conf
527 %{?with_ldap:mod_ldap}
528 %{?with_quotafile:mod_quotatab mod_quotatab_file}
529 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
530 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
531 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
532 %{?with_mysql:mod_sql mod_sql_mysql}
533 %{?with_pgsql:mod_sql mod_sql_postgres}
535 for module in $MODULES; do
536 echo "LoadModule $module.c" > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/$module.conf
538 install %{SOURCE10} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_tls.conf
539 install %{SOURCE11} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/anonftp.conf
540 install %{SOURCE12} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_clamav.conf
542 %{?with_pam:install %{SOURCE3} $RPM_BUILD_ROOT/etc/pam.d/ftp}
543 install %{SOURCE4} $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/ftpd
544 install %{SOURCE5} $RPM_BUILD_ROOT/etc/sysconfig/proftpd
545 install %{SOURCE6} $RPM_BUILD_ROOT/etc/rc.d/init.d/proftpd
546 install contrib/xferstats.holger-preiss $RPM_BUILD_ROOT%{_bindir}/xferstat
548 bzip2 -dc %{SOURCE7} | tar xf - -C $RPM_BUILD_ROOT%{_mandir}
550 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers.default
551 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers
553 install %{SOURCE13} $RPM_BUILD_ROOT/usr/lib/tmpfiles.d/%{name}.conf
555 # only for -inetd package?
556 ln -sf proftpd $RPM_BUILD_ROOT%{_sbindir}/ftpd
558 :> $RPM_BUILD_ROOT/etc/security/blacklist.ftp
560 rm $RPM_BUILD_ROOT%{_libexecdir}/*.a
561 rm $RPM_BUILD_ROOT%{_libexecdir}/*.la
563 rm -f $RPM_BUILD_ROOT%{_mandir}/ftpusers-path.diff*
564 cp -aL include/* config.h $RPM_BUILD_ROOT%{_includedir}/%{name}
567 rm -rf $RPM_BUILD_ROOT
571 awk -F: '{ if (($3 < 500) && ($1 != "ftp")) print $1; }' < /etc/passwd >> %{_sysconfdir}/ftpusers.default
572 if [ ! -f %{_sysconfdir}/ftpusers ]; then
573 cp -f %{_sysconfdir}/ftpusers.default %{_sysconfdir}/ftpusers
577 if grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf ; then
578 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
579 sed -i -e 's/^ServerType[[:space:]]\+standalone/ServerType inetd/g' %{_sysconfdir}/proftpd.conf
581 %service -q rc-inetd reload
584 if [ "$1" = "0" ]; then
585 %service -q rc-inetd reload
588 %posttrans standalone
589 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf ; then
590 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
591 sed -i -e 's/^ServerType[[:space:]]\+inetd/ServerType standalone/g' %{_sysconfdir}/proftpd.conf
593 /sbin/chkconfig --add proftpd
594 %service proftpd restart "ProFTPD daemon"
597 if [ "$1" = "0" ]; then
598 %service proftpd stop
599 /sbin/chkconfig --del proftpd
602 %triggerin standalone -- pam
603 # restart proftpd if pam is upgraded
604 # (proftpd is linked with old libpam but tries to open modules linked with new libpam)
605 if [ "$2" != 1 ]; then
606 %service -q proftpd restart
609 # macro called at module post scriptlet
610 %define module_post \
611 if [ "$1" = "1" ]; then \
612 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
613 %service -q rc-inetd reload \
614 elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
615 %service -q proftpd restart \
619 # macro called at module postun scriptlet
620 %define module_postun \
621 if [ "$1" = "0" ]; 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 # it's sooo annoying to write them
630 %define module_scripts() \
637 %module_scripts mod_auth_pam
638 %module_scripts mod_ldap
639 %module_scripts mod_quotatab
640 %module_scripts mod_quotatab_file
641 %module_scripts mod_quotatab_ldap
642 %module_scripts mod_quotatab_sql
643 %module_scripts mod_ratio
644 %module_scripts mod_readme
645 %module_scripts mod_rewrite
646 %module_scripts mod_sql
647 %module_scripts mod_sql_mysql
648 %module_scripts mod_sql_postgres
649 %module_scripts mod_tls
650 %module_scripts mod_wrap
653 %defattr(644,root,root,755)
654 %doc sample-configurations/*.conf CREDITS ChangeLog NEWS RELEASE_NOTES
655 %doc README README.capabilities README.classes README.controls README.IPv6
657 %doc doc/*.html doc/contrib doc/howto doc/modules
658 %dir %attr(750,root,ftp) %dir %{_sysconfdir}
659 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*.conf
660 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %ghost %{_sysconfdir}/ftpusers
661 %attr(640,root,root) %{_sysconfdir}/ftpusers.default
662 %dir %attr(750,root,root) %{_sysconfdir}/conf.d
663 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_file.conf
664 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ident.conf
665 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_clamav.conf
666 #%attr(640,root,root) %ghost /var/log/*
667 %attr(755,root,root) %{_bindir}/*
668 %attr(755,root,root) %{_sbindir}/*
670 %attr(755,root,root) %{_libexecdir}/mod_auth_file.so
671 %attr(755,root,root) %{_libexecdir}/mod_facl.so
672 %attr(755,root,root) %{_libexecdir}/mod_ident.so
673 %attr(755,root,root) %{_libexecdir}/mod_ifsession.so
674 %dir %{_localstatedir}/proftpd
675 /usr/lib/tmpfiles.d/%{name}.conf
677 %lang(ja) %{_mandir}/ja/man5/ftpusers*
678 %lang(pl) %{_mandir}/pl/man5/ftpusers*
679 %lang(pt_BR) %{_mandir}/pt_BR/man5/ftpusers*
680 %lang(ru) %{_mandir}/ru/man5/ftpusers*
683 %dir /var/lib/ftp/pub
684 %attr(711,ftp,ftp) %dir /var/lib/ftp/pub/Incoming
687 %defattr(644,root,root,755)
688 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/rc-inetd/ftpd
691 %defattr(644,root,root,755)
692 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/proftpd
693 %attr(754,root,root) /etc/rc.d/init.d/proftpd
696 %defattr(644,root,root,755)
697 %{_includedir}/%{name}
698 %{_pkgconfigdir}/%{name}.pc
701 %defattr(644,root,root,755)
702 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/anonftp.conf
706 %defattr(644,root,root,755)
708 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/pam.d/*
709 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/security/blacklist.ftp
710 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_pam.conf
711 %attr(755,root,root) %{_libexecdir}/mod_auth_pam.so
716 %defattr(644,root,root,755)
718 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ldap.conf
719 %attr(755,root,root) %{_libexecdir}/mod_ldap.so
723 %defattr(644,root,root,755)
724 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab.conf
725 %attr(755,root,root) %{_libexecdir}/mod_quotatab.so
727 %if %{with quotafile}
728 %files mod_quotatab_file
729 %defattr(644,root,root,755)
730 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_file.conf
731 %attr(755,root,root) %{_libexecdir}/mod_quotatab_file.so
734 %if %{with quotaldap}
735 %files mod_quotatab_ldap
736 %defattr(644,root,root,755)
737 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_ldap.conf
738 %attr(755,root,root) %{_libexecdir}/mod_quotatab_ldap.so
741 %if %{with quotamysql} || %{with quotapgsql}
742 %files mod_quotatab_sql
743 %defattr(644,root,root,755)
744 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_sql.conf
745 %attr(755,root,root) %{_libexecdir}/mod_quotatab_sql.so
749 %defattr(644,root,root,755)
750 %doc contrib/README.ratio
751 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ratio.conf
752 %attr(755,root,root) %{_libexecdir}/mod_ratio.so
755 %defattr(644,root,root,755)
756 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_readme.conf
757 %attr(755,root,root) %{_libexecdir}/mod_readme.so
760 %defattr(644,root,root,755)
761 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_rewrite.conf
762 %attr(755,root,root) %{_libexecdir}/mod_rewrite.so
764 %if %{with mysql} || %{with pgsql}
766 %defattr(644,root,root,755)
767 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql.conf
768 %attr(755,root,root) %{_libexecdir}/mod_sql.so
773 %defattr(644,root,root,755)
774 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_mysql.conf
775 %attr(755,root,root) %{_libexecdir}/mod_sql_mysql.so
779 %files mod_sql_postgres
780 %defattr(644,root,root,755)
781 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_postgres.conf
782 %attr(755,root,root) %{_libexecdir}/mod_sql_postgres.so
786 %defattr(644,root,root,755)
787 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_tls.conf
788 %attr(755,root,root) %{_libexecdir}/mod_tls.so
791 %defattr(644,root,root,755)
792 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_wrap.conf
793 %attr(755,root,root) %{_libexecdir}/mod_wrap.so