forked from pool/libssh
- Update to version 0.11.2 * Security: * CVE-2025-4877 - Write beyond bounds in binary to base64 conversion (bsc#1245309) * CVE-2025-4878 - Use of uninitialized variable in privatekey_from_file() (bsc#1245310) * CVE-2025-5318 - Likely read beyond bounds in sftp server handle management (bsc#1245311) * CVE-2025-5351 - Double free in functions exporting keys (bsc#1245312) * CVE-2025-5372 - ssh_kdf() returns a success code on certain failures (bsc#1245314) * CVE-2025-5449 - Likely read beyond bounds in sftp server message decoding (bsc#1245316) * CVE-2025-5987 - Invalid return code for chacha20 poly1305 with OpenSSL (bsc#1245317) * Compatibility * Fixed compatibility with CPM.cmake * Compatibility with OpenSSH 10.0 * Tests compatibility with new Dropbear releases * Removed p11-kit remoting from the pkcs11 testsuite * Bugfixes * Implement missing packet filter for DH GEX * Properly process the SSH2_MSG_DEBUG message * Allow escaping quotes in quoted arguments to ssh configuration * Do not fail with unknown match keywords in ssh configuration * Process packets before selecting signature algorithm during authentication * Do not fail hard when the SFTP status message is not sent by noncompliant servers - Removed libssh-CmakeLists-Fix-multiple-digit-major-version-for-OpenSSH.patch - Removed libssh-misc-Fix-OpenSSH-banner-parsing.patch OBS-URL: https://build.opensuse.org/request/show/1288631 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/libssh?expand=0&rev=79
197 lines
6.4 KiB
RPMSpec
197 lines
6.4 KiB
RPMSpec
#
|
|
# spec file for package libssh
|
|
#
|
|
# Copyright (c) 2025 SUSE LLC
|
|
#
|
|
# 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/
|
|
#
|
|
|
|
|
|
%global flavor @BUILD_FLAVOR@%{nil}
|
|
%if "%{flavor}" == "test"
|
|
%define pkg_suffix -test
|
|
%bcond_without test
|
|
%else
|
|
%define pkg_suffix %{nil}
|
|
%bcond_with test
|
|
%endif
|
|
|
|
%if %{defined _distconfdir}
|
|
%define _configdir %{_distconfdir}
|
|
%else
|
|
%define _configdir %{_sysconfdir}
|
|
%endif
|
|
|
|
Name: libssh%{pkg_suffix}
|
|
Version: 0.11.2
|
|
Release: 0
|
|
Summary: The SSH library
|
|
License: LGPL-2.1-or-later
|
|
Group: Development/Libraries/C and C++
|
|
URL: https://www.libssh.org
|
|
Source0: https://www.libssh.org/files/0.11/libssh-%{version}.tar.xz
|
|
Source1: https://www.libssh.org/files/0.11/libssh-%{version}.tar.xz.asc
|
|
Source2: https://www.libssh.org/files/0x03D5DF8CFDD3E8E7_libssh_libssh_org_gpgkey.asc#/libssh.keyring
|
|
Source3: libssh_client.config
|
|
Source4: libssh_server.config
|
|
Source99: baselibs.conf
|
|
# PATCH-FIX-UPSTREAM: libssh tries to read config from wrong crypto-policies location (bsc#1222716)
|
|
Patch0: libssh-cmake-Add-option-WITH_HERMETIC_USR.patch
|
|
# PATCH-FIX-SUSE: fix hang in torture_channel tests (bsc#1243799)
|
|
Patch1: libssh-tests-Fix-an-issue-where-torture_session-request-a-SIGTERM-too-early.patch
|
|
BuildRequires: cmake
|
|
BuildRequires: gcc-c++
|
|
BuildRequires: krb5-devel
|
|
BuildRequires: openssl-devel
|
|
BuildRequires: pkgconfig
|
|
BuildRequires: xz
|
|
BuildRequires: zlib-devel
|
|
# doxygen generated documentation used to be in subpkg
|
|
Obsoletes: %{name}-devel-doc <= 0.8.6
|
|
%if %{with test}
|
|
BuildRequires: libcmocka-devel
|
|
BuildRequires: openssh
|
|
%if 0%{?suse_version} > 1550
|
|
BuildRequires: nss_wrapper
|
|
BuildRequires: pam_wrapper
|
|
BuildRequires: socket_wrapper
|
|
BuildRequires: uid_wrapper
|
|
%endif
|
|
%endif
|
|
|
|
%description
|
|
An SSH implementation in the form of a library. With libssh, you can remotely
|
|
execute programs, transfer files, use a secure and transparent tunnel for your
|
|
remote programs. It supports SFTP as well.
|
|
|
|
This package provides libssh from https://www.libssh.org that should not be
|
|
confused with libssh2 available from https://www.libssh2.org (libssh2 package)
|
|
|
|
%package -n libssh4
|
|
Summary: SSH library
|
|
Group: System/Libraries
|
|
Requires: %{name}-config >= %{version}
|
|
|
|
%description -n libssh4
|
|
An SSH implementation in the form of a library. With libssh, you can remotely
|
|
execute programs, transfer files, use a secure and transparent tunnel for your
|
|
remote programs. It supports SFTP as well.
|
|
|
|
This package provides libssh from https://www.libssh.org that should not be
|
|
confused with libssh2 available from https://www.libssh2.org (libssh2 package)
|
|
|
|
%package config
|
|
Summary: SSH library configuration files
|
|
Group: Productivity/Networking/SSH
|
|
BuildArch: noarch
|
|
|
|
%description config
|
|
Configuration files for the SSH library.
|
|
|
|
%package devel
|
|
Summary: SSH library development headers
|
|
Group: Development/Libraries/C and C++
|
|
Requires: libssh4 = %{version}
|
|
|
|
%description devel
|
|
Development headers for the SSH library.
|
|
|
|
%prep
|
|
%autosetup -p1 -n libssh-%{version}
|
|
|
|
%build
|
|
%cmake \
|
|
-DCMAKE_C_FLAGS:STRING="%{optflags} -DOPENSSL_LOAD_CONF" \
|
|
%if %{with test}
|
|
-DUNIT_TESTING="ON" \
|
|
%if 0%{?suse_version} > 1550
|
|
-DCLIENT_TESTING=ON \
|
|
-DSERVER_TESTING=ON \
|
|
%endif
|
|
%endif
|
|
-DWITH_GSSAPI=ON \
|
|
-DWITH_EXAMPLES="OFF" \
|
|
%if %{defined _distconfdir}
|
|
-DWITH_HERMETIC_USR=ON \
|
|
%endif
|
|
-DGLOBAL_CLIENT_CONFIG="%{_sysconfdir}/libssh/libssh_client.config" \
|
|
-DGLOBAL_BIND_CONFIG="%{_sysconfdir}/libssh/libssh_server.config"
|
|
|
|
%make_build
|
|
|
|
%install
|
|
%if !%{with test}
|
|
%cmake_install
|
|
|
|
install -d -m755 %{buildroot}%{_configdir}/libssh
|
|
install -m644 %{SOURCE3} %{buildroot}%{_configdir}/libssh/libssh_client.config
|
|
install -m644 %{SOURCE4} %{buildroot}%{_configdir}/libssh/libssh_server.config
|
|
|
|
# Fix incorrect include path, (boo#1211718).
|
|
%if 0%{?suse_version} > 1600
|
|
sed -i '/^Include/ s|/etc|/usr/etc|' %{buildroot}%{_configdir}/libssh/libssh_client.config
|
|
sed -i '/^Include/ s|/etc|/usr/etc|' %{buildroot}%{_configdir}/libssh/libssh_server.config
|
|
# Don't change the path for crypto-policies libssh.config (bsc#1222716)
|
|
sed -i '/^Include/ s|/usr/etc/crypto-policies|/etc/crypto-policies|' %{buildroot}%{_configdir}/libssh/libssh_client.config
|
|
sed -i '/^Include/ s|/usr/etc/crypto-policies|/etc/crypto-policies|' %{buildroot}%{_configdir}/libssh/libssh_server.config
|
|
%endif
|
|
|
|
%endif
|
|
|
|
%check
|
|
%if %{with test}
|
|
# Tests are randomly failing when run in parallel
|
|
%define _smp_mflags %{nil}
|
|
%ctest
|
|
%endif
|
|
|
|
%if !%{with test}
|
|
%post -n libssh4 -p /sbin/ldconfig
|
|
%postun -n libssh4 -p /sbin/ldconfig
|
|
|
|
%files -n libssh4
|
|
%doc AUTHORS README CHANGELOG
|
|
%{_libdir}/libssh.so.*
|
|
|
|
%files config
|
|
%dir %{_configdir}/libssh
|
|
%if %{defined _distconfdir}
|
|
%{_configdir}/libssh/libssh_client.config
|
|
%{_configdir}/libssh/libssh_server.config
|
|
%else
|
|
%config(noreplace) %{_configdir}/libssh/libssh_client.config
|
|
%config(noreplace) %{_configdir}/libssh/libssh_server.config
|
|
%endif
|
|
|
|
%if %{defined _distconfdir}
|
|
%pre config
|
|
test -f /etc/libssh/libssh_server.config.rpmsave && mv -v /etc/libssh/libssh_server.config.rpmsave /etc/libssh/libssh_server.config.rpmsave.old ||:
|
|
test -f /etc/libssh/libssh_client.config.rpmsave && mv -v /etc/libssh/libssh_client.config.rpmsave /etc/libssh/libssh_client.config.rpmsave.old ||:
|
|
|
|
%posttrans config
|
|
test -f /etc/libssh/libssh_server.config.rpmsave && mv -v /etc/libssh/libssh_server.config.rpmsave /etc/libssh/libssh_server.config ||:
|
|
test -f /etc/libssh/libssh_client.config.rpmsave && mv -v /etc/libssh/libssh_client.config.rpmsave /etc/libssh/libssh_client.config ||:
|
|
%endif
|
|
|
|
%files devel
|
|
%{_includedir}/libssh
|
|
%{_libdir}/libssh.so
|
|
%{_libdir}/pkgconfig/libssh.pc
|
|
%dir %{_libdir}/cmake
|
|
%dir %{_libdir}/cmake/libssh
|
|
%{_libdir}/cmake/libssh/libssh-config.cmake
|
|
%{_libdir}/cmake/libssh/libssh-config-relwithdebinfo.cmake
|
|
%{_libdir}/cmake/libssh/libssh-config-version.cmake
|
|
%endif
|
|
|
|
%changelog
|