]> git.ipfire.org Git - thirdparty/dbus.git/log
thirdparty/dbus.git
4 years agoMerge branch 'spec-correction' into 'master' 34/merge
Zeeshan Ali [Tue, 16 Mar 2021 12:07:08 +0000 (12:07 +0000)] 
Merge branch 'spec-correction' into 'master'

Add a few clarifications to the spec

See merge request dbus/dbus!203

4 years agospec: Clarify Array element needs to be padded even if inexistent
Zeeshan Ali [Wed, 24 Feb 2021 11:34:08 +0000 (12:34 +0100)] 
spec: Clarify Array element needs to be padded even if inexistent

4 years agospec: Clarify that Variant's value needs padding
Zeeshan Ali [Wed, 24 Feb 2021 11:16:08 +0000 (12:16 +0100)] 
spec: Clarify that Variant's value needs padding

4 years agoMerge branch 'ci' into 'master'
Simon McVittie [Wed, 13 Jan 2021 15:05:17 +0000 (15:05 +0000)] 
Merge branch 'ci' into 'master'

ci: bump msys2 deps, fix broken links

See merge request dbus/dbus!201

4 years agoci: bump msys2 deps, fix broken links
Marc-André Lureau [Sun, 10 Jan 2021 18:54:43 +0000 (22:54 +0400)] 
ci: bump msys2 deps, fix broken links

Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
4 years agoReference CVE-2020-35512 in NEWS
Simon McVittie [Thu, 7 Jan 2021 11:55:19 +0000 (11:55 +0000)] 
Reference CVE-2020-35512 in NEWS

Signed-off-by: Simon McVittie <smcv@collabora.com>
4 years agoMerge branch 'cmake-add-unit-test-macro' into 'master'
Ralf Habacker [Fri, 11 Dec 2020 09:11:31 +0000 (09:11 +0000)] 
Merge branch 'cmake-add-unit-test-macro' into 'master'

cmake: add macro add_unit_test to reduce code duplication

See merge request dbus/dbus!196

4 years agocmake: add macro add_unit_test to reduce code duplication
Ralf Habacker [Sat, 14 Nov 2020 11:30:32 +0000 (12:30 +0100)] 
cmake: add macro add_unit_test to reduce code duplication

This macro is now used by add_test_executable and
add_session_test_executable.

4 years agoMerge branch 'ci-dependency-fixes' into 'master'
Ralf Habacker [Tue, 24 Nov 2020 07:18:19 +0000 (07:18 +0000)] 
Merge branch 'ci-dependency-fixes' into 'master'

Cleanup package installation on CI

See merge request dbus/dbus!187

4 years agotools/ci-install.sh: Use package=() style for local package list to avoid '\' notation
Ralf Habacker [Tue, 10 Nov 2020 22:35:16 +0000 (23:35 +0100)] 
tools/ci-install.sh: Use package=() style for local package list to avoid '\' notation

4 years agoOn CI use common install prefix named 'dep_prefix' for installing local packages
Ralf Habacker [Mon, 9 Nov 2020 09:58:22 +0000 (10:58 +0100)] 
On CI use common install prefix named 'dep_prefix' for installing local packages

With this commit a new variable 'ci_local_packages' has been introduced
to have a choice for using development packages from a local installation
or from the distribution.

4 years agotools/ci-build.sh: Clean up directories from possible previous builds
Ralf Habacker [Mon, 9 Nov 2020 10:06:14 +0000 (11:06 +0100)] 
tools/ci-build.sh: Clean up directories from possible previous builds

Otherwise, ci-build.sh cannot be executed on a local system if there
are previous runs.

4 years agotools/ci-install.sh: merge multiple calls to apt-get
Ralf Habacker [Fri, 6 Nov 2020 11:08:12 +0000 (12:08 +0100)] 
tools/ci-install.sh: merge multiple calls to apt-get

This required a reorganization of the steps that had been carried out.
The new order is:
   1. install packages with apt-get
   2. create user for build if required
   3. fetch and unpack tar balls
   4. create messagebus user

4 years agoMove installing packages into tools/ci-install.sh
Ralf Habacker [Fri, 6 Nov 2020 08:45:40 +0000 (09:45 +0100)] 
Move installing packages into tools/ci-install.sh

In tools/ci-build.sh the cross compile setup has to be moved further up
to match the correct subdirectory.

4 years agoMerge branch 'misc-windows-fixes' into 'master'
Simon McVittie [Mon, 23 Nov 2020 14:45:32 +0000 (14:45 +0000)] 
Merge branch 'misc-windows-fixes' into 'master'

sysdeps-win: Expand/fix verbose logging

See merge request dbus/dbus!193

4 years ago_dbus_poll_select (): fix concating multiple verbose lines
Ralf Habacker [Tue, 5 May 2020 22:28:04 +0000 (00:28 +0200)] 
_dbus_poll_select (): fix concating multiple verbose lines

4 years agoAdd verbose info to publishing session bus related functions
Ralf Habacker [Tue, 5 Feb 2019 15:13:42 +0000 (16:13 +0100)] 
Add verbose info to publishing session bus related functions

This is useful for tracking auto launch support in dbus-daemon.

4 years agoMerge branch 'update-selinux-auditing' into 'master'
Simon McVittie [Mon, 23 Nov 2020 13:23:12 +0000 (13:23 +0000)] 
Merge branch 'update-selinux-auditing' into 'master'

bus/selinux: Fix audit message types.

See merge request dbus/dbus!173

4 years agobus/selinux: Fix audit message types.
Chris PeBenito [Mon, 14 Sep 2020 15:34:04 +0000 (11:34 -0400)] 
bus/selinux: Fix audit message types.

The SELinux log callback includes a message type. Not all messages are
auditable and those that are have varying audit types. An audit message is
a security-relevant event: security state changes, MAC permission denied,
etc.  A message that is auditable is not necessarily sensitive.  Messages
that are not auditable are not security-relevant, like messages about
socket polling errors.  Update the auditing accordingly.

If the message is not auditable, fall through and write it to syslog.

Signed-off-by: Chris PeBenito <chpebeni@linux.microsoft.com>
4 years agoMerge branch 'travis-ci-cleanup' into 'master'
Simon McVittie [Mon, 23 Nov 2020 12:06:10 +0000 (12:06 +0000)] 
Merge branch 'travis-ci-cleanup' into 'master'

Drop unused travis CI configuration files

See merge request dbus/dbus!197

4 years agoDrop unused travis CI configuration files
Ralf Habacker [Tue, 10 Nov 2020 18:57:18 +0000 (19:57 +0100)] 
Drop unused travis CI configuration files

4 years agoMerge branch 'bug/NEWS-machine-id-paths' into 'master'
Simon McVittie [Mon, 9 Nov 2020 15:00:39 +0000 (15:00 +0000)] 
Merge branch 'bug/NEWS-machine-id-paths' into 'master'

NEWS: Add missing directory 'lib' to three paths

See merge request dbus/dbus!182

5 years agoNEWS: Add missing directory 'lib' to three paths
Samy Mahmoudi [Thu, 5 Nov 2020 23:13:23 +0000 (18:13 -0500)] 
NEWS: Add missing directory 'lib' to three paths

Since ${localstatedir}/dbus should be ${localstatedir}/lib/dbus,
insert the missing directory 'lib' into the three erroneous paths.

5 years agoMerge branch 'macos-x11-bugfix' into 'master'
Simon McVittie [Fri, 6 Nov 2020 17:26:28 +0000 (17:26 +0000)] 
Merge branch 'macos-x11-bugfix' into 'master'

dbus-launch: Replace slashes in DISPLAY if present

Closes #8 and #311

See merge request dbus/dbus!180

5 years agodbus-launch: Replace slashes in DISPLAY if present
William Earley [Sun, 27 Sep 2020 11:39:04 +0000 (12:39 +0100)] 
dbus-launch: Replace slashes in DISPLAY if present

dbus-daemon fails to autolaunch with X11 on macOS 10.8+ because XQuartz
(the X11 package for macOS) provides a value for `$DISPLAY` that is
not expected by dbus, in that it contains `/` characters. This is
addressed by replacing the invalid path character `/` with `_`.

Resolves: #8
Resolves: #311

5 years agoMerge branch 'macos-setrlimit-bugfix' into 'master'
Simon McVittie [Fri, 6 Nov 2020 15:20:51 +0000 (15:20 +0000)] 
Merge branch 'macos-setrlimit-bugfix' into 'master'

sysdeps: Don't raise RLIMIT_NOFILE beyond OPEN_MAX on macOS

Closes #309

See merge request dbus/dbus!178

5 years agosysdeps: Don't raise RLIMIT_NOFILE beyond OPEN_MAX on macOS
William Earley [Sun, 27 Sep 2020 11:24:30 +0000 (12:24 +0100)] 
sysdeps: Don't raise RLIMIT_NOFILE beyond OPEN_MAX on macOS

dbus-daemon fails to launch on macOS 10.5 and above because of a breaking
change in setrlimit, in which RLIM_INFINITY is no longer supported
for RLIMIT_NOFILE. Instead we must use OPEN_MAX.

Resolves: #309

5 years agoMerge branch 'docs-generate-reproducible-ids' into 'master'
Simon McVittie [Fri, 6 Nov 2020 14:01:46 +0000 (14:01 +0000)] 
Merge branch 'docs-generate-reproducible-ids' into 'master'

docs: generate reproducible ids

See merge request dbus/dbus!189

5 years agodocs: generate reproducible ids
Arnout Engelen [Thu, 5 Nov 2020 20:27:02 +0000 (21:27 +0100)] 
docs: generate reproducible ids

With this parameter, docbook will generate the same id's when generating the
same docs. This is helpful to get bit-by-bit 'reproducible' output, which
makes auditing the package easier.

Tested both the cmake output and the automake output

5 years agoMerge branch 'wip/update-msys-packages' into 'master'
Simon McVittie [Fri, 6 Nov 2020 13:51:17 +0000 (13:51 +0000)] 
Merge branch 'wip/update-msys-packages' into 'master'

ci-build: Update required MSYS packages

Closes #318

See merge request dbus/dbus!190

5 years agoci-build: Update required MSYS packages
Simon McVittie [Fri, 6 Nov 2020 13:38:45 +0000 (13:38 +0000)] 
ci-build: Update required MSYS packages

The older versions we were previously building against are no longer
available on mirrors.

Based on changes proposed in !189 by Arnout Engelen, and the package
list gathered by Ralf Habacker in #318.

Resolves: https://gitlab.freedesktop.org/dbus/dbus/-/issues/318
Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agoMerge branch 'patch-1' into 'master'
Simon McVittie [Mon, 19 Oct 2020 19:49:03 +0000 (19:49 +0000)] 
Merge branch 'patch-1' into 'master'

doc: Fix typo in dbus-daemon(1)

See merge request dbus/dbus!183

5 years agodoc: Fix typo in dbus-daemon(1)
Chigozirim Chukwu [Mon, 19 Oct 2020 18:38:09 +0000 (18:38 +0000)] 
doc: Fix typo in dbus-daemon(1)

5 years agoMerge branch 'glibc' into 'master'
Simon McVittie [Mon, 28 Sep 2020 13:42:55 +0000 (13:42 +0000)] 
Merge branch 'glibc' into 'master'

disable fork-malloc-exec for non-glibc-systems

See merge request dbus/dbus!181

5 years agodisable fork-malloc-exec for non-glibc-systems
Jean-Louis Fuchs [Mon, 28 Sep 2020 12:45:15 +0000 (14:45 +0200)] 
disable fork-malloc-exec for non-glibc-systems

Calling malloc() after fork is undefined behaviour if the process is
multi-threaded. locks held by a thread on fork() will never be released.
malloc() is usally protected by a lock and can therefore deadlock. glibc
is known not to deadlock in this case.

This commit does not rule out other problems on glibc-systems, but fixes an
issue on musl-libc-systems. Only restricting to async-signal safe functions
between fork() and exec() prevents undefined behaviour for sure. See
signal-safety(7).

5 years agoMerge branch 'cmake-enable-traditional-activation' into 'master'
Simon McVittie [Thu, 24 Sep 2020 10:48:47 +0000 (10:48 +0000)] 
Merge branch 'cmake-enable-traditional-activation' into 'master'

CMake: allow traditional activation to be disabled

See merge request dbus/dbus!159

5 years agocmake: make support for traditional activation optional
Ralf Habacker [Wed, 23 Sep 2020 14:32:54 +0000 (16:32 +0200)] 
cmake: make support for traditional activation optional

Traditional activation is enabled/disabled with the cmake configure
parameter -DENABLE_TRADITIONAL_ACTIVATION, which is enabled by default.

This was added to the Autotools build system as part of dbus/dbus!107
but until now was not possible to disable when building with CMake.

5 years agoMerge branch 'cmake-fixup' into 'master'
Ralf Habacker [Wed, 23 Sep 2020 15:02:08 +0000 (15:02 +0000)] 
Merge branch 'cmake-fixup' into 'master'

cmake: move up checking DBUS_ENABLE_EMBEDDED_TESTS from subdir test/name-test to test

See merge request dbus/dbus!177

5 years agocmake: move up checking DBUS_ENABLE_EMBEDDED_TESTS from subdir test/name-test to...
Ralf Habacker [Mon, 27 Apr 2020 18:24:57 +0000 (20:24 +0200)] 
cmake: move up checking DBUS_ENABLE_EMBEDDED_TESTS from subdir test/name-test to test

The whole file is only added with the mentioned variable
set, so it can also be skipped completly one level up.

5 years agoMerge branch 'install-ddlh' into 'master'
Simon McVittie [Wed, 23 Sep 2020 14:18:48 +0000 (14:18 +0000)] 
Merge branch 'install-ddlh' into 'master'

cmake: install dbus-daemon-launch-helper

Closes #310

See merge request dbus/dbus!175

5 years agocmake: install dbus-daemon-launch-helper on Unix
Ralf Habacker [Mon, 21 Sep 2020 12:36:24 +0000 (14:36 +0200)] 
cmake: install dbus-daemon-launch-helper on Unix

Previously it was built on Unix platforms, but not installed. This
would prevent traditional activation on the system bus (on Linux
without systemd or non-Linux, or for services without SystemdService),
which requires the activation helper.

Because the executable is an internal implementation detail of how
traditional activation is implemented on Unix, it is not exported to
the generated cmake support files.

Resolves: dbus#310

5 years agoMerge branch 'spec-cookie-timeouts' into 'master'
Simon McVittie [Mon, 21 Sep 2020 11:23:25 +0000 (11:23 +0000)] 
Merge branch 'spec-cookie-timeouts' into 'master'

spec: Update recommendations for DBUS_COOKIE_SHA1 timeouts

See merge request dbus/dbus!171

5 years agospec: Update recommendations for DBUS_COOKIE_SHA1 timeouts
Simon McVittie [Mon, 7 Sep 2020 10:57:19 +0000 (11:57 +0100)] 
spec: Update recommendations for DBUS_COOKIE_SHA1 timeouts

This had two issues that could damage interoperability.

First, the spec wording suggested that any cookie that had not been
deleted was suitable for use in authentication. However, this introduces
a race condition, which is called out in comments in both the reference
implementation and GDBus: the newest cookie might be less old than the
arbitrary lifetime when authentication *begins*, but older than the
lifetime at the time authentication *ends*. As a result, we need a grace
period during which an old cookie will still be accepted, but a newer
cookie exists and will be used for new authentication operations.

Second, the spec wording implied that the arbitrary timeouts were
completely up to the implementor. However, GLib bug
https://gitlab.gnome.org/GNOME/glib/-/issues/2164 indicates that they
need to be reasonably compatible: in particular, GDBus servers
historically didn't allocate new cookies until 10 minutes had passed,
but libdbus clients would decline to use a cookie older than 5 minutes,
causing authentication to fail if the gdbus-server test-case (in which
GDBus and libdbus clients connect to a GDBus server) happened to take
longer than 5 minutes to run.

While I'm here, also be consistent about calling the secrets "cookies"
(consistent with the name of the mechanism) rather than "keys" (which
is what they are called in libdbus' dbus-keyring.c).

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agoMerge branch 'glib-tests-on-freebsd' into 'master'
Simon McVittie [Wed, 19 Aug 2020 14:28:04 +0000 (14:28 +0000)] 
Merge branch 'glib-tests-on-freebsd' into 'master'

tests: On Unix, include <netinet/in.h> for IPPROTO_TCP

See merge request dbus/dbus!167

5 years agotests: On Unix, include <netinet/in.h> for IPPROTO_TCP
Simon McVittie [Wed, 1 Jul 2020 15:01:38 +0000 (16:01 +0100)] 
tests: On Unix, include <netinet/in.h> for IPPROTO_TCP

Otherwise, dbus doesn't compile on FreeBSD if the GLib-based tests
are enabled (which suggests that no FreeBSD user has run those tests
successfully).

We already include <netinet/in.h> in other places with no conditions
or checks other than "is Unix", so apparently it's portable enough that
specifically testing for its presence is not necessary. POSIX requires it
to exist.

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agov1.13.18 dbus-1.13.18
Simon McVittie [Thu, 2 Jul 2020 10:09:48 +0000 (11:09 +0100)] 
v1.13.18

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agoUpdate NEWS
Simon McVittie [Thu, 2 Jul 2020 09:24:55 +0000 (10:24 +0100)] 
Update NEWS

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agoMerge branch 'issue305' into 'master'
Simon McVittie [Wed, 1 Jul 2020 13:29:39 +0000 (13:29 +0000)] 
Merge branch 'issue305' into 'master'

userdb: Reference-count DBusUserInfo, DBusGroupInfo

Closes #305

See merge request dbus/dbus!166

5 years agouserdb: Reference-count DBusUserInfo, DBusGroupInfo
Simon McVittie [Tue, 30 Jun 2020 18:29:06 +0000 (19:29 +0100)] 
userdb: Reference-count DBusUserInfo, DBusGroupInfo

Previously, the hash table indexed by uid (or gid) took ownership of the
single reference to the heap-allocated struct, and the hash table
indexed by username (or group name) had a borrowed pointer to the same
struct that exists in the other hash table.

However, this can break down if you have two or more distinct usernames
that share a numeric identifier. This is generally a bad idea, because
the user-space model in such situations does not match the kernel-space
reality, and in particular there is no effective kernel-level security
boundary between such users, but it is sometimes done anyway.

In this case, when the second username is looked up in the userdb, it
overwrites (replaces) the entry in the hash table that is indexed by
uid, freeing the DBusUserInfo. This results in both the key and the
value in the hash table that is indexed by username becoming dangling
pointers (use-after-free), leading to undefined behaviour, which is
certainly not what we want to see when doing access control.

An equivalent situation can occur with groups, in the rare case where
a numeric group ID has two names (although I have not heard of this
being done in practice).

Solve this by reference-counting the data structure. There are up to
three references in practice: one held temporarily while the lookup
function is populating and storing it, one held by the hash table that
is indexed by uid, and one held by the hash table that is indexed by
name.

Closes: dbus#305
Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agouserdb: Make lookups return a const pointer
Simon McVittie [Tue, 30 Jun 2020 18:13:17 +0000 (19:13 +0100)] 
userdb: Make lookups return a const pointer

This makes it more obvious that the returned pointer points to a
struct owned by the userdb, which must not be freed or have its
contents modified, and is only valid to dereference until the next
modification to the userdb's underlying hash tables (which in practice
means until the lock is released, because after that we have no
guarantees about what might be going on in another thread).

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agoMerge branch 'illumos_cmsg' into 'master'
Simon McVittie [Mon, 15 Jun 2020 13:16:51 +0000 (13:16 +0000)] 
Merge branch 'illumos_cmsg' into 'master'

Solaris and derivatives do not adjust cmsg_len on MSG_CTRUNC

Closes #304

See merge request dbus/dbus!165

5 years agoSolaris and derivatives do not adjust cmsg_len on MSG_CTRUNC
Andy Fiddaman [Fri, 12 Jun 2020 12:32:20 +0000 (12:32 +0000)] 
Solaris and derivatives do not adjust cmsg_len on MSG_CTRUNC

5 years agoMerge branch 'cmake-fix-install' into 'master'
Simon McVittie [Wed, 10 Jun 2020 18:22:48 +0000 (18:22 +0000)] 
Merge branch 'cmake-fix-install' into 'master'

cmake: Fix installed files

See merge request dbus/dbus!155

5 years agocmake: add support for user session semantic on Linux operating systems
Ralf Habacker [Mon, 18 May 2020 10:47:51 +0000 (12:47 +0200)] 
cmake: add support for user session semantic on Linux operating systems

Systemd user support is controlled by the cmake variable ENABLE_USER_SESSION,
which and WITH_SYSTEMD_USERUNITDIR to specify a custom installation
location. If WITH_SYSTEMD_USERUNITDIR is not specified, the related install
path is determined from an installed systemd package, if present.

This was added to the Autotools build system as part of fd.o#61301,
but until now was not possible to enable when building with CMake.

5 years agocmake: Add support for systemd integration on Linux operating systems
Ralf Habacker [Mon, 18 May 2020 10:44:37 +0000 (12:44 +0200)] 
cmake: Add support for systemd integration on Linux operating systems

Previously, only the Autotools build system could do this. This commit
includes most of the same features as in the Autotools build, although
not the user-session semantics, which will be added separately.

Systemd support is controlled by the cmake variable ENABLE_SYSTEMD, which can
have the values OFF, ON and AUTO, the latter enabling support by default if
the required libraries are available.

With WITH_SYSTEMD_SYSTEMUNITDIR a custom installation location can be specified.
If it is not specified, the related install path is determined from the installed
systemd package, if present.

5 years agocmake: Add macro check_auto_option() as an addition to add_auto_option()
Ralf Habacker [Mon, 18 May 2020 10:51:03 +0000 (12:51 +0200)] 
cmake: Add macro check_auto_option() as an addition to add_auto_option()

check_auto_option() checks the values given to an auto-option and prints
a fatal error in case of invalid combinations.

5 years agocmake: rename tristateoption() to add_auto_option() and make signature compatible...
Ralf Habacker [Mon, 18 May 2020 10:02:36 +0000 (12:02 +0200)] 
cmake: rename tristateoption() to add_auto_option() and make signature compatible to option()

5 years agocmake: Use CMAKE_INSTALL_FULL_<dir> for configuration and state
Ralf Habacker [Thu, 23 Apr 2020 16:41:03 +0000 (18:41 +0200)] 
cmake: Use CMAKE_INSTALL_FULL_<dir> for configuration and state

This means we apply GNUInstallDirs' various special cases when
the prefix is /, /usr or something starting with /opt; these are
not applied when installing to CMAKE_INSTALL_<dir>. See
https://cmake.org/cmake/help/latest/module/GNUInstallDirs.html#special-cases

5 years agocmake: fix installation of example files
Ralf Habacker [Thu, 23 Apr 2020 16:37:54 +0000 (18:37 +0200)] 
cmake: fix installation of example files

5 years agoMerge branch 'normalize-trailing-newlines' into 'master'
Simon McVittie [Wed, 10 Jun 2020 10:56:26 +0000 (10:56 +0000)] 
Merge branch 'normalize-trailing-newlines' into 'master'

Normalize C source files to end with exactly one newline

See merge request dbus/dbus!162

5 years agoNormalize C source files to end with exactly one newline
Simon McVittie [Wed, 10 Jun 2020 08:47:15 +0000 (09:47 +0100)] 
Normalize C source files to end with exactly one newline

Some editors automatically remove trailing blank lines, or
automatically add a trailing newline to avoid having a trailing
non-blank line that is not terminated by a newline. To avoid unrelated
whitespace changes when users of such editors contribute to dbus,
let's pre-emptively normalize all files.

Unlike more intrusive whitespace normalization like removing trailing
whitespace from each line, this seems unlikely to cause significant
issues with cherry-picking changes to stable branches.

Implemented by:

    find . -name '*.[ch]' -print0 | \
    xargs -0 perl -0777 -p -i -e 's/\n+\z//g; s/\z/\n/g'

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agoMerge branch 'misc-comment' into 'master'
Simon McVittie [Wed, 10 Jun 2020 10:46:42 +0000 (10:46 +0000)] 
Merge branch 'misc-comment' into 'master'

dbus-protocol.h: fix DBUS_ERROR_SPAWN_NO_MEMORY comment

See merge request dbus/dbus!163

5 years agodbus-protocol.h: fix DBUS_ERROR_SPAWN_NO_MEMORY comment
Marc-André Lureau [Wed, 10 Jun 2020 10:25:59 +0000 (14:25 +0400)] 
dbus-protocol.h: fix DBUS_ERROR_SPAWN_NO_MEMORY comment

Although this error seems to be unused (DBUS_ERROR_NO_MEMORY is used
instead), let's correct the comment.

Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
5 years agoStart 1.13.18 development
Simon McVittie [Tue, 2 Jun 2020 20:07:31 +0000 (21:07 +0100)] 
Start 1.13.18 development

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agoPrepare 1.13.16 dbus-1.13.16
Simon McVittie [Tue, 2 Jun 2020 11:18:05 +0000 (12:18 +0100)] 
Prepare 1.13.16

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agofdpass test: Assert that we don't leak file descriptors
Simon McVittie [Thu, 16 Apr 2020 13:41:48 +0000 (14:41 +0100)] 
fdpass test: Assert that we don't leak file descriptors

Reproduces: dbus#294
Reproduces: CVE-2020-12049
Reproduces: GHSL-2020-057
Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agosysdeps-unix: On MSG_CTRUNC, close the fds we did receive
Simon McVittie [Thu, 16 Apr 2020 13:45:11 +0000 (14:45 +0100)] 
sysdeps-unix: On MSG_CTRUNC, close the fds we did receive

MSG_CTRUNC indicates that we have received fewer fds that we should
have done because the buffer was too small, but we were treating it
as though it indicated that we received *no* fds. If we received any,
we still have to make sure we close them, otherwise they will be leaked.

On the system bus, if an attacker can induce us to leak fds in this
way, that's a local denial of service via resource exhaustion.

Reported-by: Kevin Backhouse, GitHub Security Lab
Fixes: dbus#294
Fixes: CVE-2020-12049
Fixes: GHSL-2020-057
5 years agoUpdate NEWS
Simon McVittie [Mon, 1 Jun 2020 09:46:22 +0000 (10:46 +0100)] 
Update NEWS

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agoMerge branch 'ci-run-cross-compiled-tests' into 'master'
Simon McVittie [Fri, 29 May 2020 14:56:15 +0000 (14:56 +0000)] 
Merge branch 'ci-run-cross-compiled-tests' into 'master'

CI: run cross compiled tests

Closes #296

See merge request dbus/dbus!158

5 years agoCI: for cmake show the used command lines when compiling and linking
Ralf Habacker [Fri, 29 May 2020 14:43:24 +0000 (16:43 +0200)] 
CI: for cmake show the used command lines when compiling and linking

This helps to detect incorrect settings.

5 years agoCI: Add running test cases for cross builds
Ralf Habacker [Fri, 29 May 2020 14:40:44 +0000 (16:40 +0200)] 
CI: Add running test cases for cross builds

Before building a wine prefix is created and search pathes
for binaries are configured in the wine prefix.

This commit adds a new shell variable 'ci_runtime' for specifing
the type of compiler support library which defaults to static for now.

5 years agoMerge branch 'wine-symbol-support' into 'master'
Simon McVittie [Thu, 28 May 2020 19:08:29 +0000 (19:08 +0000)] 
Merge branch 'wine-symbol-support' into 'master'

Let Wine display the correct file name and line numbers for backtraces

See merge request dbus/dbus!104

5 years agocmake: Let Wine display the correct file name and line numbers for backtraces
Ralf Habacker [Tue, 5 Feb 2019 13:46:51 +0000 (14:46 +0100)] 
cmake: Let Wine display the correct file name and line numbers for backtraces

Wine currently only supports the symbol formats STABS and DWARF 2,
but not the other versions, with STABS providing the most information
and being the first choice.

Since we already use the cmake variable DBUS_USE_WINE for running tests
under Wine, we also use it to activate the special symbol format.

Closes dbus/dbus/#133

5 years ago.gitlab-ci.yml: Use x86_64 build chain to cross build 64bit executables
Ralf Habacker [Fri, 1 May 2020 11:27:20 +0000 (13:27 +0200)] 
.gitlab-ci.yml: Use x86_64 build chain to cross build 64bit executables

This error was discovered when working with the merge request
dbus/dbus!158.

5 years agocmake: Fix setting default value for DBUS_BUILD_TESTS too late
Ralf Habacker [Tue, 28 Apr 2020 19:52:47 +0000 (21:52 +0200)] 
cmake: Fix setting default value for DBUS_BUILD_TESTS too late

This prevented setting cross compile support required for !158.

5 years agoMerge branch 'cmake-build-missing-tools' into 'master'
Ralf Habacker [Thu, 30 Apr 2020 00:31:04 +0000 (00:31 +0000)] 
Merge branch 'cmake-build-missing-tools' into 'master'

Build missing tools with cmake

See merge request dbus/dbus!154

5 years agocmake: build and install dbus-cleanup-sockets on non Windows platforms
Ralf Habacker [Wed, 22 Apr 2020 13:03:30 +0000 (15:03 +0200)] 
cmake: build and install dbus-cleanup-sockets on non Windows platforms

5 years agocmake: build and install dbus-uuidgen on non Windows platforms
Ralf Habacker [Mon, 27 Apr 2020 18:19:57 +0000 (20:19 +0200)] 
cmake: build and install dbus-uuidgen on non Windows platforms

5 years agoMerge branch 'qthelp-docs-support' into 'master'
Ralf Habacker [Wed, 29 Apr 2020 15:32:32 +0000 (15:32 +0000)] 
Merge branch 'qthelp-docs-support' into 'master'

Add support to generate the api documentation in Qt help format

See merge request dbus/dbus!150

5 years agoAdd support to generate the api documentation in Qt help format
Ralf Habacker [Tue, 28 Apr 2020 17:03:59 +0000 (19:03 +0200)] 
Add support to generate the api documentation in Qt help format

Qt help files are used by Qt Creator and KDevelop, for example, to support
the development of Qt-based applications and libraries.

Generating api documentation in Qt help format is controlled by two
user specific options named --enable-qt-help and --with-qchdir (autotools)
and -DENABLE_QT_HELP and -DINSTALL_QCH_DIR (cmake).

5 years agocmake: remove component 'dev' as we never used that consistently
Ralf Habacker [Mon, 27 Apr 2020 20:12:18 +0000 (22:12 +0200)] 
cmake: remove component 'dev' as we never used that consistently

Marking targets with a component would only be useful if we
marked every target with a component in a consistent way,
but because we don't do that, it's pointless to have it
in just a few places.

5 years agoMerge branch 'fix-dbus_poll-buffer-overflow' into 'master'
Simon McVittie [Wed, 29 Apr 2020 10:59:08 +0000 (10:59 +0000)] 
Merge branch 'fix-dbus_poll-buffer-overflow' into 'master'

_dbus_poll(): Prevent buffer overflow in Windows verbose logging

See merge request dbus/dbus!125

5 years agoFix return type and usage of WSAWaitForMultipleEvents()
Ralf Habacker [Tue, 3 Dec 2019 01:23:29 +0000 (02:23 +0100)] 
Fix return type and usage of WSAWaitForMultipleEvents()

The former int type leads to warnings.

5 years agoAdd debug output functions for _dbus_poll_xx() functions
Ralf Habacker [Tue, 28 Apr 2020 05:06:41 +0000 (07:06 +0200)] 
Add debug output functions for _dbus_poll_xx() functions

5 years agoFix bug not detecting out of memory condition in _dbus_poll_events ()
Ralf Habacker [Tue, 28 Apr 2020 05:02:09 +0000 (07:02 +0200)] 
Fix bug not detecting out of memory condition in _dbus_poll_events ()

For cleaning purpose the event list members are initialized with
WSA_INVALID_EVENT. The cleanup code detects and handles the
case that the event list has been created from calloc ().

5 years agoSeparate the event based implementation for _dbus_poll() from the fd based one
Ralf Habacker [Tue, 28 Apr 2020 05:04:25 +0000 (07:04 +0200)] 
Separate the event based implementation for _dbus_poll() from the fd based one

The function _dbus_poll() has been split into two functions,
_dbus_poll_events() and _dbus_poll_select(), each containing the
corresponding implementation.

_dbus_poll() now calls the corresponding function.

5 years agodbus_poll(): Remove debug output to make room for a better implementation
Ralf Habacker [Tue, 3 Dec 2019 00:29:10 +0000 (01:29 +0100)] 
dbus_poll(): Remove debug output to make room for a better implementation

5 years agoMerge branch 'shell-test-tap' into 'master'
Simon McVittie [Tue, 28 Apr 2020 11:00:29 +0000 (11:00 +0000)] 
Merge branch 'shell-test-tap' into 'master'

shell-test: Print diagnostics to stderr

See merge request dbus/dbus!157

5 years agoshell-test: Print diagnostics to stderr
Félix Piédallu [Mon, 27 Apr 2020 18:15:54 +0000 (20:15 +0200)] 
shell-test: Print diagnostics to stderr

Some of the command-lines that we print as diagnostics contain newlines,
which will cause warnings or errors under a strict TAP parser (and one of
them wasn't correctly prefixed with '#' anyway). TAP parsers only parse
stdout, not stderr, so we can use stderr for these diagnostic messages.

[smcv: Expand commit message]

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agoMerge branch 'coverity-354884' into 'master'
Ralf Habacker [Mon, 27 Apr 2020 15:15:10 +0000 (15:15 +0000)] 
Merge branch 'coverity-354884' into 'master'

Free allocated buffer in test_content() to avoid a resource leak

See merge request dbus/dbus!146

5 years agodesktop-file test: Free result on all code paths
Ralf Habacker [Sat, 18 Apr 2020 11:34:19 +0000 (13:34 +0200)] 
desktop-file test: Free result on all code paths

Otherwise, Coverity will diagnose this as a resource leak,
because it doesn't understand that our assertions end up guaranteeing
that the result is freed if and only if it's non-`NULL`.

Coverity CID: 354884

5 years agoMerge branch 'dbus-get-autolaunch-address-stderr-fixes' into 'master'
Ralf Habacker [Mon, 27 Apr 2020 12:16:46 +0000 (12:16 +0000)] 
Merge branch 'dbus-get-autolaunch-address-stderr-fixes' into 'master'

In dbus_get_autolaunch_address() return all errors as dbus error

Closes #191

See merge request dbus/dbus!131

5 years agoIn dbus_get_autolaunch_address() return all errors as dbus error
Ralf Habacker [Sat, 18 Apr 2020 08:52:37 +0000 (10:52 +0200)] 
In dbus_get_autolaunch_address() return all errors as dbus error

This provides a consistent error reporting.

Fixes #191

5 years agoFix indention in _dbus_get_autolaunch_address()
Ralf Habacker [Sat, 18 Apr 2020 08:53:34 +0000 (10:53 +0200)] 
Fix indention in _dbus_get_autolaunch_address()

5 years agoMerge branch 'dbus_logv-uses-dbusstring' into 'master'
Ralf Habacker [Mon, 27 Apr 2020 12:01:30 +0000 (12:01 +0000)] 
Merge branch 'dbus_logv-uses-dbusstring' into 'master'

Fix possible truncation of protocol output in dbus_logv()

See merge request dbus/dbus!134

5 years ago_dbus_verbose_real: Use the Python convention for quoting potentially multi-line...
Ralf Habacker [Mon, 27 Apr 2020 12:01:30 +0000 (12:01 +0000)] 
_dbus_verbose_real: Use the Python convention for quoting potentially multi-line strings when memory is unavailable on Windows

5 years agoStart dbus 1.13.16 development
Simon McVittie [Tue, 21 Apr 2020 20:02:03 +0000 (21:02 +0100)] 
Start dbus 1.13.16 development

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agoReference implementation v1.13.14 and Specification v0.36 dbus-1.13.14
Simon McVittie [Tue, 21 Apr 2020 10:25:27 +0000 (11:25 +0100)] 
Reference implementation v1.13.14 and Specification v0.36

Signed-off-by: Simon McVittie <smcv@collabora.com>
5 years agoUpdate NEWS
Simon McVittie [Mon, 20 Apr 2020 18:28:05 +0000 (19:28 +0100)] 
Update NEWS

5 years agoMerge branch 'more-modular-tests' into 'master'
Simon McVittie [Mon, 20 Apr 2020 17:46:52 +0000 (17:46 +0000)] 
Merge branch 'more-modular-tests' into 'master'

Make more tests modular

See merge request dbus/dbus!153