1 %define dbus_user_uid 81
4 Url: http://dbus.freedesktop.org/
5 Summary: D-Bus Message Bus System
6 License: GPL-2.0+ or AFL-2.1
10 # We can't enable this right now, because it will create a build cycle between
11 # dbus-1 and systemd. Fun!
12 %define with_systemd 1
14 BuildRequires: doxygen
15 BuildRequires: expat-devel
16 BuildRequires: libtool
17 BuildRequires: libxslt-tools
19 BuildRequires: pkg-config
22 BuildRequires: pkgconfig(libsystemd-daemon)
23 BuildRequires: pkgconfig(libsystemd-login)
27 Source0: http://dbus.freedesktop.org/releases/dbus/dbus-%{version}.tar.gz
29 Source3: dbus_at_console.ck
30 Source4: baselibs.conf
31 Source5: dbus-user.service
32 Source6: dbus-user.socket
33 BuildRequires: libcap-ng-devel
35 Requires(pre): /usr/sbin/groupadd /usr/sbin/useradd
40 Summary: Library package for D-Bus
45 Summary: Developer package for D-Bus
46 Group: Development/Libraries
47 Requires: libdbus = %{version}
53 Summary: Developer documentation package for D-Bus
55 Requires: %{name} = %{version}
59 D-Bus is a message bus system, a simple way for applications to talk to
60 one another. D-Bus supplies both a system daemon and a
61 per-user-login-session daemon. Also, the message bus is built on top of
62 a general one-to-one message passing framework, which can be used by
63 any two apps to communicate directly (without going through the message
66 %description -n libdbus
67 D-Bus is a message bus system, a simple way for applications to talk to
68 one another. D-Bus supplies both a system daemon and a
69 per-user-login-session daemon. Also, the message bus is built on top of
70 a general one-to-one message passing framework, which can be used by
71 any two apps to communicate directly (without going through the message
75 D-Bus is a message bus system, a simple way for applications to talk to
76 one another. D-Bus supplies both a system daemon and a
77 per-user-login-session daemon. Also, the message bus is built on top of
78 a general one-to-one message passing framework, which can be used by
79 any two apps to communicate directly (without going through the message
82 %description devel-doc
83 D-Bus is a message bus system, a simple way for applications to talk to
84 one another. D-BUS supplies both a system daemon and a
85 per-user-login-session daemon. Also, the message bus is built on top of
86 a general one-to-one message passing framework, which can be used by
87 any two apps to communicate directly (without going through the message
92 %setup -n dbus-%{version} -q
96 # We use -fpie/-pie for the whole build; this is the recommended way to harden
97 # the build upstream, see discussion in fdo#46570
98 export CFLAGS="${RPM_OPT_FLAGS} -fno-strict-aliasing -fPIC -fpie"
100 export CXXFLAGS="${RPM_OPT_FLAGS} -fno-strict-aliasing"
101 export CFLAGS="$CFLAGS -fstack-protector"
102 export CXXFLAGS="$CXXFLAGS -fstack-protector"
107 --with-dbus-user=dbus \
108 --libexecdir=%{_libdir}/%{name} \
109 --libdir=%{_libdir} \
110 --with-init-scripts=suse \
112 --enable-doxygen-docs \
116 --with-console-auth-dir=/var/run/dbus/at_console/ \
117 --with-systemdsystemunitdir=%{_unitdir}
122 make DESTDIR=%{buildroot} install
123 mkdir -p %{buildroot}/usr/sbin
124 install -d %{buildroot}/%{_localstatedir}/run/dbus
125 mkdir -p %{buildroot}/%{_libdir}/pkgconfig
126 mkdir -p %{buildroot}/lib/dbus-1/system-services
127 mkdir -p %{buildroot}/%{_datadir}/dbus-1/system-services
128 mkdir -p %{buildroot}/%{_datadir}/dbus-1/interfaces
129 rm -f %{buildroot}/%{_libdir}/*.la
131 rm -f %{buildroot}/%{_bindir}/dbus-launch
132 rm -f %{buildroot}/%{_mandir}/man1/dbus-launch.1*
133 chmod a-x AUTHORS COPYING HACKING NEWS README doc/*.txt doc/file-boilerplate.c doc/TODO
135 install -d %{buildroot}%{_sysconfdir}/ConsoleKit/run-session.d
136 install -m 755 %{SOURCE3} %{buildroot}%{_sysconfdir}/ConsoleKit/run-session.d
137 mkdir -p %{buildroot}%{_localstatedir}/lib/dbus
138 touch %{buildroot}/%{_localstatedir}/lib/dbus/machine-id
140 mkdir -p %{buildroot}%{_unitdir_user}
141 install -m0644 %{SOURCE5} %{buildroot}%{_unitdir_user}/dbus.service
142 install -m0644 %{SOURCE6} %{buildroot}%{_unitdir_user}/dbus.socket
146 # Add the "dbus" user and group
147 /usr/sbin/groupadd -r -g %{dbus_user_uid} dbus 2>/dev/null || :
148 /usr/sbin/useradd -c 'System message bus' -u %{dbus_user_uid} -g %{dbus_user_uid} \
149 -s /sbin/nologin -r -d '/' dbus 2> /dev/null || :
151 %post -n libdbus -p /sbin/ldconfig
153 %postun -n libdbus -p /sbin/ldconfig
158 %defattr(-, root, root)
159 %dir %{_localstatedir}/lib/dbus
161 %dir /lib/dbus-1/system-services
163 %config(noreplace) %{_sysconfdir}/dbus-1/session.conf
164 %config(noreplace) %{_sysconfdir}/dbus-1/system.conf
165 %{_sysconfdir}/ConsoleKit
166 %{_bindir}/dbus-cleanup-sockets
167 %{_bindir}/dbus-daemon
168 %{_bindir}/dbus-monitor
170 %{_bindir}/dbus-uuidgen
171 # See doc/system-activation.txt in source tarball for the rationale
172 # behind these permissions
173 %attr(4750,root,dbus) %verify(not mode) %{_libdir}/dbus/dbus-daemon-launch-helper
174 %ghost %{_localstatedir}/run/dbus
175 %ghost %{_localstatedir}/lib/dbus/machine-id
177 %{_unitdir}/dbus.service
178 %{_unitdir}/dbus.socket
179 %{_unitdir_user}/dbus.service
180 %{_unitdir_user}/dbus.socket
181 %dir %{_unitdir}/dbus.target.wants
182 %{_unitdir}/dbus.target.wants/dbus.socket
183 %dir %{_unitdir}/multi-user.target.wants
184 %{_unitdir}/multi-user.target.wants/dbus.service
185 %dir %{_unitdir}/sockets.target.wants
186 %{_unitdir}/sockets.target.wants/dbus.socket
189 %defattr(-, root, root)
190 %{_libdir}/libdbus-1.so.*
191 # Own those directories in the library instead of dbus-1, since dbus users
192 # often ship files there
193 %dir %{_sysconfdir}/dbus-1
194 %dir %{_sysconfdir}/dbus-1/session.d
195 %dir %{_sysconfdir}/dbus-1/system.d
196 %dir %{_datadir}/dbus-1
197 %dir %{_datadir}/dbus-1/interfaces
198 %dir %{_datadir}/dbus-1/services
199 %dir %{_datadir}/dbus-1/system-services
202 %defattr(-,root,root)
204 %{_libdir}/libdbus-1.so
205 %dir %{_libdir}/dbus-1.0
206 %{_libdir}/dbus-1.0/include
207 %{_libdir}/pkgconfig/dbus-1.pc
210 %defattr(-,root,root)
211 %dir %{_datadir}/doc/dbus
212 %{_datadir}/doc/dbus/api/
213 %doc %{_datadir}/doc/dbus/dbus-faq.html
214 %doc %{_datadir}/doc/dbus/dbus-specification.html
215 %doc %{_datadir}/doc/dbus/dbus-test-plan.html
216 %doc %{_datadir}/doc/dbus/dbus-tutorial.html
217 %doc %{_datadir}/doc/dbus/dbus.devhelp
218 %doc %{_datadir}/doc/dbus/diagram.*
219 %doc %{_datadir}/doc/dbus/system-activation.txt
220 %doc doc/*.txt doc/file-boilerplate.c doc/TODO