-# TODO:
-# - get rid of gcc_4_2 patch and header files crapolla
-
+#
# Conditional build:
-%bcond_without tests
-%bcond_with purify # Compile openssl with \-DPURIFY, useful when one wants to
+%bcond_without tests # don't perform "make tests"
+%bcond_with purify # Compile openssl with \-DPURIFY, useful when one wants to
# use valgrind debugger against openssl-linked programs
#
%include /usr/lib/rpm/macros.perl
Summary(ru.UTF-8): Библиотеки и утилиты для соединений через Secure Sockets Layer
Summary(uk.UTF-8): Бібліотеки та утиліти для з'єднань через Secure Sockets Layer
Name: openssl
-Version: 0.9.8e
-Release: 5
-License: Apache-style License
+Version: 0.9.8k
+Release: 1
+License: Apache-like
Group: Libraries
Source0: ftp://ftp.openssl.org/source/%{name}-%{version}.tar.gz
-# Source0-md5: 3a7ff24f6ea5cd711984722ad654b927
-Source1: %{name}-ca-bundle.crt
+# Source0-md5: e555c6d58d276aec7fdc53363e338ab3
Source2: %{name}.1.pl
Source3: %{name}-ssl-certificate.sh
+Source4: %{name}-c_rehash.sh
Patch0: %{name}-alpha-ccc.patch
Patch1: %{name}-optflags.patch
Patch2: %{name}-globalCA.diff
Patch3: %{name}-include.patch
-Patch4: %{name}-md5-sparcv9.patch
-Patch5: %{name}-libvar.patch
-Patch6: %{name}-gcc_4_2.patch
-Patch7: %{name}-CVE-2007-3108.patch
+Patch4: %{name}-libvar.patch
+Patch5: %{name}-man-namespace.patch
+Patch6: %{name}-asflag.patch
+Patch7: %{name}-ca-certificates.patch
+Patch8: %{name}-fips_install.patch
URL: http://www.openssl.org/
+# problem with =< 1.0.0beta2
+# Fixes should be in sourcecode
+BuildRequires: security(CVE-2009-1377)
+BuildRequires: security(CVE-2009-1378)
+BuildRequires: security(CVE-2009-1379)
+##
BuildRequires: bc
BuildRequires: perl-devel >= 1:5.6.1
BuildRequires: rpm-perlprov >= 4.1-13
Obsoletes: SSLeay-devel
Obsoletes: SSLeay-perl
Obsoletes: libopenssl0
+Requires: ca-certificates >= 20080809-4
+Requires: rpm-whiteout >= 1.7
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
%description
%patch3 -p1
%patch4 -p1
%patch5 -p1
-# XXX: gcc 4.2 hack
-cp crypto/asn1/asn1.h crypto/asn1/asn1.h.X
-cp crypto/ocsp/ocsp.h crypto/ocsp/ocsp.h.X
-cp crypto/pem/pem.h crypto/pem/pem.h.X
%patch6 -p1
%patch7 -p1
+%patch8 -p0
-%build
%{__perl} -pi -e 's#%{_prefix}/local/bin/perl#%{__perl}#g' \
`grep -l -r "%{_prefix}/local/bin/perl" *`
+sed -i -e 's|$prefix/lib/engines|%{_libdir}/engines|g' Configure
+
+%build
touch Makefile.*
%{__perl} util/perlpath.pl %{__perl}
-OPTFLAGS="%{rpmcflags} %{?with_purify:-DPURIFY}"
-LDFLAGS="%{rpmldflags}"
-export OPTFLAGS LDFLAGS
+OPTFLAGS="%{rpmcflags} %{?with_purify:-DPURIFY}" \
./Configure \
+%if "%{pld_release}" == "ti"
--openssldir=%{_var}/lib/%{name} \
+%else
+ --openssldir=%{_sysconfdir}/%{name} \
+%endif
--lib=%{_lib} \
shared threads \
enable-mdc2 enable-rc5 \
%{__make} -j1 all rehash %{?with_tests:tests} \
CC="%{__cc}" \
+ ASFLAG='$(CFLAG) -Wa,--noexecstack' \
INSTALLTOP=%{_prefix}
-# Conv PODs to man pages. "openssl_" prefix is added to each manpage
-# to avoid potential conflicts with others packages.
-center="OpenSSL 0.9.7"
-rel="OpenSSL 0.9.7"
-
-cd doc/apps || exit 1
-%{__perl} -pi -e 's/(\W)((?<!openssl_)\w+)(\(\d\))/$1openssl_$2$3/g; s/openssl_openssl/openssl/g;' *.pod;
-
-for pod in *.pod; do
- if [ $pod != "openssl.pod" ]; then
- mv -f $pod openssl_$pod;
- pod=openssl_$pod;
- fi
-
- sec=1
- if [ $pod = "openssl_config.pod" ]; then
- sec=5
- fi
-
- manpage=`basename $pod .pod`.$sec;
- pod2man --section="$sec" --release="$rel" --center="$center" \
- $pod > $manpage;
- echo "$manpage";
-done
-cd ..
+# Rename POD sources of man pages. "openssl_" prefix is added to each
+# manpage to avoid potential conflicts with other packages.
-sec=3
-for dir in ssl crypto; do
+for dir in doc/{apps,ssl,crypto}; do
cd $dir || exit 1;
- if [ $dir = "ssl" ]; then
- rel="OpenSSL SSL/TLS library"
- elif [ $dir = "crypto" ]; then
- rel="OpenSSL cryptographic library"
- fi
-
%{__perl} -pi -e 's/(\W)((?<!openssl_)\w+)(\(\d\))/$1openssl_$2$3/g; s/openssl_openssl/openssl/g;' *.pod;
- for pod in *.pod; do
- sec=`[ "$pod" = "des_modes.pod" ] && echo 7 || echo 3`;
+ for pod in !(openssl*).pod; do
mv -f $pod openssl_$pod;
- pod=openssl_$pod;
- manpage=`basename $pod .pod`.$sec;
- pod2man --section="$sec" --release="$rel" --center=" " $pod > $manpage;
- echo "$manpage";
done
- cd ..
+ cd ../..
done
-#cd perl
-#%%{__perl} Makefile.PL \
-# INSTALLDIRS=vendor
-#%{__make}
-
%install
rm -rf $RPM_BUILD_ROOT
install -d $RPM_BUILD_ROOT{%{_sysconfdir}/%{name},%{_libdir}/%{name}} \
$RPM_BUILD_ROOT%{_pkgconfigdir}
%{__make} install \
- CC="%{__cc}" \
INSTALLTOP=%{_prefix} \
INSTALL_PREFIX=$RPM_BUILD_ROOT \
MANDIR=%{_mandir}
-install %{SOURCE1} $RPM_BUILD_ROOT%{_datadir}/ssl/ca-bundle.crt
install libcrypto.a libssl.a $RPM_BUILD_ROOT%{_libdir}
install lib*.so.*.* $RPM_BUILD_ROOT%{_libdir}
ln -sf libcrypto.so.*.* $RPM_BUILD_ROOT%{_libdir}/libcrypto.so
ln -sf libssl.so.*.* $RPM_BUILD_ROOT%{_libdir}/libssl.so
-mv -f $RPM_BUILD_ROOT%{_var}/lib/%{name}/openssl.cnf $RPM_BUILD_ROOT%{_sysconfdir}/%{name}
-ln -s %{_sysconfdir}/%{name}/openssl.cnf \
- $RPM_BUILD_ROOT%{_var}/lib/%{name}/%{name}.cnf
-
+%if "%{pld_release}" == "ti"
+ln -sf %{_var}/lib/%{name}/%{name}.cnf \
+ $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/openssl.cnf
+ln -sf %{_var}/lib/%{name}/certs \
+ $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/certs
+ln -sf %{_var}/lib/%{name}/private \
+ $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/private
mv -f $RPM_BUILD_ROOT%{_var}/lib/%{name}/misc/* $RPM_BUILD_ROOT%{_libdir}/%{name}
rm -rf $RPM_BUILD_ROOT%{_var}/lib/%{name}/misc
+%else
+mv -f $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/misc/* $RPM_BUILD_ROOT%{_libdir}/%{name}
+rm -rf $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/misc
+%endif
+
+# not installed as individual utilities (see openssl dgst instead)
+%{__rm} $RPM_BUILD_ROOT%{_mandir}/man1/{md2,md4,md5,mdc2,ripemd160,sha,sha1}.1
-find $RPM_BUILD_ROOT%{_mandir} -type f | xargs rm -f
-install doc/apps/*.1 $RPM_BUILD_ROOT%{_mandir}/man1
-install doc/apps/*.5 $RPM_BUILD_ROOT%{_mandir}/man5
-install doc/ssl/*.3 doc/crypto/*.3 $RPM_BUILD_ROOT%{_mandir}/man3
-install doc/crypto/*.7 $RPM_BUILD_ROOT%{_mandir}/man7
install %{SOURCE2} $RPM_BUILD_ROOT%{_mandir}/pl/man1/openssl.1
install %{SOURCE3} $RPM_BUILD_ROOT%{_bindir}/ssl-certificate
-
-rm $RPM_BUILD_ROOT%{_mandir}/man5/x509v3_config.5
-echo ".so openssl_x509v3_config.5" > $RPM_BUILD_ROOT%{_mandir}/man5/x509v3_config.5
-rm $RPM_BUILD_ROOT%{_mandir}/man5/config.5
-echo ".so openssl_config.5" > $RPM_BUILD_ROOT%{_mandir}/man5/config.5
-rm $RPM_BUILD_ROOT%{_mandir}/man7/Modes_of_DES.7
-echo ".so openssl_des_modes.7" > $RPM_BUILD_ROOT%{_mandir}/man7/Modes_of_DES.7
-
-# XXX: gcc 4.2 hack
-install crypto/asn1/asn1.h.X $RPM_BUILD_ROOT%{_includedir}/%{name}/asn1.h
-install crypto/ocsp/ocsp.h.X $RPM_BUILD_ROOT%{_includedir}/%{name}/ocsp.h
-install crypto/pem/pem.h.X $RPM_BUILD_ROOT%{_includedir}/%{name}/pem.h
+install %{SOURCE4} $RPM_BUILD_ROOT%{_bindir}/c_rehash.sh
%clean
rm -rf $RPM_BUILD_ROOT
%post -p /sbin/ldconfig
%postun -p /sbin/ldconfig
+%if "%{pld_release}" == "ti"
+%triggerin -- %{name}-tools < 0.9.8i-2
+if [ -L /var/lib/openssl/openssl.cnf ] ; then
+ echo "Saving old configuration as /var/lib/openssl/openssl.cnf.rpmsave"
+ rm /var/lib/openssl/openssl.cnf
+ mv %{_sysconfdir}/%{name}/openssl.cnf /var/lib/openssl/openssl.cnf.rpmsave 2>/dev/null || :
+fi
+%else
+%triggerpostun -- %{name} < 0.9.8i-2
+if [ -d /var/lib/openssl/certs ] ; then
+ mv /var/lib/openssl/certs/* %{_sysconfdir}/%{name}/certs 2>/dev/null || :
+fi
+if [ -d /var/lib/openssl/private ] ; then
+ mv /var/lib/openssl/private/* %{_sysconfdir}/%{name}/private 2>/dev/null || :
+fi
+if [ -d /var/lib/openssl ] ; then
+ for f in /var/lib/openssl/* ; do
+ [ -f "$f" ] && mv "$f" %{_sysconfdir}/%{name} 2>/dev/null || :
+ done
+fi
+%endif
+
%files
%defattr(644,root,root,755)
%doc CHANGES CHANGES.SSLeay LICENSE NEWS README doc/*.txt
%attr(755,root,root) %{_libdir}/libssl.so.*.*.*
%dir %{_libdir}/engines
%attr(755,root,root) %{_libdir}/engines/*.so
+%if "%{pld_release}" == "ti"
%dir %{_var}/lib/%{name}
%dir %{_var}/lib/%{name}/certs
%dir %{_var}/lib/%{name}/private
+%dir %{_sysconfdir}/%{name}
+%attr(755,root,root) %{_sysconfdir}/%{name}/certs
+%attr(755,root,root) %{_sysconfdir}/%{name}/private
+%else
+%dir %{_sysconfdir}/%{name}
+%dir %{_sysconfdir}/%{name}/certs
+%dir %{_sysconfdir}/%{name}/private
+%endif
%dir %{_datadir}/ssl
-%config(noreplace) %verify(not md5 mtime size) %{_datadir}/ssl/ca-bundle.crt
%files tools
%defattr(644,root,root,755)
-%dir %{_sysconfdir}/%{name}
-
-%config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/%{name}/openssl.cnf
+%if "%{pld_release}" == "ti"
+%{_sysconfdir}/%{name}/openssl.cnf
%config(noreplace) %verify(not md5 mtime size) %{_var}/lib/%{name}/openssl.cnf
-
+%else
+%config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/%{name}/openssl.cnf
+%endif
%attr(755,root,root) %{_bindir}/%{name}
+%attr(755,root,root) %{_bindir}/c_rehash.sh
%attr(754,root,root) %{_bindir}/ssl-certificate
%dir %{_libdir}/%{name}
%{_mandir}/man1/openssl_verify.1*
%{_mandir}/man1/openssl_version.1*
%{_mandir}/man1/openssl_x509.1*
-%{_mandir}/man1/openssl_x509v3_config.1*
-%{_mandir}/man5/*.5*
+%{_mandir}/man5/openssl_config.5*
+%{_mandir}/man5/openssl_x509v3_config.5*
%lang(pl) %{_mandir}/pl/man1/openssl.1*
%files tools-perl
%{_pkgconfigdir}/libssl.pc
%{_pkgconfigdir}/openssl.pc
%{_mandir}/man3/openssl*.3*
-%{_mandir}/man7/*.7*
+%{_mandir}/man7/openssl_des_modes.7*
%files static
%defattr(644,root,root,755)