spec: Change useradd/groupadd to handle in security-manager.
[platform/upstream/dbus.git] / NEWS
1 D-Bus 1.10.6 (2015-12-01)
2 ==
3
4 The “marzipan beetles” release.
5
6 Fixes:
7
8 • On Unix when running tests as root, don't assert that root and
9   the dbus-daemon user can still call UpdateActivationEnvironment;
10   assert that those privileged users can call BecomeMonitor instead
11   (fd.o #93036, Simon McVittie)
12
13 • On Windows, fix a memory leak in the autolaunch transport (fd.o #92899,
14   Simon McVittie)
15
16 • On Windows Autotools builds, don't run tests that rely on
17   dbus-run-session and other Unix-specifics (fd.o #92899, Simon McVittie)
18
19 D-Bus 1.10.4 (2015-11-17)
20 ==
21
22 The “Frostburn Canyon” release.
23
24 Enhancements:
25
26 • GetConnectionCredentials, GetConnectionUnixUser and
27   GetConnectionUnixProcessID with argument "org.freedesktop.DBus"
28   will now return details of the dbus-daemon itself. This is required
29   to be able to call SetEnvironment on systemd.
30   (fd.o #92857, Jan Alexander Steffens)
31
32 Fixes:
33
34 • Make UpdateActivationEnvironment always fail with AccessDenied on the
35   system bus. Previously, it was possible to configure it so root could
36   call it, but the environment variables were not actually used,
37   because the launch helper would discard them.
38   (fd.o #92857, Jan Alexander Steffens)
39
40 • On Unix with --systemd-activation on a user bus, make
41   UpdateActivationEnvironment pass on its arguments to systemd's
42   SetEnvironment method, solving inconsistency between the environments
43   used for traditional activation and systemd user-service activation.
44   (fd.o #92857, Jan Alexander Steffens)
45
46 • On Windows, don't crash if <syslog/> or --syslog is used
47   (fd.o #92538, Ralf Habacker)
48
49 • On Windows, fix a memory leak when setting a DBusError from a Windows
50   error (fd.o #92721, Ralf Habacker)
51
52 • On Windows, don't go into infinite recursion if we abort the process
53   with backtraces enabled (fd.o #92721, Ralf Habacker)
54
55 • Fix various failing tests, variously on Windows and cross-platform:
56   · don't test system.conf features (users, groups) that only make sense
57     on the system bus, which is not supported on Windows
58   · don't call _dbus_warn() when we skip a test, since it is fatal
59   · fix computation of expected <standard_session_servicedirs/>
60   · when running TAP tests, translate newlines to Unix format, fixing
61     cross-compiled tests under Wine on Linux
62   · don't stress-test refcounting under Wine, where it's really slow
63   · stop assuming that a message looped-back to the test will be received
64     immediately
65   · skip some system bus tests on Windows since they make no sense there
66   (fd.o #92538, fd.o #92721; Ralf Habacker, Simon McVittie)
67
68 D-Bus 1.10.2 (2015-10-26)
69 ==
70
71 The “worst pies in London” release.
72
73 Fixes:
74
75 • Correct error handling for activation: if there are multiple attempts
76   to activate the same service and it fails immediately, the first attempt
77   would get the correct reply, but the rest would time out. We now send
78   the same error reply to each attempt. (fd.o #92200, Simon McVittie)
79
80 • If BecomeMonitor is called with a syntactically invalid match rule,
81   don't crash with an assertion failure, fixing a regression in 1.9.10.
82   This was not exploitable as a denial of service, because the check
83   for a privileged user is done first. (fd.o #92298, Simon McVittie)
84
85 • On Linux with --enable-user-session, add the bus address to the
86   environment of systemd services for better backwards compatibility
87   (fd.o #92612, Jan Alexander Steffens)
88
89 • On Windows, fix the logic for replacing the installation prefix
90   in service files' Exec lines (fd.o #83539; Milan Crha, Simon McVittie)
91
92 • On Windows, if installed in the conventional layout with ${prefix}/etc
93   and ${prefix}/share, use relative paths between bus configuration files
94   to allow the tree to be relocated (fd.o #92028, Simon McVittie)
95
96 • Make more of the regression tests pass in Windows builds (fd.o #92538,
97   Simon McVittie)
98
99 D-Bus 1.10.0 (2015-08-25)
100 ==
101
102 The “0x20” release.
103
104 This is a new stable branch, recommended for use in OS distributions.
105
106 Fixes since 1.9.20:
107
108 • distribute test/tap-test.sh.in, even if the tarball was built without
109   tests enabled (fd.o #91684, Simon McVittie)
110 • work around a fd leak in libcap-ng < 0.7.7 (fd.o #91684, Simon McVittie)
111
112 Summary of major changes since 1.8.0:
113
114 • The basic setup for the well-known system and session buses is
115   now done in read-only files in ${datadir} (normally /usr/share).
116   See the NEWS entry for 1.9.18 for details.
117
118 • AppArmor integration has been merged, with features similar to the
119   pre-existing SELinux integration. It is mostly compatible with the
120   patches previously shipped by Ubuntu, with one significant change:
121   Ubuntu's GetConnectionAppArmorSecurityContext method has been superseded
122   by GetConnectionCredentials and was not included.
123
124 • The --enable-user-session configure option can be enabled
125   by OS integrators intending to use systemd to provide a session bus
126   per user (in effect, treating all concurrent graphical and non-graphical
127   login sessions as one large session).
128
129 • The new listenable address mode "unix:runtime=yes" listens on
130   $XDG_RUNTIME_DIR/bus, the same AF_UNIX socket used by the systemd
131   user session. libdbus and "dbus-launch --autolaunch" will connect to
132   this address by default. GLib ≥ 2.45.3 and sd-bus ≥ 209 have a
133   matching default.
134
135 • All executables are now dynamically linked to libdbus-1.
136   Previously, some executables, most notably dbus-daemon, were statically
137   linked to a specially-compiled variant of libdbus. This results in
138   various private functions in the _dbus namespace being exposed by the
139   shared library. These are not API, and must not be used outside
140   the dbus source tree.
141
142 • On platforms with ELF symbol versioning, all public symbols
143   are versioned LIBDBUS_1_3.
144
145 New bus APIs:
146
147 • org.freedesktop.DBus.GetConnectionCredentials returns
148   LinuxSecurityLabel where supported
149 • org.freedesktop.DBus.Monitoring interface (privileged)
150   · BecomeMonitor method supersedes match rules with eavesdrop=true,
151     which are now deprecated
152 • org.freedesktop.DBus.Stats interface (semi-privileged)
153   · now enabled by default
154   · new GetAllMatchRules method
155 • org.freedesktop.DBus.Verbose interface (not normally compiled)
156   · toggles the effect of DBUS_VERBOSE
157
158 New executables:
159
160 • dbus-test-tool
161 • dbus-update-activation-environment
162
163 New optional dependencies:
164
165 • The systemd: pseudo-transport requires libsystemd or libsd-daemon
166 • Complete documentation requires Ducktype and yelp-tools
167 • Full test coverage requires GLib 2.36 and PyGI
168 • AppArmor integration requires libapparmor and optionally libaudit
169
170 Dependencies removed:
171
172 • dbus-glib
173
174 D-Bus 1.9.20 (2015-08-06)
175 ==
176
177 The “Remember Tomorrow” release.
178
179 This is a release-candidate for D-Bus 1.10.0. OS distribution vendors
180 should test it.
181
182 Fixes:
183
184 • Don't second-guess what the ABI of poll() is, allowing it to be used
185   on Integrity RTOS and other unusual platforms (fd.o #90314;
186   Rolland Dudemaine, Simon McVittie)
187
188 • Don't duplicate audit subsystem integration if AppArmor and SELinux are
189   both enabled (fd.o #89225, Simon McVittie)
190
191 • Log audit events for AppArmor/SELinux policy violations whenever
192   we have CAP_AUDIT_WRITE, even if not the system bus
193   (fd.o #83856, Laurent Bigonville)
194
195 D-Bus 1.9.18 (2015-07-21)
196 ==
197
198 The “Pirate Elite” release.
199
200 Configuration changes:
201
202 • The basic setup for the well-known system and session buses is now done
203   in read-only files in ${datadir}, moving a step closer to systems
204   that can operate with an empty /etc directory. In increasing order
205   of precedence:
206
207   · ${datadir}/dbus-1/s*.conf now perform the basic setup such as setting
208     the default message policies.
209   · ${sysconfdir}/dbus-1/s*.conf are now optional. By default
210     dbus still installs a trivial version of each, for documentation
211     purposes; putting configuration directives in these files is deprecated.
212   · ${datadir}/dbus-1/s*.d/ are now available for third-party software
213     to install "drop-in" configuration snippets (any packages
214     using those directories should explicitly depend on at least this
215     version of dbus).
216   · ${sysconfdir}/dbus-1/s*.d/ are also still available for sysadmins
217     or third-party software to install "drop-in" configuration snippets
218   · ${sysconfdir}/dbus-1/s*-local.conf are still available for sysadmins'
219     overrides
220
221   ${datadir} is normally /usr/share, ${sysconfdir} is normally /etc,
222   and "s*" refers to either system or session as appropriate.
223
224   (fd.o #89280, Dimitri John Ledkov)
225
226 Fixes:
227
228 • Fix a memory leak when GetConnectionCredentials() succeeds
229   (fd.o #91008, Jacek Bukarewicz)
230
231 • Ensure that dbus-monitor does not reply to messages intended for others,
232   resulting in its own disconnection (fd.o #90952, Simon McVittie)
233
234 D-Bus 1.9.16 (2015-05-14)
235 ==
236
237 The “titanium barns” release.
238
239 Dependencies:
240
241 • Automake 1.13 is now required when compiling from git or modifying
242   the build system.
243
244 Security hardening:
245
246 • On Unix platforms, change the default configuration for the session bus
247   to only allow EXTERNAL authentication (secure kernel-mediated
248   credentials-passing), as was already done for the system bus.
249
250   This avoids falling back to DBUS_COOKIE_SHA1, which relies on strongly
251   unpredictable pseudo-random numbers.
252
253   If you are using D-Bus over the (unencrypted!) tcp: or nonce-tcp: transport,
254   in conjunction with DBUS_COOKIE_SHA1 and a shared home directory using
255   NFS or similar, you will need to reconfigure the session bus to accept
256   DBUS_COOKIE_SHA1 by commenting out the <auth> element. This configuration
257   is not recommended.
258
259   (fd.o #90414, Simon McVittie)
260
261 • When asked for random numbers for DBUS_COOKIE_SHA1, the nonce-tcp:
262   transport, UUIDs or any other reason, fail if we cannot obtain entropy
263   (from /dev/urandom or CryptGenRandom()) or an out-of-memory condition
264   occurs, instead of silently falling back to low-entropy pseudorandom
265   numbers from rand(). (fd.o #90414; Simon McVittie, Ralf Habacker)
266
267 Enhancements:
268
269 • Add dbus_message_iter_get_element_count()
270   (fd.o #30350; Christian Dywan, Simon McVittie)
271
272 • Introduce new internal DBusSocket and DBusPollable types so we can
273   stop treating the Windows SOCKET type as if it was int. DBusSocket
274   is specifically a socket, cross-platform. DBusPollable is whatever
275   _dbus_poll() can act on, i.e. a fd on Unix or a SOCKET on Windows.
276   (fd.o #89444; Ralf Habacker, Simon McVittie)
277
278 • All regression tests now output TAP <https://testanything.org/>
279   (fd.o #89846, Simon McVittie)
280
281 • Internal APIs consistently use signed values for timestamps
282   (fd.o #18494, Peter McCurdy)
283
284 • Improve diagnostics when UpdateActivationEnvironment calls are rejected
285   (fd.o #88812, Simon McVittie)
286
287 • Clean up a lot of compiler warnings
288   (fd.o #17289, fd.o #89284; Ralf Habacker, Simon McVittie)
289
290 Fixes:
291
292 • Add locking to DBusCounter's reference count and notify function
293   (fd.o #89297, Adrian Szyndela)
294
295 • Ensure that DBusTransport's reference count is protected by the
296   corresponding DBusConnection's lock (fd.o #90312, Adrian Szyndela)
297
298 • Correctly release DBusServer mutex before early-return if we run out
299   of memory while copying authentication mechanisms (fd.o #90021,
300   Ralf Habacker)
301
302 • Make dbus-test-tool and dbus-update-activation-environment portable
303   to Windows (fd.o #90089, Ralf Habacker)
304
305 • Correctly initialize all fields of DBusTypeReader (fd.o #90021;
306   Ralf Habacker, Simon McVittie)
307
308 • Fix some missing \n in verbose (debug log) messages (fd.o #90004,
309   Ralf Habacker)
310
311 • Clean up some memory and fd leaks in test code and tools
312   (fd.o #90021, Ralf Habacker)
313
314 • Fix a NULL dereference if the dbus-daemon cannot read a configuration
315   directory for a reason that is not ENOENT (fd.o #90021, Ralf Habacker)
316
317 • CMake generates a versioned shared library even if the revision is 0,
318   as it usually is on the development branch. (fd.o #89450, Ralf Habacker)
319
320 D-Bus 1.9.14 (2015-03-02)
321 ==
322
323 The “don't stand in the poison cloud” release.
324
325 Dependencies:
326
327 • dbus-daemon and dbus-daemon-launch-helper now require libdbus. They
328   were previously linked to a static version of libdbus.
329
330 • The tests no longer require dbus-glib in order to exercise the libdbus
331   shared library; they are always linked to libdbus now.
332
333 Build-time configuration:
334
335 • The new --enable-user-session option, off by default, can be enabled
336   by OS integrators intending to use systemd to provide a session bus
337   per user (in effect, treating all concurrent graphical and non-graphical
338   login sessions as one large session)
339
340 Enhancements:
341
342 • All executables are now linked dynamically to libdbus.
343   (fd.o #83115; Bertrand SIMONNET, Simon McVittie, Ralf Habacker)
344
345 • On platforms that support them (GNU libc and possibly others),
346   libdbus now has versioned symbols for its public API.
347   All public symbols (visible in the header files) are currently
348   versioned as LIBDBUS_1_3; private symbols starting with _dbus or
349   dbus_internal have a version that changes with each release, and
350   must not be used by applications. (also fd.o #83115)
351
352 • New listenable address mode "unix:runtime=yes" which listens on
353   a real filesystem (non-abstract) socket $XDG_RUNTIME_DIR/bus
354   (fd.o #61303; Colin Walters, Alexander Larsson, Simon McVittie)
355
356 • Add optional systemd units for a per-user bus listening on
357   $XDG_RUNTIME_DIR/bus (fd.o #61301; Simon McVittie, Colin Walters)
358
359 • On Unix platforms, both libdbus and "dbus-launch --autolaunch"
360   default to connecting to $XDG_RUNTIME_DIR/bus if it is a socket
361   (also fd.o #61301)
362
363 • New dbus-update-activation-environment tool uploads environment
364   variables to "dbus-daemon --session" and optionally "systemd --user",
365   primarily as a way to keep the per-user bus compatible with
366   distributions' existing X11 login scripts (also fd.o #61301)
367
368 • <includedir/> elements in dbus-daemon configuration are now silently
369   ignored if the directory does not exist. (fd.o #89280, Dimitri John Ledkov)
370
371 • Add microsecond-resolution timestamps to the default output of
372   dbus-monitor and dbus-send (fd.o #88896; Ralf Habacker, Simon McVittie)
373
374 Fixes:
375
376 • Fix a race condition in the 'monitor' test introduced in 1.9.10
377   (fd.o #89222, Simon McVittie)
378
379 D-Bus 1.9.12 (2015-02-19)
380 ==
381
382 The “monster lasagna” release.
383
384 Dependencies:
385
386 • Ducktype and yelp-tools are now required to build complete documentation
387   (they are optional for normal builds).
388
389 Enhancements:
390
391 • D-Bus Specification version 0.26
392   · GetConnectionCredentials can return LinuxSecurityLabel or WindowsSID
393   · document the BecomeMonitor method
394
395 • On Linux, add LinuxSecurityLabel to GetConnectionCredentials
396   (fd.o #89041; Tyler Hicks, Simon McVittie)
397
398 • On Linux, add support for AppArmor mediation of message sending and
399   receiving and name ownership (paralleling existing SELinux mediation
400   support), and eavesdropping (a new check, currently AppArmor-specific)
401   (fd.o #75113; John Johansen, Tyler Hicks, Simon McVittie)
402
403 • In dbus-send and dbus-monitor, pretty-print \0-terminated bytestrings
404   that have printable ASCII contents; we previously only did this for
405   unterminated bytestrings (fd.o #89109, Simon McVittie)
406
407 • Add a guide to designing good D-Bus APIs (fd.o #88994, Philip Withnall)
408
409 • On Windows, add WindowsSID to GetConnectionCredentials
410   (fd.o #54445, Ralf Habacker)
411
412 • Improve clarity of dbus-monitor --profile output and add more columns
413   (fd.o #89165, Ralf Habacker)
414
415 • Add a man page for dbus-test-tool, and build it under CMake as well
416   as Autotools (fd.o#89086, Simon McVittie)
417
418 • If dbus-daemon was compiled with --enable-verbose, add a D-Bus API
419   to control it at runtime, overriding the DBUS_VERBOSE environment variable
420   (fd.o #88896, Ralf Habacker)
421
422 Fixes:
423
424 • Reduce the number of file descriptors used in the fd-passing test,
425   avoiding failure under the default Linux fd limit, and automatically
426   skip it if the rlimit is too small (fd.o #88998, Simon McVittie)
427
428 D-Bus 1.9.10 (2015-02-09)
429 ==
430
431 The “sad cyborgs” release.
432
433 Security fixes merged from 1.8.16:
434
435 • Do not allow non-uid-0 processes to send forged ActivationFailure
436   messages. On Linux systems with systemd activation, this would
437   allow a local denial of service: unprivileged processes could
438   flood the bus with these forged messages, winning the race with
439   the actual service activation and causing an error reply
440   to be sent back when service auto-activation was requested.
441   This does not prevent the real service from being started,
442   so the attack only works while the real service is not running.
443   (CVE-2015-0245, fd.o #88811; Simon McVittie)
444
445 Enhancements:
446
447 • The new Monitoring interface in the dbus-daemon lets dbus-monitor and
448   similar tools receive messages without altering the security properties
449   of the system bus, by calling the new BecomeMonitor method on a
450   private connection. This bypasses the normal <allow> and <deny> rules
451   entirely, so to preserve normal message-privacy assumptions, only root
452   is allowed to do this on the system bus. Restricted environments,
453   such as Linux with LSMs, should lock down access to the Monitoring
454   interface. (fd.o #46787, Simon McVittie)
455
456 • dbus-monitor uses BecomeMonitor to capture more traffic, if the
457   dbus-daemon supports it and access permissions allow it.
458   It still supports the previous approach ("eavesdropping" match rules)
459   for compatibility with older bus daemons. (fd.o #46787, Simon)
460
461 • dbus-monitor can now log the message stream as binary data for later
462   analysis, with either no extra framing beyond the normal D-Bus headers,
463   or libpcap-compatible framing treating each D-Bus message
464   as a captured packet. (fd.o #46787, Simon)
465
466 Other fixes:
467
468 • Fix some CMake build regressions (fd.o #88964, Ralf Habacker)
469
470 • On Unix, forcibly terminate regression tests after 60 seconds to
471   prevent them from blocking continuous integration frameworks
472   (fd.o #46787, Simon)
473
474 D-Bus 1.9.8 (2015-02-03)
475 ==
476
477 The “all the types of precipitation” release.
478
479 Dependencies:
480
481 • full test coverage now requires GLib 2.36
482 • full test coverage now requires PyGI (PyGObject 3,
483   "import gi.repository.GObject") instead of the
484   obsolete PyGObject 2 ("import gobject")
485
486 Enhancements:
487
488 • add GLib-style "installed tests" (fd.o #88810, Simon McVittie)
489
490 • better regression test coverage, including systemd activation
491   (fd.o #57952, #88810; Simon McVittie)
492
493 Fixes:
494
495 • fatal errors correctly make the dbus-daemon exit even if <syslog/> is
496   turned off (fd.o #88808, Simon McVittie)
497
498 • TCP sockets on Windows no longer fail to listen approximately 1 time
499   in 256, caused by a logic error that should have always made it fail but
500   was mitigated by incorrect endianness for the port number
501   (fd.o #87999, Ralf Habacker)
502
503 • fix some Windows build failures (fd.o #88009, #88010; Ralf Habacker)
504
505 • on Windows, allow up to 8K connections to the dbus-daemon instead of the
506   previous 64, completing a previous fix which only worked under
507   Autotools (fd.o #71297, Ralf Habacker)
508
509 • on Windows, if the IP family is unspecified only use IPv4,
510   to mitigate IPv6 not working correctly (fd.o #87999, Ralf Habacker)
511
512 • fix some unlikely memory leaks on OOM (fd.o #88087, Simon McVittie)
513
514 • lcov code coverage analysis works again (fd.o #88808, Simon McVittie)
515
516 • fix an unused function error with --disable-embedded-tests (fd.o #87837,
517   Thiago Macieira)
518
519 D-Bus 1.9.6 (2015-01-05)
520 ==
521
522 The “I do have a bread knife” release.
523
524 Security hardening:
525
526 • Do not allow calls to UpdateActivationEnvironment from uids other than
527   the uid of the dbus-daemon. If a system service installs unsafe
528   security policy rules that allow arbitrary method calls
529   (such as CVE-2014-8148) then this prevents memory consumption and
530   possible privilege escalation via UpdateActivationEnvironment.
531
532   We believe that in practice, privilege escalation here is avoided
533   by dbus-daemon-launch-helper sanitizing its environment; but
534   it seems better to be safe.
535
536 • Do not allow calls to UpdateActivationEnvironment or the Stats interface
537   on object paths other than /org/freedesktop/DBus. Some system services
538   install unsafe security policy rules that allow arbitrary method calls
539   to any destination, method and interface with a specified object path;
540   while less bad than allowing arbitrary method calls, these security
541   policies are still harmful, since dbus-daemon normally offers the
542   same API on all object paths and other system services might behave
543   similarly.
544
545 Other fixes:
546
547 • Add missing initialization so GetExtendedTcpTable doesn't crash on
548   Windows Vista SP0 (fd.o #77008, Илья А. Ткаченко)
549
550 D-Bus 1.9.4 (2014-11-24)
551 ==
552
553 The “extra-sturdy caramel” release.
554
555 Fixes:
556
557 • Partially revert the CVE-2014-3639 patch by increasing the default
558   authentication timeout on the system bus from 5 seconds back to 30
559   seconds, since this has been reported to cause boot regressions for
560   some users, mostly with parallel boot (systemd) on slower hardware.
561
562   On fast systems where local users are considered particularly hostile,
563   administrators can return to the 5 second timeout (or any other value
564   in milliseconds) by saving this as /etc/dbus-1/system-local.conf:
565
566   <busconfig>
567     <limit name="auth_timeout">5000</limit>
568   </busconfig>
569
570   (fd.o #86431, Simon McVittie)
571
572 • Add a message in syslog/the Journal when the auth_timeout is exceeded
573   (fd.o #86431, Simon McVittie)
574
575 • Send back an AccessDenied error if the addressed recipient is not allowed
576   to receive a message (and in builds with assertions enabled, don't
577   assert under the same conditions). (fd.o #86194, Jacek Bukarewicz)
578
579 D-Bus 1.9.2 (2014-11-10)
580 ==
581
582 The “structurally unsound flapjack” release.
583
584 Security fixes:
585
586 • Increase dbus-daemon's RLIMIT_NOFILE rlimit to 65536
587   so that CVE-2014-3636 part A cannot exhaust the system bus'
588   file descriptors, completing the incomplete fix in 1.8.8.
589   (CVE-2014-7824, fd.o #85105; Simon McVittie, Alban Crequy)
590
591 Enhancements:
592
593 • D-Bus Specification version 0.25
594   · new value 'const' for EmitsChangedSignal annotation
595     (fd.o #72958, Lennart Poettering)
596   · new ALLOW_INTERACTIVE_AUTHORIZATION flag, for PolicyKit and similar
597     (fd.o #83449; Lennart Poettering, Simon McVittie)
598   · annotate table of types with reserved/basic/container, and for
599     basic types, fixed/string-like
600   · clarify arbitrary limits by quoting them in mebibytes
601
602 • New API: add accessors for the ALLOW_INTERACTIVE_AUTHORIZATION flag
603   (fd.o #83449, Simon McVittie)
604
605 • Add dbus-test-tool, a D-Bus swiss army knife with multiple subcommands,
606   useful for debugging and performance testing:
607   · dbus-test-tool spam: send repeated messages
608   · dbus-test-tool echo: send an empty reply for all method calls
609   · dbus-test-tool black-hole: do not reply to method calls
610   (fd.o #34140; Alban Crequy, Simon McVittie, Will Thompson)
611
612 • Add support for process ID in credentials-passing on NetBSD
613   (fd.o #69702, Patrick Welche)
614
615 • Add an example script to find potentially undesired match rules
616   (fd.o #84598, Alban Crequy)
617
618 • Document the central assumption that makes our use of credentials-passing
619   secure (fd.o #83499, Simon McVittie)
620
621 • Replace the dbus-glib section of the tutorial with a GDBus recommendation,
622   and add some links to GDBus and QtDBus documentation (fd.o #25140,
623   Simon McVittie)
624
625 Fixes:
626
627 • Use a less confusing NoReply message when disconnected with a reply pending
628   (fd.o #76112, Simon McVittie)
629
630 • Make the .pc file relocatable by letting pkg-config do all variable
631   expansion itself (fd.o #75858, Руслан Ижбулатов)
632
633 • Fix a build failure on platforms with kqueue, which regressed in 1.9.0
634   (fd.o #85563, Patrick Welche)
635
636 • Consistently save errno after socket calls (fd.o #83625, Simon McVittie)
637
638 • In dbus-spawn, when the grandchild process exits due to a failed exec(),
639   do not lose the exec() errno (fd.o #24821, Simon McVittie)
640
641 • Do not fail the tests if a parent process has leaked non-close-on-exec
642   file descriptors to us (fd.o #73689, fd.o #83899; Simon McVittie)
643
644 • Do not fail the tests on Unix platforms with incomplete
645   credentials-passing support, but do fail if we can't pass credentials
646   on a platform where it is known to work: Linux, FreeBSD, OpenBSD, NetBSD
647   (fd.o #69702, Simon McVittie)
648
649 • Detect accept4, dirfd, inotify_init1, pipe2, and Unix fd passing
650   when building with cmake, and expand test coverage there
651   (fd.o #73689; Ralf Habacker, Simon McVittie)
652
653 D-Bus 1.9.0 (2014-10-01)
654 ==
655
656 The “tiered cheeses” release.
657
658 Requirements:
659
660 • Support for the systemd: (LISTEN_FDS) pseudo-transport on Linux now
661   requires either the libsystemd or libsd-daemon shared library, dropping the
662   embedded convenience copy of sd-daemon (fd.o #71818, Simon)
663
664 Build-time configuration changes:
665
666 • The Stats interface is now enabled by default, and locked-down to
667   root-only on the system bus. Configure with --disable-stats
668   to disable it altogether on memory- or disk-constrained systems,
669   or see ${docdir}/examples/ to open it up to non-root users on the
670   system bus or restrict access on the session bus.
671   (fd.o #80759; Simon McVittie, Alban Crequy)
672
673 • The CMake build system now builds the same shared library name as Autotools
674   on at least Linux and Windows:
675   - on Linux (and perhaps other Unix platforms), it previously built
676     libdbus-1.so, but now builds libdbus-1.so.3.* with development
677     symlink libdbus-1.so and SONAME/symlink libdbus-1.so.3
678   - on Windows, it previously built either libdbus-1.dll (release) or
679     libdbus-1d.dll (debug), but now builds libdbus-1-3.dll, copied to
680     libdbus-1.dll for compatibility with older applications.
681   (fd.o #74117, Ralf Habacker)
682
683 Enhancements:
684
685 • D-Bus Specification version 0.24
686   · document how to quote match rules (fd.o #24307, Simon McVittie)
687   · explicitly say that most message types never expect a reply
688     regardles of whether they have NO_REPLY_EXPECTED
689     (fd.o #75749, Simon McVittie)
690
691 • on Unix platforms, disable Nagle's algorithm on TCP connections to improve
692   initial latency (fd.o #75544, Matt Hoosier)
693
694 • use backtrace() if it is in -lexecinfo instead of libc, as on NetBSD
695   (fd.o #69702, Patrick Welche)
696
697 • in dbus-monitor, print more information about file descriptors
698   (fd.o #80603, Alban Crequy)
699
700 • do not install system bus configuration if built for Windows
701   (fd.o #83583; Ralf Habacker, Simon McVittie)
702
703 • Add GetAllMatchRules to the Stats interface (fd.o #24307, Alban Crequy)
704
705 • Add a regression test for file descriptor passing (fd.o #83622,
706   Simon McVittie)
707
708 Fixes:
709
710 • fix an incorrect error message if a Unix socket path is too long
711   (fd.o #73887, Antoine Jacoutot)
712
713 • in an MSYS/Cygwin environment, pass Unix-style filenames to xmlto,
714   fixing documentation generation (fd.o #75860, Руслан Ижбулатов)
715
716 • in Unix with X11, avoid giving dbus-launch a misleading argv[0]
717   in ps(1) (fd.o #69716, Chengwei Yang)
718
719 • avoid calling poll() with timeout < -1, which is considered invalid
720   on FreeBSD and NetBSD (fd.o #78480, Jaap Boender)
721
722 • be portable to BSD-derived platforms where O_CLOEXEC is unavailable in libc
723   (like Mac OS X 10.6), or available in libc but unsupported by the kernel
724   (fd.o #77032; rmvsxop, OBATA Akio, Patrick Welche)
725
726 • Fix include path for test/internal/*.c with cmake (Ralf Habacker)
727
728 • Documentation improvements
729   (fd.o #80795, #84313; Thomas Haller, Sebastian Rasmussen)
730
731 • in dbus-monitor, do not leak file descriptors that we have monitored
732   (fd.o #80603, Alban Crequy)
733
734 • Set the close-on-exec flag for the inotify file descriptor, even
735   if built with CMake or older libc (fd.o #73689, Simon McVittie)
736
737 • Remove some LGPL code from the Windows dbus-daemon
738   (fd.o #57272, Ralf Habacker)
739
740 D-Bus 1.8.8 (2014-09-16)
741 ==
742
743 The "smashy smashy egg man" release.
744
745 Security fixes:
746
747 • Do not accept an extra fd in the padding of a cmsg message, which
748   could lead to a 4-byte heap buffer overrun.
749   (CVE-2014-3635, fd.o #83622; Simon McVittie)
750
751 • Reduce default for maximum Unix file descriptors passed per message
752   from 1024 to 16, preventing a uid with the default maximum number of
753   connections from exhausting the system bus' file descriptors under
754   Linux's default rlimit. Distributors or system administrators with a
755   more restrictive fd limit may wish to reduce these limits further.
756
757   Additionally, on Linux this prevents a second denial of service
758   in which the dbus-daemon can be made to exceed the maximum number
759   of fds per sendmsg() and disconnect the process that would have
760   received them.
761   (CVE-2014-3636, fd.o #82820; Alban Crequy)
762
763 • Disconnect connections that still have a fd pending unmarshalling after
764   a new configurable limit, pending_fd_timeout (defaulting to 150 seconds),
765   removing the possibility of creating an abusive connection that cannot be
766   disconnected by setting up a circular reference to a connection's
767   file descriptor.
768   (CVE-2014-3637, fd.o #80559; Alban Crequy)
769
770 • Reduce default for maximum pending replies per connection from 8192 to 128,
771   mitigating an algorithmic complexity denial-of-service attack
772   (CVE-2014-3638, fd.o #81053; Alban Crequy)
773
774 • Reduce default for authentication timeout on the system bus from
775   30 seconds to 5 seconds, avoiding denial of service by using up
776   all unauthenticated connection slots; and when all unauthenticated
777   connection slots are used up, make new connection attempts block
778   instead of disconnecting them.
779   (CVE-2014-3639, fd.o #80919; Alban Crequy)
780
781 Other fixes:
782
783 • Check for libsystemd from systemd >= 209, falling back to
784   the older separate libraries if not found (Umut Tezduyar Lindskog,
785   Simon McVittie)
786
787 • On Linux, use prctl() to disable core dumps from a test executable
788   that deliberately raises SIGSEGV to test dbus-daemon's handling
789   of that condition (fd.o #83772, Simon McVittie)
790
791 • Fix compilation with --enable-stats (fd.o #81043, Gentoo #507232;
792   Alban Crequy)
793
794 • Improve documentation for running tests on Windows (fd.o #41252,
795   Ralf Habacker)
796
797 D-Bus 1.8.6 (2014-06-02)
798 ==
799
800 Security fixes:
801
802 • On Linux ≥ 2.6.37-rc4, if sendmsg() fails with ETOOMANYREFS, silently drop
803   the message. This prevents an attack in which a malicious client can
804   make dbus-daemon disconnect a system service, which is a local
805   denial of service.
806   (fd.o #80163, CVE-2014-3532; Alban Crequy)
807
808 • Track remaining Unix file descriptors correctly when more than one
809   message in quick succession contains fds. This prevents another attack
810   in which a malicious client can make dbus-daemon disconnect a system
811   service.
812   (fd.o #79694, fd.o #80469, CVE-2014-3533; Alejandro Martínez Suárez,
813   Simon McVittie, Alban Crequy)
814
815 Other fixes:
816
817 • When dbus-launch --exit-with-session starts a dbus-daemon but then cannot
818   attach to a session, kill the dbus-daemon as intended
819   (fd.o #74698, Роман Донченко)
820
821 D-Bus 1.8.4 (2014-06-10)
822 ==
823
824 Security fix:
825
826 • Alban Crequy at Collabora Ltd. discovered and fixed a denial-of-service
827   flaw in dbus-daemon, part of the reference implementation of D-Bus.
828   Additionally, in highly unusual environments the same flaw could lead to
829   a side channel between processes that should not be able to communicate.
830   (CVE-2014-3477, fd.o #78979)
831
832 D-Bus 1.8.2 (2014-04-30)
833 ==
834
835 The “nobody wants red” release.
836
837 Enhancements:
838
839 • in the CMake build system, add some hints for Linux users cross-compiling
840   Windows D-Bus binaries to be able to run tests under Wine
841   (fd.o #41252, Ralf Habacker)
842
843 • add Documentation key to dbus.service (fd.o #77447, Cameron Norman)
844
845 Fixes:
846
847 • in "dbus-uuidgen --ensure", try to copy systemd's /etc/machine-id
848   to /var/lib/dbus/machine-id instead of generating an entirely new ID
849   (fd.o #77941, Simon McVittie)
850
851 • if dbus-launch receives an X error very quickly, do not kill
852   unrelated processes (fd.o #74698, Роман Донченко)
853
854 • on Windows, allow up to 8K connections to the dbus-daemon, instead of the
855   previous 64 (fd.o #71297; Cristian Onet, Ralf Habacker)
856
857 • cope with \r\n newlines in regression tests, since on Windows,
858   dbus-daemon.exe uses text mode (fd.o #75863, Руслан Ижбулатов)
859
860 D-Bus 1.8.0 (2014-01-20)
861 ==
862
863 The “Wolverine distrusts my printer” release.
864
865 This starts a new stable branch. The 1.6.x branch is now considered to be
866 outdated, and will only receive fixes for serious bugs such as security
867 flaws. The 1.4.x and 1.2.x branches no longer have upstream support and
868 are unlikely to get any more releases, but if distributors still need to
869 support them, please share security patches via upstream.
870
871 Summary of changes since 1.6.x:
872
873 • libdbus always behaves as if dbus_threads_init_default() had been called
874   (thread-safety by default)
875 • new dbus-run-session tool, replacing certain misuses of dbus-launch
876 • dbus-monitor can talk to outdated versions of dbus-daemon again
877 • new org.freedesktop.DBus.GetConnectionCredentials method
878 • GetConnectionUnixProcessID also works correctly on Windows, returning
879   the Windows process ID
880 • GetConnectionWindowsSID returns the correct SID on Windows
881 • expat is required, libxml2 can no longer be used as a substitute
882 • the userDB cache is required, and cannot be disabled
883 • a 64-bit integer type (either int, long, long long or _int64) is required
884 • better systemd-journald integration on Linux
885 • fixed long-standing fd and array leaks when failing to parse a message
886 • fixed referenced-but-never-freed parent nodes (effectively memory leaks)
887   when using certain object-path allocation patterns, notably in Avahi
888 • better defaults for Windows support
889 • better CMake support
890 • better portability to mingw32, FreeBSD, NetBSD, QNX and Hurd
891 • the source language for the man pages is now Docbook XML
892
893 Enhancements since 1.7.10:
894
895 • Enhance the CMake build system to check for GLib and compile/run
896   a subset of the regression tests (fd.o #41252, #73495; Ralf Habacker)
897
898 Fixes since 1.7.10:
899
900 • don't rely on va_copy(), use DBUS_VA_COPY() wrapper (fd.o #72840,
901   Ralf Habacker)
902
903 • fix compilation of systemd journal support on older systemd versions where
904   sd-journal.h doesn't include syslog.h (fd.o #73455, Ralf Habacker)
905
906 • fix compilation on older MSVC versions by including stdlib.h
907   (fd.o #73455, Ralf Habacker)
908
909 • Allow <allow_anonymous/> to appear in an included configuration file
910   (fd.o #73475, Matt Hoosier)
911
912 Test behaviour changes since 1.7.10:
913
914 • If the tests crash with an assertion failure, they no longer default to
915   blocking for a debugger to be attached. Set DBUS_BLOCK_ON_ABORT in the
916   environment if you want the old behaviour.
917
918 • To improve debuggability, the dbus-daemon and dbus-daemon-eavesdrop tests
919   can be run with an external dbus-daemon by setting
920   DBUS_TEST_DAEMON_ADDRESS in the environment. Test-cases that require
921   an unusually-configured dbus-daemon are skipped.
922
923 D-Bus 1.7.10 (2014-01-06)
924 ==
925
926 The “weighted companion cube” release.
927
928 This is a release candidate for D-Bus 1.8.
929
930 D-Bus Specification 0.23:
931
932 • don't require messages with no INTERFACE to be dispatched
933   (fd.o #68597, Simon McVittie)
934
935 • document "tcp:bind=..." and "nonce-tcp:bind=..." (fd.o #72301,
936   Chengwei Yang)
937
938 • define "listenable" and "connectable" addresses, and discuss
939   the difference (fd.o #61303, Simon McVittie)
940
941 Enhancements:
942
943 • support printing Unix file descriptors in dbus-send, dbus-monitor
944   (fd.o #70592, Robert Ancell)
945
946 • don't install systemd units if --disable-systemd is given
947   (fd.o #71818, Chengwei Yang)
948
949 Fixes:
950
951 • don't leak memory on out-of-memory while listing activatable or
952   active services (fd.o #71526, Radoslaw Pajak)
953
954 • fix undefined behaviour in a regression test (fd.o #69924, DreamNik)
955
956 • escape Unix socket addresses correctly (fd.o #46013, Chengwei Yang)
957
958 • on SELinux systems, don't assume that SECCLASS_DBUS, DBUS__ACQUIRE_SVC
959   and DBUS__SEND_MSG are numerically equal to their values in the
960   reference policy (fd.o #88719, osmond sun)
961
962 • define PROCESS_QUERY_LIMITED_INFORMATION if missing from MinGW < 4 headers
963   (fd.o #71366, Matt Fischer)
964
965 • define WIN32_LEAN_AND_MEAN to avoid conflicts between winsock.h and
966   winsock2.h (fd.o #71405, Matt Fischer)
967
968 • do not return failure from _dbus_read_nonce() with no error set,
969   preventing a potential crash (fd.o #72298, Chengwei Yang)
970
971 • on BSD systems, avoid some O(1)-per-process memory and fd leaks in kqueue,
972   preventing test failures (fd.o #69332, fd.o #72213; Chengwei Yang)
973
974 • fix warning spam on Hurd by not trying to set SO_REUSEADDR on Unix sockets,
975   which doesn't do anything anyway on at least Linux and FreeBSD
976   (fd.o #69492, Simon McVittie)
977
978 • fix use of TCP sockets on FreeBSD and Hurd by tolerating EINVAL from
979   sendmsg() with SCM_CREDS (retrying with plain send()), and looking
980   for credentials more correctly (fd.o #69492, Simon McVittie)
981
982 • ensure that tests run with a temporary XDG_RUNTIME_DIR to avoid
983   getting mixed up in XDG/systemd "user sessions" (fd.o #61301,
984   Simon McVittie)
985
986 • refresh cached policy rules for existing connections when bus
987   configuration changes (fd.o #39463, Chengwei Yang)
988
989 D-Bus 1.7.8 (2013-11-01)
990 ==
991
992 The “extreme hills” release.
993
994 Dependencies:
995
996 • If systemd support is enabled, libsystemd-journal is now required.
997
998 Enhancements:
999
1000 • When activating a non-systemd service under systemd, annotate its
1001   stdout/stderr with its bus name in the Journal. Known limitation:
1002   because the socket is opened before forking, the process will still be
1003   logged as if it had dbus-daemon's process ID and user ID.
1004   (fd.o #68559, Chengwei Yang)
1005
1006 • Document more configuration elements in dbus-daemon(1)
1007   (fd.o #69125, Chengwei Yang)
1008
1009 Fixes:
1010
1011 • Don't leak string arrays or fds if dbus_message_iter_get_args_valist()
1012   unpacks them and then encounters an error (fd.o #21259, Chengwei Yang)
1013
1014 • If compiled with libaudit, retain CAP_AUDIT_WRITE so we can write
1015   disallowed method calls to the audit log, fixing a regression in 1.7.6
1016   (fd.o #49062, Colin Walters)
1017
1018 • path_namespace='/' in match rules incorrectly matched nothing; it
1019   now matches everything. (fd.o #70799, Simon McVittie)
1020
1021 D-Bus 1.7.6 (2013-10-09)
1022 ==
1023
1024 The “CSI Shrewsbury” release.
1025
1026 Build-time configuration changes:
1027
1028 • Directory change notification via dnotify on Linux is no longer
1029   supported; it hadn't compiled successfully since 2010 in any case.
1030   If you don't have inotify (Linux) or kqueue (*BSD), you will need
1031   to send SIGHUP to the dbus-daemon when its configuration changes.
1032   (fd.o #33001, Chengwei Yang)
1033
1034 • Compiling with --disable-userdb-cache is no longer supported;
1035   it didn't work since at least 2008, and would lead to an extremely
1036   slow dbus-daemon even it worked. (fd.o #15589, #17133, #66947;
1037   Chengwei Yang)
1038
1039 • The DBUS_DISABLE_ASSERTS CMake option didn't actually disable most
1040   assertions. It has been renamed to DBUS_DISABLE_ASSERT to be consistent
1041   with the Autotools build system. (fd.o #66142, Chengwei Yang)
1042
1043 • --with-valgrind=auto enables Valgrind instrumentation if and only if
1044   valgrind headers are available. The default is still --with-valgrind=no.
1045   (fd.o #56925, Simon McVittie)
1046
1047 Dependencies:
1048
1049 • Platforms with no 64-bit integer type are no longer supported.
1050   (fd.o #65429, Simon McVittie)
1051
1052 • GNU make is now (documented to be) required. (fd.o #48277, Simon McVittie)
1053
1054 • Full test coverage no longer requires dbus-glib, although the tests do not
1055   exercise the shared library (only a static copy) if dbus-glib is missing.
1056   (fd.o #68852, Simon McVittie)
1057
1058 Enhancements:
1059
1060 • D-Bus Specification 0.22
1061   · Document GetAdtAuditSessionData() and
1062     GetConnectionSELinuxSecurityContext() (fd.o #54445, Simon)
1063   · Fix example .service file (fd.o #66481, Chengwei Yang)
1064   · Don't claim D-Bus is "low-latency" (lower than what?), just
1065     give factual statements about it supporting async use
1066     (fd.o #65141, Justin Lee)
1067   · Document the contents of .service files, and the fact that
1068     system services' filenames are constrained
1069     (fd.o #66608; Simon McVittie, Chengwei Yang)
1070
1071 • Be thread-safe by default on all platforms, even if
1072   dbus_threads_init_default() has not been called. For compatibility with
1073   older libdbus, library users should continue to call
1074   dbus_threads_init_default(): it is harmless to do so.
1075   (fd.o #54972, Simon McVittie)
1076
1077 • Add GetConnectionCredentials() method (fd.o #54445, Simon)
1078
1079 • New API: dbus_setenv(), a simple wrapper around setenv().
1080   Note that this is not thread-safe. (fd.o #39196, Simon)
1081
1082 • Add dbus-send --peer=ADDRESS (connect to a given peer-to-peer connection,
1083   like --address=ADDRESS in previous versions) and dbus-send --bus=ADDRESS
1084   (connect to a given bus, like dbus-monitor --address=ADDRESS).
1085   dbus-send --address still exists for backwards compatibility,
1086   but is no longer documented. (fd.o #48816, Andrey Mazo)
1087
1088 • Windows-specific:
1089   · "dbus-daemon --nofork" is allowed on Windows again. (fd.o #68852,
1090     Simon McVittie)
1091
1092 Fixes:
1093
1094 • Avoid an infinite busy-loop if a signal interrupts waitpid()
1095   (fd.o #68945, Simon McVittie)
1096
1097 • Clean up memory for parent nodes when objects are unexported
1098   (fd.o #60176, Thomas Fitzsimmons)
1099
1100 • Make dbus_connection_set_route_peer_messages(x, FALSE) behave as
1101   documented. Previously, it assumed its second parameter was TRUE.
1102   (fd.o #69165, Chengwei Yang)
1103
1104 • Escape addresses containing non-ASCII characters correctly
1105   (fd.o #53499, Chengwei Yang)
1106
1107 • Document <servicedir> search order correctly (fd.o #66994, Chengwei Yang)
1108
1109 • Don't crash on "dbus-send --session / x.y.z" which regressed in 1.7.4.
1110   (fd.o #65923, Chengwei Yang)
1111
1112 • If malloc() returns NULL in _dbus_string_init() or similar, don't free
1113   an invalid pointer if the string is later freed (fd.o #65959, Chengwei Yang)
1114
1115 • If malloc() returns NULL in dbus_set_error(), don't va_end() a va_list
1116   that was never va_start()ed (fd.o #66300, Chengwei Yang)
1117
1118 • fix build failure with --enable-stats (fd.o #66004, Chengwei Yang)
1119
1120 • fix a regression test on platforms with strict alignment (fd.o #67279,
1121   Colin Walters)
1122
1123 • Avoid calling function parameters "interface" since certain Windows headers
1124   have a namespace-polluting macro of that name (fd.o #66493, Ivan Romanov)
1125
1126 • Assorted Doxygen fixes (fd.o #65755, Chengwei Yang)
1127
1128 • Various thread-safety improvements to static variables (fd.o #68610,
1129   Simon McVittie)
1130
1131 • Make "make -j check" work (fd.o #68852, Simon McVittie)
1132
1133 • Fix a NULL pointer dereference on an unlikely error path
1134   (fd.o #69327, Sviatoslav Chagaev)
1135
1136 • Improve valgrind memory pool tracking (fd.o #69326,
1137   Sviatoslav Chagaev)
1138
1139 • Don't over-allocate memory in dbus-monitor (fd.o #69329,
1140   Sviatoslav Chagaev)
1141
1142 • dbus-monitor can monitor dbus-daemon < 1.5.6 again
1143   (fd.o #66107, Chengwei Yang)
1144
1145 • Unix-specific:
1146   · If accept4() fails with EINVAL, as it can on older Linux kernels
1147     with newer glibc, try accept() instead of going into a busy-loop.
1148     (fd.o #69026, Chengwei Yang)
1149   · If socket() or socketpair() fails with EINVAL or EPROTOTYPE,
1150     for instance on Hurd or older Linux with a new glibc, try without
1151     SOCK_CLOEXEC. (fd.o #69073; Pino Toscano, Chengwei Yang)
1152   · Fix a file descriptor leak on an error code path.
1153     (fd.o #69182, Sviatoslav Chagaev)
1154   · dbus-run-session: clear some unwanted environment variables
1155     (fd.o #39196, Simon)
1156   · dbus-run-session: compile on FreeBSD (fd.o #66197, Chengwei Yang)
1157   · Don't fail the autolaunch test if there is no DISPLAY (fd.o #40352, Simon)
1158   · Use dbus-launch from the builddir for testing, not the installed copy
1159     (fd.o #37849, Chengwei Yang)
1160   · Fix compilation if writev() is unavailable (fd.o #69409,
1161     Vasiliy Balyasnyy)
1162   · Remove broken support for LOCAL_CREDS credentials passing, and
1163     document where each credential-passing scheme is used (fd.o #60340,
1164     Simon McVittie)
1165   · Make autogen.sh work on *BSD by not assuming GNU coreutils functionality
1166     (fd.o #35881, #69787; Chengwei Yang)
1167   · dbus-monitor: be portable to NetBSD (fd.o #69842, Chengwei Yang)
1168   · dbus-launch: stop using non-portable asprintf (fd.o #37849, Simon)
1169   · Improve error reporting from the setuid activation helper (fd.o #66728,
1170     Chengwei Yang)
1171
1172 • Windows-specific:
1173   · Remove unavailable command-line options from 'dbus-daemon --help'
1174     (fd.o #42441, Ralf Habacker)
1175   · Add support for looking up local TCPv4 clients' credentials on
1176     Windows XP via the undocumented AllocateAndGetTcpExTableFromStack
1177     function (fd.o #66060, Ralf Habacker)
1178   · Fix insufficient dependency-tracking (fd.o #68505, Simon McVittie)
1179   · Don't include wspiapi.h, fixing a compiler warning (fd.o #68852,
1180     Simon McVittie)
1181
1182 • Internal changes:
1183   · add DBUS_ENABLE_ASSERT, DBUS_ENABLE_CHECKS for less confusing
1184     conditionals (fd.o #66142, Chengwei Yang)
1185   · improve verbose-mode output (fd.o #63047, Colin Walters)
1186   · consolidate Autotools and CMake build (fd.o #64875, Ralf Habacker)
1187   · fix various unused variables, unusual build configurations
1188     etc. (fd.o #65712, #65990, #66005, #66257, #69165, #69410, #70218;
1189     Chengwei Yang, Vasiliy Balyasnyy)
1190
1191 D-Bus 1.7.4 (2013-06-13)
1192 ==
1193
1194 The “but is your thread-safety thread-safe?” release.
1195
1196 Security fixes:
1197
1198 • CVE-2013-2168: Fix misuse of va_list that could be used as a denial
1199   of service for system services. Vulnerability reported by Alexandru Cornea.
1200   (Simon)
1201
1202 Dependencies:
1203
1204 • The Windows version of libdbus now contains a C++ source file, used
1205   to provide global initialization when the library is loaded.
1206   gcc (mingw*) users should ensure that g++ is also installed.
1207
1208 • The libxml2-based configuration reader (which hasn't worked for 2.5 years,
1209   and was never the recommended option) has been removed. Expat is now a
1210   hard dependency.
1211
1212 Enhancements:
1213
1214 • It should now be safe to call dbus_threads_init_default() from any thread,
1215   at any time. Authors of loadable modules and plugins that use libdbus
1216   should consider doing so during initialization.
1217   (fd.o #54972, Simon McVittie)
1218
1219 • Improve dbus-send documentation and command-line parsing (fd.o #65424,
1220   Chengwei Yang)
1221
1222 Unix-specific:
1223   · dbus-run-session: experimental new tool to start a temporary D-Bus
1224     session, e.g. for regression tests or a text console, replacing
1225     certain uses of dbus-launch which weren't really correct
1226     (fd.o #39196, Simon)
1227
1228 Other fixes:
1229
1230 • In dbus-daemon, don't crash if a .service file starts with key=value
1231   (fd.o #60853, Chengwei Yang)
1232
1233 • Unix-specific:
1234   · Fix a crash similar to CVE-2013-2168 the first time we try to use syslog
1235     on a platform not defining LOG_PERROR, such as Solaris or QNX.
1236     This regressed in 1.7.0. (Simon)
1237   · Fix an assertion failure if we try to activate systemd services before
1238     systemd connects to the bus (fd.o #50199, Chengwei Yang)
1239   · Avoid compiler warnings for ignoring the return from write()
1240     (Chengwei Yang)
1241
1242 • Windows-specific:
1243   · Under cmake, install runtime libraries (DLLs) into bin/ instead of lib/
1244     so that Windows finds them (fd.o #59733, Ralf Habacker)
1245
1246 D-Bus 1.7.2 (2013-04-25)
1247 ==
1248
1249 The “only partially opaque” release.
1250
1251 Configuration changes:
1252
1253 • On non-QNX Unix platforms, the default limit on fds per message in the
1254   session bus configuration has reduced from 4096 to 1024. The default
1255   limit used on the system bus was already 1024. On QNX, both limits are
1256   reduced further, to 128.
1257
1258 Enhancements:
1259
1260 • D-Bus Specification 0.21
1261   · Following Unicode Corrigendum #9, the noncharacters U+nFFFE, U+nFFFF,
1262     U+FDD0..U+FDEF are allowed in UTF-8 strings again. (fd.o #63072,
1263     Simon McVittie)
1264
1265 Fixes:
1266
1267 • Diagnose incorrect use of dbus_connection_get_data() with negative slot
1268   (i.e. before allocating the slot) rather than returning junk
1269   (fd.o #63127, Dan Williams)
1270
1271 • Fix a cmake build regression since 1.7.0 (fd.o #63682; Ralf Habacker,
1272   Simon McVittie)
1273
1274 • Unix-specific:
1275   · On Linux, link successfully with glibc 2.17 (fd.o #63166, Simon McVittie)
1276   · Under systemd, log to syslog only, not stderr, avoiding duplication
1277     (fd.o #61399, #39987; Colin Walters, Dagobert Michelsen)
1278   · Under systemd, remove unnecessary dependency on syslog.socket
1279     (fd.o #63531, Cristian Rodríguez)
1280   · Include alloca.h for alloca() if available, fixing compilation on
1281     Solaris 10 (fd.o #63071, Dagobert Michelsen)
1282   · Allow use of systemd-logind without the rest of systemd
1283     (fd.o #62585, Martin Pitt)
1284   · When built with CMake, link to librt and use the right path for
1285     meinproc's XSLT stylesheets (fd.o #61637, Ralf Habacker)
1286   · Reduce the default limit on number of fds per message to 128 under
1287     QNX, working around an arbitrary OS limit (fd.o #61176, Matt Fischer)
1288
1289 • Windows-specific:
1290   · Do not claim that all bus clients have the dbus-daemon's credentials;
1291     pick up local TCPv4 clients' credentials (process ID and security
1292     identifier, i.e. user) using GetExtendedTcpTable() (fd.o #61787,
1293     Ralf Habacker)
1294
1295 D-Bus 1.7.0 (2013-02-22)
1296 ==
1297
1298 The "Disingenuous Assertions" release.
1299
1300 This is a new development release, starting the 1.7.x branch. D-Bus 1.6
1301 remains the recommended version for long-term-supported distributions
1302 or the upcoming GNOME 3.8 release.
1303
1304 Build-time configuration changes:
1305
1306 • The --with-dbus-session-bus-default-address configure option is no longer
1307   supported. Use the new --with-dbus-session-bus-connect-address and
1308   --with-dbus-session-bus-listen-address options instead. On Windows, you
1309   usually want them to have the same argument; on Unix, the defaults are
1310   usually correct.
1311
1312 • Similarly, the DBUS_SESSION_BUS_DEFAULT_ADDRESS CMake variable is no longer
1313   supported; use the new DBUS_SESSION_BUS_LISTEN_ADDRESS and
1314   DBUS_SESSION_BUS_CONNECT_ADDRESS variables instead.
1315
1316 • cmake/cross-compile.sh has been removed. Instead, please use a
1317   cross-toolchain file (-DCMAKE_TOOLCHAIN_FILE) as documented at
1318   <http://www.vtk.org/Wiki/CMake_Cross_Compiling>; or use Autotools
1319   as documented in "info automake Cross-Compilation", and set
1320   PKG_CONFIG_PATH appropriately.
1321
1322 Requirements:
1323
1324 • Man pages now require xmlto (or either xmlto or meinproc, if using CMake).
1325 • man2html is no longer used.
1326
1327 Enhancements:
1328
1329 • D-Bus Specification 0.20
1330   · actually say that /org/freedesktop/DBus is the object that
1331     implements o.fd.DBus (fd.o #51865, Colin Walters)
1332   · various reorganisation for better clarity (fd.o #38252, Simon McVittie)
1333   · stop claiming that all basic types work just like INT32 (strings don't!)
1334
1335 • The "source code" for the man pages is now Docbook XML, eliminating
1336   the outdated duplicate copies used when building with CMake.
1337   (fd.o #59805; Ralf Habacker, Simon McVittie)
1338
1339 Fixes:
1340
1341 • In the activation helper, when compiled for tests, do not reset the system
1342   bus address, fixing the regression tests. (fd.o #52202, Simon)
1343
1344 • Fix building with Valgrind 3.8, at the cost of causing harmless warnings
1345   with Valgrind 3.6 on some compilers (fd.o #55932, Arun Raghavan)
1346
1347 • Merge <servicehelper> from system-local.conf if necessary (fd.o #51560,
1348   Krzysztof Konopko)
1349
1350 • Under CMake, prefer xmlto over meinproc (fd.o #59733, Ralf Habacker)
1351
1352 • Stop duplicating CMake's own logic to find libexpat
1353   (fd.o #59733, Ralf Habacker)
1354
1355 • Don't assume CMake host and build system are the same (fd.o #59733,
1356   Ralf Habacker)
1357
1358 • Avoid deprecation warnings for GLib 2.35 (fd.o #59971, Simon McVittie)
1359
1360 • Unix-specific:
1361   · Check for functions in libpthread correctly, fixing compilation on
1362     (at least) OpenBSD (fd.o #47239, Simon)
1363   · Don't leak temporary fds pointing to /dev/null (fd.o #56927,
1364     Michel HERMIER)
1365   · Update sd-daemon.[ch] from systemd (fd.o #60681)
1366   · Add partial support for QNX (fd.o #60339, fd.o #61176; Matt Fischer)
1367
1368 • Windows-specific:
1369   · The default session bus listening and connecting address is now
1370     "autolaunch:", which makes D-Bus on Windows interoperate with itself
1371     and GDBus "out of the box". Use the configure options and cmake variables
1372     described above if you require a different autolaunch scope.
1373     (fd.o #38201, Simon McVittie)
1374   · Avoid a CMake warning under Cygwin (fd.o #59401, Ralf Habacker)
1375
1376 • Create session.d, system.d directories under CMake (fd.o #41319,
1377   Ralf Habacker)
1378
1379 D-Bus 1.6.8 (2012-09-28)
1380 ==
1381
1382 The "Fix one thing, break another" release.
1383
1384 • Follow up to CVE-2012-3524: The additional hardening
1385   work to use __secure_getenv() as a followup to bug #52202
1386   broke certain configurations of gnome-keyring.  Given
1387   the difficulty of making this work without extensive
1388   changes to gnome-keyring, use of __secure_getenv() is
1389   deferred.
1390
1391 D-Bus 1.6.6 (2012-09-28)
1392 ==
1393
1394 The "Clear the environment in your setuid binaries, please" release.
1395
1396 • CVE-2012-3524: Don't access environment variables (fd.o #52202)
1397   Thanks to work and input from Colin Walters, Simon McVittie,
1398   Geoffrey Thomas, and others.
1399 • Unix-specific:
1400   · Fix compilation on Solaris (fd.o #53286, Jonathan Perkin)
1401   · Work around interdependent headers on OpenBSD by including sys/types.h
1402     before each use of sys/socket.h (fd.o #54418, Brad Smith)
1403
1404 D-Bus 1.6.4 (2012-07-18)
1405 ==
1406
1407 • Detect that users are "at the console" correctly when configured with
1408   a non-default path such as --enable-console-auth-dir=/run/console
1409   (fd.o #51521, Dave Reisner)
1410
1411 • Remove an incorrect assertion from DBusTransport (fd.o #51657,
1412   Simon McVittie)
1413
1414 • Make --enable-developer default to "no" (regression in 1.6.2;
1415   fd.o #51657, Simon McVittie)
1416
1417 • Windows-specific:
1418   · Launch dbus-daemon correctly if its path contains a space
1419     (fd.o #49450, Wolfgang Baron)
1420
1421 D-Bus 1.6.2 (2012-06-27)
1422 ==
1423
1424 The "Ice Cabbage" release.
1425
1426 • Change how we create /var/lib/dbus so it works under Automake >= 1.11.4
1427   (fd.o #51406, Simon McVittie)
1428
1429 • Don't return from dbus_pending_call_set_notify with a lock held on OOM
1430   (fd.o #51032, Simon McVittie)
1431
1432 • Disconnect "developer mode" (assertions, verbose mode etc.) from
1433   Automake maintainer mode. D-Bus developers should now configure with
1434   --enable-developer. Automake maintainer mode is now on by default;
1435   distributions can disable it with --disable-maintainer-mode.
1436   (fd.o #34671, Simon McVittie)
1437
1438 • Automatically define DBUS_STATIC_BUILD in static-only Autotools builds,
1439   fixing linking when targeting Windows (fd.o #33973; william, Simon McVittie)
1440
1441 • Unix-specific:
1442   · Check for libpthread under CMake on Unix (fd.o #47237, Simon McVittie)
1443
1444 D-Bus 1.6.0 (2012-06-05)
1445 ==
1446
1447 The “soul of this machine has improved” release.
1448
1449 This version starts a new stable branch of D-Bus: only bug fixes will
1450 be accepted into 1.6.x. Other changes will now go to the 1.7.x branch.
1451
1452 Summary of changes since 1.4.x:
1453
1454 • New requirements
1455   · PTHREAD_MUTEX_RECURSIVE on Unix
1456   · compiler support for 64-bit integers (int64_t or equivalent)
1457
1458 • D-Bus Specification v0.19
1459
1460 • New dbus-daemon features
1461   · <allow own_prefix="com.example.Service"/> rules allow the service to
1462     own names like com.example.Service.Instance3
1463   · optional systemd integration when checking at_console policies
1464   · --nopidfile option, mainly for use by systemd
1465   · path_namespace and arg0namespace may appear in match rules
1466   · eavesdropping is disabled unless the match rule contains eavesdrop=true
1467
1468 • New public API
1469   · functions to validate various string types (dbus_validate_path() etc.)
1470   · dbus_type_is_valid()
1471   · DBusBasicValue, a union of every basic type
1472
1473 • Bug fixes
1474   · removed an unsafe reimplementation of recursive mutexes
1475   · dbus-daemon no longer busy-loops if it has far too many file descriptors
1476   · dbus-daemon.exe --print-address works on Windows
1477   · all the other bug fixes from 1.4.20
1478
1479 • Other major implementation changes
1480   · on Linux, dbus-daemon uses epoll if supported, for better scalability
1481   · dbus_threads_init() ignores its argument and behaves like
1482     dbus_threads_init_default() instead
1483   · removed the per-connection link cache, improving dbus-daemon performance
1484
1485 • Developer features
1486   · optional Valgrind instrumentation (--with-valgrind)
1487   · optional Stats interface on the dbus-daemon (--enable-stats)
1488   · optionally abort whenever malloc() fails (--enable-embedded-tests
1489     and export DBUS_MALLOC_CANNOT_FAIL=1)
1490
1491 Changes since 1.5.12:
1492
1493 • Be more careful about monotonic time vs. real time, fixing DBUS_COOKIE_SHA1
1494   spec-compliance (fd.o #48580, David Zeuthen)
1495
1496 • Don't use install(1) within the source/build trees, fixing the build as
1497   non-root when using OpenBSD install(1) (fd.o #48217, Antoine Jacoutot)
1498
1499 • Add missing commas in some tcp and nonce-tcp addresses, and remove
1500   an unused duplicate copy of the nonce-tcp transport in Windows builds
1501   (fd.o #45896, Simon McVittie)
1502
1503 D-Bus 1.5.12 (2012-03-27)
1504 ==
1505
1506 The “Big Book of Science” release.
1507
1508 • Add public API to validate various string types:
1509   dbus_validate_path(), dbus_validate_interface(), dbus_validate_member(),
1510   dbus_validate_error_name(), dbus_validate_bus_name(), dbus_validate_utf8()
1511   (fd.o #39549, Simon McVittie)
1512
1513 • Turn DBusBasicValue into public API so bindings don't need to invent their
1514   own "union of everything" type (fd.o #11191, Simon McVittie)
1515
1516 • Enumerate data files included in the build rather than using find(1)
1517   (fd.o #33840, Simon McVittie)
1518
1519 • Add support for policy rules like <allow own_prefix="com.example.Service"/>
1520   in dbus-daemon (fd.o #46273, Alban Crequy)
1521
1522 • Windows-specific:
1523   · make dbus-daemon.exe --print-address (and --print-pid) work again
1524     on Win32, but not on WinCE (fd.o #46049, Simon McVittie)
1525   · fix duplicate case value when compiling against mingw-w64
1526     (fd.o #47321, Andoni Morales Alastruey)
1527
1528 D-Bus 1.5.10 (2012-02-21)
1529 ==
1530
1531 The "fire in Delerium" release.
1532
1533 On Unix platforms, PTHREAD_MUTEX_RECURSIVE (as specified in POSIX 2008 Base
1534 and SUSv2) is now required.
1535
1536 • D-Bus Specification 0.19:
1537   · Formally define unique connection names and well-known bus names,
1538     and document best practices for interface, bus, member and error names,
1539     and object paths (fd.o #37095, Simon McVittie)
1540   · Document the search path for session and system services on Unix, and
1541     where they should be installed by build systems (fd.o #21620, fd.o #35306;
1542     Simon McVittie)
1543   · Document the systemd transport (fd.o #35232, Lennart Poettering)
1544
1545 • Make dbus_threads_init() use the same built-in threading implementation
1546   as dbus_threads_init_default(); the user-specified primitives that it
1547   takes as a parameter are now ignored (fd.o #43744, Simon McVittie)
1548
1549 • Allow all configured auth mechanisms, not just one (fd.o #45106,
1550   Pavel Strashkin)
1551
1552 • Improve cmake build system (Ralf Habacker):
1553   · simplify XML parser dependencies (fd.o #41027)
1554   · generate build timestamp (fd.o #41029)
1555   · only create batch files on Windows
1556   · fix option and cache syntax
1557   · add help-options target
1558   · share dbus-arch-deps.h.in with autotools rather than having our
1559     own version (fd.o #41033)
1560
1561 • Build tests successfully with older GLib, as found in e.g. Debian 6
1562   (fd.o #41219, Simon McVittie)
1563
1564 • Avoid use of deprecated GThread API (fd.o #44413, Martin Pitt)
1565
1566 • Build documentation correctly if man2html doesn't support filenames on
1567   its command-line (fd.o #43875, Jack Nagel)
1568
1569 • Improve test coverage. To get even more coverage, run the tests with
1570   DBUS_TEST_SLOW=1 (fd.o #38285, #42811; Simon McVittie)
1571
1572 • Reduce the size of the shared library by moving functionality only used
1573   by dbus-daemon, tests etc. into their internal library and deleting
1574   unused code (fd.o #34976, #39759; Simon McVittie)
1575
1576 • Add dbus-daemon --nopidfile option, overriding the configuration, for
1577   setups where the default configuration must include <pidfile/> to avoid
1578   breaking traditional init, but the pid file is in fact unnecessary; use
1579   it under systemd to improve startup time a bit (fd.o #45520,
1580   Lennart Poettering)
1581
1582 • Optionally (if configured --with-valgrind) add instrumentation to debug
1583   libdbus and associated tools more meaningfully under Valgrind
1584   (fd.o #37286, Simon McVittie)
1585
1586 • Improve the dbus-send(1) man page (fd.o #14005, Simon McVittie)
1587
1588 • Make dbus-protocol.h compatible with C++11 (fd.o #46147, Marc Mutz)
1589
1590 • If tests are enabled and DBUS_MALLOC_CANNOT_FAIL is set in the environment,
1591   abort on failure to malloc() (like GLib does), to turn runaway memory leaks
1592   into a debuggable core-dump if a resource limit is applied (fd.o #41048,
1593   Simon McVittie)
1594
1595 • Don't crash if realloc() returns NULL in a debug build (fd.o #41048,
1596   Simon McVittie)
1597
1598 • Unix-specific:
1599   · Replace our broken reimplementation of recursive mutexes, which has
1600     been broken since 2006, with an ordinary pthreads recursive mutex
1601     (fd.o #43744; Sigmund Augdal, Simon McVittie)
1602   · Use epoll(7) for a more efficient main loop in Linux; equivalent patches
1603     welcomed for other OSs' equivalents like kqueue, /dev/poll, or Solaris
1604     event ports (fd.o #33337; Simon McVittie, Ralf Habacker)
1605   · When running under systemd, use it instead of ConsoleKit to check
1606     whether to apply at_console policies (fd.o #39609, Lennart Poettering)
1607   · Avoid a highly unlikely fd leak (fd.o #29881, Simon McVittie)
1608   · Don't close invalid fd -1 if getaddrinfo fails (fd.o #37258, eXeC001er)
1609   · Don't touch ~/.dbus and ~/.dbus-keyrings when running 'make installcheck'
1610     (fd.o #41218, Simon McVittie)
1611   · Stop pretending we respect XDG_DATA_DIRS for system services: the launch
1612     helper doesn't obey environment variables to avoid privilege escalation
1613     attacks, so make the system bus follow the same rules
1614     (fd.o #21620, Simon McVittie)
1615
1616 • Windows-specific:
1617   · Find the dbus-daemon executable next to the shared library (fd.o #41558;
1618     Jesper Dam, Ralf Habacker)
1619   · Remove the faulty implementation of _dbus_condvar_wake_all (fd.o #44609,
1620     Simon McVittie)
1621
1622 D-Bus 1.5.8 (2011-09-21)
1623 ==
1624
1625 The "cross-metering" release.
1626
1627 In addition to dead code removal and refactoring, this release contains all
1628 of the bugfixes from 1.4.16.
1629
1630 • Clean up dead code, and make more warnings fatal in development builds
1631   (fd.o #39231, fd.o #41012; Simon McVittie)
1632
1633 • If full test coverage is requested via --enable-tests, strictly require
1634   Python, pygobject and dbus-python, which are required by some tests; if not,
1635   and Python is missing, skip those tests rather than failing
1636   (fd.o #37847, Simon McVittie)
1637
1638 • When using cmake, provide the same version-info API in the installed headers
1639   as for autotools (DBUS_VERSION, etc.) (fd.o #40905, Ralf Habacker)
1640
1641 • Add a regression test for fd.o #38005 (fd.o #39836, Simon McVittie)
1642
1643 • Make "NOCONFIGURE=1 ./autogen.sh" not run configure (Colin Walters)
1644
1645 • Add _DBUS_STATIC_ASSERT and use it to check invariants (fd.o #39636,
1646   Simon McVittie)
1647
1648 • Fix duplicates in authors list (Ralf Habacker)
1649
1650 • Fix broken links from dbus-tutorial.html if $(htmldir) != $(docdir)
1651   (fd.o #39879, Chris Mayo)
1652
1653 • Fix a small memory leak, and a failure to report errors, when updating
1654   a service file entry for activation (fd.o #39230, Simon McVittie)
1655
1656 • Unix-specific:
1657   · Clean up (non-abstract) Unix sockets on bus daemon exit (fd.o #38656;
1658     Brian Cameron, Simon McVittie)
1659   · On systems that use libcap-ng but not systemd, drop supplemental groups
1660     when switching to the daemon user (Red Hat #726953, Steve Grubb)
1661   · Make the cmake build work again on GNU platforms (fd.o #29228,
1662     Simon McVittie)
1663   · Fix compilation on non-C99 systems that have inttypes.h but not stdint.h,
1664     like Solaris (fd.o #40313, Dagobert Michelsen)
1665   · Define CMSG_ALIGN, CMSG_LEN, CMSG_SPACE on Solaris < 10
1666     (fd.o #40235, Simon McVittie)
1667   · Cope with Unixes that don't have LOG_PERROR, like Solaris 10
1668     (fd.o #39987, Simon McVittie)
1669   · Cope with platforms whose vsnprintf violates both POSIX and C99, like
1670     Tru64, IRIX and HP-UX (fd.o #11668, Simon McVittie)
1671
1672 • Windows-specific:
1673   · Fix compilation on MSVC, which doesn't understand "inline" with its
1674     C99 meaning (fd.o #40000; Ralf Habacker, Simon McVittie)
1675   · Fix misuse of GPid in test/dbus-daemon.c (fd.o #40003, Simon McVittie)
1676   · Fix cross-compilation to Windows with Automake (fd.o #40003, Simon McVittie)
1677
1678 D-Bus 1.5.6 (2011-07-29)
1679 ==
1680
1681 The "weird, gravy-like aftertaste" release.
1682
1683 In addition to new features and refactoring, this release contains all of the
1684 bugfixes from 1.4.14.
1685
1686 Potentially incompatible (Bustle and similar debugging tools will need
1687 changes to work as intended):
1688
1689 • Do not allow match rules to "eavesdrop" (receive messages intended for a
1690   different recipient) by mistake: eavesdroppers must now opt-in to this
1691   behaviour by putting "eavesdrop='true'" in the match rule, which will
1692   not have any practical effect on buses where eavesdropping is not allowed
1693   (fd.o #37890, Cosimo Alfarano)
1694
1695 Other changes:
1696
1697 • D-Bus Specification version 0.18 (fd.o #37890, fd.o #39450, fd.o #38252;
1698   Cosimo Alfarano, Simon McVittie)
1699   · add the "eavesdrop" keyword to match rules
1700   · define eavesdropping, unicast messages and broadcast messages
1701   · stop claiming that match rules are needed to match unicast messages to you
1702   · promote the type system to be a top-level section
1703
1704 • Use DBUS_ERROR_OBJECT_PATH_IN_USE if dbus_connection_try_register_object_path
1705   or dbus_connection_try_register_fallback fails, not ...ADDRESS_IN_USE,
1706   and simplify object-path registration (fd.o #38874, Jiří Klimeš)
1707
1708 • Consistently use atomic operations on everything that is ever manipulated
1709   via atomic ops, as was done for changes to DBusConnection's refcount in
1710   1.4.12 (fd.o #38005, Simon McVittie)
1711
1712 • Fix a file descriptor leak when connecting to a TCP socket (fd.o #37258,
1713   Simon McVittie)
1714
1715 • Make "make check" in a clean tree work, by not running tests until
1716   test data has been set up (fd.o #34405, Simon McVittie)
1717
1718 • The dbus-daemon no longer busy-loops if it has a very large number of file
1719   descriptors (fd.o #23194, Simon McVittie)
1720
1721 • Refactor message flow through dispatching to avoid locking violations if
1722   the bus daemon's message limit is hit; remove the per-connection link cache,
1723   which was meant to improve performance, but now reduces it (fd.o #34393,
1724   Simon McVittie)
1725
1726 • Some cmake fixes (Ralf Habacker)
1727
1728 • Remove dead code, mainly from DBusString (fd.o #38570, fd.o #39610;
1729   Simon McVittie, Lennart Poettering)
1730
1731 • Stop storing two extra byte order indicators in each D-Bus message
1732   (fd.o #38287, Simon McVittie)
1733
1734 • Add an optional Stats interface which can be used to get statistics from
1735   a running dbus-daemon if enabled at configure time with --enable-stats
1736   (fd.o #34040, Simon McVittie)
1737
1738 • Fix various typos (fd.o #27227, fd.o #38284; Sascha Silbe, Simon McVittie)
1739
1740 • Documentation (fd.o #36156, Simon McVittie):
1741   · let xsltproc be overridden as usual: ./configure XSLTPROC=myxsltproc
1742   · install more documentation automatically, including man2html output
1743   · put dbus.devhelp in the right place (it must go in ${htmldir})
1744
1745 • Unix-specific:
1746   · look for system services in /lib/dbus-1/system-services in addition to all
1747     the other well-known locations; note that this should always be /lib,
1748     even on platforms where shared libraries on the root FS would go in /lib64,
1749     /lib/x86_64-linux-gnu or similar (fd.o #35229, Lennart Poettering)
1750   · opt-in to fd passing on Solaris (fd.o #33465, Simon McVittie)
1751
1752 • Windows-specific (Ralf Habacker):
1753   · fix use of a mutex for autolaunch server detection
1754   · don't crash on malloc failure in _dbus_printf_string_upper_bound
1755
1756 D-Bus 1.5.4 (2011-06-10)
1757 ==
1758
1759 Security (local denial of service):
1760
1761 • Byte-swap foreign-endian messages correctly, preventing a long-standing
1762   local DoS if foreign-endian messages are relayed through the dbus-daemon
1763   (backporters: this is git commit c3223ba6c401ba81df1305851312a47c485e6cd7)
1764   (CVE-2011-2200, fd.o #38120, Debian #629938; Simon McVittie)
1765
1766 New things:
1767
1768 • The constant to use for an infinite timeout now has a name,
1769   DBUS_TIMEOUT_INFINITE. It is numerically equivalent to 0x7fffffff (INT32_MAX)
1770   which can be used for source compatibility with older versions of libdbus.
1771
1772 • If GLib and DBus-GLib are already installed, more tests will be built,
1773   providing better coverage. The new tests can also be installed via
1774       ./configure --enable-installed-tests
1775   for system integration testing, if required. (fd.o #34570, Simon McVittie)
1776
1777 Changes:
1778
1779 • Consistently use atomic operations for the DBusConnection's refcount,
1780   fixing potential threading problems (fd.o #38005, Simon McVittie)
1781
1782 • Don't use -Wl,--gc-sections by default: in practice the size decrease is
1783   small (300KiB on x86-64) and it frequently doesn't work in unusual
1784   toolchains. To optimize for minimum installed size, you should benchmark
1785   various possibilities for CFLAGS and LDFLAGS, and set the best flags for
1786   your particular toolchain at configure time. (fd.o #33466, Simon McVittie)
1787
1788 • Use #!/bin/sh for run-with-tmp-session-bus.sh, making it work on *BSD
1789   (fd.o #35880, Timothy Redaelli)
1790
1791 • Use ln -fs to set up dbus for systemd, which should fix reinstallation
1792   when not using a DESTDIR (fd.o #37870, Simon McVittie)
1793
1794 • Windows-specific changes:
1795   · don't try to build dbus-daemon-launch-helper (fd.o #37838, Mark Brand)
1796
1797 D-Bus 1.5.2 (2011-06-01)
1798 ==
1799
1800 The "Boar Hunter" release.
1801
1802 Notes for distributors:
1803
1804   This version of D-Bus no longer uses -fPIE by default. Distributions wishing
1805   to harden the dbus-daemon and dbus-launch-helper can re-enable this if their
1806   toolchain supports it reliably, via something like:
1807
1808     ./configure CFLAGS=-fPIE LDFLAGS="-pie -Wl,-z,relro"
1809
1810   or by using distribution-specific wrappers such as Debian's hardening-wrapper.
1811
1812 Changes:
1813
1814   • D-Bus Specification v0.17
1815     · Reserve the extra characters used in signatures by GVariant
1816       (fd.o #34529, Simon McVittie)
1817     · Define the ObjectManager interface (fd.o #34869, David Zeuthen)
1818   • Don't force -fPIE: distributions and libtool know better than we do whether
1819     it's desirable (fd.o #16621, fd.o #27215; Simon McVittie)
1820   • Allow --disable-gc-sections, in case your toolchain offers the
1821     -ffunction-sections, -fdata-sections and -Wl,--gc-sections options
1822     but they're broken, as seen on Solaris (fd.o #33466, Simon McVittie)
1823   • Install dbus-daemon and dbus-daemon-launch-helper in a more normal way
1824     (fd.o #14512; Simon McVittie, loosely based on a patch from Luca Barbato)
1825   • Ensure that maintainers upload documentation with the right permissions
1826     (fd.o #36130, Simon McVittie)
1827   • Don't force users of libdbus to be linked against -lpthread, -lrt
1828     (fd.o #32827, Simon McVittie)
1829   • Log system-bus activation information to syslog (fd.o #35705,
1830     Colin Walters)
1831   • Log messages dropped due to quotas to syslog (fd.o #35358,
1832     Simon McVittie)
1833   • Make the nonce-tcp transport work on Unix (fd.o #34569, Simon McVittie)
1834   • On Unix, if /var/lib/dbus/machine-id cannot be read, try /etc/machine-id
1835     (fd.o #35228, Lennart Poettering)
1836   • In the regression tests, don't report fds as "leaked" if they were open
1837     on startup (fd.o #35173, Simon McVittie)
1838   • Make dbus-monitor bail out if asked to monitor more than one bus,
1839     rather than silently using the last one (fd.o #26548, Will Thompson)
1840   • Clarify documentation (fd.o #35182, Simon McVittie)
1841   • Clean up minor dead code and some incorrect error handling
1842     (fd.o #33128, fd.o #29881; Simon McVittie)
1843   • Check that compiler options are supported before using them (fd.o #19681,
1844     Simon McVittie)
1845   • Windows:
1846     • Remove obsolete workaround for winioctl.h (fd.o #35083, Ralf Habacker)
1847
1848 D-Bus 1.5.0 (2011-04-11)
1849 ==
1850
1851 The "you never know when you need to tow something from your giant
1852 flying shark" release.
1853
1854   • D-Bus Specification v0.16
1855     · Add support for path_namespace and arg0namespace in match rules
1856       (fd.o #24317, #34870; Will Thompson, David Zeuthen, Simon McVittie)
1857     · Make argNpath support object paths, not just object-path-like strings,
1858       and document it better (fd.o #31818, Will Thompson)
1859   • Let the bus daemon implement more than one interface (fd.o #33757,
1860     Simon McVittie)
1861   • Optimize _dbus_string_replace_len to reduce waste (fd.o #21261,
1862     Roberto Guido)
1863   • Require user intervention to compile with missing 64-bit support
1864     (fd.o #35114, Simon McVittie)
1865   • Add dbus_type_is_valid as public API (fd.o #20496, Simon McVittie)
1866   • Raise UnknownObject instead of UnknownMethod for calls to methods on
1867     paths that are not part of the object tree, and UnknownInterface for calls
1868     to unknown interfaces in the bus daemon (fd.o #34527, Lennart Poettering)
1869
1870 D-Bus 1.4.8 (2011-04-08)
1871 ==
1872
1873 The "It's like the beginning of a lobster" release.
1874
1875   • Rename configure.in to configure.ac, and update it to modern conventions
1876     (fd.o #32245; Javier Jardón, Simon McVittie)
1877   • Correctly give XDG_DATA_HOME priority over XDG_DATA_DIRS (fd.o #34496,
1878     Anders Kaseorg)
1879   • Prevent X11 autolaunching if $DISPLAY is unset or empty, and add
1880     --disable-x11-autolaunch configure option to prevent it altogether
1881     in embedded environments (fd.o #19997, NB#219964; Simon McVittie)
1882   • Install the documentation, and an index for Devhelp (fd.o #13495,
1883     Debian #454142; Simon McVittie, Matthias Clasen)
1884   • If checks are not disabled, check validity of string-like types and
1885     booleans when sending them (fd.o #16338, NB#223152; Simon McVittie)
1886   • Add UnknownObject, UnknownInterface, UnknownProperty and PropertyReadOnly
1887     errors to dbus-shared.h (fd.o #34527, Lennart Poettering)
1888   • Break up a huge conditional in config-parser so gcov can produce coverage
1889     data (fd.o #10887, Simon McVittie)
1890   • List which parts of the Desktop Entry specification are applicable to
1891     .service files (fd.o #19159, Sven Herzberg)
1892   • Don't suppress service activation if two services have the same Exec=
1893     (fd.o #35750, Colin Walters)
1894   • Windows:
1895     · Avoid the name ELEMENT_TYPE due to namespace-pollution from winioctl.h
1896       (Andre Heinecke)
1897     · Include _dbus_path_is_absolute in libdbus on Windows, fixing compilation
1898       (fd.o #32805, Mark Brand)
1899
1900 D-Bus 1.4.6 (2010-02-17)
1901 ==
1902
1903 The "1, 2, miss a few, 99, 100" release.
1904
1905   • Remove unfinished changes intended to support GTest-based tests,
1906     which were mistakenly included in 1.4.4
1907
1908 D-Bus 1.4.4 (2010-02-17)
1909 ==
1910
1911   • Switch back to using even micro versions for stable releases; 1.4.1
1912     should have been called 1.4.2, so skip that version number
1913   • Don't leave bad file descriptors being watched when spawning processes,
1914     which could result in a busy-loop (fd.o #32992, NB#200248; possibly
1915     also LP#656134, LP#680444, LP#713157)
1916   • Check for MSG_NOSIGNAL correctly
1917   • Fix failure to detect abstract socket support (fd.o #29895)
1918   • Make _dbus_system_logv actually exit with DBUS_SYSTEM_LOG_FATAL
1919     (fd.o #32262, NB#180486)
1920   • Improve some error code paths (fd.o #29981, fd.o #32264, fd.o #32262,
1921     fd.o #33128, fd.o #33277, fd.o #33126, NB#180486)
1922   • Avoid possible symlink attacks in /tmp during compilation (fd.o #32854)
1923   • Tidy up dead code (fd.o #25306, fd.o #33128, fd.o #34292, NB#180486)
1924   • Improve gcc malloc annotations (fd.o #32710)
1925   • If the system bus is launched via systemd, protect it from the OOM killer
1926   • Documentation improvements (fd.o #11190)
1927   • Avoid readdir_r, which is difficult to use correctly (fd.o #8284,
1928     fd.o #15922, LP#241619)
1929   • Cope with invalid files in session.d, system.d (fd.o #19186,
1930     Debian #230231)
1931   • Don't distribute generated files that embed our builddir (fd.o #30285,
1932     fd.o #34292)
1933   • Raise the system bus's fd limit to be sufficient for its configuration
1934     (fd.o #33474, LP#381063)
1935   • Fix syslog string processing
1936   • Ignore -Waddress
1937   • Remove broken gcov parsing code and --enable-gcov, and replace them
1938     with lcov HTML reports and --enable-compiler-coverage (fd.o #10887)
1939   • Windows:
1940     · avoid live-lock in Windows CE due to unfair condition variables
1941   • OpenBSD:
1942     · support credentials-passing (fd.o #32542)
1943   • Solaris:
1944     · opt-in to thread safety (fd.o #33464)
1945
1946 D-Bus 1.4.1 (20 December 2010)
1947 ==
1948
1949  • Fix for CVE-2010-4352: sending messages with excessively-nested variants can
1950    crash the bus. The existing restriction to 64-levels of nesting previously
1951    only applied to the static type signature; now it also applies to dynamic
1952    nesting using variants. Thanks to Rémi Denis-Courmont for discoving this
1953    issue.
1954  • OS X portability fixes, including launchd support.
1955  • Windows autolaunch improvements.
1956  • Various bug fixes.
1957
1958 D-Bus 1.4.0 (6 Sep 2010)
1959 ==
1960  - systemd hookup
1961
1962 D-Bus 1.3.1 (23 June 2010)
1963 ==
1964  - New standardized PropertiesChanged signal in the properties interface
1965  - Various portability fixes, in particular to Windows platforms
1966  - Support forking bus services, for compatibility
1967
1968 D-Bus 1.3.0 (29 July 2009)
1969 ==
1970  - ability for dbus-send to send to any bus (--address)
1971  - file descriptor passing on Unix socket transports
1972  - use of GCC atomic intrinsics for better processor support
1973    (requires -march=i486 or above for x86 compilation)
1974  - thread-safe FD_CLOEXEC setting on recent Linux kernels (2.6.24-27 and up)
1975    and glibc (2.9 for pipe2 and 2.10 for accept4)
1976  - feature negotiation in the bus daemon