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: 13c6fd7ce320886adc371c81a3e23f07
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}
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
452 patch -p0 < mod_clamav-%{mod_clamav_version}/proftpd.patch
453 cp -a mod_clamav-%{mod_clamav_version}/*.{c,h} contrib/
455 cp -f /usr/share/automake/config.sub .
457 # cleanup backups after patching
458 find . '(' -name '*~' -o -name '*.orig' ')' -print0 | xargs -0 -r -l512 rm -f
474 %{?with_pam:mod_auth_pam}
475 %{?with_ldap:mod_ldap}
476 %{?with_quotafile:mod_quotatab mod_quotatab_file}
477 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
478 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
479 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
480 %{?with_mysql:mod_sql mod_sql_mysql}
481 %{?with_pgsql:mod_sql mod_sql_postgres}
484 MODARG=$(echo $MODULES | tr ' ' '\n' | sort -u | xargs | tr ' ' ':')
486 --with-includes=/usr/include/ncurses%{?with_mysql::%{_includedir}/mysql} \
488 --enable-buffer-size=4096 \
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} \
507 $RPM_BUILD_ROOT/usr/lib/tmpfiles.d
510 DESTDIR=$RPM_BUILD_ROOT \
511 INSTALL_USER=%(id -u) \
512 INSTALL_GROUP=%(id -g)
514 rm $RPM_BUILD_ROOT%{_sbindir}/in.proftpd
516 install %{SOURCE2} $RPM_BUILD_ROOT%{_sysconfdir}
517 install %{SOURCE9} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_auth_pam.conf
525 %{?with_ldap:mod_ldap}
526 %{?with_quotafile:mod_quotatab mod_quotatab_file}
527 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
528 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
529 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
530 %{?with_mysql:mod_sql mod_sql_mysql}
531 %{?with_pgsql:mod_sql mod_sql_postgres}
533 for module in $MODULES; do
534 echo "LoadModule $module.c" > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/$module.conf
536 install %{SOURCE10} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_tls.conf
537 install %{SOURCE11} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/anonftp.conf
538 install %{SOURCE12} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_clamav.conf
540 %{?with_pam:install %{SOURCE3} $RPM_BUILD_ROOT/etc/pam.d/ftp}
541 install %{SOURCE4} $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/ftpd
542 install %{SOURCE5} $RPM_BUILD_ROOT/etc/sysconfig/proftpd
543 install %{SOURCE6} $RPM_BUILD_ROOT/etc/rc.d/init.d/proftpd
544 install contrib/xferstats.holger-preiss $RPM_BUILD_ROOT%{_bindir}/xferstat
546 bzip2 -dc %{SOURCE7} | tar xf - -C $RPM_BUILD_ROOT%{_mandir}
548 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers.default
549 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers
551 install %{SOURCE13} $RPM_BUILD_ROOT/usr/lib/tmpfiles.d/%{name}.conf
553 # only for -inetd package?
554 ln -sf proftpd $RPM_BUILD_ROOT%{_sbindir}/ftpd
556 :> $RPM_BUILD_ROOT/etc/security/blacklist.ftp
558 rm $RPM_BUILD_ROOT%{_libexecdir}/*.a
559 rm $RPM_BUILD_ROOT%{_libexecdir}/*.la
561 rm -f $RPM_BUILD_ROOT%{_mandir}/ftpusers-path.diff*
562 cp -aL include/* config.h $RPM_BUILD_ROOT%{_includedir}/%{name}
565 rm -rf $RPM_BUILD_ROOT
569 awk -F: '{ if (($3 < 500) && ($1 != "ftp")) print $1; }' < /etc/passwd >> %{_sysconfdir}/ftpusers.default
570 if [ ! -f %{_sysconfdir}/ftpusers ]; then
571 cp -f %{_sysconfdir}/ftpusers.default %{_sysconfdir}/ftpusers
575 if grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf ; then
576 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
577 sed -i -e 's/^ServerType[[:space:]]\+standalone/ServerType inetd/g' %{_sysconfdir}/proftpd.conf
579 %service -q rc-inetd reload
582 if [ "$1" = "0" ]; then
583 %service -q rc-inetd reload
586 %posttrans standalone
587 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf ; then
588 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
589 sed -i -e 's/^ServerType[[:space:]]\+inetd/ServerType standalone/g' %{_sysconfdir}/proftpd.conf
591 /sbin/chkconfig --add proftpd
592 %service proftpd restart "ProFTPD daemon"
595 if [ "$1" = "0" ]; then
596 %service proftpd stop
597 /sbin/chkconfig --del proftpd
600 %triggerin standalone -- pam
601 # restart proftpd if pam is upgraded
602 # (proftpd is linked with old libpam but tries to open modules linked with new libpam)
603 if [ "$2" != 1 ]; then
604 %service -q proftpd restart
607 # macro called at module post scriptlet
608 %define module_post \
609 if [ "$1" = "1" ]; 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 # macro called at module postun scriptlet
618 %define module_postun \
619 if [ "$1" = "0" ]; then \
620 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
621 %service -q rc-inetd reload \
622 elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
623 %service -q proftpd restart \
627 # it's sooo annoying to write them
628 %define module_scripts() \
635 %module_scripts mod_auth_pam
636 %module_scripts mod_ldap
637 %module_scripts mod_quotatab
638 %module_scripts mod_quotatab_file
639 %module_scripts mod_quotatab_ldap
640 %module_scripts mod_quotatab_sql
641 %module_scripts mod_ratio
642 %module_scripts mod_readme
643 %module_scripts mod_rewrite
644 %module_scripts mod_sql
645 %module_scripts mod_sql_mysql
646 %module_scripts mod_sql_postgres
647 %module_scripts mod_tls
648 %module_scripts mod_wrap
651 %defattr(644,root,root,755)
652 %doc sample-configurations/*.conf CREDITS ChangeLog NEWS RELEASE_NOTES
653 %doc README README.capabilities README.classes README.controls README.IPv6
655 %doc doc/*.html doc/contrib doc/howto doc/modules
656 %dir %attr(750,root,ftp) %dir %{_sysconfdir}
657 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*.conf
658 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %ghost %{_sysconfdir}/ftpusers
659 %attr(640,root,root) %{_sysconfdir}/ftpusers.default
660 %dir %attr(750,root,root) %{_sysconfdir}/conf.d
661 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_file.conf
662 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ident.conf
663 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_clamav.conf
664 #%attr(640,root,root) %ghost /var/log/*
665 %attr(755,root,root) %{_bindir}/*
666 %attr(755,root,root) %{_sbindir}/*
668 %attr(755,root,root) %{_libexecdir}/mod_auth_file.so
669 %attr(755,root,root) %{_libexecdir}/mod_facl.so
670 %attr(755,root,root) %{_libexecdir}/mod_ident.so
671 %attr(755,root,root) %{_libexecdir}/mod_ifsession.so
672 %attr(755,root,root) %{_libexecdir}/mod_lang.so
673 %dir %{_localstatedir}/proftpd
674 /usr/lib/tmpfiles.d/%{name}.conf
676 %lang(ja) %{_mandir}/ja/man5/ftpusers*
677 %lang(pl) %{_mandir}/pl/man5/ftpusers*
678 %lang(pt_BR) %{_mandir}/pt_BR/man5/ftpusers*
679 %lang(ru) %{_mandir}/ru/man5/ftpusers*
682 %dir /var/lib/ftp/pub
683 %attr(711,ftp,ftp) %dir /var/lib/ftp/pub/Incoming
686 %defattr(644,root,root,755)
687 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/rc-inetd/ftpd
690 %defattr(644,root,root,755)
691 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/proftpd
692 %attr(754,root,root) /etc/rc.d/init.d/proftpd
695 %defattr(644,root,root,755)
696 %{_includedir}/%{name}
697 %{_pkgconfigdir}/%{name}.pc
700 %defattr(644,root,root,755)
701 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/anonftp.conf
705 %defattr(644,root,root,755)
707 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/pam.d/*
708 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/security/blacklist.ftp
709 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_pam.conf
710 %attr(755,root,root) %{_libexecdir}/mod_auth_pam.so
715 %defattr(644,root,root,755)
717 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ldap.conf
718 %attr(755,root,root) %{_libexecdir}/mod_ldap.so
722 %defattr(644,root,root,755)
723 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab.conf
724 %attr(755,root,root) %{_libexecdir}/mod_quotatab.so
726 %if %{with quotafile}
727 %files mod_quotatab_file
728 %defattr(644,root,root,755)
729 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_file.conf
730 %attr(755,root,root) %{_libexecdir}/mod_quotatab_file.so
733 %if %{with quotaldap}
734 %files mod_quotatab_ldap
735 %defattr(644,root,root,755)
736 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_ldap.conf
737 %attr(755,root,root) %{_libexecdir}/mod_quotatab_ldap.so
740 %if %{with quotamysql} || %{with quotapgsql}
741 %files mod_quotatab_sql
742 %defattr(644,root,root,755)
743 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_sql.conf
744 %attr(755,root,root) %{_libexecdir}/mod_quotatab_sql.so
748 %defattr(644,root,root,755)
749 %doc contrib/README.ratio
750 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ratio.conf
751 %attr(755,root,root) %{_libexecdir}/mod_ratio.so
754 %defattr(644,root,root,755)
755 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_readme.conf
756 %attr(755,root,root) %{_libexecdir}/mod_readme.so
759 %defattr(644,root,root,755)
760 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_rewrite.conf
761 %attr(755,root,root) %{_libexecdir}/mod_rewrite.so
763 %if %{with mysql} || %{with pgsql}
765 %defattr(644,root,root,755)
766 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql.conf
767 %attr(755,root,root) %{_libexecdir}/mod_sql.so
772 %defattr(644,root,root,755)
773 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_mysql.conf
774 %attr(755,root,root) %{_libexecdir}/mod_sql_mysql.so
778 %files mod_sql_postgres
779 %defattr(644,root,root,755)
780 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_postgres.conf
781 %attr(755,root,root) %{_libexecdir}/mod_sql_postgres.so
785 %defattr(644,root,root,755)
786 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_tls.conf
787 %attr(755,root,root) %{_libexecdir}/mod_tls.so
790 %defattr(644,root,root,755)
791 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_wrap.conf
792 %attr(755,root,root) %{_libexecdir}/mod_wrap.so