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
openSUSE Build Service is sponsored by