]> git.pld-linux.org Git - packages/proftpd.git/blob - proftpd.spec
- revert source url
[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            # disable LDAP support
9 %bcond_without  mysql           # disable MySQL support
10 %bcond_without  pgsql           # disable PostgreSQL support
11 %bcond_without  quotafile       # disable quota file support
12 %bcond_without  quotaldap       # disable quota ldap support
13 %bcond_without  quotamysql      # disable quota mysql support
14 %bcond_without  quotapgsql      # disable 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.1
23 %define _rc     rc3
24 Release:        0.%{_rc}1
25 Epoch:          2
26 License:        GPL v2+
27 Group:          Daemons
28 Source0:        ftp://ftp.proftpd.org/distrib/source/%{name}-%{version}%{_rc}.tar.bz2
29 # Source0-md5:  485af3aee9ecebfeae1ae2003250a3a9
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 Patch6:         %{name}-mysql-typo.patch
47 URL:            http://www.proftpd.org/
48 BuildRequires:  autoconf
49 BuildRequires:  automake
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 %patch6 -p1
433
434 cp -f /usr/share/automake/config.sub .
435
436 # cleanup backups after patching
437 find . '(' -name '*~' -o -name '*.orig' ')' -print0 | xargs -0 -r -l512 rm -f
438
439 %build
440 %{__autoconf}
441
442 MODULES="
443 mod_ratio
444 mod_readme
445 mod_wrap
446 %{?with_ssl:mod_tls}
447 %{?with_pam:mod_auth_pam}
448 %{?with_ldap:mod_ldap}
449 %{?with_quotafile:mod_quotatab mod_quotatab_file}
450 %{?with_quotaldap:mod_quotatab mod_quotatab_ldap}
451 %{?with_quotamysql:mod_quotatab mod_quotatab_sql}
452 %{?with_quotapgsql:mod_quotatab mod_quotatab_sql}
453 %{?with_linuxprivs:mod_linuxprivs}
454 %{?with_mysql:mod_sql mod_sql_mysql}
455 %{?with_pgsql:mod_sql mod_sql_postgres}
456 "
457
458 MODARG=$(echo $MODULES | tr ' ' '\n' | sort -u | xargs | tr ' ' ':')
459 %configure \
460         --with-includes=/usr/include/ncurses%{?with_mysql::%{_includedir}/mysql} \
461         --enable-autoshadow \
462         --enable-ctrls \
463         --enable-dso \
464         --enable-facl \
465         %{?with_ipv6:--enable-ipv6} \
466         --enable-sendfile \
467         %{!?with_ssl:--disable-tls} \
468         --with-shared=$MODARG \
469
470 %{__make}
471
472 %install
473 rm -rf $RPM_BUILD_ROOT
474 install -d $RPM_BUILD_ROOT/etc/{pam.d,security,sysconfig/rc-inetd,rc.d/init.d} \
475         $RPM_BUILD_ROOT/var/{lib/ftp/pub/Incoming,log} \
476         $RPM_BUILD_ROOT%{_sysconfdir}/conf.d \
477         $RPM_BUILD_ROOT%{_includedir}/%{name}
478
479 %{__make} install \
480         DESTDIR=$RPM_BUILD_ROOT \
481         INSTALL_USER=%(id -u) \
482         INSTALL_GROUP=%(id -g)
483
484 rm $RPM_BUILD_ROOT%{_sbindir}/in.proftpd
485
486 install %{SOURCE1} $RPM_BUILD_ROOT%{_sysconfdir}
487 install %{SOURCE9} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_auth_pam.conf
488 %{?with_ldap:echo 'LoadModule        mod_ldap.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_ldap.conf}
489 echo 'LoadModule        mod_quotatab.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab.conf
490 echo 'LoadModule        mod_quotatab_file.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab_file.conf
491 %{?with_quotaldap:echo 'LoadModule        mod_quotatab_ldap.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab_ldap.conf}
492 echo 'LoadModule        mod_ratio.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_ratio.conf
493 echo 'LoadModule        mod_readme.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_readme.conf
494 %if %{with mysql} || %{with pgsql}
495 echo 'LoadModule        mod_quotatab_sql.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_quotatab_sql.conf
496 echo 'LoadModule        mod_sql.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_sql.conf
497 %endif
498 %{?with_mysql:echo 'LoadModule        mod_sql_mysql.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_sql_mysql.conf}
499 %{?with_pgsql:echo 'LoadModule        mod_sql_postgres.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_sql_postgres.conf}
500 install %{SOURCE10} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_tls.conf
501 echo 'LoadModule        mod_wrap.c' > $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/mod_wrap.conf
502 install %{SOURCE11} $RPM_BUILD_ROOT%{_sysconfdir}/conf.d/anonftp.conf
503
504 %{?with_pam:install %{SOURCE3} $RPM_BUILD_ROOT/etc/pam.d/ftp}
505 install %{SOURCE4} $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/ftpd
506 install %{SOURCE5} $RPM_BUILD_ROOT/etc/sysconfig/proftpd
507 install %{SOURCE6} $RPM_BUILD_ROOT/etc/rc.d/init.d/proftpd
508 install contrib/xferstats.holger-preiss $RPM_BUILD_ROOT%{_bindir}/xferstat
509
510 bzip2 -dc %{SOURCE7} | tar xf - -C $RPM_BUILD_ROOT%{_mandir}
511
512 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers.default
513 :> $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers
514
515 # only for -inetd package?
516 ln -sf proftpd $RPM_BUILD_ROOT%{_sbindir}/ftpd
517
518 :> $RPM_BUILD_ROOT/etc/security/blacklist.ftp
519
520 rm $RPM_BUILD_ROOT%{_libdir}/%{name}/*.a
521 rm $RPM_BUILD_ROOT%{_libdir}/%{name}/*.la
522
523 rm -f $RPM_BUILD_ROOT%{_mandir}/ftpusers-path.diff*
524 cp -aL include/* config.h $RPM_BUILD_ROOT%{_includedir}/%{name}
525
526 %clean
527 rm -rf $RPM_BUILD_ROOT
528
529 %post common
530 umask 027
531 awk -F: '{ if (($3 < 500) && ($1 != "ftp")) print $1; }' < /etc/passwd >> %{_sysconfdir}/ftpusers.default
532 if [ ! -f %{_sysconfdir}/ftpusers ]; then
533         cp -f %{_sysconfdir}/ftpusers.default %{_sysconfdir}/ftpusers
534 fi
535
536 %posttrans inetd
537 if grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf ; then
538         cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
539         sed -i -e 's/^ServerType[[:space:]]\+standalone/ServerType                      inetd/g' %{_sysconfdir}/proftpd.conf
540 fi
541 %service -q rc-inetd reload
542
543 %postun inetd
544 if [ "$1" = "0" ]; then
545         %service -q rc-inetd reload
546 fi
547
548 %posttrans standalone
549 if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf ; then
550         cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
551         sed -i -e 's/^ServerType[[:space:]]\+inetd/ServerType                   standalone/g' %{_sysconfdir}/proftpd.conf
552 fi
553 /sbin/chkconfig --add proftpd
554 %service proftpd restart "ProFTPD daemon"
555
556 %preun standalone
557 if [ "$1" = "0" ]; then
558         %service proftpd stop
559         /sbin/chkconfig --del proftpd
560 fi
561
562 # macro called at module post scriptlet
563 %define module_post \
564 if [ "$1" = "1" ]; then \
565         if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
566                 %service -q rc-inetd reload \
567         elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
568                 %service -q proftpd restart \
569         fi \
570 fi
571
572 # macro called at module postun scriptlet
573 %define module_postun \
574 if [ "$1" = "0" ]; then \
575         if grep -iEqs "^ServerType[[:space:]]+inetd" %{_sysconfdir}/proftpd.conf; then \
576                 %service -q rc-inetd reload \
577         elif grep -iEqs "^ServerType[[:space:]]+standalone" %{_sysconfdir}/proftpd.conf; then \
578                 %service -q proftpd restart \
579         fi \
580 fi
581
582 # it's sooo annoying to write them
583 %define module_scripts() \
584 %post %1 \
585 %module_post \
586 \
587 %postun %1 \
588 %module_postun
589
590 %module_scripts mod_auth_pam
591 %module_scripts mod_ldap
592 %module_scripts mod_quotatab
593 %module_scripts mod_quotatab_file
594 %module_scripts mod_quotatab_ldap
595 %module_scripts mod_quotatab_sql
596 %module_scripts mod_ratio
597 %module_scripts mod_readme
598 %module_scripts mod_sql
599 %module_scripts mod_sql_mysql
600 %module_scripts mod_sql_postgres
601 %module_scripts mod_tls
602 %module_scripts mod_wrap
603
604 %triggerpostun inetd -- %{name}-inetd <= 1:1.2.10
605 echo "Changing deprecated config options"
606 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
607 sed -i -e '
608         s/AuthPAMAuthoritative\b/AuthPAM/
609         s/TCPDServiceName/TCPServiceName/
610         s/TlsRsaCertFile/TLSRSACertificateFile/
611         s/TlsRsaKeyFile/TLSRSACertificateKeyFile/
612         s/TlsDsaCertFile/TLSDSACertificateFile/
613         s/TlsDsaKeyFile/TLSDSACertificateKeyFile/
614         s/TlsCrlFile/TLSCARevocationFile/
615         s/TlsDhParamFile/TLSDHParamFile/
616         s/TlsCipherList/TLSCipherSuite/
617         s/TlsCertsOk/TLSVerifyClient/
618         /UseTCPD/d
619 ' %{_sysconfdir}/proftpd.conf
620
621 %triggerpostun standalone -- %{name}-standalone <= 1:1.2.10
622 echo "Changing deprecated config options"
623 cp -f %{_sysconfdir}/proftpd.conf{,.rpmorig}
624 sed -i -e '
625         s/AuthPAMAuthoritative\b/AuthPAM/
626         s/TCPDServiceName/TCPServiceName/
627         s/TlsRsaCertFile/TLSRSACertificateFile/
628         s/TlsRsaKeyFile/TLSRSACertificateKeyFile/
629         s/TlsDsaCertFile/TLSDSACertificateFile/
630         s/TlsDsaKeyFile/TLSDSACertificateKeyFile/
631         s/TlsCrlFile/TLSCARevocationFile/
632         s/TlsDhParamFile/TLSDHParamFile/
633         s/TlsCipherList/TLSCipherSuite/
634         s/TlsCertsOk/TLSVerifyClient/
635         /UseTCPD/d
636 ' %{_sysconfdir}/proftpd.conf
637
638 %files common
639 %defattr(644,root,root,755)
640 %doc sample-configurations/*.conf CREDITS ChangeLog NEWS RELEASE_NOTES
641 %doc README README.capabilities README.classes README.controls README.IPv6
642 %doc README.modules
643 %doc doc/*html
644 %dir %attr(750,root,ftp) %dir %{_sysconfdir}
645 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*.conf
646 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %ghost %{_sysconfdir}/ftpusers
647 %attr(640,root,root) %{_sysconfdir}/ftpusers.default
648 %dir %attr(750,root,root) %{_sysconfdir}/conf.d
649 #%attr(640,root,root) %ghost /var/log/*
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.09168 seconds and 4 git commands to generate.