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 +++++++++++++++++++++++++++++++++++++++++++++++++++ src/Daemon/Polkit.h | 39 ++++++++++++++++++++++++++++++++ 2 files changed, 101 insertions(+) create mode 100644 src/Daemon/Polkit.cpp create mode 100644 src/Daemon/Polkit.h (limited to 'src/Daemon') 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; +} + diff --git a/src/Daemon/Polkit.h b/src/Daemon/Polkit.h new file mode 100644 index 0000000..b03e0d4 --- /dev/null +++ b/src/Daemon/Polkit.h @@ -0,0 +1,39 @@ +/* + Polkit.h - header file for PolicyKit integration + + 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. +*/ + +#ifndef ABRT_POLKIT_H +#define ABRT_POLKIT_H + +typedef enum { +/* Authorization status is unknown */ +PolkitUnknown = 0x0, +/* Subject is authorized for the action */ +PolkitYes = 0x01, +/* Subject is not authorized for the action */ +PolkitNo = 0x02, +/* Challenge is needed for this action, only when flag is +POLKIT_CHECK_AUTHORIZATION_FLAGS_NONE*/ +PolkitChallenge = 0x03 +} PolkitResult; + +PolkitResult polkit_check_authorization(char *action_id); + +#endif -- 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 ++-- src/Daemon/Polkit.h | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) (limited to 'src/Daemon') 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, diff --git a/src/Daemon/Polkit.h b/src/Daemon/Polkit.h index b03e0d4..bb03822 100644 --- a/src/Daemon/Polkit.h +++ b/src/Daemon/Polkit.h @@ -34,6 +34,6 @@ POLKIT_CHECK_AUTHORIZATION_FLAGS_NONE*/ PolkitChallenge = 0x03 } PolkitResult; -PolkitResult polkit_check_authorization(char *action_id); +PolkitResult polkit_check_authorization(char * dbus_name,char *action_id); #endif -- cgit