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.bz2
32 # Source0-md5: acc49b6589bc8c9fdf1dce9000bebdbd
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 Patch0: %{name}-paths.patch
47 Patch1: %{name}-noautopriv.patch
48 Patch2: %{name}-wtmp.patch
49 Patch3: %{name}-pool.patch
50 Patch4: %{name}-nostrip.patch
51 Patch5: %{name}-link.patch
52 URL: http://www.proftpd.org/
53 BuildRequires: acl-devel
54 BuildRequires: autoconf
55 BuildRequires: automake
56 BuildRequires: libcap-devel
57 BuildRequires: libstdc++-devel
58 BuildRequires: libwrap-devel
59 %if %{with mysql} || %{with quotamysql}
60 BuildRequires: mysql-devel
62 BuildRequires: ncurses-devel
63 %if %{with ldap} || %{with quotaldap}
64 BuildRequires: openldap-devel
66 %{?with_ssl:BuildRequires: openssl-devel >= 0.9.7d}
67 %{?with_pam:BuildRequires: pam-devel}
68 %if %{with pgsql} || %{with quotapgsql}
69 BuildRequires: postgresql-devel
71 BuildRequires: rpmbuild(macros) >= 1.268
72 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
74 %define _sysconfdir /etc/ftpd
75 %define _localstatedir /var/run
76 %define _libexecdir %{_prefix}/%{_lib}/%{name}
79 ProFTPD is a highly configurable FTP daemon for Unix and Unix-like
80 operating systems. ProFTPD is designed to be somewhat of a "drop-in"
81 replacement for wu-ftpd. Full online documentation is available at
82 <http://www.proftpd.org/>, including a server configuration directive
85 %description -l es.UTF-8
86 ProFTPD es un servidor FTP altamente configurable para sistemas
87 operativos Unix. Está proyectado para ser un substituto directo al
88 wu-ftpd. La documentación completa está disponible en
89 <http://www.proftpd.org/>, incluido el manual de referencia para las
90 directivas de configuración del servidor.
92 %description -l pl.UTF-8
93 ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
94 ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
95 dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
96 włącznie z dokumentacją dotyczącą konfigurowania.
98 %description -l pt_BR.UTF-8
99 O ProFTPD é um servidor FTP altamente configurável para sistemas
102 É projetado para ser um substituto direto para o wu-ftpd. A
103 documentação completa está disponível em <http://www.proftpd.org/>,
104 incluindo o manual de referência para as diretivas de configuração do
108 Summary: PROfessional FTP Daemon with apache-like configuration syntax - common files
109 Summary(pl.UTF-8): PROfesionalny serwer FTP - wspólne pliki
110 Group: Networking/Daemons
112 Requires(post): fileutils
113 Obsoletes: proftpd < 0:1.2.2rc1-3
116 ProFTPD is a highly configurable FTP daemon for Unix and Unix-like
117 operating systems. ProFTPD is designed to be somewhat of a "drop-in"
118 replacement for wu-ftpd. Full online documentation is available at
119 <http://www.proftpd.org/>, including a server configuration directive
122 %description common -l es.UTF-8
123 ProFTPD es un servidor FTP altamente configurable para sistemas
124 operativos Unix. Está proyectado para ser un substituto directo al
125 wu-ftpd. La documentación completa está disponible en
126 <http://www.proftpd.org/>, incluido el manual de referencia para las
127 directivas de configuración del servidor.
129 %description common -l pl.UTF-8
130 ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
131 ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
132 dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
133 włącznie z dokumentacją dotyczącą konfigurowania.
135 %description common -l pt_BR.UTF-8
136 O ProFTPD é um servidor FTP altamente configurável para sistemas
139 É projetado para ser um substituto direto para o wu-ftpd. A
140 documentação completa está disponível em <http://www.proftpd.org/>,
141 incluindo o manual de referência para as diretivas de configuração do
145 Summary: inetd configs for proftpd
146 Summary(pl.UTF-8): Pliki konfiguracyjne do użycia proftpd poprzez inetd
147 Group: Networking/Daemons
148 Requires(post): fileutils
150 Requires(post): sed >= 4.0
151 Requires(triggerpostun): sed >= 4.0
152 Requires: %{name}-common = %{epoch}:%{version}-%{release}
155 Provides: proftpd = %{epoch}:%{version}-%{release}
161 Obsoletes: heimdal-ftpd
163 Obsoletes: linux-ftpd
164 Obsoletes: muddleftpd
165 Obsoletes: proftpd-standalone
167 Obsoletes: troll-ftpd
170 Conflicts: man-pages < 1.51
171 Conflicts: rpm < 4.4.2-0.2
174 ProFTPD configs for running from inetd.
176 %description inetd -l pl.UTF-8
177 Pliki konfiguracyjna ProFTPD do startowania demona poprzez inetd.
180 Summary: Standalone daemon configs for proftpd
181 Summary(pl.UTF-8): Pliki konfiguracyjne do startowania proftpd w trybie standalone
182 Group: Networking/Daemons
183 Requires(post): fileutils
185 Requires(post): sed >= 4.0
186 Requires(post,preun): /sbin/chkconfig
187 Requires(triggerpostun): sed >= 4.0
188 Requires: %{name}-common = %{epoch}:%{version}-%{release}
191 Provides: proftpd = %{epoch}:%{version}-%{release}
197 Obsoletes: heimdal-ftpd
199 Obsoletes: linux-ftpd
200 Obsoletes: muddleftpd
201 Obsoletes: proftpd-inetd
203 Obsoletes: troll-ftpd
206 Conflicts: man-pages < 1.51
207 Conflicts: rpm < 4.4.2-0.2
209 %description standalone
210 ProFTPD configs for running as a standalone daemon.
212 %description standalone -l pl.UTF-8
213 Pliki konfiguracyjne ProFTPD do startowania demona w trybie
217 Summary: Header files ProFTPD
218 Summary(pl.UTF-8): Pliki nagłówkowe ProFTPD
219 Group: Development/Libraries
223 This is the package containing the header files for ProFTPD.
225 %description devel -l pl.UTF-8
226 Ten pakiet zawiera pliki nagłówkowe ProFTPD
229 Summary: Anonymous FTP config for ProFTPD
230 Summary(pl.UTF-8): Konfiguracja anonimowego FTP dla ProFTPD
231 Group: Networking/Daemons
232 Requires: %{name}-common = %{epoch}:%{version}-%{release}
235 Anonymous FTP config for ProFTPD.
237 %description anonftp -l pl.UTF-8
238 Konfiguracja anonimowego FTP dla ProFTPD.
240 %package mod_auth_pam
241 Summary: ProFTPD PAM auth module
242 Summary(pl.UTF-8): Moduł uwierzytelnienia PAM dla ProFTPD
243 Group: Networking/Daemons
244 Requires: %{name}-common = %{epoch}:%{version}-%{release}
245 Requires: pam >= 0.79.0
247 %description mod_auth_pam
248 PAM authentication method for ProFTPD.
250 %description mod_auth_pam -l pl.UTF-8
251 Metoda uwierzytelnienia PAM dla ProFTPD.
254 Summary: ProFTPD OpenLDAP module
255 Summary(pl.UTF-8): Moduł OpenLDAP dla ProFTPD
256 Group: Networking/Daemons
257 Requires: %{name}-common = %{epoch}:%{version}-%{release}
259 %description mod_ldap
260 mod_ldap provides LDAP authentication support for ProFTPD. It supports
261 many features useful in "toaster" environments such as default UID/GID
262 and autocreation/autogeneration of home directories.
264 %description mod_ldap -l pl.UTF-8
265 mod_ldap dodaje obsługę uwierzytelnienia LDAP do ProFTPD. Obsługuje
266 wiele cech przydatnych w środowiskach "tosterowych", takich jak
267 domyślny UID/GID i automatyczne tworzenie/generowanie katalogów
270 %package mod_quotatab
271 Summary: ProFTPD quotatab module
272 Summary(pl.UTF-8): Moduł quotatab dla ProFTPD
273 Group: Networking/Daemons
274 Requires: %{name}-common = %{epoch}:%{version}-%{release}
276 %description mod_quotatab
277 A module for managing FTP byte/file quotas via centralized tables.
279 %description mod_quotatab -l pl.UTF-8
280 Moduł do zarządzania ograniczeniami bajtów/plików FTP poprzez
281 scentralizowane tabele.
283 %package mod_quotatab_file
284 Summary: ProFTPD quotatab file module
285 Summary(pl.UTF-8): Moduł quotatab_file dla ProFTPD
286 Group: Networking/Daemons
287 Requires: %{name}-common = %{epoch}:%{version}-%{release}
288 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
290 %description mod_quotatab_file
291 A mod_quotatab sub-module for managing quota data via file-based
294 %description mod_quotatab_file -l pl.UTF-8
295 Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
296 tabele zapisane w pliku.
298 %package mod_quotatab_ldap
299 Summary: ProFTPD quotatab ldap module
300 Summary(pl.UTF-8): Moduł quotatab_ldap dla ProFTPD
301 Group: Networking/Daemons
302 Requires: %{name}-common = %{epoch}:%{version}-%{release}
303 Requires: %{name}-mod_ldap = %{epoch}:%{version}-%{release}
304 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
306 %description mod_quotatab_ldap
307 A mod_quotatab sub-module for obtaining quota information from an LDAP
310 %description mod_quotatab_ldap -l pl.UTF-8
311 Podmoduł mod_quotatab do pobierania informacji o ograniczeniach z
314 %package mod_quotatab_sql
315 Summary: ProFTPD quotatab sql module
316 Summary(pl.UTF-8): Moduł quotatab_sql dla ProFTPD
317 Group: Networking/Daemons
318 Requires: %{name}-common = %{epoch}:%{version}-%{release}
319 Requires: %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
320 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
322 %description mod_quotatab_sql
323 A mod_quotatab sub-module for managing quota data via SQL-based
326 %description mod_quotatab_sql -l pl.UTF-8
327 Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
331 Summary: ProFTPD ratio module
332 Summary(pl.UTF-8): Moduł ratio dla ProFTPD
333 Group: Networking/Daemons
334 Requires: %{name}-common = %{epoch}:%{version}-%{release}
336 %description mod_ratio
337 Support upload/download ratios.
339 %description mod_ratio -l pl.UTF-8
340 Obsługa współczynników upload/download.
343 Summary: ProFTPD readme module
344 Summary(pl.UTF-8): Moduł readme dla ProFTPD
345 Group: Networking/Daemons
346 Requires: %{name}-common = %{epoch}:%{version}-%{release}
348 %description mod_readme
349 "README" file support.
351 %description mod_readme -l pl.UTF-8
352 Obsługa pliku "README".
355 Summary: ProFTPD rewrite module
356 Summary(pl.UTF-8): Moduł rewrite dla ProFTPD
357 Group: Networking/Daemons
358 Requires: %{name}-common = %{epoch}:%{version}-%{release}
360 %description mod_rewrite
361 Runtime rewrite engine.
363 %description mod_rewrite -l pl.UTF-8
364 Silnik przepisujący adresy w locie.
367 Summary: ProFTPD SQL support module
368 Summary(pl.UTF-8): Moduł obsługi SQL dla ProFTPD
369 Group: Networking/Daemons
370 Requires: %{name}-common = %{epoch}:%{version}-%{release}
373 This module provides the necessary support for SQL based
374 authentication, logging and other features as required.
376 %description mod_sql -l pl.UTF-8
377 Ten moduł dodaje obsługę SQL potrzebną do uwierzytelniania, logowania
378 i innych możliwości opartych o SQL.
380 %package mod_sql_mysql
381 Summary: ProFTPD sql mysql module
382 Summary(pl.UTF-8): Moduł sql_mysql dla ProFTPD
383 Group: Networking/Daemons
384 Requires: %{name}-common = %{epoch}:%{version}-%{release}
385 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
387 %description mod_sql_mysql
388 Support for connecting to MySQL databases.
390 %description mod_sql_mysql -l pl.UTF-8
391 Obsługa łączenia się z bazami danych MySQL.
393 %package mod_sql_postgres
394 Summary: ProFTPD sql postgres module
395 Summary(pl.UTF-8): Moduł sql_postgres dla ProFTPD
396 Group: Networking/Daemons
397 Requires: %{name}-common = %{epoch}:%{version}-%{release}
398 Requires: %{name}-mod_sql = %{epoch}:%{version}-%{release}
400 %description mod_sql_postgres
401 Support for connecting to PostgreSQL databases.
403 %description mod_sql_postgres -l pl.UTF-8
404 Obsługa łączenia się z bazami danych PostgreSQL.
407 Summary: ProFTPD TLS support
408 Summary(pl.UTF-8): Obsługa TLS dla ProFTPD
409 Group: Networking/Daemons
410 Requires: %{name}-common = %{epoch}:%{version}-%{release}
413 An RFC2228 SSL/TLS module for ProFTPD.
415 %description mod_tls -l pl.UTF-8
416 Moduł SSL/TLS zgodny z RFC2228 dla ProFTPD.
419 Summary: ProFTPD interface to libwrap
420 Summary(pl.UTF-8): Interfejs ProFTPD do libwrap
421 Group: Networking/Daemons
422 Requires: %{name}-common = %{epoch}:%{version}-%{release}
425 %description mod_wrap
426 It enables the daemon to use the common tcpwrappers access control
427 library while in standalone mode, and in a very configurable manner.
429 Many programs will automatically add entries in the common allow/deny
430 files, and use of this module will allow a ProFTPD daemon running in
431 standalone mode to adapt as these entries are added. The portsentry
432 program does this, for example: when illegal access is attempted, it
433 will add hosts to the /etc/hosts.deny file.
435 %description mod_wrap -l pl.UTF-8
436 Ten pakiet pozwala demonowi używać wspólnej biblioteki kontroli
437 dostępu tcpwrappers w trybie samodzielnym w bardzo wygodny sposób.
439 Wiele programów automatycznie dodaje wpisy we wspólnych plikach
440 allow/deny, a użycie tego modułu pozwala demonowi ProFTPD działającemu
441 w trybie samodzielnym adaptować te wpisy w miarę dodawania. Robi tak
442 na przykład program portsentry: przy próbie niedozwolonego dostępu
443 dodaje hosty do pliku /etc/hosts.deny.
446 %setup -q -n %{name}-%{version}%{?_rc} -a1
455 patch -p0 < mod_clamav-%{mod_clamav_version}/proftpd.patch
456 cp -a mod_clamav-%{mod_clamav_version}/*.{c,h} contrib/
458 cp -f /usr/share/automake/config.sub .
460 # cleanup backups after patching
461 find . '(' -name '*~' -o -name '*.orig' ')' -print0 | xargs -0 -r -l512 rm -f
477 %{?with_pam:mod_auth_pam}
478 %{?with_ldap:mod_ldap}
479 %{?with_quotafile:mod_quotatab mod_quotatab_file}
480 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
481 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
482 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
483 %{?with_mysql:mod_sql mod_sql_mysql}
484 %{?with_pgsql:mod_sql mod_sql_postgres}
487 MODARG=$(echo $MODULES | tr ' ' '\n' | sort -u | xargs | tr ' ' ':')
489 --with-includes=/usr/include/ncurses%{?with_mysql::%{_includedir}/mysql} \
490 --enable-buffer-size=4096 \
491 --disable-auth-file \
492 --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}
511 DESTDIR=$RPM_BUILD_ROOT \
512 INSTALL_USER=%(id -u) \
513 INSTALL_GROUP=%(id -g)
515 rm $RPM_BUILD_ROOT%{_sbindir}/in.proftpd
517 install %{SOURCE2} $RPM_BUILD_ROOT%{_sysconfdir}
518 install %{SOURCE9} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_auth_pam.conf
526 %{?with_ldap:mod_ldap}
527 %{?with_quotafile:mod_quotatab mod_quotatab_file}
528 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
529 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
530 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
531 %{?with_mysql:mod_sql mod_sql_mysql}
532 %{?with_pgsql:mod_sql mod_sql_postgres}
534 for module in $MODULES; do
535 echo "LoadModule $module.c" > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/$module.conf
537 install %{SOURCE10} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_tls.conf
538 install %{SOURCE11} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/anonftp.conf
539 install %{SOURCE12} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_clamav.conf
541 %{?with_pam:install %{SOURCE3} $RPM_BUILD_ROOT/etc/pam.d/ftp}
542 install %{SOURCE4} $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/ftpd
543 install %{SOURCE5} $RPM_BUILD_ROOT/etc/sysconfig/proftpd
544 install %{SOURCE6} $RPM_BUILD_ROOT/etc/rc.d/init.d/proftpd
545 install contrib/xferstats.holger-preiss $RPM_BUILD_ROOT%{_bindir}/xferstat
547 bzip2 -dc %{SOURCE7} | tar xf - -C $RPM_BUILD_ROOT%{_mandir}
549 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers.default
550 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers
552 # only for -inetd package?
553 ln -sf proftpd $RPM_BUILD_ROOT%{_sbindir}/ftpd
555 :> $RPM_BUILD_ROOT/etc/security/blacklist.ftp
557 rm $RPM_BUILD_ROOT%{_libexecdir}/*.a
558 rm $RPM_BUILD_ROOT%{_libexecdir}/*.la
560 rm -f $RPM_BUILD_ROOT%{_mandir}/ftpusers-path.diff*
561 cp -aL include/* config.h $RPM_BUILD_ROOT%{_includedir}/%{name}
564 rm -rf $RPM_BUILD_ROOT
568 awk -F: '{ if (($3 < 500) && ($1 != "ftp")) print $1; }' < /etc/passwd >> %{_sysconfdir}/ftpusers.default
569 if [ ! -f %{_sysconfdir}/ftpusers ]; then
570 cp -f %{_sysconfdir}/ftpusers.default %{_sysconfdir}/ftpusers
574 if grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf ; then
575 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
576 sed -i -e 's/^ServerType[[:space:]]\+standalone/ServerType inetd/g' %{_sysconfdir}/proftpd.conf
578 %service -q rc-inetd reload
581 if [ "$1" = "0" ]; then
582 %service -q rc-inetd reload
585 %posttrans standalone
586 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf ; then
587 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
588 sed -i -e 's/^ServerType[[:space:]]\+inetd/ServerType standalone/g' %{_sysconfdir}/proftpd.conf
590 /sbin/chkconfig --add proftpd
591 %service proftpd restart "ProFTPD daemon"
594 if [ "$1" = "0" ]; then
595 %service proftpd stop
596 /sbin/chkconfig --del proftpd
599 %triggerin standalone -- pam
600 # restart proftpd if pam is upgraded
601 # (proftpd is linked with old libpam but tries to open modules linked with new libpam)
602 if [ "$2" != 1 ]; then
603 %service -q proftpd restart
606 # macro called at module post scriptlet
607 %define module_post \
608 if [ "$1" = "1" ]; then \
609 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
610 %service -q rc-inetd reload \
611 elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
612 %service -q proftpd restart \
616 # macro called at module postun scriptlet
617 %define module_postun \
618 if [ "$1" = "0" ]; then \
619 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
620 %service -q rc-inetd reload \
621 elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
622 %service -q proftpd restart \
626 # it's sooo annoying to write them
627 %define module_scripts() \
634 %module_scripts mod_auth_pam
635 %module_scripts mod_ldap
636 %module_scripts mod_quotatab
637 %module_scripts mod_quotatab_file
638 %module_scripts mod_quotatab_ldap
639 %module_scripts mod_quotatab_sql
640 %module_scripts mod_ratio
641 %module_scripts mod_readme
642 %module_scripts mod_rewrite
643 %module_scripts mod_sql
644 %module_scripts mod_sql_mysql
645 %module_scripts mod_sql_postgres
646 %module_scripts mod_tls
647 %module_scripts mod_wrap
650 %defattr(644,root,root,755)
651 %doc sample-configurations/*.conf CREDITS ChangeLog NEWS RELEASE_NOTES
652 %doc README README.capabilities README.classes README.controls README.IPv6
654 %doc doc/*.html doc/contrib doc/howto doc/modules
655 %dir %attr(750,root,ftp) %dir %{_sysconfdir}
656 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*.conf
657 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %ghost %{_sysconfdir}/ftpusers
658 %attr(640,root,root) %{_sysconfdir}/ftpusers.default
659 %dir %attr(750,root,root) %{_sysconfdir}/conf.d
660 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_file.conf
661 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ident.conf
662 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_clamav.conf
663 #%attr(640,root,root) %ghost /var/log/*
664 %attr(755,root,root) %{_bindir}/*
665 %attr(755,root,root) %{_sbindir}/*
667 %attr(755,root,root) %{_libexecdir}/mod_auth_file.so
668 %attr(755,root,root) %{_libexecdir}/mod_facl.so
669 %attr(755,root,root) %{_libexecdir}/mod_ident.so
670 %attr(755,root,root) %{_libexecdir}/mod_ifsession.so
671 %attr(755,root,root) %{_libexecdir}/mod_lang.so
672 %dir %{_localstatedir}/proftpd
675 %dir /var/lib/ftp/pub
676 %attr(711,ftp,ftp) %dir /var/lib/ftp/pub/Incoming
679 %defattr(644,root,root,755)
680 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/rc-inetd/ftpd
682 %lang(ja) %{_mandir}/ja/man5/ftpusers*
683 %lang(pl) %{_mandir}/pl/man5/ftpusers*
684 %lang(pt_BR) %{_mandir}/pt_BR/man5/ftpusers*
685 %lang(ru) %{_mandir}/ru/man5/ftpusers*
688 %defattr(644,root,root,755)
689 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/proftpd
690 %attr(754,root,root) /etc/rc.d/init.d/proftpd
692 %lang(ja) %{_mandir}/ja/man5/ftpusers*
693 %lang(pl) %{_mandir}/pl/man5/ftpusers*
694 %lang(pt_BR) %{_mandir}/pt_BR/man5/ftpusers*
695 %lang(ru) %{_mandir}/ru/man5/ftpusers*
698 %defattr(644,root,root,755)
699 %{_includedir}/%{name}
700 %{_pkgconfigdir}/%{name}.pc
703 %defattr(644,root,root,755)
704 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/anonftp.conf
708 %defattr(644,root,root,755)
710 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/pam.d/*
711 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/security/blacklist.ftp
712 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_pam.conf
713 %attr(755,root,root) %{_libexecdir}/mod_auth_pam.so
718 %defattr(644,root,root,755)
720 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ldap.conf
721 %attr(755,root,root) %{_libexecdir}/mod_ldap.so
725 %defattr(644,root,root,755)
726 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab.conf
727 %attr(755,root,root) %{_libexecdir}/mod_quotatab.so
729 %if %{with quotafile}
730 %files mod_quotatab_file
731 %defattr(644,root,root,755)
732 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_file.conf
733 %attr(755,root,root) %{_libexecdir}/mod_quotatab_file.so
736 %if %{with quotaldap}
737 %files mod_quotatab_ldap
738 %defattr(644,root,root,755)
739 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_ldap.conf
740 %attr(755,root,root) %{_libexecdir}/mod_quotatab_ldap.so
743 %if %{with quotamysql} || %{with quotapgsql}
744 %files mod_quotatab_sql
745 %defattr(644,root,root,755)
746 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_sql.conf
747 %attr(755,root,root) %{_libexecdir}/mod_quotatab_sql.so
751 %defattr(644,root,root,755)
752 %doc contrib/README.ratio
753 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ratio.conf
754 %attr(755,root,root) %{_libexecdir}/mod_ratio.so
757 %defattr(644,root,root,755)
758 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_readme.conf
759 %attr(755,root,root) %{_libexecdir}/mod_readme.so
762 %defattr(644,root,root,755)
763 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_rewrite.conf
764 %attr(755,root,root) %{_libexecdir}/mod_rewrite.so
766 %if %{with mysql} || %{with pgsql}
768 %defattr(644,root,root,755)
769 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql.conf
770 %attr(755,root,root) %{_libexecdir}/mod_sql.so
775 %defattr(644,root,root,755)
776 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_mysql.conf
777 %attr(755,root,root) %{_libexecdir}/mod_sql_mysql.so
781 %files mod_sql_postgres
782 %defattr(644,root,root,755)
783 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_postgres.conf
784 %attr(755,root,root) %{_libexecdir}/mod_sql_postgres.so
788 %defattr(644,root,root,755)
789 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_tls.conf
790 %attr(755,root,root) %{_libexecdir}/mod_tls.so
793 %defattr(644,root,root,755)
794 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_wrap.conf
795 %attr(755,root,root) %{_libexecdir}/mod_wrap.so