X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=dbus.spec;h=d66221af0979d310d62d8636e02b897a27e857d0;hb=9d99a896f01232b2b634ed9afa8e384aee8dbec8;hp=6256478d13a72cec290f59b10e75ddbe6499b029;hpb=c4e0c6b7221ad59f5739bf71735047bead987537;p=packages%2Fdbus.git diff --git a/dbus.spec b/dbus.spec index 6256478..d66221a 100644 --- a/dbus.spec +++ b/dbus.spec @@ -1,34 +1,43 @@ +# +# Conditional build: +%bcond_without selinux # build without SELinux support +%bcond_without X11 # build without X11 support + %define expat_version 1:1.95.5 Summary: D-BUS message bus Summary(pl.UTF-8): Magistrala przesyłania komunikatów D-BUS Name: dbus -Version: 1.1.3 -Release: 1 +Version: 1.4.20 +Release: 2 License: AFL v2.1 or GPL v2 Group: Libraries Source0: http://dbus.freedesktop.org/releases/dbus/%{name}-%{version}.tar.gz -# Source0-md5: 2e0185e1f8b4c61c9248049c680d2ab6 +# Source0-md5: 79eca2f2c1894ac347acce128314428b Source1: messagebus.init Source2: %{name}-daemon-1-profile.d-sh Source3: %{name}-sysconfig Source4: %{name}-xinitrc.sh +Source5: messagebus.upstart +Source6: %{name}.tmpfiles Patch0: %{name}-nolibs.patch Patch1: %{name}-config.patch Patch2: %{name}-no_fatal_checks.patch +Patch3: %{name}-allow-introspection.patch URL: http://www.freedesktop.org/Software/dbus BuildRequires: audit-libs-devel -BuildRequires: autoconf >= 2.52 -BuildRequires: automake +BuildRequires: autoconf >= 2.63 +BuildRequires: automake >= 1:1.10 BuildRequires: doxygen BuildRequires: expat-devel >= %{expat_version} -BuildRequires: libcap-devel -BuildRequires: libselinux-devel -BuildRequires: libtool +BuildRequires: libcap-ng-devel +%{?with_selinux:BuildRequires: libselinux-devel} +BuildRequires: libtool >= 2:2.0 +BuildRequires: libxslt-progs BuildRequires: pkgconfig -BuildRequires: rpmbuild(macros) >= 1.268 +BuildRequires: rpmbuild(macros) >= 1.626 BuildRequires: sed >= 4.0 BuildRequires: xmlto -BuildRequires: xorg-lib-libX11-devel +%{?with_X11:BuildRequires: xorg-lib-libX11-devel} Requires(post,postun): /sbin/ldconfig Requires(post,preun): /sbin/chkconfig Requires(postun): /usr/sbin/groupdel @@ -37,14 +46,17 @@ Requires(pre): /bin/id Requires(pre): /usr/bin/getgid Requires(pre): /usr/sbin/groupadd Requires(pre): /usr/sbin/useradd +Requires(post,preun,postun): systemd-units >= 38 +Requires: %{name}-dirs = %{version}-%{release} Requires: %{name}-libs = %{version}-%{release} Requires: expat >= %{expat_version} -Requires: rc-scripts +Requires: rc-scripts >= 0.4.3.0 +Requires: systemd-units >= 38 Provides: group(messagebus) Provides: user(messagebus) -Conflicts: pam < 0.99.7.1 -Obsoletes: dbus-X11 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) @@ -59,81 +71,136 @@ 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 upstart +Summary: Upstart job description for system message bus +Summary(pl.UTF-8): Opis zadania Upstart dla magistrali systemowej DBus +Group: Daemons +Requires: %{name} = %{version}-%{release} +Requires: upstart >= 0.6 + +%description upstart +Upstart job description for system message bus. + +%description upstart -l pl.UTF-8 +Opis zadania Upstart dla magistrali systemowej DBus. + +%package dirs +Summary: D-BUS directories +Summary(pl.UTF-8): Katalogi D-BUS +Group: Libraries + +%description dirs +D-BUS directories. + +%description dirs -l pl.UTF-8 +Katalogi D-BUS. + %package libs -Summary: D-BUS libraries -Summary(pl.UTF-8): Biblioteki D-BUS +Summary: D-BUS library +Summary(pl.UTF-8): Biblioteka D-BUS Group: Libraries %description libs -D-BUS libraries. +D-BUS library. %description libs -l pl.UTF-8 -Biblioteki D-BUS. +Biblioteka D-BUS. %package devel -Summary: Header files for D-BUS -Summary(pl.UTF-8): Pliki nagłówkowe D-BUS +Summary: Header files for D-BUS library +Summary(pl.UTF-8): Pliki nagłówkowe biblioteki D-BUS Group: Development/Libraries Requires: %{name}-libs = %{version}-%{release} %description devel -Header files for D-BUS. +Header files for D-BUS library. %description devel -l pl.UTF-8 -Pliki nagłówkowe D-BUS. +Pliki nagłówkowe biblioteki D-BUS. %package static -Summary: Static D-BUS libraries -Summary(pl.UTF-8): Statyczne biblioteki D-BUS +Summary: Static D-BUS library +Summary(pl.UTF-8): Statyczna biblioteka D-BUS Group: Development/Libraries Requires: %{name}-devel = %{version}-%{release} %description static -Static D-BUS libraries. +Static D-BUS library. %description static -l pl.UTF-8 -Statyczne biblioteki D-BUS. +Statyczna biblioteka D-BUS. + +%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 x11 +This package contains D-BUS utilities to start D-BUS service together +with user X11 session. + +%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 -p1 %build %{__libtoolize} -%{__aclocal} +%{__aclocal} -I m4 %{__autoconf} %{__autoheader} %{__automake} %configure \ %{?debug:--enable-verbose-mode} \ --disable-asserts \ + --disable-silent-rules \ --disable-tests \ - --enable-abstract-sockets \ - --enable-selinux \ + --enable-abstract-sockets=auto \ + %{?with_selinux:--enable-selinux} \ --with-console-auth-dir=%{_localstatedir}/run/console/ \ --with-session-socket-dir=/tmp \ --with-system-pid-file=%{_localstatedir}/run/dbus.pid \ - --with-xml=expat + --with-xml=expat \ + --with-systemdsystemunitdir=%{systemdunitdir} \ + %{!?with_X11:--without-x} %{__make} %install rm -rf $RPM_BUILD_ROOT -install -d $RPM_BUILD_ROOT/etc/profile.d -install -d $RPM_BUILD_ROOT/etc/rc.d/init.d -install -d $RPM_BUILD_ROOT/etc/sysconfig -install -d $RPM_BUILD_ROOT/etc/X11/xinit/xinitrc.d -install -d $RPM_BUILD_ROOT%{_datadir}/dbus-1/{services,interfaces} -install -d $RPM_BUILD_ROOT%{_localstatedir}/run/dbus +install -d $RPM_BUILD_ROOT/etc/{init,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/usr/lib/tmpfiles.d %{__make} install \ DESTDIR=$RPM_BUILD_ROOT -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/messagebus -install %{SOURCE4} $RPM_BUILD_ROOT/etc/X11/xinit/xinitrc.d +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/etc/init/messagebus.conf + +install %{SOURCE6} $RPM_BUILD_ROOT/usr/lib/tmpfiles.d/%{name}.conf + +# upstart (/sbin/init) requires libdbus so it must be in /lib(64) +mv -f $RPM_BUILD_ROOT%{_libdir}/libdbus-1.so.* $RPM_BUILD_ROOT/%{_lib} +ln -sf /%{_lib}/$(basename $RPM_BUILD_ROOT/%{_lib}/libdbus-1.so.*.*.*) \ + $RPM_BUILD_ROOT%{_libdir}/libdbus-1.so + +ln -s dbus.service $RPM_BUILD_ROOT%{systemdunitdir}/messagebus.service + +%{__rm} -rf $RPM_BUILD_ROOT%{_docdir}/dbus/api %clean rm -rf $RPM_BUILD_ROOT @@ -145,6 +212,8 @@ rm -rf $RPM_BUILD_ROOT %post /sbin/chkconfig --add messagebus %service messagebus restart "D-Bus daemon" +export NORESTART="yes" +%systemd_post messagebus.service %preun if [ "$1" = "0" ];then @@ -157,16 +226,10 @@ if [ "$1" = "0" ]; then %userremove messagebus %groupremove messagebus fi +%systemd_reload -%post libs -p /sbin/ldconfig -%postun libs -p /sbin/ldconfig - -%triggerpostun -- %{name} < 0.92 -%banner %{name} << EOF -WARNING!!! -configuration file /etc/sysconfig/dbus has been moved to /etc/sysconfig/messagebus! -EOF - +%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} @@ -175,43 +238,66 @@ elif [ -f /etc/sysconfig/dbus.rpmsave ]; then mv -f /etc/sysconfig/{dbus.rpmsave,messagebus} fi +%if 0 +%post upstart +%upstart_post messagebus + +%postun upstart +%upstart_postun messagebus +%endif + +%post libs -p /sbin/ldconfig +%postun libs -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 -# R: libX11 -%attr(755,root,root) %{_bindir}/dbus-launch %attr(755,root,root) %{_bindir}/dbus-monitor %attr(755,root,root) %{_bindir}/dbus-send %attr(4754,root,messagebus) %{_libdir}/dbus-daemon-launch-helper -%dir %{_libdir}/dbus-1 %dir %{_datadir}/dbus-1 %dir %{_datadir}/dbus-1/interfaces %dir %{_datadir}/dbus-1/services %dir %{_datadir}/dbus-1/system-services -%dir %{_sysconfdir}/dbus-1 -%config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/dbus-1/*.conf -%dir %{_sysconfdir}/dbus-1/system.d -%dir %{_sysconfdir}/dbus-1/session.d +%config(noreplace) %verify(not md5 mtime size) /etc/dbus-1/*.conf %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/messagebus -%attr(754,root,root) /etc/rc.d/init.d/* +%attr(754,root,root) /etc/rc.d/init.d/messagebus %attr(755,root,root) /etc/profile.d/dbus-daemon-1.sh -%attr(755,root,root) /etc/X11/xinit/xinitrc.d/*.sh +/usr/lib/tmpfiles.d/%{name}.conf +%dir %{_localstatedir}/lib/dbus %dir %{_localstatedir}/run/dbus -%dir /var/lib/dbus %{_mandir}/man1/dbus-cleanup-sockets.1* %{_mandir}/man1/dbus-daemon.1* %{_mandir}/man1/dbus-uuidgen.1* -%{_mandir}/man1/dbus-launch.1* %{_mandir}/man1/dbus-monitor.1* %{_mandir}/man1/dbus-send.1* +%{systemdunitdir}/dbus.service +%{systemdunitdir}/dbus.socket +%{systemdunitdir}/dbus.target.wants/dbus.socket +%{systemdunitdir}/messagebus.service +%{systemdunitdir}/multi-user.target.wants/dbus.service +%{systemdunitdir}/sockets.target.wants/dbus.socket + +%if "%{pld_release}" != "ti" +%files upstart +%defattr(644,root,root,755) +%config(noreplace) %verify(not md5 mtime size) /etc/init/messagebus.conf +%endif + +%files dirs +%defattr(644,root,root,755) +%dir /etc/dbus-1 +%dir /etc/dbus-1/system.d +%dir /etc/dbus-1/session.d + %files libs %defattr(644,root,root,755) %doc AUTHORS COPYING ChangeLog NEWS README doc/TODO -%attr(755,root,root) %{_libdir}/libdbus-1.so.*.*.* -%attr(755,root,root) %ghost %{_libdir}/libdbus-1.so.3 +%attr(755,root,root) /%{_lib}/libdbus-1.so.*.*.* +%attr(755,root,root) %ghost /%{_lib}/libdbus-1.so.3 %files devel %defattr(644,root,root,755) @@ -220,9 +306,15 @@ fi %{_libdir}/libdbus-1.la %dir %{_libdir}/dbus-1.0 %{_libdir}/dbus-1.0/include -%{_pkgconfigdir}/dbus-1.pc %{_includedir}/dbus-1.0 +%{_pkgconfigdir}/dbus-1.pc %files static %defattr(644,root,root,755) %{_libdir}/libdbus-1.a + +%files x11 +%defattr(644,root,root,755) +%attr(755,root,root) %{_bindir}/dbus-launch +%{_mandir}/man1/dbus-launch.1* +%attr(755,root,root) /etc/X11/xinit/xinitrc.d/dbus-xinitrc.sh