From: Ralf Habacker Date: Fri, 7 Sep 2012 03:00:59 +0000 (+0200) Subject: Windows implementation of GetConnectionCredentials. X-Git-Tag: dbus-1.10.6~259 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b417088ff7ef8c346181b279048bcd4b3da338a5;p=platform%2Fupstream%2Fdbus.git Windows implementation of GetConnectionCredentials. Reviewed-by: Simon McVittie Bug: https://bugs.freedesktop.org/show_bug.cgi?id=54445 --- diff --git a/bus/driver.c b/bus/driver.c index ceebb6f..8304066 100644 --- a/bus/driver.c +++ b/bus/driver.c @@ -38,6 +38,7 @@ #include #include #include +#include #include static DBusConnection * @@ -1646,6 +1647,7 @@ bus_driver_handle_get_connection_credentials (DBusConnection *connection, DBusMessageIter reply_iter; DBusMessageIter array_iter; unsigned long ulong_val; + char *windows_sid; const char *service; _DBUS_ASSERT_ERROR_IS_CLEAR (error); @@ -1680,6 +1682,24 @@ bus_driver_handle_get_connection_credentials (DBusConnection *connection, goto oom; } + if (dbus_connection_get_windows_user (conn, &windows_sid)) + { + DBusString str; + dbus_bool_t result; + _dbus_string_init_const (&str, windows_sid); + result = _dbus_validate_utf8 (&str, 0, _dbus_string_get_length (&str)); + _dbus_string_free (&str); + if (result) + { + if (!_dbus_asv_add_string (&array_iter, "WindowsSID", windows_sid)) + { + dbus_free(windows_sid); + goto oom; + } + } + dbus_free(windows_sid); + } + if (!_dbus_asv_close (&reply_iter, &array_iter)) goto oom; diff --git a/doc/dbus-specification.xml b/doc/dbus-specification.xml index 2f9fef8..a9a8c59 100644 --- a/doc/dbus-specification.xml +++ b/doc/dbus-specification.xml @@ -6005,6 +6005,14 @@ this concept. On Unix, this is the process ID defined by POSIX. + + WindowsSID + STRING + The Windows security identifier in its string form, + e.g. "S-1-5-21-3623811015-3361044348-30300820-1013" for + a domain or local computer user or "S-1-5-18" for the + LOCAL_SYSTEM user +