bus: don't forward messages with unix fds on connections that don't support it
authorLennart Poettering <lennart@poettering.net>
Wed, 20 May 2009 23:00:52 +0000 (01:00 +0200)
committerLennart Poettering <lennart@poettering.net>
Wed, 20 May 2009 23:21:35 +0000 (01:21 +0200)
This simply verifies that we forward unix fds only on connection that
support it. We willr eturn an error if a client attempts to send a
message with unix fds to another client that cannot do it.

bus/dispatch.c
dbus/dbus-message-internal.h
dbus/dbus-message.c
dbus/dbus-message.h

index 8ed88dad41469eefeb23b939f01e66e5a7f051fd..fa5874d2afd8ee8d63e3a5fec3dfa21a755741d1 100644 (file)
@@ -56,6 +56,10 @@ send_one_message (DBusConnection *connection,
                                           message,
                                           NULL))
     return TRUE; /* silently don't send it */
+
+  if (dbus_message_contains_unix_fds(message) &&
+      !dbus_connection_can_send_type(connection, DBUS_TYPE_UNIX_FD))
+    return TRUE; /* silently don't send it */
   
   if (!bus_transaction_send (transaction,
                              connection,
@@ -300,6 +304,16 @@ bus_dispatch (DBusConnection *connection,
                                                   addressed_recipient,
                                                   message, &error))
             goto out;
+
+          if (dbus_message_contains_unix_fds(message) &&
+              !dbus_connection_can_send_type(addressed_recipient, DBUS_TYPE_UNIX_FD))
+            {
+              dbus_set_error(&error,
+                             DBUS_ERROR_NOT_SUPPORTED,
+                             "Tried to send message with Unix file descriptors"
+                             "to a client that doesn't support that.");
+              goto out;
+          }
           
           /* Dispatch the message */
           if (!bus_transaction_send (transaction, addressed_recipient, message))
index 0565d6115e3270658cf7bec3e99d0449da791985..4302f0916ad27d8935a9fc19917303ae8fea990e 100644 (file)
@@ -34,7 +34,7 @@ typedef struct DBusMessageLoader DBusMessageLoader;
 void _dbus_message_get_network_data  (DBusMessage       *message,
                                      const DBusString **header,
                                      const DBusString **body);
-void _dbus_message_get_unix_fds      (DBusMessage *messgage,
+void _dbus_message_get_unix_fds      (DBusMessage *message,
                                       const int **fds,
                                       unsigned *n_fds);
 
index d9ea649ea1ff15c9939b091755ccf95b577c61ea..d8d746a6384fae054f597801dd79a67724576afc 100644 (file)
@@ -3560,6 +3560,20 @@ dbus_set_error_from_message (DBusError   *error,
   return TRUE;
 }
 
+/**
+ * Checks whether a message contains unix fds
+ *
+ * @param message the message
+ * @returns #TRUE if the message contains unix fds
+ */
+dbus_bool_t
+dbus_message_contains_unix_fds(DBusMessage *message)
+{
+  _dbus_assert(message);
+
+  return message->n_unix_fds > 0;
+}
+
 /** @} */
 
 /**
index 2e29fef0033fc20c9be5b7e100ed1831f44f7a2f..3a3ddd969820573af599a50d9c6aaa47496c18d8 100644 (file)
@@ -159,6 +159,7 @@ dbus_bool_t dbus_message_get_args_valist      (DBusMessage     *message,
                                               int              first_arg_type,
                                               va_list          var_args);
 
+dbus_bool_t dbus_message_contains_unix_fds    (DBusMessage *message);
 
 dbus_bool_t dbus_message_iter_init             (DBusMessage     *message,
                                                 DBusMessageIter *iter);