]> git.pld-linux.org Git - packages/proftpd.git/blob - proftpd.spec
- converted to UTF-8
[packages/proftpd.git] / proftpd.spec
1 # TODO
2 # - mod_caps uses uname -r for detection
3 #
4 # Conditional build:
5 %bcond_without  pam             # disable PAM support
6 %bcond_without  ipv6            # disable IPv6 and TCPD support
7 %bcond_without  ssl             # disbale TLS/SSL support
8 %bcond_without  ldap            # enable LDAP support
9 %bcond_without  mysql           # enable MySQL support
10 %bcond_without  pgsql           # enable PostgreSQL support
11 %bcond_without  quotafile       # enable quota file support
12 %bcond_without  quotaldap       # enable quota ldap support
13 %bcond_without  quotamysql      # enable quota mysql support
14 %bcond_without  quotapgsql      # enable quota pgsql support
15 #
16 Summary:        PROfessional FTP Daemon with apache-like configuration syntax
17 Summary(es.UTF-8):   Servidor FTP profesional, con sintaxis de configuración semejante a la del apache
18 Summary(pl.UTF-8):   PROfesionalny serwer FTP
19 Summary(pt_BR.UTF-8):   Servidor FTP profissional, com sintaxe de configuração semelhante à do apache
20 Summary(zh_CN.UTF-8):   易于管理的,安全的 FTP 服务器
21 Name:           proftpd
22 Version:        1.3.0
23 Release:        4
24 Epoch:          1
25 License:        GPL v2+
26 Group:          Daemons
27 Source0:        ftp://ftp.proftpd.org/distrib/source/%{name}-%{version}.tar.bz2
28 # Source0-md5:  fae47d01b52e035eb6b7190e74c17722
29 Source1:        %{name}.conf
30 Source3:        ftp.pamd
31 Source4:        %{name}.inetd
32 Source5:        %{name}.sysconfig
33 Source6:        %{name}.init
34 Source7:        ftpusers.tar.bz2
35 # Source7-md5:  76c80b6ec9f4d079a1e27316edddbe16
36 Source9:        %{name}-mod_pam.conf
37 Source10:       %{name}-mod_tls.conf
38 Source11:       %{name}-anonftp.conf
39 Patch0:         %{name}-umode_t.patch
40 Patch1:         %{name}-paths.patch
41 Patch2:         %{name}-noautopriv.patch
42 Patch3:         %{name}-wtmp.patch
43 Patch4:         %{name}-configure.patch
44 Patch5:         %{name}-pool.patch
45 Patch6:         %{name}-CVE-2006-5815.patch
46 Patch7:         %{name}-ctrls-reqarglen.patch
47 Patch8:         %{name}-CVE-2006-6170.patch
48 URL:            http://www.proftpd.org/
49 BuildRequires:  autoconf
50 BuildRequires:  automake
51 BuildRequires:  libwrap-devel
52 %if %{with mysql} || %{with quotamysql}
53 BuildRequires:  mysql-devel
54 %endif
55 BuildRequires:  ncurses-devel
56 %if %{with ldap} || %{with quotaldap}
57 BuildRequires:  openldap-devel
58 %endif
59 %{?with_ssl:BuildRequires:      openssl-devel >= 0.9.7d}
60 %{?with_pam:BuildRequires:              pam-devel}
61 %if %{with pgsql} || %{with quotapgsql}
62 BuildRequires:  postgresql-devel
63 %endif
64 BuildRequires:  rpmbuild(macros) >= 1.268
65 BuildRoot:      %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
66
67 %define         _sysconfdir             /etc/ftpd
68 %define         _localstatedir  /var/run
69 %define         _libexecdir             %{_prefix}/%{_lib}/%{name}
70
71 %description
72 ProFTPD is a highly configurable FTP daemon for unix and unix-like
73 operating systems. ProFTPD is designed to be somewhat of a "drop-in"
74 replacement for wu-ftpd. Full online documentation is available at
75 <http://www.proftpd.org/>, including a server configuration directive
76 reference manual.
77
78 %description -l es.UTF-8
79 ProFTPD es un servidor FTP altamente configurable para sistemas
80 operativos unix. Está proyectado para ser un substituto directo al
81 wu-ftpd. La documentación completa está disponible en
82 <http://www.proftpd.org/>, incluido el manual de referencia para las
83 directivas de configuración del servidor.
84
85 %description -l pl.UTF-8
86 ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
87 ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
88 dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
89 włącznie z dokumentacją dotyczącą konfigurowania.
90
91 %description -l pt_BR.UTF-8
92 O ProFTPD é um servidor FTP altamente configurável para sistemas
93 operacionais unix.
94
95 É projetado para ser um substituto direto para o wu-ftpd. A
96 documentação completa está disponível em <http://www.proftpd.org/>,
97 incluindo o manual de referência para as diretivas de configuração do
98 servidor.
99
100 %package common
101 Summary:        PROfessional FTP Daemon with apache-like configuration syntax - common files
102 Summary(pl.UTF-8):   PROfesionalny serwer FTP  - wspólne pliki
103 Group:          Daemons
104 Requires(post): awk
105 Requires(post): fileutils
106 Obsoletes:      proftpd < 0:1.2.2rc1-3
107
108 %description common
109 ProFTPD is a highly configurable FTP daemon for unix and unix-like
110 operating systems. ProFTPD is designed to be somewhat of a "drop-in"
111 replacement for wu-ftpd. Full online documentation is available at
112 <http://www.proftpd.org/>, including a server configuration directive
113 reference manual.
114
115 %description common -l es.UTF-8
116 ProFTPD es un servidor FTP altamente configurable para sistemas
117 operativos unix. Está proyectado para ser un substituto directo al
118 wu-ftpd. La documentación completa está disponible en
119 <http://www.proftpd.org/>, incluido el manual de referencia para las
120 directivas de configuración del servidor.
121
122 %description common -l pl.UTF-8
123 ProFTPD jest wysoce konfigurowalnym serwerem FTP dla systemów Unix.
124 ProFTPD jest robiony jako bezpośredni zamiennik wu-ftpd. Pełna
125 dokumentacja jest dostępna on-line pod <http://www.proftpd.org/>
126 włącznie z dokumentacją dotyczącą konfigurowania.
127
128 %description common -l pt_BR.UTF-8
129 O ProFTPD é um servidor FTP altamente configurável para sistemas
130 operacionais unix.
131
132 É projetado para ser um substituto direto para o wu-ftpd. A
133 documentação completa está disponível em <http://www.proftpd.org/>,
134 incluindo o manual de referência para as diretivas de configuração do
135 servidor.
136
137 %package inetd
138 Summary:        inetd configs for proftpd
139 Summary(pl.UTF-8):   Pliki konfiguracyjne do użycia proftpd poprzez inetd
140 Group:          Daemons
141 Requires(post): fileutils
142 Requires(post): grep
143 Requires(post): sed >= 4.0
144 Requires(triggerpostun):        sed >= 4.0
145 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
146 Requires:       rc-inetd
147 Provides:       ftpserver
148 Provides:       proftpd = %{epoch}:%{version}-%{release}
149 Obsoletes:      anonftp
150 Obsoletes:      bftpd
151 Obsoletes:      ftpd-BSD
152 Obsoletes:      ftpserver
153 Obsoletes:      glftpd
154 Obsoletes:      heimdal-ftpd
155 Obsoletes:      linux-ftpd
156 Obsoletes:      muddleftpd
157 Obsoletes:      proftpd-standalone
158 Obsoletes:      pure-ftpd
159 Obsoletes:      troll-ftpd
160 Obsoletes:      vsftpd
161 Obsoletes:      wu-ftpd
162 Conflicts:      man-pages < 1.51
163 Conflicts:      rpm < 4.4.2-0.2
164
165 %description inetd
166 ProFTPD configs for running from inetd.
167
168 %description inetd -l pl.UTF-8
169 Pliki konfiguracyjna ProFTPD do startowania demona poprzez inetd.
170
171 %package standalone
172 Summary:        Standalone daemon configs for proftpd
173 Summary(pl.UTF-8):   Pliki konfiguracyjne do startowania proftpd w trybie standalone
174 Group:          Daemons
175 Requires(post): fileutils
176 Requires(post): grep
177 Requires(post): sed >= 4.0
178 Requires(post,preun):   /sbin/chkconfig
179 Requires(triggerpostun):        sed >= 4.0
180 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
181 Requires:       rc-scripts
182 Provides:       ftpserver
183 Provides:       proftpd = %{epoch}:%{version}-%{release}
184 Obsoletes:      anonftp
185 Obsoletes:      bftpd
186 Obsoletes:      ftpd-BSD
187 Obsoletes:      ftpserver
188 Obsoletes:      glftpd
189 Obsoletes:      heimdal-ftpd
190 Obsoletes:      linux-ftpd
191 Obsoletes:      muddleftpd
192 Obsoletes:      proftpd-inetd
193 Obsoletes:      pure-ftpd
194 Obsoletes:      troll-ftpd
195 Obsoletes:      vsftpd
196 Obsoletes:      wu-ftpd
197 Conflicts:      man-pages < 1.51
198 Conflicts:      rpm < 4.4.2-0.2
199
200 %description standalone
201 ProFTPD configs for running as a standalone daemon.
202
203 %description standalone -l pl.UTF-8
204 Pliki konfiguracyjne ProFTPD do startowania demona w trybie
205 standalone.
206
207 %package devel
208 Summary:        Header files ProFTPD
209 Summary(pl.UTF-8):   Pliki nagłówkowe ProFTPD
210 Group:          Development/Libraries
211
212 %description devel
213 This is the package containing the header files for ProFTPD.
214
215 %description devel -l pl.UTF-8
216 Ten pakiet zawiera pliki nagłówkowe ProFTPD
217
218 %package anonftp
219 Summary:        Anonymous FTP config for ProFTPD
220 Summary(pl.UTF-8):   Konfiguracja anonimowego FTP dla ProFTPD
221 Group:          Daemons
222 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
223
224 %description anonftp
225 Anonymous FTP config for ProFTPD.
226
227 %description anonftp -l pl.UTF-8
228 Konfiguracja anonimowego FTP dla ProFTPD.
229
230 %package mod_auth_pam
231 Summary:        ProFTPD PAM auth module
232 Summary(pl.UTF-8):   Moduł uwierzytelnienia PAM dla ProFTPD
233 Group:          Daemons
234 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
235 Requires:       pam >= 0.79.0
236
237 %description mod_auth_pam
238 PAM authentication method for ProFTPD.
239
240 %description mod_auth_pam -l pl.UTF-8
241 Metoda uwierzytelnienia PAM dla ProFTPD.
242
243 %package mod_ldap
244 Summary:        ProFTPD OpenLDAP module
245 Summary(pl.UTF-8):   Moduł OpenLDAP dla ProFTPD
246 Group:          Daemons
247 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
248
249 %description mod_ldap
250 mod_ldap provides LDAP authentication support for ProFTPD. It supports
251 many features useful in "toaster" environments such as default UID/GID
252 and autocreation/autogeneration of home directories.
253
254 %description mod_ldap -l pl.UTF-8
255 mod_ldap dodaje obsługę uwierzytelnienia LDAP do ProFTPD. Obsługuje
256 wiele cech przydatnych w środowiskach "tosterowych", takich jak
257 domyślny UID/GID i automatyczne tworzenie/generowanie katalogów
258 domowych.
259
260 %package mod_quotatab
261 Summary:        ProFTPD quotatab module
262 Summary(pl.UTF-8):   Moduł quotatab dla ProFTPD
263 Group:          Daemons
264 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
265
266 %description mod_quotatab
267 A module for managing FTP byte/file quotas via centralized tables.
268
269 %description mod_quotatab -l pl.UTF-8
270 Moduł do zarządzania ograniczeniami bajtów/plików FTP poprzez
271 scentralizowane tabele.
272
273 %package mod_quotatab_file
274 Summary:        ProFTPD quotatab file module
275 Summary(pl.UTF-8):   Moduł quotatab_file dla ProFTPD
276 Group:          Daemons
277 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
278 Requires:       %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
279
280 %description mod_quotatab_file
281 A mod_quotatab sub-module for managing quota data via file-based
282 tables.
283
284 %description mod_quotatab_file -l pl.UTF-8
285 Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
286 tabele zapisane w pliku.
287
288 %package mod_quotatab_ldap
289 Summary:        ProFTPD quotatab ldap module
290 Summary(pl.UTF-8):   Moduł quotatab_ldap dla ProFTPD
291 Group:          Daemons
292 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
293 Requires:       %{name}-mod_ldap = %{epoch}:%{version}-%{release}
294 Requires:       %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
295
296 %description mod_quotatab_ldap
297 A mod_quotatab sub-module for obtaining quota information from an LDAP
298 directory.
299
300 %description mod_quotatab_ldap -l pl.UTF-8
301 Podmoduł mod_quotatab do pobierania informacji o ograniczeniach z
302 katalogu LDAP.
303
304 %package mod_quotatab_sql
305 Summary:        ProFTPD quotatab sql module
306 Summary(pl.UTF-8):   Moduł quotatab_sql dla ProFTPD
307 Group:          Daemons
308 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
309 Requires:       %{name}-mod_quotatab = %{epoch}:%{version}-%{release}
310 Requires:       %{name}-mod_sql = %{epoch}:%{version}-%{release}
311
312 %description mod_quotatab_sql
313 A mod_quotatab sub-module for managing quota data via SQL-based
314 tables.
315
316 %description mod_quotatab_sql -l pl.UTF-8
317 Podmoduł mod_quotatab do zarządzania danymi o ograniczeniach poprzez
318 tabele SQL.
319
320 %package mod_ratio
321 Summary:        ProFTPD ratio module
322 Summary(pl.UTF-8):   Moduł ratio dla ProFTPD
323 Group:          Daemons
324 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
325
326 %description mod_ratio
327 Support upload/download ratios.
328
329 %description mod_ratio -l pl.UTF-8
330 Obsługa współczynników upload/download.
331
332 %package mod_readme
333 Summary:        ProFTPD readme module
334 Summary(pl.UTF-8):   Moduł readme dla ProFTPD
335 Group:          Daemons
336 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
337
338 %description mod_readme
339 "README" file support.
340
341 %description mod_readme -l pl.UTF-8
342 Obsługa pliku "README".
343
344 %package mod_sql
345 Summary:        ProFTPD SQL support module
346 Summary(pl.UTF-8):   Moduł obsługi SQL dla ProFTPD
347 Group:          Daemons
348 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
349
350 %description mod_sql
351 This module provides the necessary support for SQL based
352 authentication, logging and other features as required.
353
354 %description mod_sql -l pl.UTF-8
355 Ten moduł dodaje obsługę SQL potrzebną do uwierzytelniania, logowania
356 i innych możliwości opartych o SQL.
357
358 %package mod_sql_mysql
359 Summary:        ProFTPD sql mysql module
360 Summary(pl.UTF-8):   Moduł sql_mysql dla ProFTPD
361 Group:          Daemons
362 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
363 Requires:       %{name}-mod_sql = %{epoch}:%{version}-%{release}
364
365 %description mod_sql_mysql
366 Support for connecting to MySQL databases.
367
368 %description mod_sql_mysql -l pl.UTF-8
369 Obsługa łączenia się z bazami danych MySQL.
370
371 %package mod_sql_postgres
372 Summary:        ProFTPD sql postgres module
373 Summary(pl.UTF-8):   Moduł sql_postgres dla ProFTPD
374 Group:          Daemons
375 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
376 Requires:       %{name}-mod_sql = %{epoch}:%{version}-%{release}
377
378 %description mod_sql_postgres
379 Support for connecting to PostgreSQL databases.
380
381 %description mod_sql_postgres -l pl.UTF-8
382 Obsługa łączenia się z bazami danych PostgreSQL.
383
384 %package mod_tls
385 Summary:        ProFTPD TLS support
386 Summary(pl.UTF-8):   Obsługa TLS dla ProFTPD
387 Group:          Daemons
388 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
389
390 %description mod_tls
391 An RFC2228 SSL/TLS module for ProFTPD.
392
393 %description mod_tls -l pl.UTF-8
394 Moduł SSL/TLS zgodny z RFC2228 dla ProFTPD.
395
396 %package mod_wrap
397 Summary:        ProFTPD interface to libwrap
398 Summary(pl.UTF-8):   Interfejs ProFTPD do libwrap
399 Group:          Daemons
400 Requires:       %{name}-common = %{epoch}:%{version}-%{release}
401 Requires:       libwrap
402
403 %description mod_wrap
404 It enables the daemon to use the common tcpwrappers access control
405 library while in standalone mode, and in a very configurable manner.
406
407 Many programs will automatically add entries in the common allow/deny
408 files, and use of this module will allow a ProFTPD daemon running in
409 standalone mode to adapt as these entries are added. The portsentry
410 program does this, for example: when illegal access is attempted, it
411 will add hosts to the /etc/hosts.deny file.
412
413 %description mod_wrap -l pl.UTF-8
414 Ten pakiet pozwala demonowi używać wspólnej biblioteki kontroli
415 dostępu tcpwrappers w trybie samodzielnym w bardzo wygodny sposób.
416
417 Wiele programów automatycznie dodaje wpisy we wspólnych plikach
418 allow/deny, a użycie tego modułu pozwala demonowi ProFTPD działającemu
419 w trybie samodzielnym adaptować te wpisy w miarę dodawania. Robi tak
420 na przykład program portsentry: przy próbie niedozwolonego dostępu
421 dodaje hosty do pliku /etc/hosts.deny.
422
423 %prep
424 %setup -q -n %{name}-%{version}%{?_rc}
425 %patch0 -p1
426 %patch1 -p1
427 %patch2 -p1
428 %patch3 -p1
429 %patch4 -p1
430 %patch5 -p1
431 %patch6 -p1
432 %patch7 -p0
433 %patch8 -p1
434
435 cp -f /usr/share/automake/config.sub .
436
437 # cleanup backups after patching
438 find . '(' -name '*~' -o -name '*.orig' ')' -print0 | xargs -0 -r -l512 rm -f
439
440 %build
441 %{__autoconf}
442
443 MODULES="
444 mod_ratio
445 mod_readme
446 mod_wrap
447 %{?with_ssl:mod_tls}
448 %{?with_pam:mod_auth_pam}
449 %{?with_ldap:mod_ldap}
450 %{?with_quotafile:mod_quotatab mod_quotatab_file}
451 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
452 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
453 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
454 %{?with_linuxprivs:mod_linuxprivs}
455 %{?with_mysql:mod_sql mod_sql_mysql}
456 %{?with_pgsql:mod_sql mod_sql_postgres}
457 "
458
459 MODARG=$(echo $MODULES | tr ' ' '\n' | sort -u | xargs | tr ' ' ':')
460 %configure \
461         --with-includes=/usr/include/ncurses%{?with_mysql::%{_includedir}/mysql} \
462         --enable-autoshadow \
463         --enable-ctrls \
464         --enable-dso \
465         --enable-facl \
466         %{?with_ipv6:--enable-ipv6} \
467         --enable-sendfile \
468         %{!?with_ssl:--disable-tls} \
469         --with-shared=$MODARG \
470
471 %{__make}
472
473 %install
474 rm -rf $RPM_BUILD_ROOT
475 install -d $RPM_BUILD_ROOT/etc/{pam.d,security,sysconfig/rc-inetd,rc.d/init.d} \
476         $RPM_BUILD_ROOT/var/{lib/ftp/pub/Incoming,log} \
477         $RPM_BUILD_ROOT%{_sysconfdir}/conf.d \
478         $RPM_BUILD_ROOT%{_includedir}/%{name}
479
480 %{__make} install \
481         DESTDIR=$RPM_BUILD_ROOT \
482         INSTALL_USER=%(id -u) \
483         INSTALL_GROUP=%(id -g)
484
485 rm $RPM_BUILD_ROOT%{_sbindir}/in.proftpd
486
487 install %{SOURCE1} $RPM_BUILD_ROOT%{_sysconfdir}
488 install %{SOURCE9} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_auth_pam.conf
489 %{?with_ldap:echo 'LoadModule        mod_ldap.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_ldap.conf}
490 echo 'LoadModule        mod_quotatab.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab.conf
491 echo 'LoadModule        mod_quotatab_file.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab_file.conf
492 %{?with_quotaldap:echo 'LoadModule        mod_quotatab_ldap.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab_ldap.conf}
493 echo 'LoadModule        mod_ratio.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_ratio.conf
494 echo 'LoadModule        mod_readme.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_readme.conf
495 %if %{with mysql} || %{with pgsql}
496 echo 'LoadModule        mod_quotatab_sql.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab_sql.conf
497 echo 'LoadModule        mod_sql.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_sql.conf
498 %endif
499 %{?with_mysql:echo 'LoadModule        mod_sql_mysql.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_sql_mysql.conf}
500 %{?with_pgsql:echo 'LoadModule        mod_sql_postgres.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_sql_postgres.conf}
501 install %{SOURCE10} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_tls.conf
502 echo 'LoadModule        mod_wrap.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_wrap.conf
503 install %{SOURCE11} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/anonftp.conf
504
505 %{?with_pam:install %{SOURCE3} $RPM_BUILD_ROOT/etc/pam.d/ftp}
506 install %{SOURCE4} $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/ftpd
507 install %{SOURCE5} $RPM_BUILD_ROOT/etc/sysconfig/proftpd
508 install %{SOURCE6} $RPM_BUILD_ROOT/etc/rc.d/init.d/proftpd
509 install contrib/xferstats.holger-preiss $RPM_BUILD_ROOT%{_bindir}/xferstat
510
511 bzip2 -dc %{SOURCE7} | tar xf - -C $RPM_BUILD_ROOT%{_mandir}
512
513 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers.default
514 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers
515
516 # only for -inetd package?
517 ln -sf proftpd $RPM_BUILD_ROOT%{_sbindir}/ftpd
518
519 :> $RPM_BUILD_ROOT/etc/security/blacklist.ftp
520
521 rm $RPM_BUILD_ROOT%{_libdir}/%{name}/*.a
522 rm $RPM_BUILD_ROOT%{_libdir}/%{name}/*.la
523
524 rm -f $RPM_BUILD_ROOT%{_mandir}/ftpusers-path.diff*
525 cp -aL include/* config.h $RPM_BUILD_ROOT%{_includedir}/%{name}
526
527 %clean
528 rm -rf $RPM_BUILD_ROOT
529
530 %post common
531 umask 027
532 awk -F: '{ if (($3 < 500) && ($1 != "ftp")) print $1; }' < /etc/passwd >> %{_sysconfdir}/ftpusers.default
533 if [ ! -f %{_sysconfdir}/ftpusers ]; then
534         cp -f %{_sysconfdir}/ftpusers.default %{_sysconfdir}/ftpusers
535 fi
536
537 %posttrans inetd
538 if grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf ; then
539         cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
540         sed -i -e 's/^ServerType[[:space:]]\+standalone/ServerType                      inetd/g' %{_sysconfdir}/proftpd.conf
541 fi
542 %service -q rc-inetd reload
543
544 %postun inetd
545 if [ "$1" = "0" ]; then
546         %service -q rc-inetd reload
547 fi
548
549 %posttrans standalone
550 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf ; then
551         cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
552         sed -i -e 's/^ServerType[[:space:]]\+inetd/ServerType                   standalone/g' %{_sysconfdir}/proftpd.conf
553 fi
554 /sbin/chkconfig --add proftpd
555 %service proftpd restart "ProFTPD daemon"
556
557 %preun standalone
558 if [ "$1" = "0" ]; then
559         %service proftpd stop
560         /sbin/chkconfig --del proftpd
561 fi
562
563 # macro called at module post scriptlet
564 %define module_post \
565 if [ "$1" = "1" ]; then \
566         if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
567                 %service -q rc-inetd reload \
568         elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
569                 %service -q proftpd restart \
570         fi \
571 fi
572
573 # macro called at module postun scriptlet
574 %define module_postun \
575 if [ "$1" = "0" ]; then \
576         if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
577                 %service -q rc-inetd reload \
578         elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
579                 %service -q proftpd restart \
580         fi \
581 fi
582
583 # it's sooo annoying to write them
584 %define module_scripts() \
585 %post %1 \
586 %module_post \
587 \
588 %postun %1 \
589 %module_postun
590
591 %module_scripts mod_auth_pam
592 %module_scripts mod_ldap
593 %module_scripts mod_quotatab
594 %module_scripts mod_quotatab_file
595 %module_scripts mod_quotatab_ldap
596 %module_scripts mod_quotatab_sql
597 %module_scripts mod_ratio
598 %module_scripts mod_readme
599 %module_scripts mod_sql
600 %module_scripts mod_sql_mysql
601 %module_scripts mod_sql_postgres
602 %module_scripts mod_tls
603 %module_scripts mod_wrap
604
605 %triggerpostun inetd -- %{name}-inetd <= 1:1.2.10
606 echo "Changing deprecated config options"
607 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
608 sed -i -e '
609         s/AuthPAMAuthoritative\b/AuthPAM/
610         s/TCPDServiceName/TCPServiceName/
611         s/TlsRsaCertFile/TLSRSACertificateFile/
612         s/TlsRsaKeyFile/TLSRSACertificateKeyFile/
613         s/TlsDsaCertFile/TLSDSACertificateFile/
614         s/TlsDsaKeyFile/TLSDSACertificateKeyFile/
615         s/TlsCrlFile/TLSCARevocationFile/
616         s/TlsDhParamFile/TLSDHParamFile/
617         s/TlsCipherList/TLSCipherSuite/
618         s/TlsCertsOk/TLSVerifyClient/
619         /UseTCPD/d
620 ' %{_sysconfdir}/proftpd.conf
621
622 %triggerpostun standalone -- %{name}-standalone <= 1:1.2.10
623 echo "Changing deprecated config options"
624 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
625 sed -i -e '
626         s/AuthPAMAuthoritative\b/AuthPAM/
627         s/TCPDServiceName/TCPServiceName/
628         s/TlsRsaCertFile/TLSRSACertificateFile/
629         s/TlsRsaKeyFile/TLSRSACertificateKeyFile/
630         s/TlsDsaCertFile/TLSDSACertificateFile/
631         s/TlsDsaKeyFile/TLSDSACertificateKeyFile/
632         s/TlsCrlFile/TLSCARevocationFile/
633         s/TlsDhParamFile/TLSDHParamFile/
634         s/TlsCipherList/TLSCipherSuite/
635         s/TlsCertsOk/TLSVerifyClient/
636         /UseTCPD/d
637 ' %{_sysconfdir}/proftpd.conf
638
639 %files common
640 %defattr(644,root,root,755)
641 %doc sample-configurations/*.conf CREDITS ChangeLog NEWS RELEASE_NOTES
642 %doc README README.capabilities README.classes README.controls README.IPv6
643 %doc README.modules
644 %doc doc/*html
645 %dir %attr(750,root,ftp) %dir %{_sysconfdir}
646 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*.conf
647 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %ghost %{_sysconfdir}/ftpusers
648 %attr(640,root,root) %{_sysconfdir}/ftpusers.default
649 %dir %attr(750,root,root) %{_sysconfdir}/conf.d
650 %attr(755,root,root) %{_bindir}/*
651 %attr(755,root,root) %{_sbindir}/*
652 %dir %{_libdir}/%{name}
653 %dir /var/run/proftpd
654 %{_mandir}/man[18]/*
655 %dir /var/lib/ftp
656 %dir /var/lib/ftp/pub
657 %attr(711,ftp,ftp) %dir /var/lib/ftp/pub/Incoming
658
659 %files inetd
660 %defattr(644,root,root,755)
661 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/rc-inetd/ftpd
662 %{_mandir}/man5/*
663 %lang(ja) %{_mandir}/ja/man5/ftpusers*
664 %lang(pl) %{_mandir}/pl/man5/ftpusers*
665 %lang(pt_BR) %{_mandir}/pt_BR/man5/ftpusers*
666 %lang(ru) %{_mandir}/ru/man5/ftpusers*
667
668 %files standalone
669 %defattr(644,root,root,755)
670 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/proftpd
671 %attr(754,root,root) /etc/rc.d/init.d/proftpd
672 %{_mandir}/man5/*
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*
677
678 %files devel
679 %defattr(644,root,root,755)
680 %{_includedir}/%{name}
681
682 %files anonftp
683 %defattr(644,root,root,755)
684 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/anonftp.conf
685
686 %if %{with pam}
687 %files mod_auth_pam
688 %defattr(644,root,root,755)
689 %doc README.PAM
690 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/pam.d/*
691 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/security/blacklist.ftp
692 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_auth_pam.conf
693 %attr(755,root,root) %{_libexecdir}/mod_auth_pam.so
694 %endif
695
696 %if %{with ldap}
697 %files mod_ldap
698 %defattr(644,root,root,755)
699 %doc README.LDAP
700 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ldap.conf
701 %attr(755,root,root) %{_libexecdir}/mod_ldap.so
702 %endif
703
704 %files mod_quotatab
705 %defattr(644,root,root,755)
706 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab.conf
707 %attr(755,root,root) %{_libexecdir}/mod_quotatab.so
708
709 %if %{with quotafile}
710 %files mod_quotatab_file
711 %defattr(644,root,root,755)
712 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_file.conf
713 %attr(755,root,root) %{_libexecdir}/mod_quotatab_file.so
714 %endif
715
716 %if %{with quotaldap}
717 %files mod_quotatab_ldap
718 %defattr(644,root,root,755)
719 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_ldap.conf
720 %attr(755,root,root) %{_libexecdir}/mod_quotatab_ldap.so
721 %endif
722
723 %if %{with quotamysql} || %{with quotapgsql}
724 %files mod_quotatab_sql
725 %defattr(644,root,root,755)
726 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_quotatab_sql.conf
727 %attr(755,root,root) %{_libexecdir}/mod_quotatab_sql.so
728 %endif
729
730 %files mod_ratio
731 %defattr(644,root,root,755)
732 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_ratio.conf
733 %attr(755,root,root) %{_libexecdir}/mod_ratio.so
734
735 %files mod_readme
736 %defattr(644,root,root,755)
737 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_readme.conf
738 %attr(755,root,root) %{_libexecdir}/mod_readme.so
739
740 %if %{with mysql} || %{with pgsql}
741 %files mod_sql
742 %defattr(644,root,root,755)
743 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql.conf
744 %attr(755,root,root) %{_libexecdir}/mod_sql.so
745 %endif
746
747 %if %{with mysql}
748 %files mod_sql_mysql
749 %defattr(644,root,root,755)
750 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_mysql.conf
751 %attr(755,root,root) %{_libexecdir}/mod_sql_mysql.so
752 %endif
753
754 %if %{with pgsql}
755 %files mod_sql_postgres
756 %defattr(644,root,root,755)
757 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_sql_postgres.conf
758 %attr(755,root,root) %{_libexecdir}/mod_sql_postgres.so
759 %endif
760
761 %files mod_tls
762 %defattr(644,root,root,755)
763 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_tls.conf
764 %attr(755,root,root) %{_libexecdir}/mod_tls.so
765
766 %files mod_wrap
767 %defattr(644,root,root,755)
768 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/conf.d/mod_wrap.conf
769 %attr(755,root,root) %{_libexecdir}/mod_wrap.so
This page took 0.146225 seconds and 4 git commands to generate.