X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=pure-ftpd.spec;h=5aeaf3741359920d4b97f6251ff3395a56c5819c;hb=b99c8afc08ea9b4c0e596081711d86c966b877aa;hp=8d3348184f076fd75c44638299e97f4f1d36435e;hpb=a701bd9407d1685af46f5d618220e89f4c1db832;p=packages%2Fpure-ftpd.git diff --git a/pure-ftpd.spec b/pure-ftpd.spec index 8d33481..5aeaf37 100644 --- a/pure-ftpd.spec +++ b/pure-ftpd.spec @@ -7,44 +7,53 @@ %bcond_without pgsql # disable PostgreSQL support %bcond_without puredb # disable pure-db support %bcond_without tls # disable SSL/TLS support +%bcond_without cap # disable capabilities # Summary: Small, fast and secure FTP server -Summary(pl): Ma³y, szybki i bezpieczny serwer FTP +Summary(pl.UTF-8): Mały, szybki i bezpieczny serwer FTP Name: pure-ftpd -Version: 1.0.20 -Release: 2 +Version: 1.0.21 +Release: 5%{?with_extra:extra} Epoch: 0 -License: BSD-like +License: BSD-like%{?with_extra:, GLPv2 for pure-config due to libcfg+ license} Group: Daemons Source0: ftp://ftp.pureftpd.org/pub/pure-ftpd/releases/%{name}-%{version}.tar.bz2 -# Source0-md5: e928e9e15adf6b52bfe6183fdad20144 +# Source0-md5: ca8a8dbec0cd9c8ea92fc4c37ea9c410 Source1: %{name}.pamd Source2: %{name}.init Source3: ftpusers.tar.bz2 # Source3-md5: 76c80b6ec9f4d079a1e27316edddbe16 +Source4: http://twittner.host.sk/files/pure-config/pure-config-20041201.tar.gz +# Source4-md5: 3f2ff6b00b5c38ee11ce588ee5af6cf6 Patch0: %{name}-config.patch -# This patch is broken and changes default pureftpd behaviour Patch1: %{name}-path_to_ssl_cert_in_config.patch Patch2: %{name}-pure-pw_passwd.patch -Patch3: %{name}-userlength.patch +Patch3: %{name}-mysql_config.patch +Patch4: %{name}-nosymlinks-hideuidmismatch.patch +Patch5: %{name}-auth-can-delete-pure.patch URL: http://www.pureftpd.org/ -BuildRequires: libcap-devel -%{?with_ldap:BuildRequires: openldap-devel} +%{?with_extra:BuildRequires: autoconf} +%{?with_extra:BuildRequires: automake} +%{?with_cap:BuildRequires: libcap-devel} +%{?with_extra:BuildRequires: libcfg+-devel >= 0.6.2} %{?with_mysql:BuildRequires: mysql-devel} -%{?with_pgsql:BuildRequires: postgresql-devel} +%{?with_ldap:BuildRequires: openldap-devel >= 2.3.0} %{?with_tls:BuildRequires: openssl-devel} BuildRequires: pam-devel -PreReq: rc-scripts -Requires(post,preun):/sbin/chkconfig -Requires: pam >= 0.77.3 -Requires: perl-base +%{?with_pgsql:BuildRequires: postgresql-devel} +BuildRequires: rpmbuild(macros) >= 1.304 +Requires(post,preun): /sbin/chkconfig +Requires: pam >= 0.79.0 +%{!?with_extra:Requires: perl-base} +Requires: rc-scripts Provides: ftpserver -Obsoletes: ftpserver Obsoletes: anonftp Obsoletes: bftpd Obsoletes: ftpd-BSD +Obsoletes: ftpserver Obsoletes: glftpd Obsoletes: heimdal-ftpd +Obsoletes: krb5-ftpd Obsoletes: linux-ftpd Obsoletes: muddleftpd Obsoletes: proftpd @@ -59,6 +68,7 @@ BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) %define _sysconfdir /etc/ftpd %define _ftpdir /home/services/ftp +%define schemadir /usr/share/openldap/schema %description Pure-FTPd is a fast, production-quality, standard-comformant FTP @@ -69,25 +79,43 @@ capabilities) . Features include PAM support, IPv6, chroot()ed home directories, virtual domains, built-in LS, anti-warez system, bounded ports for passive downloads... -%description -l pl -Pure-FTPD to szybki, wysokiej jako¶ci, odpowiadaj±cy standardom serwer -FTP bazuj±cy na Troll-FTPd. W przeciwieñstwie do innych serwerów FTP -nie ma znanych luk w bezpieczeñstwie. Ponadto jest trywialny w +%description -l pl.UTF-8 +Pure-FTPD to szybki, wysokiej jakości, odpowiadający standardom serwer +FTP bazujący na Troll-FTPd. W przeciwieństwie do innych serwerów FTP +nie ma znanych luk w bezpieczeństwie. Ponadto jest trywialny w konfiguracji i specjalnie zaprojektowany dla nowych kerneli Linuksa -(setfsuid, sendfile, capabilibies). Mo¿liwo¶ci to wsparcie dla PAMa, -IPv6, chroot()owanych katalogów domowych, virtualne domeny, wbudowany -LS, system anty-warezowy, ograniczanie portów dla pasywnych -po³±czeñ... +(setfsuid, sendfile, capabilibies). Możliwości to wsparcie dla PAM-a, +IPv6, chroot()owanych katalogów domowych, virtualne domeny, wbudowany +LS, system anty-warezowy, ograniczanie portów dla pasywnych +połączeń... + +%package -n openldap-schema-pureftpd +Summary: Pure-FTPd LDAP schema +Summary(pl.UTF-8): Schemat LDAP dla Pure-FTPd +Group: Networking/Daemons +Requires(post,postun): sed >= 4.0 +Requires: openldap-servers +Requires: sed >= 4.0 + +%description -n openldap-schema-pureftpd +This package contains an Pure-FTPd openldap schema. + +%description -n openldap-schema-pureftpd -l pl.UTF-8 +Ten pakiet zawiera schemat Pure-FTPd pureftpd.schema dla openldapa. %prep -%setup -q +%setup -q -a 4 %patch0 -p0 -%{?with_longusername:%patch3 -p1} +%patch3 -p1 +%patch4 -p1 +%patch5 -p1 %{?with_extra:%patch1 -p1} %{?with_extra:%patch2 -p1} %build +# drop --without-cork for Th %configure \ + --without-cork \ --with-boring \ --with-altlog \ --with-cookie \ @@ -96,6 +124,7 @@ po --with-ftpwho \ --with-language=english \ --with-largefile \ + %{!?with_cap:--without-capabilities} \ %{?with_ldap:--with-ldap} \ %{?with_mysql:CPPFLAGS="-I%{_includedir}/mysql" --with-mysql} \ --with-pam \ @@ -109,12 +138,22 @@ po %{?with_tls:--with-tls --with-certfile=%{_sharedstatedir}/openssl/certs/ftpd.pem} \ --with-uploadscript \ --with-virtualchroot \ - --with-virtualhosts - + --with-virtualhosts + +%if %{with extra} +cd pure-config +%{__aclocal} +%{__autoconf} +%{__autoheader} +%{__automake} +%configure +%{__make} +%endif + %install rm -rf $RPM_BUILD_ROOT install -d $RPM_BUILD_ROOT/etc/{pam.d,sysconfig,security,rc.d/init.d} \ - $RPM_BUILD_ROOT{%{_sysconfdir}/vhosts,%{_ftpdir}} + $RPM_BUILD_ROOT{%{_sysconfdir}/vhosts,%{_ftpdir},%{schemadir}} %{__make} install \ DESTDIR=$RPM_BUILD_ROOT @@ -126,40 +165,53 @@ install %{SOURCE2} $RPM_BUILD_ROOT/etc/rc.d/init.d/%{name} %{?with_mysql:install pureftpd-mysql.conf $RPM_BUILD_ROOT%{_sysconfdir}/pureftpd-mysql.conf} %{?with_pgsql:install pureftpd-pgsql.conf $RPM_BUILD_ROOT%{_sysconfdir}/pureftpd-pgsql.conf} install configuration-file/pure-ftpd.conf $RPM_BUILD_ROOT%{_sysconfdir}/pureftpd.conf -install configuration-file/pure-config.pl $RPM_BUILD_ROOT%{_sbindir} -touch $RPM_BUILD_ROOT/etc/security/blacklist.ftp +%{!?with_extra:install configuration-file/pure-config.pl $RPM_BUILD_ROOT%{_sbindir}} +install pureftpd.schema $RPM_BUILD_ROOT%{schemadir}/pureftpd.schema + +touch $RPM_BUILD_ROOT%{_sysconfdir}/ftpusers ln -s vhosts $RPM_BUILD_ROOT%{_sysconfdir}/pure-ftpd bzip2 -dc %{SOURCE3} | tar xf - -C $RPM_BUILD_ROOT%{_mandir} +rm -f $RPM_BUILD_ROOT%{_mandir}/ftpusers-path.diff + +%if %{with extra} +%{__make} -C pure-config install \ + DESTDIR=$RPM_BUILD_ROOT +%endif %clean rm -rf $RPM_BUILD_ROOT %post /sbin/chkconfig --add %{name} -if [ -f %{_var}/lock/subsys/%{name} ]; then - /etc/rc.d/init.d/%{name} restart 1>&2 -else - echo "Run \"/etc/rc.d/init.d/%{name} start\" to start PureFTPD daemon." -fi +%service %{name} restart "PureFTPD daemon" %preun if [ "$1" = "0" ]; then - if [ -f %{_var}/lock/subsys/%{name} ]; then - /etc/rc.d/init.d/%{name} stop 1>&2 - fi + %service %{name} stop /sbin/chkconfig --del %{name} fi +%post -n openldap-schema-pureftpd +%openldap_schema_register %{schemadir}/pureftpd.schema -d core +%service -q ldap restart + +%postun -n openldap-schema-pureftpd +if [ "$1" = "0" ]; then + %openldap_schema_unregister %{schemadir}/pureftpd.schema + %service -q ldap restart +fi + + %files %defattr(644,root,root,755) -%doc AUTHORS ChangeLog CONTACT FAQ HISTORY NEWS README* THANKS pure*.conf pureftpd.schema +%doc AUTHORS ChangeLog CONTACT COPYING FAQ HISTORY NEWS README* THANKS pure*.conf pureftpd.schema %attr(755,root,root) %{_bindir}/* %attr(755,root,root) %{_sbindir}/* %attr(754,root,root) /etc/rc.d/init.d/%{name} %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/pam.d/* -%attr(640,root,root) %config(noreplace) %verify(not md5 size mtime) /etc/security/blacklist.ftp +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/ftpusers %{?with_ldap:%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/pureftpd-ldap.conf} %{?with_mysql:%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/pureftpd-mysql.conf} %{?with_pgsql:%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/pureftpd-pgsql.conf} @@ -173,3 +225,7 @@ fi %lang(pl) %{_mandir}/pl/man5/ftpusers* %lang(pt_BR) %{_mandir}/pt_BR/man5/ftpusers* %lang(ru) %{_mandir}/ru/man5/ftpusers* + +%files -n openldap-schema-pureftpd +%defattr(644,root,root,755) +%{schemadir}/pureftpd.schema