]> git.pld-linux.org Git - packages/cvs-nserver.git/blobdiff - cvs-nserver.spec
Release 36 (by relup.sh)
[packages/cvs-nserver.git] / cvs-nserver.spec
index 82353f1c2733660429d2bd53255fe06b311753cc..5386a417cfc9d2349c7974b35c9f59a84389be7a 100644 (file)
@@ -1,28 +1,56 @@
+# TODO:
+# - trigger for upgrade from old cvs - after that package stays without any
+#   users and nserver-common is not installed...
+# - cvschkpw causes sig11 when run without CVSSERVER variable set.
 Summary:       Concurrent Versions System - nserver
-Summary(de):   Concurrent-Versioning-System - nserver
-Summary(fr):   Un système pour maintenir à jour des fichiers - nserver
-Summary(pl):   Concurrent Versions System - nserver
-Summary(tr):   Sürüm denetim sistemi - nserver
+Summary(de.UTF-8):     Concurrent-Versioning-System - nserver
+Summary(fr.UTF-8):     Un système pour maintenir à jour des fichiers - nserver
+Summary(pl.UTF-8):     Concurrent Versions System - nserver
+Summary(tr.UTF-8):     Sürüm denetim sistemi - nserver
 Name:          cvs-nserver
-Version:       1.11.1.4
-Release:       3
+Version:       1.11.1.52
+Release:       36
 License:       GPL
 Group:         Development/Version Control
-Source0:       http://unc.dl.sourceforge.net/sourceforge/cvs-nserver/%{name}-%{version}.tar.gz
+Source0:       http://dl.sourceforge.net/cvs-nserver/%{name}-%{version}.tar.gz
+# Source0-md5: 357fb5f37cc556977dad79175e9c2d97
 Source1:       %{name}.inetd
 Source2:       cvs-pserver.inetd
 Patch0:                %{name}-cvspasswd.patch
 Patch1:                %{name}-info.patch
-# outdated, but maybe will be needed for checkpasswd (outside programs):
-Patch3:                %{name}-PAM_fix.patch
-Patch4:                %{name}-am_ac.patch
-Patch5:                %{name}-zlib.patch
+Patch2:                %{name}-am_ac.patch
+Patch3:                %{name}-cvspass.patch
+Patch4:                %{name}-home_etc.patch
+Patch5:                %{name}-ssl-link.patch
+Patch6:                %{name}-fix_doc_CVSUSER.patch
+Patch7:                %{name}-segv.patch
+Patch8:                %{name}-initgroups-rootonly.patch
+Patch9:                %{name}-zlibfix.patch
+Patch10:       %{name}-home_etc2.patch
+Patch11:       %{name}-posix.patch
+Patch12:       %{name}-CAN-2002-0844.patch
+Patch13:       %{name}-CAN-2003-0015.patch
+Patch14:       %{name}-CAN-2003-0977-and-CAN-2004-0180.patch
+Patch15:       %{name}-CAN-2004-0396.patch
+Patch16:       %{name}-CAN-2004-0414.patch
+Patch17:       %{name}-CAN-2004-0416-0417-0418.patch
+Patch18:       %{name}-dblshutdown.patch
+Patch19:       %{name}-krb5.patch
+Patch20:       %{name}-cvspasswd-mode.patch
+Patch21:       %{name}-getline.patch
+Patch22:       format-security.patch
+Patch23:       openssl.patch
+URL:           http://cvs-nserver.sourceforge.net/
 BuildRequires: autoconf
 BuildRequires: automake
+BuildRequires: heimdal-devel
+BuildRequires: openssl-devel >= 0.9.7d
+BuildRequires: rpmbuild(macros) >= 1.268
 BuildRequires: texinfo
+BuildRequires: zlib-devel
 BuildRoot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
-%define                _cvsroot        /home/cvsroot
+%define                _cvsroot        /var/lib/cvs
 
 %description
 CVS is a version control system, which allows you to keep old versions
@@ -35,273 +63,283 @@ and to control the concurrent editing of source files among multiple
 authors. CVS allows triggers to enable/log/control various operations
 and works well over a wide area network.
 
-%description -l de
-CVS ist ein Frontend für das RCS(1)-Revisionskontrollsystem, das den
+%description -l de.UTF-8
+CVS ist ein Frontend für das RCS(1)-Revisionskontrollsystem, das den
 Begriff der Revisionskontrolle von einer Sammlung von Dateien in einem
 einzelnen Verzeichnis auf eine ganze Hierarchie ausweitet, bestehend
 aus revisionskontrollierten Dateien. Diese Verzeichnisse und Dateien
 lassen sich zu einer Software-Release kombinieren. CVS bietet die
 Funktionen, die zur Verwaltung von Software-Releases und zur
-Überwachung der gleichzeitigen Bearbeitung von Quelldateien durch
+Überwachung der gleichzeitigen Bearbeitung von Quelldateien durch
 mehrere Software- Entwickler notwendig sind.
 
-%description -l fr
-"CVS" signifie "Concurrent Version System". C'est un système de
+%description -l fr.UTF-8
+"CVS" signifie "Concurrent Version System". C'est un système de
 comparaison de versions de fichiers, qui peut garder une trace des
-changements apportés à des fichiers (le plus souvent, les fichiers des
-sources d'un programme). CVS conserve seulement les différences, et
-non l'intégralité d'un fichier récent et d'un fichier plus ancien. A
+changements apportés à des fichiers (le plus souvent, les fichiers des
+sources d'un programme). CVS conserve seulement les différences, et
+non l'intégralité d'un fichier récent et d'un fichier plus ancien. A
 chaque modification d'un fichier, CVS garde (entre autres) le nom de
 la personne ayant fait la modification, la raison justifiant cette
-modification, et la date à laquelle celle-ci a eu lieu. CVS est très
-utile pour gérer la mise en commun des modifications apportées par
-plusieurs personnes travaillant en parallèle sur les mêmes fichiers.
+modification, et la date à laquelle celle-ci a eu lieu. CVS est très
+utile pour gérer la mise en commun des modifications apportées par
+plusieurs personnes travaillant en parallèle sur les mêmes fichiers.
 Au lieu de garder plusieurs versions des fichiers dans un seul
-répertoire, CVS crée une série de répertoires, chacun contenant une
-nouvelle version des fichiers. Ces répertoires et ces fichiers peuvent
-ensuite être regroupés pour former la version la plus à jour du
+répertoire, CVS crée une série de répertoires, chacun contenant une
+nouvelle version des fichiers. Ces répertoires et ces fichiers peuvent
+ensuite être regroupés pour former la version la plus à jour du
 logiciel. Installez ce package si vous avez besoin d'utiliser un
-système de contrôle de version.
-
-%description -l pl
-CVS jest nak³adk± na rcs (Revision Control System, czyli w wolnym
-t³umaczeniu system kontroli wersji zasobów), który rozszerza
-mo¿liwo¶ci rcs'a z narzêdzia do kontroli zbioru plików w pojedynczym
-katalogu o mo¿liwo¶æ kontroli zbioru hierarchicznie u³o¿onych
-katalogów z plikami. Z pomoc± CVS w ³atwy sposób mo¿na zarz±dzaæ kodem
-¼ród³owym opracowywanym przez nawet bardzo du¿e zespó³y programistów
-umo¿liwiaj±c ¶ledzenie i kontrolê wszystkich zmian w trakcie pracy nad
-projektami i wypuszczaniem pe³nych wersji oprogramowania (release).
-
-%description -l tr
+système de contrôle de version.
+
+%description -l pl.UTF-8
+CVS jest nakładką na rcs (Revision Control System, czyli w wolnym
+tłumaczeniu system kontroli wersji zasobów), który rozszerza
+możliwości rcs'a z narzędzia do kontroli zbioru plików w pojedynczym
+katalogu o możliwość kontroli zbioru hierarchicznie ułożonych
+katalogów z plikami. Z pomocą CVS w łatwy sposób można zarządzać kodem
+źródłowym opracowywanym przez nawet bardzo duże zespoły programistów
+umożliwiając śledzenie i kontrolę wszystkich zmian w trakcie pracy nad
+projektami i wypuszczaniem pełnych wersji oprogramowania (release).
+
+%description -l tr.UTF-8
 CVS (Concurrent Versioning System), tek bir dizindeki dosya
-topluluðunun sürüm denetimini, denetimi yapýlmýþ dizinlerin hiyerarþik
-topluluðuna geniþleten rcs(1) sürüm denetim sisteminin ön yüzüdür. Bu
-dizin ve dosyalar, bir yazýlým yayýný oluþturma amacýyla biraraya
-getirilebilir. CVS, bu yazýlým yayýnlarýnýn yönetilmesini ve kaynak
-dosyalarý bakýmýnýn birden çok yazýlým geliþtiricisi tarafýndan
-eþzamanlý olarak yapýlmasýný kontrol etmek için gereken iþlevleri
-saðlar.
-
-%package -n cvs-nserver-client
+topluluğunun sürüm denetimini, denetimi yapılmış dizinlerin hiyerarşik
+topluluğuna genişleten rcs(1) sürüm denetim sisteminin ön yüzüdür. Bu
+dizin ve dosyalar, bir yazılım yayını oluşturma amacıyla biraraya
+getirilebilir. CVS, bu yazılım yayınlarının yönetilmesini ve kaynak
+dosyaları bakımının birden çok yazılım geliştiricisi tarafından
+eşzamanlı olarak yapılmasını kontrol etmek için gereken işlevleri
+sağlar.
+
+%package client
 Summary:       Concurrent Versions System - client
-Summary(pl):   Concurrent Versions System - klient
+Summary(pl.UTF-8):     Concurrent Versions System - klient
 Group:         Development/Version Control
+Provides:      cvs-client = %{version}
+Obsoletes:     cvs-client
 Obsoletes:     cvs-npclient
-Obsoletes:     cvs
+Conflicts:     cvs
 
-%description -n cvs-nserver-client
+%description client
 CVS client.
 
-%description -n cvs-nserver-client -l pl
+%description client -l pl.UTF-8
 Klient CVS.
 
-%package -n cvs-nserver-common
-Summary:       Concurrent Versions System - common files.
-Summary(pl):   Concurrent Versions System - wspólne pliki.
+%package common
+Summary:       Concurrent Versions System - common files
+Summary(pl.UTF-8):     Concurrent Versions System - wspólne pliki
 Group:         Development/Version Control
-Requires:      cvs-nserver-client
-Obsoletes:     cvs-nserver
-Obsoletes:     cvs
-Requires(pre): /usr/bin/getgid
+Requires(postun):      /usr/sbin/groupdel
+Requires(postun):      /usr/sbin/userdel
 Requires(pre): /bin/id
+Requires(pre): /usr/bin/getgid
 Requires(pre): /usr/sbin/groupadd
 Requires(pre): /usr/sbin/useradd
 Requires(pre): cvs-nserver-client
 Requires(pre): fileutils
-Requires(postun):      /usr/sbin/userdel
-Requires(postun):      /usr/sbin/groupdel
+Requires:      %{name}-client = %{version}-%{release}
+Provides:      group(cvs)
+Provides:      group(cvsadmin)
+Provides:      user(cvs)
+Provides:      user(cvsadmin)
+Obsoletes:     cvs-nserver
 
-%description -n cvs-nserver-common
+%description common
 CVS - common server files.
 
-%description -n cvs-nserver-common -l pl
-Wspólne pliki serwerów CVS.
+%description common -l pl.UTF-8
+Wspólne pliki serwerów CVS.
 
-%package -n cvs-nserver-pserver
+%package pserver
 Summary:       Concurrent Versions System - pserver
-Summary(pl):   Concurrent Versions System - pserver
+Summary(pl.UTF-8):     Concurrent Versions System - pserver
 Group:         Development/Version Control
-Requires:      cvs-nserver-common
+Requires:      %{name}-common = %{version}-%{release}
+Requires:      rc-inetd
 Obsoletes:     cvs-npserver
-PreReq:                rc-inetd
+Obsoletes:     cvs-pserver
 
-%description -n cvs-nserver-pserver
+%description pserver
 CVS server - pserver files.
 
-%description -n cvs-nserver-pserver -l pl
+%description pserver -l pl.UTF-8
 Serwer CVS - pliki pservera.
 
-%package -n cvs-nserver-nserver
+%package nserver
 Summary:       Concurrent Versions System - nserver
-Summary(pl):   Concurrent Versions System - nserver
+Summary(pl.UTF-8):     Concurrent Versions System - nserver
 Group:         Development/Version Control
-Requires:      cvs-nserver-common
+Requires:      %{name}-common = %{version}-%{release}
+Requires:      rc-inetd
 Obsoletes:     cvs-nserver
-PreReq:                rc-inetd
 
-%description -n cvs-nserver-nserver
+%description nserver
 CVS server - nserver files.
 
-%description -n cvs-nserver-nserver -l pl
+%description nserver -l pl.UTF-8
 Serwer CVS - pliki nservera.
 
 %prep
 %setup -q
 %patch0 -p1
 %patch1 -p1
+%patch2 -p1
+%patch3 -p1
 %patch4 -p1
 %patch5 -p1
+%patch6 -p1
+%patch7 -p1
+%patch8 -p1
+%patch9 -p1
+%patch10 -p1
+%patch11 -p1
+%patch12 -p1
+%patch13 -p1
+%patch14 -p1
+%patch15 -p1
+%patch16 -p1
+%patch17 -p1
+%patch18 -p1
+%patch19 -p1
+%patch20 -p1
+%patch21 -p1
+%patch22 -p1
+%patch23 -p1
 
 %build
-aclocal
+%{__aclocal}
 %{__autoconf}
-automake -a -c
+%{__automake}
 %configure \
        --enable-encryption \
        --enable-client \
        --enable-server \
        --enable-setuid \
-       --without-gssapi
-%{__make}
+       --with-openssl \
+       --with-gssapi
+
+%{__make} -j1
 
 %install
 rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT/{etc/sysconfig/rc-inetd,%{_cvsroot}}
+install -d $RPM_BUILD_ROOT{/etc/sysconfig/rc-inetd,%{_cvsroot},/var/lock/cvs}
 
-%{__make} DESTDIR=$RPM_BUILD_ROOT install
+%{__make} -j1 install \
+       DESTDIR=$RPM_BUILD_ROOT
 
 install %{SOURCE1} $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/cvs-nserver
 install %{SOURCE2} $RPM_BUILD_ROOT/etc/sysconfig/rc-inetd/cvs-pserver
 
 cat << EOF >$RPM_BUILD_ROOT%{_bindir}/cvs-pserver-script
 #!/bin/sh
-CVSPASSWD=%{_bindir}/cvspasswd \
-exec %{_bindir}/cvs-pserver %{_cvsroot} -- \
+REPOSITORY="%{_cvsroot}"
+if [ -f /etc/sysconfig/cvs ]; then
+       . /etc/sysconfig/cvs
+fi
+
+CVSPASSWD=%{_bindir}/cvspasswd CVSSERVER=pserver \
+exec %{_bindir}/cvs-pserver \$REPOSITORY -- \
 %{_bindir}/cvschkpw %{_bindir}/cvs pserver
 EOF
 
 cat << EOF >$RPM_BUILD_ROOT%{_bindir}/cvs-nserver-script
 #!/bin/sh
-CVSPASSWD=%{_bindir}/cvspasswd \
-exec %{_bindir}/cvs-nserver %{_cvsroot} -- \
+REPOSITORY="%{_cvsroot}"
+if [ -f /etc/sysconfig/cvs ]; then
+       . /etc/sysconfig/cvs
+fi
+
+CVSPASSWD=%{_bindir}/cvspasswd CVSSERVER=nserver \
+exec %{_bindir}/cvs-nserver \$REPOSITORY -- \
 %{_bindir}/cvschkpw %{_bindir}/cvs nserver
 EOF
 
+cat << EOF >$RPM_BUILD_ROOT/etc/sysconfig/cvs
+# In this file you can specify additional repositories (separated with space)
+# or just set different location.
+# Default is "%{_cvsroot}".
+#REPOSITORY="%{_cvsroot}"
+# According to FHS 2.3 you can use some subdirectory in /srv, e.g.:
+#REPOSITORY="/srv/cvs"
+EOF
+
 mv -f  $RPM_BUILD_ROOT%{_datadir}/cvs-nserver/contrib/rcs2log \
        $RPM_BUILD_ROOT%{_bindir}
 
 %clean
 rm -rf $RPM_BUILD_ROOT
 
-%post -n cvs-nserver-client
-[ ! -x /usr/sbin/fix-info-dir ] || /usr/sbin/fix-info-dir -c %{_infodir} >/dev/null 2>&1
-
-%postun -n cvs-nserver-client
-[ ! -x /usr/sbin/fix-info-dir ] || /usr/sbin/fix-info-dir -c %{_infodir} >/dev/null 2>&1
-
-%pre -n cvs-nserver-common
-if [ -n "`getgid cvs`" ]; then
-       if [ "`getgid cvs`" != "52" ]; then
-               echo "Error: group cvs doesn't have gid=52. Correct this before installing cvs-nserver." 1>&2
-               exit 1
-       fi
-else
-       echo "Adding group cvs GID=52."
-       /usr/sbin/groupadd -g 52 -r -f cvs
-fi
-if [ -n "`getgid cvsadmin`" ]; then
-       if [ "`getgid cvsadmin`" != "53" ]; then
-               echo "Error: group cvsadmin doesn't have gid=53. Correct this before installing cvs-nserver." 1>&2
-               exit 1
-       fi
-else
-       echo "Adding group cvsadmin GID=53."
-       /usr/sbin/groupadd -g 53 -r -f cvsadmin
-fi
-if [ -n "`id -u cvs 2>/dev/null`" ]; then
-       if [ "`id -u cvs`" != "52" ]; then
-               echo "Error: user cvs doesn't have uid=52. Correct this before installing cvs-nserver." 1>&2
-               exit 1
-       fi
-else
-       echo "Adding user cvs UID=52."
-       /usr/sbin/useradd -u 52 -r -d %{_cvsroot} -s /bin/false -c "CVS user" -g cvs cvs 1>&2
-fi
-if [ -n "`id -u cvsadmin 2>/dev/null`" ]; then
-       if [ "`id -u cvsadmin`" != "53" ]; then
-               echo "Error: user cvsadmin doesn't have uid=53. Correct this before installing cvs-nserver." 1>&2
-               exit 1
-       fi
-else
-       echo "Adding user cvsadmin UID=53."
-       /usr/sbin/useradd -u 53 -r -d %{_cvsroot} -s /bin/false -c "CVS user" -g cvsadmin -G cvs cvsadmin 1>&2
-fi
+%post client   -p      /sbin/postshell
+-/usr/sbin/fix-info-dir -c %{_infodir}
+
+%postun client -p      /sbin/postshell
+-/usr/sbin/fix-info-dir -c %{_infodir}
+
+%pre common
+%groupadd -P %{name}-common -g 52 -r cvs
+%groupadd -P %{name}-common -g 53 -r cvsadmin
+%useradd -P %{name}-common -u 52 -r -d %{_cvsroot} -s /bin/false -c "CVS user" -g cvs cvs
+%useradd -P %{name}-common -u 53 -r -d %{_cvsroot} -s /bin/false -c "CVS user" -g cvsadmin -G cvs cvsadmin
+
 if [ "$1" = 1 ]; then
        echo "Initializing repository..."
        %{_bindir}/cvs -d :local:%{_cvsroot} init
-       chown -R cvsadmin.cvsadmin %{_cvsroot}/CVSROOT
+       chown -R cvsadmin:cvsadmin %{_cvsroot}/CVSROOT
 fi
 
-%postun -n cvs-nserver-common
+%postun common
 if [ "$1" = "0" ]; then
-       echo "Removing user cvs."
-       /usr/sbin/userdel cvs
-       echo "Removing user cvsadmin."
-       /usr/sbin/userdel cvsadmin
-       echo "Removing group cvs."
-       /usr/sbin/groupdel cvs
-       echo "Removing group cvsadmin."
-       /usr/sbin/groupdel cvsadmin
+       %userremove cvs
+       %userremove cvsadmin
+       %groupremove cvs
+       %groupremove cvsadmin
 fi
 
-%post -n cvs-nserver-pserver
-if [ -f /var/lock/subsys/rc-inetd ]; then
-        /etc/rc.d/init.d/rc-inetd reload
-fi
+%post pserver
+%service -q rc-inetd reload
 
-%postun -n cvs-nserver-pserver
-if [ -f /var/lock/subsys/rc-inetd ]; then
-        /etc/rc.d/init.d/rc-inetd reload
-fi
+%postun pserver
+%service -q rc-inetd reload
 
-%post -n cvs-nserver-nserver
-if [ -f /var/lock/subsys/rc-inetd ]; then
-        /etc/rc.d/init.d/rc-inetd reload
-fi
+%post nserver
+%service -q rc-inetd reload
 
-%postun -n cvs-nserver-nserver
-if [ -f /var/lock/subsys/rc-inetd ]; then
-        /etc/rc.d/init.d/rc-inetd reload
-fi
+%postun nserver
+%service -q rc-inetd reload
 
-%files -n cvs-nserver-client
+%files client
 %defattr(644,root,root,755)
-%doc AUTHORS BUGS NEWS PROJECTS TODO FAQ
+%doc AUTHORS BUGS ChangeLog FAQ FAQ.nserver NEWS NEWS.nserver PROJECTS
+%doc README README.checkpassword TODO
 %attr(755,root,root) %{_bindir}/cvs
 %attr(755,root,root) %{_bindir}/cvsbug
 %{_infodir}/cvs*
 %{_mandir}/man[15]/cvs.*
 %{_mandir}/man8/cvsbug.8*
 
-%files -n cvs-nserver-common
+%files common
 %defattr(644,root,root,755)
+%attr(640,root,cvs) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/cvs
 %attr(4754,cvsadmin,cvs) %{_bindir}/cvspasswd
 %attr(755,root,root) %{_bindir}/cvschkpw
 %attr(755,root,root) %{_bindir}/rcs2log
-%dir %{_datadir}/cvs-nserver/contrib/*
+%dir %{_datadir}/cvs-nserver
+%dir %{_datadir}/cvs-nserver/contrib
+%{_datadir}/cvs-nserver/contrib/*
 %attr(770,cvsadmin,cvs) %dir %{_cvsroot}
 %{_mandir}/man8/cvs-server.8*
+%attr(770,cvsadmin,cvs) %dir /var/lock/cvs
 
-%files -n cvs-nserver-pserver
+%files pserver
 %defattr(644,root,root,755)
+%config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/rc-inetd/cvs-pserver
 %attr(755,root,root) %{_bindir}/cvs-pserver*
-/etc/sysconfig/rc-inetd/cvs-pserver
 %{_mandir}/man8/cvs-pserver.8*
 
-%files -n cvs-nserver-nserver
+%files nserver
 %defattr(644,root,root,755)
-%attr(755,root,root) %{_bindir}/cvs-nserver*
 %doc NEWS.nserver FAQ.nserver
-/etc/sysconfig/rc-inetd/cvs-nserver
+%config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/rc-inetd/cvs-nserver
+%attr(755,root,root) %{_bindir}/cvs-nserver*
 %{_mandir}/man8/cvs-nserver.8*
This page took 0.444243 seconds and 4 git commands to generate.