aboutsummaryrefslogtreecommitdiff
path: root/src/dialog.c
diff options
context:
space:
mode:
authorIain Lane <iain.lane@canonical.com>2013-04-23 16:55:27 +0000
committerTarmac <Unknown>2013-04-23 16:55:27 +0000
commit704bd7fb5a1aeb17326cccaea20f8a42baf2573b (patch)
treef50b7c40ba82bb9e0078fc5d08b615c04519e5d6 /src/dialog.c
parentd2edc73c70c6ec3188fae4affe137aff9a40c0a9 (diff)
parent38399afa051605a447bd478c7b521048da8223d3 (diff)
downloadayatana-indicator-session-704bd7fb5a1aeb17326cccaea20f8a42baf2573b.tar.gz
ayatana-indicator-session-704bd7fb5a1aeb17326cccaea20f8a42baf2573b.tar.bz2
ayatana-indicator-session-704bd7fb5a1aeb17326cccaea20f8a42baf2573b.zip
Stop using ConsoleKit and UPower for session tracking and shutdown/reboot/suspend/hibernate; migrate to logind.
Approved by Mathieu Trudel-Lapierre, PS Jenkins bot.
Diffstat (limited to 'src/dialog.c')
-rw-r--r--src/dialog.c36
1 files changed, 18 insertions, 18 deletions
diff --git a/src/dialog.c b/src/dialog.c
index eb91f57..f97475e 100644
--- a/src/dialog.c
+++ b/src/dialog.c
@@ -26,7 +26,7 @@ with this program. If not, see <http://www.gnu.org/licenses/>.
#include <glib/gi18n.h>
-#include "dbus-consolekit-manager.h"
+#include "dbus-login1-manager.h"
#include "dialog.h"
/* Strings */
@@ -133,35 +133,35 @@ check_restart_required (void)
return g_file_test("/var/run/reboot-required", G_FILE_TEST_EXISTS);
}
-/* Checks with console kit to see if we can do what we want */
+/* Checks with logind to see if we can do what we want */
static gboolean
-ck_check_allowed (LogoutDialogType type)
+logind_check_allowed (LogoutDialogType type)
{
- gboolean allowed = TRUE;
-
- ConsoleKitManager * ck_proxy = console_kit_manager_proxy_new_for_bus_sync (G_BUS_TYPE_SYSTEM,
- G_DBUS_PROXY_FLAGS_NONE,
- "org.freedesktop.ConsoleKit",
- "/org/freedesktop/ConsoleKit/Manager",
- NULL,
- NULL);
- if (ck_proxy != NULL)
+ gchar * allowed = NULL;
+
+ Login1Manager * manager_proxy = login1_manager_proxy_new_for_bus_sync (G_BUS_TYPE_SYSTEM,
+ G_DBUS_PROXY_FLAGS_NONE,
+ "org.freedesktop.login1",
+ "/org/freedesktop/login1",
+ NULL,
+ NULL);
+ if (manager_proxy != NULL)
{
switch (type) {
case LOGOUT_DIALOG_TYPE_RESTART:
- console_kit_manager_call_can_restart_sync (ck_proxy, &allowed, NULL, NULL);
+ login1_manager_call_can_reboot_sync (manager_proxy, &allowed, NULL, NULL);
break;
case LOGOUT_DIALOG_TYPE_SHUTDOWN:
- console_kit_manager_call_can_stop_sync (ck_proxy, &allowed, NULL, NULL);
+ login1_manager_call_can_power_off_sync (manager_proxy, &allowed, NULL, NULL);
break;
default:
break;
}
- g_object_unref(ck_proxy);
+ g_object_unref(manager_proxy);
}
- return allowed;
+ return g_strcmp0 (allowed, "yes") == 0;
}
LogoutDialog *
@@ -188,9 +188,9 @@ logout_dialog_new (LogoutDialogType type)
gboolean allowed = FALSE;
if (type == LOGOUT_DIALOG_TYPE_LOG_OUT) {
- allowed = ck_check_allowed(LOGOUT_DIALOG_TYPE_RESTART);
+ allowed = logind_check_allowed(LOGOUT_DIALOG_TYPE_RESTART);
} else {
- allowed = ck_check_allowed(type);
+ allowed = logind_check_allowed(type);
}
gboolean restart_required = FALSE;