408 lines
14 KiB
RPMSpec
408 lines
14 KiB
RPMSpec
%define soversion 1.1
|
|
Name: openssl
|
|
Epoch: 1
|
|
Version: 1.1.1wa
|
|
Release: 7
|
|
Summary: Cryptography and SSL/TLS Toolkit
|
|
License: OpenSSL and SSLeay
|
|
URL: https://gitee.com/openeuler/openssl
|
|
Source0: https://gitee.com/openeuler/openssl/archive/refs/tags/%{name}-%{version}.tar.gz
|
|
Source1: Makefile.certificate
|
|
Patch1: openssl-1.1.1-build.patch
|
|
Patch2: openssl-1.1.1-fips.patch
|
|
Patch3: Fix-FIPS-getenv-build-failure.patch
|
|
Patch4: skip-some-test-cases.patch
|
|
Patch5: backport-Fix-OPENSSL_VERSION_NUMBER-number-problem.patch
|
|
Patch6: backport-CVE-2024-0727-fix-pkcs12-decoding-crashes.patch
|
|
Patch7: backport-Fix-mem-leaks-on-PKCS-12-read-error-in-PKCS12_key_ge.patch
|
|
Patch8: backport-CVE-2024-2511-Fix-unconstrained-session-cache-growth-in-TLSv1.3.patch
|
|
Patch9: backport-Add-a-test-for-session-cache-handling.patch
|
|
Patch10: backport-Extend-the-multi_resume-test-for-simultaneous-resump.patch
|
|
Patch11: backport-Hardening-around-not_resumable-sessions.patch
|
|
Patch12: backport-Add-a-test-for-session-cache-overflow.patch
|
|
Patch13: backport-CVE-2024-4741-Only-free-the-read-buffer.patch
|
|
Patch14: backport-CVE-2024-4741-Set-rlayer.packet-to-NULL-after-we-ve-.patch
|
|
Patch15: backport-CVE-2024-4741-test-Fix-possible-use-after-free.patch
|
|
|
|
BuildRequires: gcc perl make lksctp-tools-devel coreutils util-linux zlib-devel
|
|
Requires: coreutils %{name}-libs%{?_isa} = %{epoch}:%{version}-%{release}
|
|
Obsoletes: openssl-SMx < %{epoch}:%{version}-%{release}
|
|
Provides: openssl-SMx = %{epoch}:%{version}-%{release}
|
|
|
|
%description
|
|
OpenSSL is a robust, commercial-grade, and full-featured toolkit for the
|
|
Transport Layer Security (TLS) and Secure Sockets Layer (SSL) protocols.
|
|
|
|
%package libs
|
|
Summary: A general purpose cryptography library with TLS implementation
|
|
Group: System Environment/Libraries
|
|
Requires: ca-certificates >= 2008-5
|
|
Requires: crypto-policies >= 20180730
|
|
Recommends: openssl-pkcs11%{?_isa}
|
|
Obsoletes: openssl < 1:1.0.1-0.3.beta3
|
|
Obsoletes: openssl-fips < 1:1.0.1e-28
|
|
Provides: openssl-fips = %{epoch}:%{version}-%{release}
|
|
Obsoletes: openssl-SMx-libs < %{epoch}:%{version}-%{release}
|
|
Provides: openssl-SMx-libs = %{epoch}:%{version}-%{release}
|
|
|
|
%description libs
|
|
The openssl-libs package contains the libraries that are used
|
|
by various applications which support cryptographic algorithms
|
|
and protocols.
|
|
|
|
%package perl
|
|
Summary: Perl scripts provided with OpenSSL
|
|
Requires: perl-interpreter
|
|
Requires: %{name}%{?_isa} = %{epoch}:%{version}-%{release}
|
|
Obsoletes: openssl-SMx-perl < %{epoch}:%{version}-%{release}
|
|
Provides: openssl-SMx-perl = %{epoch}:%{version}-%{release}
|
|
|
|
%description perl
|
|
OpenSSL is a toolkit for supporting cryptography. The openssl-perl
|
|
package provides Perl scripts for converting certificates and keys
|
|
from other formats to the formats used by the OpenSSL toolkit.
|
|
|
|
%package devel
|
|
Summary: Development files for openssl
|
|
Requires: %{name}-libs%{?_isa} = %{epoch}:%{version}-%{release}
|
|
Requires: krb5-devel zlib-devel pkgconfig
|
|
Obsoletes: openssl-static < %{epoch}:%{version}-%{release}
|
|
Provides: openssl-static = %{epoch}:%{version}-%{release} openssl-static%{?_isa} = %{epoch}:%{version}-%{release}
|
|
Obsoletes: openssl-SMx-devel < %{epoch}:%{version}-%{release}
|
|
Provides: openssl-SMx-devel = %{epoch}:%{version}-%{release}
|
|
|
|
%description devel
|
|
%{summary}.
|
|
|
|
%package_help
|
|
|
|
%prep
|
|
%autosetup -n %{name}-%{version} -p1
|
|
|
|
%build
|
|
|
|
sslarch=%{_os}-%{_target_cpu}
|
|
%ifarch x86_64 aarch64
|
|
sslflags=enable-ec_nistp_64_gcc_128
|
|
%endif
|
|
%ifarch riscv64
|
|
sslarch=%{_os}64-%{_target_cpu}
|
|
sslflags="--libdir=%{_libdir}"
|
|
%endif
|
|
|
|
RPM_OPT_FLAGS="$RPM_OPT_FLAGS -Wa,--noexecstack -DPURIFY $RPM_LD_FLAGS"
|
|
./Configure \
|
|
--prefix=%{_prefix} \
|
|
--openssldir=%{_sysconfdir}/pki/tls ${sslflags} \
|
|
zlib enable-camellia enable-seed enable-rfc3779 enable-sctp \
|
|
enable-cms enable-md2 enable-rc5 enable-ssl3 enable-ssl3-method \
|
|
enable-weak-ssl-ciphers \
|
|
no-mdc2 no-ec2m enable-sm2 enable-sm3 enable-sm4 enable-tlcp \
|
|
shared ${sslarch} $RPM_OPT_FLAGS '-DDEVRANDOM="\"/dev/urandom\""'
|
|
|
|
%make_build all
|
|
|
|
%define __spec_install_post \
|
|
%{?__debug_package:%{__debug_install_post}} \
|
|
%{__arch_install_post} \
|
|
%{__os_install_post} \
|
|
crypto/fips/fips_standalone_hmac $RPM_BUILD_ROOT%{_libdir}/libcrypto.so.%{version} >$RPM_BUILD_ROOT%{_libdir}/.libcrypto.so.%{version}.hmac \
|
|
ln -sf .libcrypto.so.%{version}.hmac $RPM_BUILD_ROOT%{_libdir}/.libcrypto.so.%{soversion}.hmac \
|
|
crypto/fips/fips_standalone_hmac $RPM_BUILD_ROOT%{_libdir}/libssl.so.%{version} >$RPM_BUILD_ROOT%{_libdir}/.libssl.so.%{version}.hmac \
|
|
ln -sf .libssl.so.%{version}.hmac $RPM_BUILD_ROOT%{_libdir}/.libssl.so.%{soversion}.hmac \
|
|
%{nil}
|
|
|
|
%install
|
|
|
|
%make_install
|
|
|
|
# rename so name with actual version
|
|
rename so.%{soversion} so.%{version} $RPM_BUILD_ROOT%{_libdir}/*.so.%{soversion}
|
|
# create symbolic link
|
|
for lib in $RPM_BUILD_ROOT%{_libdir}/*.so.%{version} ; do
|
|
ln -s -f `basename ${lib}` $RPM_BUILD_ROOT%{_libdir}/`basename ${lib} .%{version}`
|
|
ln -s -f `basename ${lib}` $RPM_BUILD_ROOT%{_libdir}/`basename ${lib} .%{version}`.%{soversion}
|
|
done
|
|
|
|
mkdir -p $RPM_BUILD_ROOT%{_sysconfdir}/pki/tls/certs
|
|
install -m644 %{SOURCE1} $RPM_BUILD_ROOT%{_pkgdocdir}/Makefile.certificate
|
|
|
|
mv $RPM_BUILD_ROOT%{_sysconfdir}/pki/tls/misc/*.pl $RPM_BUILD_ROOT%{_bindir}
|
|
mv $RPM_BUILD_ROOT%{_sysconfdir}/pki/tls/misc/tsget $RPM_BUILD_ROOT%{_bindir}
|
|
|
|
|
|
mkdir -p -m755 $RPM_BUILD_ROOT%{_sysconfdir}/pki/CA/{certs,crl,newcerts,private}
|
|
chmod 700 $RPM_BUILD_ROOT%{_sysconfdir}/pki/CA/private
|
|
|
|
touch -r %{SOURCE1} $RPM_BUILD_ROOT%{_sysconfdir}/pki/tls/{openssl.cnf,ct_log_list.cnf}
|
|
|
|
|
|
# rename man pages avoid conflicting with other man pages in system
|
|
%define manpostfix _openssl
|
|
pushd $RPM_BUILD_ROOT%{_mandir}
|
|
ln -s -f config.5 man5/openssl.cnf.5
|
|
for manpage in man*/* ; do
|
|
if [ -L ${manpage} ]; then
|
|
targetfile=`ls -l ${manpage} | awk '{print $NF}'`
|
|
ln -sf ${targetfile}%{manpostfix} ${manpage}%{manpostfix}
|
|
rm -f ${manpage}
|
|
else
|
|
mv ${manpage} ${manpage}%{manpostfix}
|
|
fi
|
|
done
|
|
popd
|
|
|
|
# Next step of gradual disablement of ssl3.
|
|
# Make SSL3 disappear to newly built dependencies.
|
|
sed -i '/^\#ifndef OPENSSL_NO_SSL_TRACE/i\
|
|
#ifndef OPENSSL_NO_SSL3\
|
|
# define OPENSSL_NO_SSL3\
|
|
#endif' $RPM_BUILD_ROOT/%{_prefix}/include/openssl/opensslconf.h
|
|
|
|
rm -f $RPM_BUILD_ROOT%{_sysconfdir}/pki/tls/*.dist
|
|
|
|
%check
|
|
LD_LIBRARY_PATH=`pwd`${LD_LIBRARY_PATH:+:${LD_LIBRARY_PATH}}
|
|
export LD_LIBRARY_PATH
|
|
crypto/fips/fips_standalone_hmac libcrypto.so.%{soversion} >.libcrypto.so.%{soversion}.hmac
|
|
ln -s .libcrypto.so.%{soversion}.hmac .libcrypto.so.hmac
|
|
crypto/fips/fips_standalone_hmac libssl.so.%{soversion} >.libssl.so.%{soversion}.hmac
|
|
ln -s .libssl.so.%{soversion}.hmac .libssl.so.hmac
|
|
OPENSSL_ENABLE_MD5_VERIFY=
|
|
export OPENSSL_ENABLE_MD5_VERIFY
|
|
OPENSSL_SYSTEM_CIPHERS_OVERRIDE=xyz_nonexistent_file
|
|
export OPENSSL_SYSTEM_CIPHERS_OVERRIDE
|
|
make test || :
|
|
|
|
%post libs -p /sbin/ldconfig
|
|
|
|
%postun libs -p /sbin/ldconfig
|
|
|
|
%files
|
|
%defattr(-,root,root)
|
|
%license LICENSE
|
|
%doc AUTHORS CHANGES FAQ NEWS README
|
|
%{_pkgdocdir}/Makefile.certificate
|
|
%{_bindir}/openssl
|
|
|
|
%files libs
|
|
%defattr(-,root,root)
|
|
%license LICENSE
|
|
%dir %{_sysconfdir}/pki/tls
|
|
%dir %{_sysconfdir}/pki/tls/certs
|
|
%dir %{_sysconfdir}/pki/tls/misc
|
|
%dir %{_sysconfdir}/pki/tls/private
|
|
%config(noreplace) %{_sysconfdir}/pki/tls/openssl.cnf
|
|
%config(noreplace) %{_sysconfdir}/pki/tls/ct_log_list.cnf
|
|
%{_libdir}/libcrypto.so.%{version}
|
|
%{_libdir}/libcrypto.so.%{soversion}
|
|
%{_libdir}/libssl.so.%{version}
|
|
%{_libdir}/libssl.so.%{soversion}
|
|
%{_libdir}/engines-%{soversion}
|
|
%attr(0644,root,root) %{_libdir}/.libcrypto.so.*.hmac
|
|
%attr(0644,root,root) %{_libdir}/.libssl.so.*.hmac
|
|
|
|
%files devel
|
|
%defattr(-,root,root)
|
|
%doc doc/dir-locals.example.el doc/openssl-c-indent.el
|
|
%{_prefix}/include/openssl
|
|
%{_libdir}/pkgconfig/*.pc
|
|
%{_libdir}/*.so
|
|
%{_libdir}/*.a
|
|
|
|
%files help
|
|
%defattr(-,root,root)
|
|
%{_mandir}/man1/*
|
|
%{_mandir}/man3/*
|
|
%{_mandir}/man5/*
|
|
%{_mandir}/man7/*
|
|
%{_pkgdocdir}/html/
|
|
|
|
%files perl
|
|
%{_bindir}/c_rehash
|
|
%{_bindir}/*.pl
|
|
%{_bindir}/tsget
|
|
%dir %{_sysconfdir}/pki/CA
|
|
%dir %{_sysconfdir}/pki/CA/private
|
|
%dir %{_sysconfdir}/pki/CA/certs
|
|
%dir %{_sysconfdir}/pki/CA/crl
|
|
%dir %{_sysconfdir}/pki/CA/newcerts
|
|
|
|
%ldconfig_scriptlets libs
|
|
|
|
%changelog
|
|
* Mon Jun 3 2024 wangcheng <wangcheng156@huawei.com> - 1:1.1.1wa-7
|
|
- fix CVE-2024-4741
|
|
|
|
* Wed Apr 17 2024 fuanan <fuanan3@h-partners.com> - 1:1.1.1wa-6
|
|
- fix CVE-2024-2511
|
|
|
|
* Tue Mar 26 2024 wangjiang <wangjiang37@h-partners.com> - 1:1.1.1wa-5
|
|
- fix some bugs
|
|
|
|
* Mon Feb 5 2024 lixiao <lixiao57@huawei.com> - 1:1.1.1wa-4
|
|
- add openssl-SMx-perl rpm provides
|
|
|
|
* Tue Jan 30 2024 lixiao<lixiao57@huawei.com> - 1:1.1.1wa-3
|
|
- Fix CVE-2024-0727 PKCS12 Decoding crashes
|
|
|
|
* Fri Dec 22 2023 wangcheng <wangcheng156@huawei.com> - 1:1.1.1wa-2
|
|
- Fix OPENSSL_VERSION_NUMBER number problem
|
|
|
|
* Wed Nov 15 2023 wangcheng <wangcheng156@huawei.com> - 1:1.1.1wa-1
|
|
- upgrade to 1.1.1wa
|
|
|
|
* Tue Nov 14 2023 zhujianwei <zhujianwei7@huawei.com> - 1:1.1.1m-27
|
|
- fix CVE-2023-5678
|
|
|
|
* Fri Sep 22 2023 dongyuzhen <dongyuzhen@h-partners.com> - 1:1.1.1m-26
|
|
- Backport some upstream patches
|
|
|
|
* Fri Sep 8 2023 reverse-world <ykx1990123@163.com> - 1:1.1.1m-25
|
|
* fix FIPS getenv compatibility problem
|
|
|
|
* Tue Aug 08 2023 zcfsite <zhchf2010@126.com> - 1:1.1.1m-24
|
|
* backport some patches
|
|
|
|
* Tue Aug 08 2023 steven <steven_ygui@163.com> - 1:1.1.1m-23
|
|
- fix CVE-2023-3817
|
|
|
|
* Sat Jul 22 2023 zcfsite <zhchf2010@126.com> - 1:1.1.1m-22
|
|
* fix CVE-2023-3446
|
|
|
|
* Mon Jun 12 2023 zhujianwei <zhujianwei7@huawei.com> - 1:1.1.1m-21
|
|
- fix CVE-2023-2650
|
|
|
|
* Mon Jun 05 2023 laokz <zhangkai@iscas.ac.cn> - 1:1.1.1m-20
|
|
- fix sslarch and libdir for riscv64
|
|
|
|
* Mon May 15 2023 Xu Yizhou <xuyizhou1@huawei.com> - 1:1.1.1m-19
|
|
- Fix SM4-XTS build failure using clang
|
|
|
|
* Tue Apr 4 2023 wangcheng <wangcheng156@huawei.com> - 1:1.1.1m-18
|
|
- fix some CVEs
|
|
|
|
* Thu Feb 9 2023 wangcheng<wangcheng156@huawei.com> - 1:1.1.1m-17
|
|
- fix some CVE
|
|
|
|
* Mon Feb 6 2023 fangxiuning <fangxiuning@huawei.com> - 1:1.1.1m-16
|
|
- backport some upstream pathcesl
|
|
|
|
* Wed Nov 2 2022 Xu Yizhou <xuyizhou1@huawei.com> - 1:1.1.1m-15
|
|
- add SM3/SM4 optimization
|
|
|
|
* Fri Oct 28 2022 ExtinctFire <shenyining_00@126.com> - 1:1.1.1m-14
|
|
- backport upstream patches
|
|
|
|
* Fri Oct 28 2022 zhujianwei <zhujianwei7@huawei.com> - 1:1.1.1m-13
|
|
- update further expiring certificates
|
|
|
|
* Wed Oct 26 2022 luhuaxin <luhuaxin1@huawei.com> - 1:1.1.1m-12
|
|
- fix cms testcase
|
|
|
|
* Fri Oct 21 2022 luhuaxin <luhuaxin1@huawei.com> - 1:1.1.1m-11
|
|
- add support for SM2 PKCS7
|
|
|
|
* Mon Oct 17 2022 luhuaxin <luhuaxin1@huawei.com> - 1:1.1.1m-10
|
|
- add sm2 cert and TLCP feature from master
|
|
|
|
* Tue Sep 13 2022 wangcheng <wangcheng156@huawei.com> - 1:1.1.1m-9
|
|
- add provides for openssl-SMx
|
|
|
|
* Mon Aug 22 2022 fangxiuning <fangxiuning@huawei.com> - 1:1.1.1m-8
|
|
- fix proformance degradation on aarch64
|
|
|
|
* Tue Jul 26 2022 ExtinctFire <shenyining_00@126.com> - 1:1.1.1m-7
|
|
- fix expiring-certificates test case
|
|
|
|
* Tue Jul 12 2022 wangcheng <wangcheng156@huawei.com> - 1:1.1.1m-6
|
|
- fix the cve-2022-2097
|
|
|
|
* Thu Jun 30 2022 zhouchenchen <zhouchenchen@huawei.com> - 1:1.1.1m-5
|
|
- fix the cve-2022-0778
|
|
|
|
* Thu May 12 2022 zhouchenchen <zhouchenchen@huawei.com> - 1:1.1.1m-4
|
|
- fix the cve-2022-1292
|
|
|
|
* Mon Mar 21 2022 wangcheng <wangcheng156@huawei.com> - 1:1.1.1m-3
|
|
- fix the cve-2022-0778
|
|
|
|
* Thu Feb 17 2022 fushanqing <fushanqing@kylinos.cn> - 1:1.1.1m-2
|
|
- add subpackage openssl-perl
|
|
|
|
* Tue Dec 28 2021 Buildteam <buildteam@openeuler.org> - 1:1.1.1m-1
|
|
- update openssl-1.1.1l to openssl-1.1.1m
|
|
|
|
* Wed Dec 8 2021 lujie42 <lujie42@huawei.com> - 1:1.1.1l-1
|
|
- update openssl-1.1.1f to openssl-1.1.1l
|
|
|
|
* Fri Sep 24 2021 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1f-9
|
|
- bugfix Overflow when printing Thawte Strong Extranet
|
|
|
|
* Sat Sep 18 2021 zhuyan <zhuyan34@huawei.com> - 1:1.1.1f-8
|
|
- fix software package format problem
|
|
|
|
* Mon Aug 30 2021 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1f-7
|
|
- fix the CVE-2021-3711 and CVE-2021-3712
|
|
|
|
* Tue Jun 29 2021 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1f-6
|
|
- add perl BuildRequires
|
|
|
|
* Wed Apr 7 2021 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1f-5
|
|
- fix CVE-2021-3449
|
|
|
|
* Wed Mar 10 2021 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1f-4
|
|
- fix CVE-2021-23840 and CVE-2021-23841
|
|
|
|
* Tue Jan 19 2021 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1f-3
|
|
- fix CVE-2020-1971
|
|
|
|
* Fri Sep 11 2020 Liquor <lirui130@huawei.com> - 1:1.1.1f-2
|
|
- provides openssl-perl
|
|
|
|
* Tue May 12 2020 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1f-1
|
|
- update openssl-1.1.1d to openssl-1.1.1f and fix CVE-2020-1967
|
|
|
|
* Wed Mar 18 2020 steven <steven_ygui@163.com> - 1:1.1.1d-9
|
|
- fix division zero issue which found by oss-fuzz
|
|
|
|
* Tue Mar 3 2020 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1d-8
|
|
- add missiong /sbin/ldconfig
|
|
|
|
* Tue Mar 3 2020 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1d-7
|
|
- Fix problem caused by missing hmac files
|
|
|
|
* Mon Feb 17 2020 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1d-6
|
|
- add openssl-libs containing dynamic library for openssl
|
|
|
|
* Sun Jan 19 2020 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1d-5
|
|
- add obsoletes
|
|
|
|
* Tue Jan 14 2020 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1d-4
|
|
- clean code
|
|
|
|
* Fri Jan 10 2020 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1d-3
|
|
- delete unused files
|
|
|
|
* Fri Dec 27 2019 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1d-2
|
|
- modify obsoletes
|
|
|
|
* Mon Dec 16 2019 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1d-1
|
|
- update to 1:1.1.1d
|
|
|
|
* Thu Nov 21 2019 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1c-5
|
|
- enable sm2 and sm4
|
|
|
|
* Fri Oct 25 2019 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1c-4
|
|
- Add missing openssl/fips.h
|
|
|
|
* Thu Oct 24 2019 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1c-3
|
|
- Add buildrequires zlib-devel
|
|
|
|
* Tue Sep 24 2019 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1c-2
|
|
- Adjust requires
|
|
|
|
* Mon Sep 16 2019 openEuler Buildteam <buildteam@openeuler.org> - 1:1.1.1c-1
|
|
- Package init
|
|
|