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