File spice.spec of Package spice.19892
#
# spec file for package spice
#
# Copyright (c) 2021 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/
#
# Common info
Name: spice
Version: 0.12.7
Release: 0
Summary: SPICE client and server library
License: LGPL-2.1+
Group: Productivity/Networking/Other
Url: http://www.spice-space.org/
Source: http://spice-space.org/download/releases/%{name}-%{version}.tar.bz2
Source99: %{name}.rpmlintrc
# Patches for CVE-2016-0749 and CVE-2016-2150
Patch0: CVE-2016-0749-add-a-ref-to-item-before-adding-to-pipe.patch
Patch1: CVE-2016-0749-allocate-msg-with-the-expected-size.patch
Patch2: CVE-2016-2150-create-a-function-to-validate-surface-parameters.patch
Patch3: CVE-2016-2150-improve-primary-surface-parameter-checks.patch
Patch4: CVE-2016-9577-buffer-overflow-in-main_channel_alloc_msg_rcv_buf.patch
Patch5: CVE-2016-9578-remote-dos-via-crafted-message.patch
Patch6: CVE-2017-7506.patch
# PATCH-FIX-NOT-YET-UPSTREAM - CVE-2019-3813
Patch7: 0001-memslot-Fix-off-by-one-error-in-group-slot-boundary-.patch
Patch8: 0001-lz-Avoid-buffer-reading-overflow-checking-for-image-.patch
Patch9: 0002-lz-More-checks-on-image-sizes.patch
Patch10: bb15d481-Fix-flexible-array-buffer-overflow.patch
Patch11: 0001-quic-Check-we-have-some-data-to-start-decoding-quic-.patch
Patch12: 0002-quic-Check-image-size-in-quic_decode_begin.patch
Patch13: 0003-quic-Check-RLE-lengths.patch
Patch14: 0004-quic-Avoid-possible-buffer-overflow-in-find_bucket.patch
Patch15: 0001-With-OpenSSL-1.1-Disable-client-initiated-renegotiation.patch
Patch16: 0002-With-OpenSSL-1.0.2-and-earlier-disable-client-side-renegotiation.patch
# Build-time parameters
BuildRequires: alsa-devel
BuildRequires: celt051-devel
BuildRequires: cyrus-sasl-devel
BuildRequires: gcc-c++
BuildRequires: libjpeg-devel
BuildRequires: libopenssl-devel
BuildRequires: libpixman-1-0-devel >= 0.17.7
BuildRequires: pkg-config
BuildRequires: python-pyparsing
BuildRequires: python-six
BuildRequires: spice-protocol-devel >= 0.12.10
BuildRequires: zlib-devel
BuildRequires: pkgconfig(glib-2.0) >= 2.22
BuildRequires: pkgconfig(opus)
BuildRequires: pkgconfig(x11)
BuildRequires: pkgconfig(xext)
BuildRequires: pkgconfig(xfixes)
BuildRequires: pkgconfig(xinerama)
BuildRequires: pkgconfig(xrandr)
BuildRequires: pkgconfig(xrender)
# Install-time parameters
Requires: celt051
BuildRoot: %{_tmppath}/%{name}-%{version}-build
ExclusiveArch: %ix86 x86_64
%description
The SPICE package provides the SPICE server library and client.
These components are used to provide access to a remote machine's
display and devices.
%package -n spice-client
Summary: SPICE client
Group: Productivity/Networking/Other
%description -n spice-client
The SPICE client provides access to a remote machine's display and devices.
%package -n libspice-server1
Summary: Library for SPICE-server
Group: Productivity/Networking/Other
%description -n libspice-server1
Library for SPICE-server
The SPICE server is used to expose a remote machine's display
and devices.
%package -n libspice-server-devel
Summary: Development files for building SPICE-server
Group: Development/Languages/C and C++
Requires: libspice-server1 = %{version}
%description -n libspice-server-devel
Development files for building SPICE-server.
The SPICE server is used to expose a remote machine's display
and devices.
%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
%build
%configure \
--disable-static \
--enable-client \
--disable-smartcard
LDFLAGS="-Wl,--as-needed -Wl,--strip-all"
make %{?_smp_mflags}
%install
make DESTDIR=%{buildroot} install %{?_smp_mflags}
find %{buildroot} -type f -name "*.la" -delete -print
%post -n libspice-server1 -p /sbin/ldconfig
%postun -n libspice-server1 -p /sbin/ldconfig
%files -n spice-client
%defattr(-,root,root)
%doc AUTHORS COPYING NEWS README
%files -n libspice-server1
%defattr(-,root,root)
%{_libdir}/libspice-server.so.*
%files -n libspice-server-devel
%defattr(-,root,root)
%{_libdir}/pkgconfig/spice-server.pc
%{_includedir}/spice-server/
%{_libdir}/libspice-server.so
%changelog