From 8ddafb9cf111b7a064a8632a9b8f7aef10fe5471 Mon Sep 17 00:00:00 2001 From: Daniel Novotny Date: Thu, 3 Sep 2009 12:52:05 +0200 Subject: added Polkit files --- src/Daemon/Polkit.cpp | 62 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 src/Daemon/Polkit.cpp (limited to 'src/Daemon/Polkit.cpp') diff --git a/src/Daemon/Polkit.cpp b/src/Daemon/Polkit.cpp new file mode 100644 index 0000000..d1c05a6 --- /dev/null +++ b/src/Daemon/Polkit.cpp @@ -0,0 +1,62 @@ +/* + Polkit.cpp - PolicyKit integration for ABRT + + Copyright (C) 2009 Daniel Novotny (dnovotny@redhat.com) + Copyright (C) 2009 RedHat inc. + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program 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 General Public License for more details. + + You should have received a copy of the GNU General Public License along + with this program; if not, write to the Free Software Foundation, Inc., + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. +*/ + +#include +#include + +#include "Polkit.h" + +PolkitResult polkit_check_authorization(char *action_id) +{ + PolkitAuthority *authority; + PolkitSubject *subject; + PolkitAuthorizationResult *result; + GError *error = NULL; + + g_type_init(); + authority = polkit_authority_get(); + subject = polkit_system_bus_name_new( NULL /*TODO get bus name*/ ); + + result = polkit_authority_check_authorization_sync(authority, + subject, + action_id, + NULL, + POLKIT_CHECK_AUTHORIZATION_FLAGS_ALLOW_USER_INTERACTION, + NULL, + &error); + + if (error) { + g_error_free (error); + return PolkitUnknown; + } + + if (result) + if (polkit_authorization_result_get_is_challenge(result)) + return PolkitChallenge; + else + if (polkit_authorization_result_get_is_authorized(result)) + return PolkitYes; + else + return PolkitNo; + + return PolkitUnknown; +} + -- cgit From 336a56dc4564237476a2160263f1f7d71cd058ab Mon Sep 17 00:00:00 2001 From: Daniel Novotny Date: Thu, 3 Sep 2009 13:00:05 +0200 Subject: fix polkit --- src/Daemon/Polkit.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'src/Daemon/Polkit.cpp') diff --git a/src/Daemon/Polkit.cpp b/src/Daemon/Polkit.cpp index d1c05a6..8c8e388 100644 --- a/src/Daemon/Polkit.cpp +++ b/src/Daemon/Polkit.cpp @@ -24,7 +24,7 @@ #include "Polkit.h" -PolkitResult polkit_check_authorization(char *action_id) +PolkitResult polkit_check_authorization(char* dbus_name,char *action_id) { PolkitAuthority *authority; PolkitSubject *subject; @@ -33,7 +33,7 @@ PolkitResult polkit_check_authorization(char *action_id) g_type_init(); authority = polkit_authority_get(); - subject = polkit_system_bus_name_new( NULL /*TODO get bus name*/ ); + subject = polkit_system_bus_name_new( dbus_name ); result = polkit_authority_check_authorization_sync(authority, subject, -- cgit