+# TODO:
+# - enable ducktype-docs when it works
+# - move /etc/dbus-1 from -libs to base after external packages transition to /usr/share/dbus-1
#
# Conditional build:
-%bcond_without glib # without glib support
-%bcond_without gtk # without GTK+ programs
-%bcond_without qt # without Qt support
-%bcond_without python # without Python support
-%bcond_without dotnet # without .NET support
-%bcond_with gcj # with Java support
-#
-%if %{without glib}
-%undefine with_gtk
-%endif
+%bcond_without apparmor # AppArmor support
+%bcond_without selinux # SELinux support
+%bcond_without systemd # systemd at_console support
+%bcond_without X11 # X11 support
-%define expat_version 1.95.5
-%define glib2_version 2.2.0
-%define qt_version 3.1.0
+%define expat_version 1:1.95.5
Summary: D-BUS message bus
-Summary(pl): Magistrala przesy³ania komunikatów D-BUS
+Summary(pl.UTF-8): Magistrala przesyłania komunikatów D-BUS
Name: dbus
-Version: 0.36.2
-Release: 1
-License: AFL v2.1 or GPL v2
+Version: 1.12.20
+Release: 2
+License: AFL v2.1 or GPL v2+
Group: Libraries
-Source0: http://dbus.freedesktop.org/releases/%{name}-%{version}.tar.gz
-# Source0-md5: 45468e46967d3e70f082d0d0e6049225
+Source0: https://dbus.freedesktop.org/releases/dbus/%{name}-%{version}.tar.gz
+# Source0-md5: dfe8a71f412e0b53be26ed4fbfdc91c4
Source1: messagebus.init
Source2: %{name}-daemon-1-profile.d-sh
Source3: %{name}-sysconfig
Source4: %{name}-xinitrc.sh
-Patch0: %{name}-ac.patch
-Patch1: %{name}-nolibs.patch
-Patch2: %{name}-config.patch
-Patch3: %{name}-mint.patch
-Patch4: %{name}-python_fixes.patch
-URL: http://www.freedesktop.org/Software/dbus
-BuildRequires: XFree86-devel
-BuildRequires: autoconf >= 2.52
-BuildRequires: automake
-BuildRequires: expat-devel >= %{expat_version}
+Source5: %{name}.tmpfiles
+Patch0: %{name}-nolibs.patch
+Patch1: %{name}-config.patch
+Patch2: %{name}-no_fatal_checks.patch
+Patch3: %{name}-allow-introspection.patch
+Patch4: %{name}-autoconf-archive.patch
+URL: https://www.freedesktop.org/Software/dbus
+BuildRequires: audit-libs-devel
+BuildRequires: autoconf >= 2.63
+BuildRequires: autoconf-archive >= 2019.01.06
+BuildRequires: automake >= 1:1.13
+BuildRequires: docbook-dtd44-xml
BuildRequires: doxygen
-%{?with_glib:BuildRequires: glib2-devel >= %{glib2_version}}
-%{?with_gcj:BuildRequires: gcc-java >= 5:4.0}
-%{?with_gtk:BuildRequires: gtk+2-devel >= %{glib2_version}}
-%{?with_qt:BuildRequires: kdelibs-devel}
-# just gtk-sharp for examples
-%{?with_dotnet:BuildRequires: dotnet-gtk-sharp-devel}
-%{?with_dotnet:BuildRequires: mono-csharp >= 0.95}
-%{?with_dotnet:BuildRequires: monodoc >= 0.16}
-BuildRequires: libselinux-devel
-BuildRequires: libtool
+BuildRequires: expat-devel >= %{expat_version}
+%{?with_apparmor:BuildRequires: libapparmor-devel >= 1:2.10}
+BuildRequires: libcap-ng-devel
+%{?with_selinux:BuildRequires: libselinux-devel >= 2.0.86}
+BuildRequires: libtool >= 2:2.0
+BuildRequires: libxslt-progs
BuildRequires: pkgconfig
-%if %{with python}
-BuildRequires: python-devel >= 2.2
-BuildRequires: python-Pyrex >= 0.9.3
-%endif
-%{?with_qt:BuildRequires: qt-devel >= %{qt_version}}
-BuildRequires: rpmbuild(macros) >= 1.202
+#BuildRequires: python3-ducktype
+BuildRequires: rpm-build >= 4.6
+BuildRequires: rpmbuild(macros) >= 2.011
BuildRequires: sed >= 4.0
-BuildRequires: libselinux-devel >= 1.17.13
+%{?with_systemd:BuildRequires: systemd-devel >= 32}
BuildRequires: xmlto
-Requires: rc-scripts
-Requires: %{name}-libs = %{version}-%{release}
+%{?with_X11:BuildRequires: xorg-lib-libX11-devel}
+BuildRequires: yelp-tools
+Requires(post,postun): /sbin/ldconfig
+Requires(post,preun): /sbin/chkconfig
+Requires(postun): /usr/sbin/groupdel
+Requires(postun): /usr/sbin/userdel
Requires(pre): /bin/id
Requires(pre): /usr/bin/getgid
Requires(pre): /usr/sbin/groupadd
Requires(pre): /usr/sbin/useradd
-Requires(post,preun): /sbin/chkconfig
-Requires(post,postun): /sbin/ldconfig
-Requires(postun): /usr/sbin/groupdel
-Requires(postun): /usr/sbin/userdel
+Requires(post,preun,postun): systemd-units >= 250.1
+Requires: %{name}-libs = %{version}-%{release}
+Requires: expat >= %{expat_version}
+%{?with_apparmor:Requires: libapparmor >= 1:2.10}
+%{?with_selinux:Requires: libselinux >= 2.0.86}
+Requires: rc-scripts >= 0.4.3.0
+Requires: systemd-units >= 250.1
Provides: group(messagebus)
Provides: user(messagebus)
+Obsoletes: dbus-glib-tools
+Obsoletes: dbus-systemd
+Conflicts: pam < 0.99.7.1
+# not available for dbus 0.9x yet(?)
+#Obsoletes: dbus-gtk dbus-gcj dbus-gcj-devel dbus-gcj-static
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
%description
used both for the systemwide message bus service, and as a
per-user-login-session messaging facility.
-%description -l pl
-D-BUS to system przesy³ania komunikatów pomiêdzy aplikacjami. Jest
-u¿ywany zarówno jako ogólnosystemowa us³uga magistrali komunikatów jak
-i mo¿liwo¶æ przesy³ania komunikatów w ramach jednej sesji u¿ytkownika.
-
-%package devel
-Summary: Header files for D-BUS
-Summary(pl): Pliki nag³ówkowe D-BUS
-Group: Development/Libraries
-Requires: %{name}-libs = %{version}-%{release}
-
-%description devel
-Header files for D-BUS.
-
-%description devel -l pl
-Pliki nag³ówkowe D-BUS.
+%description -l pl.UTF-8
+D-BUS to system przesyłania komunikatów pomiędzy aplikacjami. Jest
+używany zarówno jako ogólnosystemowa usługa magistrali komunikatów jak
+i możliwość przesyłania komunikatów w ramach jednej sesji użytkownika.
%package libs
-Summary: D-BUS libraries
-Summary(pl): Biblioteki D-BUS
+Summary: D-BUS library
+Summary(pl.UTF-8): Biblioteka D-BUS
Group: Libraries
+%{?with_systemd:Requires: systemd-libs >= 32}
+Obsoletes: dbus-dirs
%description libs
-D-BUS libraries.
+D-BUS library.
-%description libs -l pl
-Biblioteki D-BUS.
+%description libs -l pl.UTF-8
+Biblioteka D-BUS.
-%package static
-Summary: Static D-BUS libraries
-Summary(pl): Statyczne biblioteki D-BUS
+%package devel
+Summary: Header files for D-BUS library
+Summary(pl.UTF-8): Pliki nagłówkowe biblioteki D-BUS
Group: Development/Libraries
-Requires: %{name}-devel = %{version}-%{release}
-
-%description static
-Static D-BUS libraries.
-
-%description static -l pl
-Statyczne biblioteki D-BUS.
-
-%package glib
-Summary: GLib-based library for using D-BUS
-Summary(pl): Biblioteka do u¿ywania D-BUS oparta o GLib
-Group: Libraries
Requires: %{name}-libs = %{version}-%{release}
-Requires: glib2 >= %{glib2_version}
+%{?with_systemd:Requires: systemd-devel >= 32}
-%description glib
-D-BUS add-on library to integrate the standard D-BUS library with the
-GLib thread abstraction and main loop.
+%description devel
+Header files for D-BUS library.
-%description glib -l pl
-Dodatkowa biblioteka D-BUS do integracji standardowej biblioteki D-BUS
-z abstrakcj± w±tków i g³ówn± pêtl± GLib.
+%description devel -l pl.UTF-8
+Pliki nagłówkowe biblioteki D-BUS.
-%package glib-devel
-Summary: Header files for GLib-based library for using D-BUS
-Summary(pl): Pliki nag³ówkowe biblioteki do u¿ywania D-BUS opartej o GLib
+%package static
+Summary: Static D-BUS library
+Summary(pl.UTF-8): Statyczna biblioteka D-BUS
Group: Development/Libraries
Requires: %{name}-devel = %{version}-%{release}
-Requires: %{name}-glib = %{version}-%{release}
-Requires: glib2-devel >= %{glib2_version}
-
-%description glib-devel
-Header files for GLib-based library for using D-BUS.
-
-%description glib-devel -l pl
-Pliki nag³ówkowe biblioteki do u¿ywania D-BUS opartej o GLib.
-
-%package glib-static
-Summary: Static GLib-based library for using D-BUS
-Summary(pl): Statyczna biblioteka do u¿ywania D-BUS oparta o GLib
-Group: Development/Libraries
-Requires: %{name}-glib-devel = %{version}-%{release}
-
-%description glib-static
-Static GLib-based library for using D-BUS.
-
-%description glib-static -l pl
-Statyczna biblioteka do u¿ywania D-BUS oparta o GLib.
-
-%package glib-tools
-Summary: GLib-based tools for D-BUS
-Summary(pl): Narzêdzia dla D-BUS oparte o GLib
-Group: Libraries
-Requires: %{name} = %{version}-%{release}
-Requires: %{name}-glib = %{version}-%{release}
-
-%description glib-tools
-GLib-based tools for D-BUS.
-
-%description glib-tools -l pl
-Narzêdzia dla D-BUS oparte o GLib
-
-%package gtk
-Summary: GTK+-based graphical D-BUS frontend utility
-Summary(pl): Oparte na GTK+ graficzne narzêdzie do D-BUS
-Group: X11/Applications
-Requires: %{name} = %{version}-%{release}
-Requires: %{name}-glib = %{version}-%{release}
-
-%description gtk
-GTK+-based graphical D-BUS frontend utility.
-
-%description gtk -l pl
-Oparte na GTK+ graficzne narzêdzie do D-BUS.
-
-%package X11
-Summary: X11 D-BUS utilities
-Summary(pl): Narzêdzia X11 D-BUSa
-Group: X11/Applications
-Requires: %{name} = %{version}-%{release}
-Requires: xinitrc
-
-%description X11
-X11 D-BUS utilities.
-
-%description X11 -l pl
-Narzêdzia X11 D-BUSa.
-%package -n dotnet-%{name}-sharp
-Summary: .NET library for using D-BUS
-Summary(pl): Biblioteka .NET do u¿ywania D-BUS
-Group: Development/Libraries
-Requires: %{name} = %{version}-%{release}
-Requires: mono
-
-%description -n dotnet-%{name}-sharp
-.NET library for using D-BUS.
-
-%description -n dotnet-%{name}-sharp -l pl
-Biblioteka .NET do u¿ywania D-BUS.
-
-%package -n dotnet-%{name}-sharp-devel
-Summary: .NET library for using D-BUS with API documentation
-Summary(pl): Biblioteka .NET do u¿ywania D-BUS, zawiera dokumentacjê API
-Group: Development/Libraries
-Requires: dotnet-%{name}-sharp = %{version}-%{release}
-Requires: %{name} = %{version}-%{release}
-
-%description -n dotnet-%{name}-sharp-devel
-.NET library for using D-BUS, with API documentation.
-
-%description -n dotnet-%{name}-sharp-devel -l pl
-Biblioteka .NET do u¿ywania D-BUS, zawiera dokumentacjê API.
-
-%package qt
-Summary: Qt-based library for using D-BUS
-Summary(pl): Biblioteka do u¿ywania D-BUS oparta o Qt
-Group: Libraries
-Requires: %{name}-libs = %{version}-%{release}
-
-%description qt
-D-BUS add-on library to integrate the standard D-BUS library with the
-Qt thread abstraction and main loop.
+%description static
+Static D-BUS library.
-%description qt -l pl
-Dodatkowa biblioteka D-BUS do integracji standardowej biblioteki D-BUS
-z abstrakcj± w±tków i g³ówn± pêtl± Qt.
+%description static -l pl.UTF-8
+Statyczna biblioteka D-BUS.
-%package qt-devel
-Summary: Header files for Qt-based library for using D-BUS
-Summary(pl): Pliki nag³ówkowe biblioteki do u¿ywania D-BUS opartej o Qt
-Group: Development/Libraries
+%package apidocs
+Summary: D-BUS API documentation
+Summary(pl.UTF-8): Dokumentacja API D-BUS
+Group: Documentation
+# dbus.devhelp refers also to common docs packaged in -devel
Requires: %{name}-devel = %{version}-%{release}
-Requires: %{name}-qt = %{version}-%{release}
-Requires: kdelibs-devel
-
-%description qt-devel
-Header files for Qt-based library for using D-BUS.
-
-%description qt-devel -l pl
-Pliki nag³ówkowe biblioteki do u¿ywania D-BUS opartej o Qt.
+BuildArch: noarch
-%package qt-static
-Summary: Static Qt-based library for using D-BUS
-Summary(pl): Statyczna biblioteka do u¿ywania D-BUS oparta o Qt
-Group: Development/Libraries
-Requires: %{name}-qt-devel = %{version}-%{release}
-
-%description qt-static
-Static Qt-based library for using D-BUS.
+%description apidocs
+D-BUS API documentation.
-%description qt-static -l pl
-Statyczna biblioteka do u¿ywania D-BUS oparta o Qt.
+%description apidocs -l pl.UTF-8
+Dokumentacja API D-BUS.
-%package gcj
-Summary: Java library for using D-BUS
-Summary(pl): Biblioteka do u¿ywania D-BUS oparta o Javê
-Group: Libraries
+%package x11
+Summary: X11 session support for D-BUS
+Summary(pl.UTF-8): Obsługa sesji X11 dla D-BUS
+Group: X11/Applications
Requires: %{name} = %{version}-%{release}
+Obsoletes: dbus-X11
-%description gcj
-D-BUS add-on library to integrate the standard D-BUS library with
-Java.
-
-%description gcj -l pl
-Dodatkowa biblioteka D-BUS do integracji standardowej biblioteki D-BUS
-z Jav±.
-
-%package gcj-devel
-Summary: Header files for Java-based library for using D-BUS
-Summary(pl): Pliki nag³ówkowe biblioteki do u¿ywania D-BUS opartej o Javê
-Group: Development/Libraries
-Requires: %{name}-gcj = %{version}-%{release}
-
-%description gcj-devel
-Header files for Java-based library for using D-BUS.
-
-%description gcj-devel -l pl
-Pliki nag³ówkowe biblioteki do u¿ywania D-BUS opartej o Javê.
+%description x11
+This package contains D-BUS utilities to start D-BUS service together
+with user X11 session.
-%package gcj-static
-Summary: Static Java-based library for using D-BUS
-Summary(pl): Statyczna biblioteka do u¿ywania D-BUS oparta o Javê
-Group: Development/Libraries
-Requires: %{name}-gcj-devel = %{version}-%{release}
-
-%description gcj-static
-Static Java-based library for using D-BUS.
-
-%description gcj-static -l pl
-Statyczna biblioteka do u¿ywania D-BUS oparta o Javê.
-
-%package -n python-dbus
-Summary: Python library for using D-BUS
-Summary(pl): Biblioteka do u¿ywania D-BUS oparta o Pythona
-Group: Libraries
-Requires: %{name}-libs = %{version}-%{release}
-%pyrequires_eq python
-
-%description -n python-dbus
-D-BUS add-on library to integrate the standard D-BUS library with
-Python.
-
-%description -n python-dbus -l pl
-Dodatkowa biblioteka D-BUS do integracji standardowej biblioteki D-BUS
-z Pythonem.
+%description x11 -l pl.UTF-8
+Ten pakiet zawiera narzędzia D-BUS pozwalające na uruchomienie usługi
+D-BUS wraz z sesją X11 użytkownika.
%prep
%setup -q
%patch0 -p1
%patch1 -p1
%patch2 -p1
-%patch3 -p0
+%patch3 -p1
%patch4 -p1
-sed -i 's:JAR.*=.*jar:JAR=fastjar:g' gcj/Makefile.{am,in}
+
+%{__sed} -i -e '1s,/usr/bin/env python,%{__python},' tools/GetAllMatchRules.py
%build
%{__libtoolize}
-%{__aclocal}
+%{__aclocal} -I m4
%{__autoconf}
%{__autoheader}
%{__automake}
%configure \
- QTDIR=/usr \
- %{!?with_glib:--disable-glib} \
- %{!?with_gtk:--disable-gtk} \
- %{!?with_qt:--disable-qt} \
- %{!?with_python:--disable-python} \
- %{!?with_gcj:--disable-gcj} \
- %{?with_gcj:--enable-gcj} \
- %{!?with_dotnet:--disable-mono} \
- %{!?with_dotnet:--disable-mono-docs} \
+ %{!?with_apparmor:--disable-apparmor} \
+ --disable-asserts \
+ --disable-ducktype-docs \
%{?debug:--enable-verbose-mode} \
+ %{!?with_selinux:--disable-selinux} \
+ --disable-silent-rules \
+ %{!?with_systemd:--disable-systemd} \
--disable-tests \
- --enable-verbose-mode \
- --enable-selinux \
- --disable-asserts \
- --with-xml=expat \
- --enable-abstract-sockets \
+ --enable-user-session \
+ --with-console-auth-dir=%{_localstatedir}/run/console/ \
--with-session-socket-dir=/tmp \
--with-system-pid-file=%{_localstatedir}/run/dbus.pid \
- --with-system-socket=%{_localstatedir}/lib/dbus-1/system_bus_socket \
- --enable-selinux
-%{__make} \
- pythondir=%{py_sitedir}
+ --with-systemdsystemunitdir=%{systemdunitdir} \
+ %{!?with_X11:--without-x}
+%{__make}
%install
rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT/etc/rc.d/init.d
-install -d $RPM_BUILD_ROOT/etc/profile.d
-install -d $RPM_BUILD_ROOT/etc/sysconfig
-install -d $RPM_BUILD_ROOT%{_sysconfdir}/X11/xinit/xinitrc.d
-install -d $RPM_BUILD_ROOT%{_datadir}/dbus-1/services
-install -d $RPM_BUILD_ROOT%{_localstatedir}/lib/dbus-1
-%if %{with dotnet}
-install -d $RPM_BUILD_ROOT%{_libdir}/monodoc/sources
-%endif
+install -d $RPM_BUILD_ROOT%{_sysconfdir}/{profile.d,rc.d/init.d,sysconfig,X11/xinit/xinitrc.d} \
+ $RPM_BUILD_ROOT%{_datadir}/dbus-1/{services,interfaces} \
+ $RPM_BUILD_ROOT%{_localstatedir}/run/dbus \
+ $RPM_BUILD_ROOT%{_localstatedir}/lib/dbus \
+ $RPM_BUILD_ROOT/%{_lib} \
+ $RPM_BUILD_ROOT%{systemdtmpfilesdir}
%{__make} install \
- DESTDIR=$RPM_BUILD_ROOT \
- pythondir=%{py_sitedir}
+ DESTDIR=$RPM_BUILD_ROOT
+
+install -p %{SOURCE1} $RPM_BUILD_ROOT/etc/rc.d/init.d/messagebus
+install -p %{SOURCE2} $RPM_BUILD_ROOT/etc/profile.d/dbus-daemon-1.sh
+cp -p %{SOURCE3} $RPM_BUILD_ROOT/etc/sysconfig/messagebus
+install -p %{SOURCE4} $RPM_BUILD_ROOT/etc/X11/xinit/xinitrc.d
+
+cp -p %{SOURCE5} $RPM_BUILD_ROOT%{systemdtmpfilesdir}/%{name}.conf
-install %{SOURCE1} $RPM_BUILD_ROOT/etc/rc.d/init.d/messagebus
-install %{SOURCE2} $RPM_BUILD_ROOT/etc/profile.d/dbus-daemon-1.sh
-install %{SOURCE3} $RPM_BUILD_ROOT/etc/sysconfig/dbus
-install %{SOURCE4} $RPM_BUILD_ROOT%{_sysconfdir}/X11/xinit/xinitrc.d/dbus.sh
+%if %{with systemd}
+ln -s dbus.service $RPM_BUILD_ROOT%{systemdunitdir}/messagebus.service
-%if %{with python}
-rm -f $RPM_BUILD_ROOT%{py_sitedir}/%{name}/*.{py,la,a}
+# we are creating messagebus user from rpm pre
+%{__rm} $RPM_BUILD_ROOT/usr/lib/sysusers.d/dbus.conf
%endif
+# for local configuration in dbus 1.10+
+install -d $RPM_BUILD_ROOT/etc/dbus-1/{session.d,system.d}
+
%clean
rm -rf $RPM_BUILD_ROOT
%pre
%groupadd -g 122 messagebus
-%useradd -u 122 -d /usr/share/empty -s /bin/false -c "System message bus" -g messagebus messagebus
+%useradd -u 122 -d /usr/share/empty -s /bin/false -c "System message bus" -g 122 messagebus
%post
/sbin/chkconfig --add messagebus
-if [ -f /var/lock/subsys/messagebus ]; then
- /etc/rc.d/init.d/messagebus restart >&2
-else
- echo "Run \"/etc/rc.d/init.d/messagebus start\" to start D-Bus daemon."
-fi
+%service -n messagebus restart "D-Bus daemon"
+export NORESTART="yes"
+%systemd_post messagebus.service
+%systemd_user_post dbus.service dbus.socket
%preun
if [ "$1" = "0" ];then
- if [ -f /var/lock/subsys/messagebus ]; then
- /etc/rc.d/init.d/messagebus stop >&2
- fi
+ %service messagebus stop
/sbin/chkconfig --del messagebus
fi
+%systemd_user_preun dbus.service dbus.socket
%postun
if [ "$1" = "0" ]; then
%userremove messagebus
%groupremove messagebus
fi
+%systemd_reload
+
+%triggerpostun -- dbus < 1.4.16-5
+%systemd_trigger messagebus.service
+if [ -f /etc/sysconfig/dbus ]; then
+ mv -f /etc/sysconfig/messagebus{,.rpmnew}
+ mv -f /etc/sysconfig/{dbus,messagebus}
+elif [ -f /etc/sysconfig/dbus.rpmsave ]; then
+ mv -f /etc/sysconfig/messagebus{,.rpmnew}
+ mv -f /etc/sysconfig/{dbus.rpmsave,messagebus}
+fi
%post libs -p /sbin/ldconfig
%postun libs -p /sbin/ldconfig
-%post glib -p /sbin/ldconfig
-%postun glib -p /sbin/ldconfig
-
-%post qt -p /sbin/ldconfig
-%postun qt -p /sbin/ldconfig
-
-%post gcj -p /sbin/ldconfig
-%postun gcj -p /sbin/ldconfig
-
%files
%defattr(644,root,root,755)
%attr(755,root,root) %{_bindir}/dbus-cleanup-sockets
%attr(755,root,root) %{_bindir}/dbus-daemon
+%attr(755,root,root) %{_bindir}/dbus-uuidgen
+%attr(755,root,root) %{_bindir}/dbus-monitor
+%attr(755,root,root) %{_bindir}/dbus-run-session
%attr(755,root,root) %{_bindir}/dbus-send
-%dir %{_sysconfdir}/dbus-1
-%config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/dbus-1/*.conf
-%config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/dbus
-%attr(754,root,root) /etc/rc.d/init.d/*
+%attr(755,root,root) %{_bindir}/dbus-test-tool
+%attr(755,root,root) %{_bindir}/dbus-update-activation-environment
+%attr(4754,root,messagebus) %{_libexecdir}/dbus-daemon-launch-helper
+%{_datadir}/dbus-1/session.conf
+%{_datadir}/dbus-1/system.conf
+%{_datadir}/xml/dbus-1
+%config(noreplace) %verify(not md5 mtime size) /etc/dbus-1/session.conf
+%config(noreplace) %verify(not md5 mtime size) /etc/dbus-1/system.conf
+%config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/messagebus
+%attr(754,root,root) /etc/rc.d/init.d/messagebus
%attr(755,root,root) /etc/profile.d/dbus-daemon-1.sh
-%dir %{_sysconfdir}/dbus-1/system.d
-%dir %{_datadir}/dbus-1
-%dir %{_datadir}/dbus-1/services
-%dir %{_localstatedir}/lib/dbus-1
+%{systemdtmpfilesdir}/%{name}.conf
+%dir %{_localstatedir}/lib/dbus
+%dir %{_localstatedir}/run/dbus
%{_mandir}/man1/dbus-cleanup-sockets.1*
%{_mandir}/man1/dbus-daemon.1*
+%{_mandir}/man1/dbus-uuidgen.1*
+%{_mandir}/man1/dbus-monitor.1*
+%{_mandir}/man1/dbus-run-session.1*
%{_mandir}/man1/dbus-send.1*
+%{_mandir}/man1/dbus-test-tool.1*
+%{_mandir}/man1/dbus-update-activation-environment.1*
+
+%if %{with systemd}
+%{systemdunitdir}/dbus.service
+%{systemdunitdir}/dbus.socket
+%{systemdunitdir}/messagebus.service
+%{systemdunitdir}/multi-user.target.wants/dbus.service
+%{systemdunitdir}/sockets.target.wants/dbus.socket
+%{systemduserunitdir}/dbus.service
+%{systemduserunitdir}/dbus.socket
+%{systemduserunitdir}/sockets.target.wants/dbus.socket
+%endif
%files libs
%defattr(644,root,root,755)
%doc AUTHORS COPYING ChangeLog NEWS README doc/TODO
%attr(755,root,root) %{_libdir}/libdbus-1.so.*.*.*
-%dir %{_libdir}/dbus-*
+%attr(755,root,root) %ghost %{_libdir}/libdbus-1.so.3
+%dir %{_datadir}/dbus-1
+%dir %{_datadir}/dbus-1/session.d
+%dir %{_datadir}/dbus-1/system.d
+# interfaces is basically devel thing, but keep dir here
+# in case something uses it at runtime
+%dir %{_datadir}/dbus-1/interfaces
+%dir %{_datadir}/dbus-1/services
+%dir %{_datadir}/dbus-1/system-services
+# TODO: now it's only for local configuration - move to base dbus package
+# after all packages place constant configuration in %{_datadir}/dbus-1
+%dir /etc/dbus-1
+%dir /etc/dbus-1/session.d
+%dir /etc/dbus-1/system.d
%files devel
%defattr(644,root,root,755)
-%doc doc/*.{html,txt}
%attr(755,root,root) %{_libdir}/libdbus-1.so
%{_libdir}/libdbus-1.la
-%{_libdir}/dbus-*/include
+%dir %{_libdir}/dbus-1.0
+%{_libdir}/dbus-1.0/include
+%{_libdir}/cmake/DBus1
+%{_includedir}/dbus-1.0
%{_pkgconfigdir}/dbus-1.pc
-%{_includedir}/dbus*
-%{?with_glib:%exclude %{_includedir}/dbus*/dbus/dbus-glib*.h}
-%{?with_qt:%exclude %{_includedir}/dbus*/dbus/dbus-qt.h}
+%dir %{_docdir}/dbus
+%{_docdir}/dbus/*.html
+%{_docdir}/dbus/*.png
+%{_docdir}/dbus/*.svg
+%{_docdir}/dbus/*.txt
%files static
%defattr(644,root,root,755)
%{_libdir}/libdbus-1.a
-%if %{with glib}
-%files glib
-%defattr(644,root,root,755)
-%attr(755,root,root) %{_libdir}/libdbus-glib-1.so.*.*.*
-
-%files glib-devel
-%defattr(644,root,root,755)
-%attr(755,root,root) %{_bindir}/dbus-binding-tool
-%attr(755,root,root) %{_libdir}/libdbus-glib-1.so
-%{_libdir}/libdbus-glib-1.la
-%{_includedir}/dbus*/dbus/dbus-glib*.h
-%{_pkgconfigdir}/dbus-glib-1.pc
-
-%files glib-static
-%defattr(644,root,root,755)
-%{_libdir}/libdbus-glib-1.a
-
-%files glib-tools
-%defattr(644,root,root,755)
-%attr(755,root,root) %{_bindir}/dbus-monitor
-%{_mandir}/man1/dbus-monitor.1*
-%endif
-
-%if %{with gtk}
-%files gtk
+%files apidocs
%defattr(644,root,root,755)
-%attr(755,root,root) %{_bindir}/dbus-viewer
-%endif
+%{_docdir}/dbus/api
+%{_docdir}/dbus/dbus.devhelp2
-%files X11
+%files x11
%defattr(644,root,root,755)
%attr(755,root,root) %{_bindir}/dbus-launch
-%attr(755,root,root) %{_sysconfdir}/X11/xinit/xinitrc.d/dbus.sh
%{_mandir}/man1/dbus-launch.1*
-
-%if %{with dotnet}
-%files -n dotnet-%{name}-sharp
-%defattr(644,root,root,755)
-%dir %{_libdir}/mono/gac/dbus-sharp
-%{_libdir}/mono/gac/dbus-sharp/*
-
-%files -n dotnet-%{name}-sharp-devel
-%defattr(644,root,root,755)
-%{_libdir}/monodoc/sources/*
-%dir %{_libdir}/mono/dbus-sharp
-%{_libdir}/mono/dbus-sharp/*
-%{_pkgconfigdir}/dbus-sharp.pc
-%endif
-
-%if %{with qt}
-%files qt
-%defattr(644,root,root,755)
-%attr(755,root,root) %{_libdir}/libdbus-qt-1.so.*.*.*
-
-%files qt-devel
-%defattr(644,root,root,755)
-%attr(755,root,root) %{_libdir}/libdbus-qt-1.so
-%{_libdir}/libdbus-qt-1.la
-%{_includedir}/dbus*/dbus/dbus-qt.h
-
-%files qt-static
-%defattr(644,root,root,755)
-%{_libdir}/libdbus-qt-1.a
-%endif
-
-%if %{with gcj}
-%files gcj
-%defattr(644,root,root,755)
-%attr(755,root,root) %{_libdir}/lib*gcj*.so.*.*.*
-
-%files gcj-devel
-%defattr(644,root,root,755)
-%attr(755,root,root) %{_libdir}/lib*gcj*.so
-%{_libdir}/lib*gcj*.la
-%{_datadir}/java/*.jar
-
-%files gcj-static
-%defattr(644,root,root,755)
-%{_libdir}/lib*gcj*.a
-%endif
-
-%if %{with python}
-%files -n python-dbus
-%defattr(644,root,root,755)
-%dir %{py_sitedir}/%{name}/
-%attr(755,root,root) %{py_sitedir}/%{name}/*.so
-%{py_sitedir}/dbus.pth
-%{py_sitedir}/%{name}/*.py[co]
-%endif
+%attr(755,root,root) /etc/X11/xinit/xinitrc.d/dbus-xinitrc.sh