2020-04-24 10:03:40 +02:00
|
|
|
#
|
|
|
|
# spec file for package openssl-3
|
|
|
|
#
|
2022-03-15 20:28:22 +01:00
|
|
|
# Copyright (c) 2022 SUSE LLC
|
2020-04-24 10:03:40 +02:00
|
|
|
#
|
|
|
|
# All modifications and additions to the file contributed by third parties
|
|
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
|
|
# upon. The license for this file, and modifications and additions to the
|
|
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
|
|
# license for the pristine package is not an Open Source License, in which
|
|
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
|
|
# published by the Open Source Initiative.
|
|
|
|
|
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
|
|
%define ssletcdir %{_sysconfdir}/ssl
|
|
|
|
%define sover 3
|
|
|
|
%define _rname openssl
|
|
|
|
Name: openssl-3
|
|
|
|
# Don't forget to update the version in the "openssl" package!
|
2022-11-01 21:31:17 +01:00
|
|
|
Version: 3.0.7
|
2020-04-24 10:03:40 +02:00
|
|
|
Release: 0
|
|
|
|
Summary: Secure Sockets and Transport Layer Security
|
2020-06-30 14:20:26 +02:00
|
|
|
License: Apache-2.0
|
2020-04-24 10:03:40 +02:00
|
|
|
URL: https://www.openssl.org/
|
2021-09-08 11:17:59 +02:00
|
|
|
Source: https://www.%{_rname}.org/source/%{_rname}-%{version}.tar.gz
|
2020-04-24 10:03:40 +02:00
|
|
|
# to get mtime of file:
|
|
|
|
Source1: %{name}.changes
|
|
|
|
Source2: baselibs.conf
|
2021-09-08 11:17:59 +02:00
|
|
|
Source3: https://www.%{_rname}.org/source/%{_rname}-%{version}.tar.gz.asc
|
2020-04-24 10:03:40 +02:00
|
|
|
# https://www.openssl.org/about/
|
|
|
|
# http://pgp.mit.edu:11371/pks/lookup?op=get&search=0xA2D29B7BF295C759#/openssl.keyring
|
|
|
|
Source4: %{_rname}.keyring
|
|
|
|
Source5: showciphers.c
|
2020-10-30 10:36:36 +01:00
|
|
|
# PATCH-FIX-OPENSUSE: do not install html mans as it takes ages
|
2020-04-24 10:03:40 +02:00
|
|
|
Patch1: openssl-1.1.0-no-html.patch
|
|
|
|
Patch2: openssl-truststore.patch
|
|
|
|
Patch3: openssl-pkgconfig.patch
|
2021-07-17 11:30:23 +02:00
|
|
|
Patch4: openssl-DEFAULT_SUSE_cipher.patch
|
2020-04-24 10:03:40 +02:00
|
|
|
Patch5: openssl-ppc64-config.patch
|
|
|
|
Patch6: openssl-no-date.patch
|
2022-01-28 20:30:29 +01:00
|
|
|
# Patches for crypto-policies
|
|
|
|
Patch7: openssl-Add-support-for-PROFILE-SYSTEM-system-default-cipher.patch
|
|
|
|
Patch8: openssl-Override-default-paths-for-the-CA-directory-tree.patch
|
|
|
|
# use openssl3.cnf
|
|
|
|
Patch9: openssl-use-versioned-config.patch
|
|
|
|
Patch10: fix-config-in-tests.patch
|
2020-04-24 10:03:40 +02:00
|
|
|
BuildRequires: pkgconfig
|
2022-03-23 13:54:06 +01:00
|
|
|
BuildRequires: pkgconfig(zlib)
|
2022-02-02 16:34:23 +01:00
|
|
|
# Add requires for ct_log_list.cnf{,.dist}
|
|
|
|
Requires: openssl
|
2022-03-23 13:54:06 +01:00
|
|
|
%if 0%{?suse_version} >= 1550 || 0%{?sle_version} >= 150400
|
|
|
|
Requires: crypto-policies
|
|
|
|
%endif
|
2022-01-28 20:30:29 +01:00
|
|
|
|
2020-04-24 10:03:40 +02:00
|
|
|
%description
|
|
|
|
OpenSSL is a software library to be used in applications that need to
|
|
|
|
secure communications over computer networks against eavesdropping or
|
|
|
|
need to ascertain the identity of the party at the other end.
|
|
|
|
OpenSSL contains an implementation of the SSL and TLS protocols.
|
|
|
|
|
|
|
|
%package -n libopenssl3
|
|
|
|
Summary: Secure Sockets and Transport Layer Security
|
2022-03-23 13:54:06 +01:00
|
|
|
%if 0%{?suse_version} >= 1550 || 0%{?sle_version} >= 150400
|
|
|
|
Requires: crypto-policies
|
|
|
|
%endif
|
2020-04-24 10:03:40 +02:00
|
|
|
Recommends: ca-certificates-mozilla
|
|
|
|
|
|
|
|
%description -n libopenssl3
|
|
|
|
OpenSSL is a software library to be used in applications that need to
|
|
|
|
secure communications over computer networks against eavesdropping or
|
|
|
|
need to ascertain the identity of the party at the other end.
|
|
|
|
OpenSSL contains an implementation of the SSL and TLS protocols.
|
|
|
|
|
|
|
|
%package -n libopenssl-3-devel
|
|
|
|
Summary: Development files for OpenSSL
|
|
|
|
Requires: libopenssl3 = %{version}
|
2022-03-23 13:54:06 +01:00
|
|
|
Requires: pkgconfig(zlib)
|
2020-04-24 10:03:40 +02:00
|
|
|
Recommends: %{name} = %{version}
|
2020-10-30 10:36:36 +01:00
|
|
|
# We need to have around only the exact version we are able to operate with
|
2020-04-24 10:03:40 +02:00
|
|
|
Conflicts: libopenssl-devel < %{version}
|
|
|
|
Conflicts: libopenssl-devel > %{version}
|
2022-02-01 16:09:19 +01:00
|
|
|
Conflicts: libressl-devel
|
2020-04-24 10:03:40 +02:00
|
|
|
Conflicts: ssl-devel
|
|
|
|
|
|
|
|
%description -n libopenssl-3-devel
|
|
|
|
This subpackage contains header files for developing applications
|
|
|
|
that want to make use of the OpenSSL C API.
|
|
|
|
|
|
|
|
%package doc
|
|
|
|
Summary: Additional Package Documentation
|
|
|
|
Conflicts: openssl-doc
|
|
|
|
Provides: openssl-doc = %{version}
|
|
|
|
Obsoletes: openssl-doc < %{version}
|
|
|
|
BuildArch: noarch
|
|
|
|
|
|
|
|
%description doc
|
|
|
|
This package contains optional documentation provided in addition to
|
|
|
|
this package's base documentation.
|
|
|
|
|
|
|
|
%prep
|
2021-09-08 11:17:59 +02:00
|
|
|
%autosetup -p1 -n %{_rname}-%{version}
|
2020-04-24 10:03:40 +02:00
|
|
|
|
|
|
|
%build
|
|
|
|
%ifarch armv5el armv5tel
|
|
|
|
export MACHINE=armv5el
|
|
|
|
%endif
|
|
|
|
%ifarch armv6l armv6hl
|
|
|
|
export MACHINE=armv6l
|
|
|
|
%endif
|
|
|
|
|
|
|
|
./config \
|
|
|
|
no-idea \
|
2021-07-17 11:30:23 +02:00
|
|
|
no-ec2m \
|
2020-04-24 10:03:40 +02:00
|
|
|
enable-rfc3779 \
|
|
|
|
%ifarch x86_64 aarch64 ppc64le
|
|
|
|
enable-ec_nistp_64_gcc_128 \
|
|
|
|
%endif
|
|
|
|
enable-camellia \
|
2022-03-23 13:54:06 +01:00
|
|
|
zlib \
|
2020-04-24 10:03:40 +02:00
|
|
|
--prefix=%{_prefix} \
|
|
|
|
--libdir=%{_lib} \
|
|
|
|
--openssldir=%{ssletcdir} \
|
|
|
|
%{optflags} \
|
|
|
|
-Wa,--noexecstack \
|
|
|
|
-Wl,-z,relro,-z,now \
|
|
|
|
-fno-common \
|
|
|
|
-DTERMIO \
|
|
|
|
-DPURIFY \
|
|
|
|
-D_GNU_SOURCE \
|
|
|
|
-DOPENSSL_NO_BUF_FREELISTS \
|
|
|
|
$(getconf LFS_CFLAGS) \
|
|
|
|
-Wall \
|
2022-03-23 13:54:06 +01:00
|
|
|
--with-rand-seed=getrandom \
|
|
|
|
--system-ciphers-file=%{_sysconfdir}/crypto-policies/back-ends/openssl.config
|
2020-04-24 10:03:40 +02:00
|
|
|
|
|
|
|
# Show build configuration
|
|
|
|
perl configdata.pm --dump
|
|
|
|
|
2020-10-17 08:43:41 +02:00
|
|
|
# util/mkdef.pl crypto update
|
2020-04-24 10:03:40 +02:00
|
|
|
%make_build depend
|
|
|
|
%make_build all
|
|
|
|
|
|
|
|
%check
|
2022-03-23 13:54:06 +01:00
|
|
|
|
|
|
|
# We must revert patch8 before running tests, otherwise they will fail.
|
|
|
|
patch -p1 -R < %{P:8}
|
|
|
|
|
2020-04-24 10:03:40 +02:00
|
|
|
export MALLOC_CHECK_=3
|
|
|
|
export MALLOC_PERTURB_=$(($RANDOM % 255 + 1))
|
2020-10-17 08:43:41 +02:00
|
|
|
# export HARNESS_VERBOSE=yes
|
2022-11-01 21:31:17 +01:00
|
|
|
LD_LIBRARY_PATH="$PWD" make TESTS='-test_evp_fetch_prov -test_tsa -test_ssl_new -test_sslapi' test -j1
|
2020-10-17 08:43:41 +02:00
|
|
|
# show ciphers
|
2020-04-24 10:03:40 +02:00
|
|
|
gcc -o showciphers %{optflags} -I%{buildroot}%{_includedir} %{SOURCE5} -L%{buildroot}%{_libdir} -lssl -lcrypto
|
|
|
|
LD_LIBRARY_PATH=%{buildroot}%{_libdir} ./showciphers
|
|
|
|
|
|
|
|
%install
|
|
|
|
%make_install %{?_smp_mflags}
|
2022-01-28 20:30:29 +01:00
|
|
|
|
2020-10-30 10:36:36 +01:00
|
|
|
# Kill static libs
|
2020-04-24 10:03:40 +02:00
|
|
|
rm -f %{buildroot}%{_libdir}/lib*.a
|
2020-10-30 10:36:36 +01:00
|
|
|
# Remove the cnf.dist
|
2022-01-28 20:30:29 +01:00
|
|
|
rm -f %{buildroot}%{_sysconfdir}/ssl/openssl3.cnf.dist
|
|
|
|
mkdir %{buildroot}/%{_datadir}/ssl-3
|
|
|
|
mv %{buildroot}/%{ssletcdir}/misc %{buildroot}/%{_datadir}/ssl-3/
|
2020-04-24 10:03:40 +02:00
|
|
|
ln -sf ./%{_rname} %{buildroot}/%{_includedir}/ssl
|
|
|
|
mkdir %{buildroot}/%{_datadir}/ssl
|
2022-01-28 20:30:29 +01:00
|
|
|
# Rename binary
|
|
|
|
mv %{buildroot}%{_bindir}/%{_rname} %{buildroot}%{_bindir}/%{name}
|
2020-10-30 10:36:36 +01:00
|
|
|
# Avoid file conflicts with man pages from other packages
|
2020-04-24 10:03:40 +02:00
|
|
|
pushd %{buildroot}/%{_mandir}
|
2020-05-24 09:32:32 +02:00
|
|
|
find . -type f -exec chmod 644 {} +
|
2020-10-30 10:36:36 +01:00
|
|
|
# Some man pages now contain spaces. This makes several
|
|
|
|
# scripts go havoc, among them /usr/sbin/Check.
|
|
|
|
# Replace spaces by underscores
|
2020-10-17 08:43:41 +02:00
|
|
|
# for i in man?/*\ *; do mv -v "$i" "${i// /_}"; done
|
2021-05-18 00:28:37 +02:00
|
|
|
|
|
|
|
touch $OLDPWD/filelist.doc $OLDPWD/filelist
|
2020-04-24 10:03:40 +02:00
|
|
|
which readlink &>/dev/null || function readlink { ( set +x; target=$(file $1 2>/dev/null); target=${target//* }; test -f $target && echo $target; ) }
|
|
|
|
for i in man?/*; do
|
2020-05-22 14:52:31 +02:00
|
|
|
if test -L $i ; then
|
|
|
|
LDEST=`readlink $i`
|
|
|
|
rm -f $i ${i}ssl
|
2022-01-28 20:30:29 +01:00
|
|
|
ln -sf ${LDEST}ssl-3 ${i}ssl-3
|
2020-05-22 14:52:31 +02:00
|
|
|
else
|
2022-01-28 20:30:29 +01:00
|
|
|
mv $i ${i}ssl-3
|
2020-05-22 14:52:31 +02:00
|
|
|
fi
|
|
|
|
case "$i" in
|
|
|
|
*.1)
|
2020-10-30 10:36:36 +01:00
|
|
|
# These are the pages mentioned in openssl(1). They go into the main package.
|
2022-01-28 20:30:29 +01:00
|
|
|
echo %doc %{_mandir}/${i}ssl-3%{?ext_man} >> $OLDPWD/filelist;;
|
2020-05-22 14:52:31 +02:00
|
|
|
*)
|
2020-10-30 10:36:36 +01:00
|
|
|
# The rest goes into the openssl-doc package.
|
2022-01-28 20:30:29 +01:00
|
|
|
echo %doc %{_mandir}/${i}ssl-3%{?ext_man} >> $OLDPWD/filelist.doc;;
|
2020-05-22 14:52:31 +02:00
|
|
|
esac
|
2020-04-24 10:03:40 +02:00
|
|
|
done
|
|
|
|
popd
|
|
|
|
|
2022-01-28 20:30:29 +01:00
|
|
|
mv %{buildroot}%{_bindir}/c_rehash %{buildroot}%{_bindir}/c_rehash-3
|
|
|
|
|
2022-02-02 16:43:26 +01:00
|
|
|
# They are provided by openssl package
|
|
|
|
rm %{buildroot}%{ssletcdir}/ct_log_list.cnf*
|
|
|
|
|
2020-04-24 10:03:40 +02:00
|
|
|
# Do not install demo scripts executable under /usr/share/doc
|
2020-05-24 09:32:32 +02:00
|
|
|
find demos -type f -perm /111 -exec chmod 644 {} +
|
2020-04-24 10:03:40 +02:00
|
|
|
|
|
|
|
# Place showciphers.c for %%doc macro
|
|
|
|
cp %{SOURCE5} .
|
|
|
|
|
|
|
|
%post -n libopenssl3 -p /sbin/ldconfig
|
|
|
|
%postun -n libopenssl3 -p /sbin/ldconfig
|
|
|
|
|
|
|
|
%files -n libopenssl3
|
Accepting request 821489 from home:pmonrealgonzalez:branches:security:tls
- Update to 3.0.0 Alpha 5
* Deprecated the 'ENGINE' API. Engines should be replaced with
providers going forward.
* Reworked the recorded ERR codes to make better space for system errors.
To distinguish them, the macro 'ERR_SYSTEM_ERROR()' indicates
if the given code is a system error (true) or an OpenSSL error (false).
* Reworked the test perl framework to better allow parallel testing.
* Added ciphertext stealing algorithms AES-128-CBC-CTS, AES-192-CBC-CTS and
AES-256-CBC-CTS to the providers. CS1, CS2 and CS3 variants are supported.
* 'Configure' has been changed to figure out the configuration target if
none is given on the command line. Consequently, the 'config' script is
now only a mere wrapper. All documentation is changed to only mention
'Configure'.
* Added a library context that applications as well as other libraries can use
to form a separate context within which libcrypto operations are performed.
- There are two ways this can be used:
1) Directly, by passing a library context to functions that take
such an argument, such as 'EVP_CIPHER_fetch' and similar algorithm
fetching functions.
2) Indirectly, by creating a new library context and then assigning
it as the new default, with 'OPENSSL_CTX_set0_default'.
- All public OpenSSL functions that take an 'OPENSSL_CTX' pointer,
apart from the functions directly related to 'OPENSSL_CTX', accept
NULL to indicate that the default library context should be used.
- Library code that changes the default library context using
'OPENSSL_CTX_set0_default' should take care to restore it with a
second call before returning to the caller.
* The security strength of SHA1 and MD5 based signatures in TLS has been
reduced. This results in SSL 3, TLS 1.0, TLS 1.1 and DTLS 1.0 no longer
working at the default security level of 1 and instead requires security
OBS-URL: https://build.opensuse.org/request/show/821489
OBS-URL: https://build.opensuse.org/package/show/security:tls/openssl-3?expand=0&rev=13
2020-07-17 13:26:23 +02:00
|
|
|
%license LICENSE.txt
|
2020-04-24 10:03:40 +02:00
|
|
|
%{_libdir}/libssl.so.%{sover}
|
|
|
|
%{_libdir}/libcrypto.so.%{sover}
|
|
|
|
%{_libdir}/engines-%{sover}
|
|
|
|
%dir %{_libdir}/ossl-modules
|
2021-07-17 11:30:23 +02:00
|
|
|
#%%{_libdir}/ossl-modules/fips.so
|
2020-04-24 10:03:40 +02:00
|
|
|
%{_libdir}/ossl-modules/legacy.so
|
|
|
|
|
|
|
|
%files -n libopenssl-3-devel
|
|
|
|
%{_includedir}/%{_rname}/
|
|
|
|
%{_includedir}/ssl
|
|
|
|
%{_libdir}/libssl.so
|
|
|
|
%{_libdir}/libcrypto.so
|
|
|
|
%{_libdir}/pkgconfig/libcrypto.pc
|
|
|
|
%{_libdir}/pkgconfig/libssl.pc
|
|
|
|
%{_libdir}/pkgconfig/openssl.pc
|
|
|
|
|
|
|
|
%files doc -f filelist.doc
|
|
|
|
%doc doc/* demos
|
|
|
|
%doc showciphers.c
|
|
|
|
|
|
|
|
%files -f filelist
|
|
|
|
%doc CHANGE*
|
|
|
|
%dir %{ssletcdir}
|
2022-01-28 20:30:29 +01:00
|
|
|
%config (noreplace) %{ssletcdir}/openssl3.cnf
|
2020-04-24 10:03:40 +02:00
|
|
|
%attr(700,root,root) %{ssletcdir}/private
|
|
|
|
|
2022-01-28 20:30:29 +01:00
|
|
|
%dir %{_datadir}/ssl-3
|
|
|
|
%{_datadir}/ssl-3/misc
|
|
|
|
%{_bindir}/c_rehash-3
|
|
|
|
%{_bindir}/%{name}
|
2020-04-24 10:03:40 +02:00
|
|
|
|
|
|
|
%changelog
|