else if (action_id != NULL)
{
PolkitSubject *subject;
+ PolkitDetails *details;
PolkitCheckAuthorizationFlags flags;
+ gchar partition_number_buf[32];
+
+ /* Set details - see polkit-action-lookup.c for where
+ * these key/value pairs are used
+ */
+ details = polkit_details_new ();
+ if (operation != NULL)
+ {
+ polkit_details_insert (details, "operation", (gpointer) operation);
+ }
+ if (device != NULL)
+ {
+ Device *drive;
+
+ polkit_details_insert (details, "unix-device", device->priv->device_file);
+ if (device->priv->device_file_by_id->len > 0)
+ polkit_details_insert (details, "unix-device-by-id", device->priv->device_file_by_id->pdata[0]);
+ if (device->priv->device_file_by_path->len > 0)
+ polkit_details_insert (details, "unix-device-by-path", device->priv->device_file_by_path->pdata[0]);
+
+ if (device->priv->device_is_drive)
+ {
+ drive = device;
+ }
+ else if (device->priv->device_is_partition)
+ {
+ polkit_details_insert (details, "is-partition", "1");
+ g_snprintf (partition_number_buf, sizeof partition_number_buf, "%d", device->priv->partition_number);
+ polkit_details_insert (details, "partition-number", partition_number_buf);
+ drive = daemon_local_find_by_object_path (device->priv->daemon, device->priv->partition_slave);
+ }
+ else
+ {
+ drive = NULL;
+ }
+
+ if (drive != NULL)
+ {
+ polkit_details_insert (details, "drive-unix-device", drive->priv->device_file);
+ if (drive->priv->device_file_by_id->len > 0)
+ polkit_details_insert (details, "drive-unix-device-by-id", drive->priv->device_file_by_id->pdata[0]);
+ if (drive->priv->device_file_by_path->len > 0)
+ polkit_details_insert (details, "drive-unix-device-by-path", drive->priv->device_file_by_path->pdata[0]);
+ if (drive->priv->drive_vendor != NULL)
+ polkit_details_insert (details, "drive-vendor", drive->priv->drive_vendor);
+ if (drive->priv->drive_model != NULL)
+ polkit_details_insert (details, "drive-model", drive->priv->drive_model);
+ if (drive->priv->drive_revision != NULL)
+ polkit_details_insert (details, "drive-revision", drive->priv->drive_revision);
+ if (drive->priv->drive_serial != NULL)
+ polkit_details_insert (details, "drive-serial", drive->priv->drive_serial);
+ if (drive->priv->drive_connection_interface != NULL)
+ polkit_details_insert (details, "drive-connection-interface", drive->priv->drive_connection_interface);
+ }
+ }
subject = polkit_system_bus_name_new (dbus_g_method_get_sender (context));
polkit_authority_check_authorization (daemon->priv->authority,
subject,
action_id,
- NULL, /* PolkitDetails */
+ details,
flags,
data->cancellable,
(GAsyncReadyCallback) lca_check_authorization_callback,
data);
g_object_unref (subject);
+ g_object_unref (details);
}
else
{
--- /dev/null
+/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
+/*
+ * Copyright (C) 2009 Red Hat, Inc.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General
+ * Public License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place, Suite 330,
+ * Boston, MA 02111-1307, USA.
+ *
+ * Author: David Zeuthen <davidz@redhat.com>
+ */
+
+#include "config.h"
+
+#include <polkitbackend/polkitbackend.h>
+
+#include <glib/gi18n-lib.h>
+
+#define UDISKS_TYPE_ACTION_LOOKUP (udisks_action_lookup_get_type())
+#define UDISKS_ACTION_LOOKUP(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), UDISKS_TYPE_ACTION_LOOKUP, UDisksActionLookup))
+#define UDISKS_ACTION_LOOKUP_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), UDISKS_TYPE_ACTION_LOOKUP, UDisksActionLookupClass))
+#define UDISKS_ACTION_LOOKUP_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), UDISKS_TYPE_ACTION_LOOKUP, UDisksActionLookupClass))
+#define UDISKS_IS_ACTION_LOOKUP(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), UDISKS_TYPE_ACTION_LOOKUP))
+#define UDISKS_IS_ACTION_LOOKUP_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), UDISKS_TYPE_ACTION_LOOKUP))
+
+typedef struct _UDisksActionLookup UDisksActionLookup;
+typedef struct _UDisksActionLookupClass UDisksActionLookupClass;
+
+struct _UDisksActionLookup
+{
+ GObject parent;
+};
+
+struct _UDisksActionLookupClass
+{
+ GObjectClass parent_class;
+};
+
+GType udisks_action_lookup_get_type (void) G_GNUC_CONST;
+
+static void
+polkit_backend_action_lookup_iface_init (PolkitBackendActionLookupIface *iface);
+
+#define _G_IMPLEMENT_INTERFACE_DYNAMIC(TYPE_IFACE, iface_init) \
+ { \
+ const GInterfaceInfo g_implement_interface_info = { \
+ (GInterfaceInitFunc) iface_init, NULL, NULL \
+ }; \
+ g_type_module_add_interface (type_module, g_define_type_id, TYPE_IFACE, &g_implement_interface_info); \
+}
+
+G_DEFINE_DYNAMIC_TYPE_EXTENDED (UDisksActionLookup,
+ udisks_action_lookup,
+ G_TYPE_OBJECT,
+ 0,
+ _G_IMPLEMENT_INTERFACE_DYNAMIC (POLKIT_BACKEND_TYPE_ACTION_LOOKUP,
+ polkit_backend_action_lookup_iface_init))
+
+static void
+udisks_action_lookup_init (UDisksActionLookup *lookup)
+{
+}
+
+static void
+udisks_action_lookup_class_finalize (UDisksActionLookupClass *klass)
+{
+}
+
+static void
+udisks_action_lookup_class_init (UDisksActionLookupClass *klass)
+{
+}
+
+/* ---------------------------------------------------------------------------------------------------- */
+
+typedef struct
+{
+ const gchar *name;
+ const gchar *message;
+} Map;
+
+static const Map map[] =
+ {
+ { "PartitionDelete", N_ ("Authentication is required to delete a partition"), },
+ { "FilesystemCreate", N_ ("Authentication is required to create a filesystem") },
+ { "PartitionCreate", N_ ("Authentication is required to create a partition") },
+ { "PartitionModify", N_ ("Authentication is required to modify a partition") },
+ { "PartitionTableCreate", N_ ("Authentication is required to create a partition table") },
+ { "FilesystemSetLabel", N_ ("Authentication is required to set the file system label") },
+ { "LinuxMdStop", N_ ("Authentication is required to stop a Software RAID device") },
+ { "LinuxMdCheck", N_ ("Authentication is required to check a Software RAID device") },
+ { "LinuxMdRepair", N_ ("Authentication is required to repair a Software RAID device") },
+ { "LinuxMdAddComponent", N_ ("Authentication is required to add a new component to a Software RAID device") },
+ { "LinuxMdRemoveComponent", N_ ("Authentication is required to remove a component from a Software RAID device") },
+ { "LinuxMdStart", N_ ("Authentication is required to start a Software RAID device") },
+ { "LinuxMdCreate", N_ ("Authentication is required to create a Software RAID device") },
+ { "DriveInhibitPolling", N_ ("Authentication is required to inhibit polling on a drive") },
+ { "DrivePollMedia", N_ ("Authentication is required to poll for media") },
+ { "InhibitAllPolling", N_ ("Authentication is required to inhibit all drive polling") },
+ { NULL, NULL, }
+ };
+
+static gchar *
+udisks_action_lookup_get_message (PolkitBackendActionLookup *lookup,
+ const gchar *action_id,
+ PolkitDetails *details,
+ PolkitActionDescription *action_description)
+{
+ const gchar *operation;
+ gchar *ret;
+ guint n;
+
+ ret = NULL;
+
+ if (!g_str_has_prefix (action_id, "org.freedesktop.udisks."))
+ goto out;
+
+ operation = polkit_details_lookup (details, "operation");
+ if (operation == NULL)
+ goto out;
+
+ for (n = 0; map[n].name != NULL; n++)
+ {
+ if (g_strcmp0 (map[n].name, operation) != 0)
+ continue;
+
+ ret = g_strdup (g_dgettext (GETTEXT_PACKAGE, map[n].message));
+ break;
+ }
+
+ out:
+ return ret;
+}
+
+static gchar *
+udisks_action_lookup_get_icon_name (PolkitBackendActionLookup *lookup,
+ const gchar *action_id,
+ PolkitDetails *details,
+ PolkitActionDescription *action_description)
+{
+ gchar *ret;
+
+ ret = NULL;
+
+ if (!g_str_has_prefix (action_id, "org.freedesktop.udisks."))
+ goto out;
+
+ /* explicitly left blank for now */
+
+ out:
+ return ret;
+}
+
+static PolkitDetails *
+udisks_action_lookup_get_details (PolkitBackendActionLookup *lookup,
+ const gchar *action_id,
+ PolkitDetails *details,
+ PolkitActionDescription *action_description)
+{
+ const gchar *s;
+ const gchar *s2;
+ const gchar *s3;
+ GString *str;
+ PolkitDetails *ret;
+
+ if (!g_str_has_prefix (action_id, "org.freedesktop.udisks."))
+ return NULL;
+
+ ret = polkit_details_new ();
+
+ /* see daemon_local_check_auth() in daemon.c
+ * for where these keys are set
+ */
+
+ s = polkit_details_lookup (details, "unix-device");
+ if (s != NULL)
+ polkit_details_insert (ret, _ ("Device"), s);
+
+ s = polkit_details_lookup (details, "drive-vendor");
+ s2 = polkit_details_lookup (details, "drive-model");
+ s3 = polkit_details_lookup (details, "drive-revision");
+ str = g_string_new (NULL);
+ if (s != NULL)
+ {
+ g_string_append (str, s);
+ }
+ if (s2 != NULL)
+ {
+ if (str->len > 0)
+ g_string_append_c (str, ' ');
+ g_string_append (str, s2);
+ }
+ if (s3 != NULL)
+ {
+ if (str->len > 0)
+ g_string_append_c (str, ' ');
+ g_string_append_printf (str, "(%s)", s3);
+ }
+
+ if (str->len > 0)
+ {
+ polkit_details_insert (ret, _ ("Drive"), str->str);
+ }
+ g_string_free (str, TRUE);
+
+ return ret;
+}
+
+static void
+polkit_backend_action_lookup_iface_init (PolkitBackendActionLookupIface *iface)
+{
+ iface->get_message = udisks_action_lookup_get_message;
+ iface->get_icon_name = udisks_action_lookup_get_icon_name;
+ iface->get_details = udisks_action_lookup_get_details;
+}
+
+/* ---------------------------------------------------------------------------------------------------- */
+
+void
+g_io_module_load (GIOModule *module)
+{
+ bindtextdomain (GETTEXT_PACKAGE, PACKAGE_LOCALE_DIR);
+ bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8");
+
+ udisks_action_lookup_register_type (G_TYPE_MODULE (module));
+
+ g_io_extension_point_implement (POLKIT_BACKEND_ACTION_LOOKUP_EXTENSION_POINT_NAME,
+ UDISKS_TYPE_ACTION_LOOKUP,
+ "udisks action lookup extension " PACKAGE_VERSION,
+ 0);
+}
+
+void
+g_io_module_unload (GIOModule *module)
+{
+}