PolicyKit: Branch 'master'
David Zeuthen
david at kemper.freedesktop.org
Fri Dec 11 12:25:03 PST 2009
src/polkitbackend/polkitbackendauthority.c | 37 ++
src/polkitbackend/polkitbackendauthority.h | 4
src/polkitbackend/polkitbackendinteractiveauthority.c | 291 ++++++++++++++++--
3 files changed, 314 insertions(+), 18 deletions(-)
New commits:
commit c93407fa915843687e4dd5656e23df780c823a50
Author: David Zeuthen <davidz at redhat.com>
Date: Fri Dec 11 15:14:49 2009 -0500
Bug 25594 â System logging
For now we log the following events
1. Daemon startup -> /var/log/messages
--------------------------------------
Dec 11 15:12:56 localhost polkitd[3035]: started daemon version 0.95 using authority implementation `local' version `0.95'
2. Authentication agent -> /var/log/secure
------------------------------------------
Dec 11 15:14:00 localhost polkitd(authority=local): Registered Authentication Agent for session /org/freedesktop/ConsoleKit/Session1 (system bus name :1.903 [./polkit-gnome-authentication-agent-1], object path /org/gnome/PolicyKit1/AuthenticationAgent, locale en_US.UTF-8)
Dec 11 15:16:18 localhost polkitd(authority=local): Unregistered Authentication Agent for session /org/freedesktop/ConsoleKit/Session1 (system bus name :1.903, object path /org/gnome/PolicyKit1/AuthenticationAgent, locale en_US.UTF-8) (disconnected from bus)
3. Authorization checks
-----------------------
Dec 11 15:17:57 localhost polkitd(authority=local): ALLOWING action org.freedesktop.policykit.example.pkexec.run-frobnicate for unix-process:2517:25785526 [bash] owned by unix-user:davidz (check requested by system-bus-name::1.905 [pkexec /usr/bin/pk-example-frobnicate])
Dec 11 15:18:10 localhost polkitd(authority=local): ALLOWING action org.freedesktop.udisks.filesystem-mount-system-internal for system-bus-name::1.902 [palimpsest] owned by unix-user:davidz (check requested by system-bus-name::1.380 [/usr/libexec/udisks-daemon])
4. Authorizations through authentication (both success and
failures) -> /var/log/secure
----------------------------------------------------------
Dec 11 15:19:01 localhost polkitd(authority=local): Operator of unix-session:/org/freedesktop/ConsoleKit/Session1 successfully authenticated as unix-user:davidz to gain TEMPORARY authorization for action org.freedesktop.policykit.example.pkexec.run-frobnicate for unix-process:2517:25785526 [bash] (owned by unix-user:davidz)
Dec 11 15:19:01 localhost polkitd(authority=local): ALLOWING action org.freedesktop.policykit.example.pkexec.run-frobnicate for unix-process:2517:25785526 [bash] owned by unix-user:davidz (check requested by system-bus-name::1.906 [pkexec /usr/bin/pk-example-frobnicate])
Dec 11 15:19:10 localhost polkitd(authority=local): Operator of unix-session:/org/freedesktop/ConsoleKit/Session1 successfully authenticated as unix-user:davidz to gain ONE-SHOT authorization for action org.freedesktop.policykit.exec for unix-process:2517:25785526 [bash] (owned by unix-user:davidz)
Dec 11 15:19:10 localhost polkitd(authority=local): ALLOWING action org.freedesktop.policykit.exec for unix-process:2517:25785526 [bash] owned by unix-user:davidz (check requested by system-bus-name::1.908 [pkexec bash])
Dec 11 15:19:10 localhost pkexec: pam_unix(polkit-1:session): session opened for user root by davidz(uid=500)
Dec 11 15:19:22 localhost polkitd(authority=local): Operator of unix-session:/org/freedesktop/ConsoleKit/Session1 FAILED to authenticate to gain authorization for action org.freedesktop.policykit.exec for unix-process:2517:25785526 [bash] (owned by unix-user:davidz)
Dec 11 15:19:22 localhost polkitd(authority=local): DENYING action org.freedesktop.policykit.exec for unix-process:2517:25785526 [bash] owned by unix-user:davidz (check requested by system-bus-name::1.910 [pkexec bash])
Dec 11 15:20:06 localhost polkitd(authority=local): Operator of unix-session:/org/freedesktop/ConsoleKit/Session1 successfully authenticated as unix-user:bateman to gain ONE-SHOT authorization for action org.freedesktop.policykit.exec for unix-process:2517:25785526 [bash] (owned by unix-user:davidz)
Dec 11 15:20:06 localhost polkitd(authority=local): ALLOWING action org.freedesktop.policykit.exec for unix-process:2517:25785526 [bash] owned by unix-user:davidz (check requested by system-bus-name::1.913 [pkexec bash])
Signed-off-by: David Zeuthen <davidz at redhat.com>
diff --git a/src/polkitbackend/polkitbackendauthority.c b/src/polkitbackend/polkitbackendauthority.c
index 090e350..44de079 100644
--- a/src/polkitbackend/polkitbackendauthority.c
+++ b/src/polkitbackend/polkitbackendauthority.c
@@ -23,6 +23,8 @@
#include <errno.h>
#include <pwd.h>
#include <string.h>
+#include <syslog.h>
+#include <stdarg.h>
#include <polkit/polkit.h>
#include <polkit/polkitprivate.h>
@@ -1510,6 +1512,7 @@ polkit_backend_authority_get (void)
GList *authority_implementations;
GType authority_type;
PolkitBackendAuthority *authority;
+ gchar *s;
/* define extension points */
if (ep == NULL)
@@ -1545,5 +1548,39 @@ polkit_backend_authority_get (void)
g_list_foreach (modules, (GFunc) g_type_module_unuse, NULL);
g_list_free (modules);
+ /* First announce that we've started in the generic log */
+ openlog ("polkitd",
+ LOG_PID,
+ LOG_DAEMON); /* system daemons without separate facility value */
+ syslog (LOG_INFO,
+ "started daemon version %s using authority implementation `%s' version `%s'",
+ VERSION,
+ polkit_backend_authority_get_name (authority),
+ polkit_backend_authority_get_version (authority));
+ closelog ();
+
+ /* and then log to the secure log */
+ s = g_strdup_printf ("polkitd(authority=%s)", polkit_backend_authority_get_name (authority));
+ openlog (s,
+ 0,
+ LOG_AUTHPRIV); /* security/authorization messages (private) */
+ /* Ugh, can't free the string - gah, thanks openlog(3) */
+ /*g_free (s);*/
+
return authority;
}
+
+void
+polkit_backend_authority_log (PolkitBackendAuthority *authority,
+ const gchar *format,
+ ...)
+{
+ va_list var_args;
+
+ g_return_if_fail (POLKIT_BACKEND_IS_AUTHORITY (authority));
+
+ va_start (var_args, format);
+ vsyslog (LOG_NOTICE, format, var_args);
+
+ va_end (var_args);
+}
diff --git a/src/polkitbackend/polkitbackendauthority.h b/src/polkitbackend/polkitbackendauthority.h
index 72bdb61..7ce5fde 100644
--- a/src/polkitbackend/polkitbackendauthority.h
+++ b/src/polkitbackend/polkitbackendauthority.h
@@ -243,6 +243,10 @@ const gchar *polkit_backend_authority_get_name (PolkitBackendAut
const gchar *polkit_backend_authority_get_version (PolkitBackendAuthority *authority);
PolkitAuthorityFeatures polkit_backend_authority_get_features (PolkitBackendAuthority *authority);
+void polkit_backend_authority_log (PolkitBackendAuthority *authority,
+ const gchar *format,
+ ...);
+
void polkit_backend_authority_system_bus_name_owner_changed (PolkitBackendAuthority *authority,
const gchar *name,
const gchar *old_owner,
diff --git a/src/polkitbackend/polkitbackendinteractiveauthority.c b/src/polkitbackend/polkitbackendinteractiveauthority.c
index 5fb0d15..abf7cf4 100644
--- a/src/polkitbackend/polkitbackendinteractiveauthority.c
+++ b/src/polkitbackend/polkitbackendinteractiveauthority.c
@@ -77,10 +77,12 @@ typedef struct AuthenticationSession AuthenticationSession;
typedef void (*AuthenticationAgentCallback) (AuthenticationAgent *agent,
PolkitSubject *subject,
PolkitIdentity *user_of_subject,
+ PolkitSubject *caller,
PolkitBackendInteractiveAuthority *authority,
const gchar *action_id,
PolkitImplicitAuthorization implicit_authorization,
gboolean authentication_success,
+ PolkitIdentity *authenticated_identity,
gpointer user_data);
static void authentication_agent_free (AuthenticationAgent *agent);
@@ -346,25 +348,193 @@ polkit_backend_interactive_authority_enumerate_actions (PolkitBackendAuthority
/* ---------------------------------------------------------------------------------------------------- */
+struct AuthenticationAgent
+{
+ PolkitSubject *session;
+
+ gchar *locale;
+ gchar *object_path;
+ gchar *unique_system_bus_name;
+
+ EggDBusObjectProxy *object_proxy;
+
+ GList *active_sessions;
+};
+
+/* TODO: should probably move to PolkitSubject
+ *
+ * Also, can't really trust the cmdline... but might be useful in the logs anyway.
+ */
+static gchar *
+_polkit_subject_get_cmdline (PolkitSubject *subject)
+{
+ PolkitSubject *process;
+ gchar *ret;
+ gint pid;
+ gchar *filename;
+ gchar *contents;
+ gsize contents_len;
+ GError *error;
+ guint n;
+
+ g_return_val_if_fail (subject != NULL, NULL);
+
+ error = NULL;
+
+ ret = NULL;
+ process = NULL;
+ filename = NULL;
+ contents = NULL;
+
+ if (POLKIT_IS_UNIX_PROCESS (subject))
+ {
+ process = g_object_ref (subject);
+ }
+ else if (POLKIT_IS_SYSTEM_BUS_NAME (subject))
+ {
+ process = polkit_system_bus_name_get_process_sync (POLKIT_SYSTEM_BUS_NAME (subject),
+ NULL,
+ &error);
+ if (process == NULL)
+ {
+ g_warning ("Error getting process for system bus name `%s': %s",
+ polkit_system_bus_name_get_name (POLKIT_SYSTEM_BUS_NAME (subject)),
+ error->message);
+ g_error_free (error);
+ goto out;
+ }
+ }
+ else
+ {
+ g_warning ("Unknown subject type passed to guess_program_name()");
+ goto out;
+ }
+
+ pid = polkit_unix_process_get_pid (POLKIT_UNIX_PROCESS (process));
+
+ filename = g_strdup_printf ("/proc/%d/cmdline", pid);
+
+ if (!g_file_get_contents (filename,
+ &contents,
+ &contents_len,
+ &error))
+ {
+ g_warning ("Error openeing `%s': %s",
+ filename,
+ error->message);
+ g_error_free (error);
+ goto out;
+ }
+
+ /* The kernel uses '\0' to separate arguments - replace those with a space. */
+ for (n = 0; n < contents_len - 1; n++)
+ {
+ if (contents[n] == '\0')
+ contents[n] = ' ';
+ }
+
+ ret = g_strdup (contents);
+ g_strstrip (ret);
+
+ out:
+ g_free (filename);
+ g_free (contents);
+ if (process != NULL)
+ g_object_unref (process);
+ return ret;
+}
+
+static void
+log_result (PolkitBackendInteractiveAuthority *authority,
+ const gchar *action_id,
+ PolkitSubject *subject,
+ PolkitSubject *caller,
+ PolkitAuthorizationResult *result)
+{
+ PolkitBackendInteractiveAuthorityPrivate *priv;
+ PolkitIdentity *user_of_subject;
+ const gchar *log_result_str;
+ gchar *subject_str;
+ gchar *user_of_subject_str;
+ gchar *caller_str;
+ gchar *subject_cmdline;
+ gchar *caller_cmdline;
+
+ priv = POLKIT_BACKEND_INTERACTIVE_AUTHORITY_GET_PRIVATE (authority);
+
+ log_result_str = "DENYING";
+ if (polkit_authorization_result_get_is_authorized (result))
+ log_result_str = "ALLOWING";
+
+ user_of_subject = polkit_backend_session_monitor_get_user_for_subject (priv->session_monitor, subject, NULL);
+
+ subject_str = polkit_subject_to_string (subject);
+ user_of_subject_str = polkit_identity_to_string (user_of_subject);
+ caller_str = polkit_subject_to_string (caller);
+
+ subject_cmdline = _polkit_subject_get_cmdline (subject);
+ if (subject_cmdline == NULL)
+ subject_cmdline = g_strdup ("<unknown>");
+
+ caller_cmdline = _polkit_subject_get_cmdline (caller);
+ if (caller_cmdline == NULL)
+ caller_cmdline = g_strdup ("<unknown>");
+
+ polkit_backend_authority_log (POLKIT_BACKEND_AUTHORITY (authority),
+ "%s action %s for %s [%s] owned by %s (check requested by %s [%s])",
+ log_result_str,
+ action_id,
+ subject_str,
+ subject_cmdline,
+ user_of_subject_str,
+ caller_str,
+ caller_cmdline);
+
+ if (user_of_subject != NULL)
+ g_object_unref (user_of_subject);
+ g_free (subject_str);
+ g_free (user_of_subject_str);
+ g_free (caller_str);
+ g_free (subject_cmdline);
+ g_free (caller_cmdline);
+}
+
static void
check_authorization_challenge_cb (AuthenticationAgent *agent,
PolkitSubject *subject,
PolkitIdentity *user_of_subject,
+ PolkitSubject *caller,
PolkitBackendInteractiveAuthority *authority,
const gchar *action_id,
PolkitImplicitAuthorization implicit_authorization,
gboolean authentication_success,
+ PolkitIdentity *authenticated_identity,
gpointer user_data)
{
GSimpleAsyncResult *simple = G_SIMPLE_ASYNC_RESULT (user_data);
PolkitBackendInteractiveAuthorityPrivate *priv;
PolkitAuthorizationResult *result;
+ gchar *session_str;
gchar *subject_str;
+ gchar *user_of_subject_str;
+ gchar *authenticated_identity_str;
+ gchar *subject_cmdline;
+ gboolean is_temp;
priv = POLKIT_BACKEND_INTERACTIVE_AUTHORITY_GET_PRIVATE (authority);
result = NULL;
+
+ session_str = polkit_subject_to_string (agent->session);
subject_str = polkit_subject_to_string (subject);
+ user_of_subject_str = polkit_identity_to_string (user_of_subject);
+ authenticated_identity_str = NULL;
+ if (authenticated_identity != NULL)
+ authenticated_identity_str = polkit_identity_to_string (authenticated_identity);
+
+ subject_cmdline = _polkit_subject_get_cmdline (subject);
+ if (subject_cmdline == NULL)
+ subject_cmdline = g_strdup ("<unknown>");
g_debug ("In check_authorization_challenge_cb\n"
" subject %s\n"
@@ -374,6 +544,7 @@ check_authorization_challenge_cb (AuthenticationAgent *agent,
action_id,
authentication_success);
+ is_temp = FALSE;
if (authentication_success)
{
PolkitDetails *details;
@@ -386,6 +557,8 @@ check_authorization_challenge_cb (AuthenticationAgent *agent,
{
const gchar *id;
+ is_temp = TRUE;
+
id = temporary_authorization_store_add_authorization (priv->temporary_authorization_store,
subject,
authentication_agent_get_session (agent),
@@ -406,19 +579,65 @@ check_authorization_challenge_cb (AuthenticationAgent *agent,
result = polkit_authorization_result_new (FALSE, FALSE, NULL);
}
+ /* Log the event */
+ if (authentication_success)
+ {
+ if (is_temp)
+ {
+ polkit_backend_authority_log (POLKIT_BACKEND_AUTHORITY (authority),
+ "Operator of %s successfully authenticated as %s to gain "
+ "TEMPORARY authorization for action %s for %s [%s] (owned by %s) ",
+ session_str,
+ authenticated_identity_str,
+ action_id,
+ subject_str,
+ subject_cmdline,
+ user_of_subject_str);
+ }
+ else
+ {
+ polkit_backend_authority_log (POLKIT_BACKEND_AUTHORITY (authority),
+ "Operator of %s successfully authenticated as %s to gain "
+ "ONE-SHOT authorization for action %s for %s [%s] (owned by %s) ",
+ session_str,
+ authenticated_identity_str,
+ action_id,
+ subject_str,
+ subject_cmdline,
+ user_of_subject_str);
+ }
+ }
+ else
+ {
+ polkit_backend_authority_log (POLKIT_BACKEND_AUTHORITY (authority),
+ "Operator of %s FAILED to authenticate to gain "
+ "authorization for action %s for %s [%s] (owned by %s) ",
+ session_str,
+ action_id,
+ subject_str,
+ subject_cmdline,
+ user_of_subject_str);
+ }
+
+ log_result (authority, action_id, subject, caller, result);
+
g_simple_async_result_set_op_res_gpointer (simple,
result,
g_object_unref);
g_simple_async_result_complete (simple);
g_object_unref (simple);
+ g_free (subject_cmdline);
+ g_free (authenticated_identity_str);
+ g_free (user_of_subject_str);
g_free (subject_str);
+ g_free (session_str);
}
static PolkitAuthorizationResult *
polkit_backend_interactive_authority_check_authorization_finish (PolkitBackendAuthority *authority,
- GAsyncResult *res,
- GError **error)
+ GAsyncResult *res,
+ GError **error)
{
GSimpleAsyncResult *simple;
PolkitAuthorizationResult *result;
@@ -609,6 +828,8 @@ polkit_backend_interactive_authority_check_authorization (PolkitBackendAuthority
}
}
+ log_result (interactive_authority, action_id, subject, caller, result);
+
/* Otherwise just return the result */
g_simple_async_result_set_op_res_gpointer (simple,
result,
@@ -927,19 +1148,6 @@ polkit_backend_interactive_authority_check_authorization_sync (PolkitBackendInte
/* ---------------------------------------------------------------------------------------------------- */
-struct AuthenticationAgent
-{
- PolkitSubject *session;
-
- gchar *locale;
- gchar *object_path;
- gchar *unique_system_bus_name;
-
- EggDBusObjectProxy *object_proxy;
-
- GList *active_sessions;
-};
-
struct AuthenticationSession
{
AuthenticationAgent *agent;
@@ -950,6 +1158,8 @@ struct AuthenticationSession
PolkitIdentity *user_of_subject;
+ PolkitSubject *caller;
+
PolkitBackendInteractiveAuthority *authority;
GList *identities;
@@ -967,6 +1177,7 @@ struct AuthenticationSession
guint call_id;
gboolean is_authenticated;
+ PolkitIdentity *authenticated_identity;
GCancellable *cancellable;
@@ -985,6 +1196,7 @@ authentication_session_new (AuthenticationAgent *agent,
const gchar *cookie,
PolkitSubject *subject,
PolkitIdentity *user_of_subject,
+ PolkitSubject *caller,
PolkitBackendInteractiveAuthority *authority,
GList *identities,
const gchar *action_id,
@@ -1001,6 +1213,7 @@ authentication_session_new (AuthenticationAgent *agent,
session->cookie = g_strdup (cookie);
session->subject = g_object_ref (subject);
session->user_of_subject = g_object_ref (user_of_subject);
+ session->caller = g_object_ref (caller);
session->authority = g_object_ref (authority);
session->identities = g_list_copy (identities);
g_list_foreach (session->identities, (GFunc) g_object_ref, NULL);
@@ -1030,11 +1243,14 @@ authentication_session_free (AuthenticationSession *session)
g_list_free (session->identities);
g_object_unref (session->subject);
g_object_unref (session->user_of_subject);
+ g_object_unref (session->caller);
g_object_unref (session->authority);
g_free (session->action_id);
g_free (session->initiated_by_system_bus_unique_name);
if (session->cancellable_signal_handler_id > 0)
g_signal_handler_disconnect (session->cancellable, session->cancellable_signal_handler_id);
+ if (session->authenticated_identity != NULL)
+ g_object_unref (session->authenticated_identity);
if (session->cancellable != NULL)
g_object_unref (session->cancellable);
g_free (session);
@@ -1302,10 +1518,12 @@ authentication_agent_begin_callback (GObject *source_object,
session->callback (session->agent,
session->subject,
session->user_of_subject,
+ session->caller,
session->authority,
session->action_id,
session->implicit_authorization,
gained_authorization,
+ session->authenticated_identity,
session->user_data);
authentication_session_free (session);
@@ -1517,6 +1735,7 @@ authentication_agent_initiate_challenge (AuthenticationAgent *agent,
cookie,
subject,
user_of_subject,
+ caller,
authority,
identities,
action_id,
@@ -1608,6 +1827,7 @@ polkit_backend_interactive_authority_register_authentication_agent (PolkitBacken
PolkitSubject *session_for_caller;
AuthenticationAgent *agent;
gboolean ret;
+ gchar *agent_cmdline;
session_for_caller = NULL;
ret = FALSE;
@@ -1666,12 +1886,29 @@ polkit_backend_interactive_authority_register_authentication_agent (PolkitBacken
g_object_ref (session_for_caller),
agent);
- g_debug ("Added authentication agent for session %s at name %s, object path %s, locale %s",
+ agent_cmdline = _polkit_subject_get_cmdline (caller);
+ if (agent_cmdline == NULL)
+ agent_cmdline = g_strdup ("<unknown>");
+
+ g_debug ("Added authentication agent for session %s at name %s [%s], object path %s, locale %s",
polkit_unix_session_get_session_id (POLKIT_UNIX_SESSION (session_for_caller)),
polkit_system_bus_name_get_name (POLKIT_SYSTEM_BUS_NAME (caller)),
+ agent_cmdline,
object_path,
locale);
+ polkit_backend_authority_log (POLKIT_BACKEND_AUTHORITY (authority),
+ "Registered Authentication Agent for session %s "
+ "(system bus name %s [%s], object path %s, locale %s)",
+ polkit_unix_session_get_session_id (POLKIT_UNIX_SESSION (session_for_caller)),
+ polkit_system_bus_name_get_name (POLKIT_SYSTEM_BUS_NAME (caller)),
+ agent_cmdline,
+ object_path,
+ locale);
+
+ g_free (agent_cmdline);
+
+
ret = TRUE;
out:
@@ -1760,10 +1997,19 @@ polkit_backend_interactive_authority_unregister_authentication_agent (PolkitBack
}
- g_debug ("Removing authentication agent for session %s at name %s, object path %s (unregistered)",
+ g_debug ("Removing authentication agent for session %s at name %s, object path %s, locale %s",
polkit_unix_session_get_session_id (POLKIT_UNIX_SESSION (agent->session)),
agent->unique_system_bus_name,
- agent->object_path);
+ agent->object_path,
+ agent->locale);
+
+ polkit_backend_authority_log (POLKIT_BACKEND_AUTHORITY (authority),
+ "Unregistered Authentication Agent for session %s "
+ "(system bus name %s, object path %s, locale %s)",
+ polkit_unix_session_get_session_id (POLKIT_UNIX_SESSION (agent->session)),
+ agent->unique_system_bus_name,
+ agent->object_path,
+ agent->locale);
/* this works because we have exactly one agent per session */
g_hash_table_remove (priv->hash_session_to_authentication_agent, agent->session);
@@ -1853,6 +2099,7 @@ polkit_backend_interactive_authority_authentication_agent_response (PolkitBacken
/* checks out, mark the session as authenticated */
session->is_authenticated = TRUE;
+ session->authenticated_identity = g_object_ref (identity);
ret = TRUE;
@@ -1895,6 +2142,14 @@ polkit_backend_interactive_authority_system_bus_name_owner_changed (PolkitBacken
agent->unique_system_bus_name,
agent->object_path);
+ polkit_backend_authority_log (POLKIT_BACKEND_AUTHORITY (authority),
+ "Unregistered Authentication Agent for session %s "
+ "(system bus name %s, object path %s, locale %s) (disconnected from bus)",
+ polkit_unix_session_get_session_id (POLKIT_UNIX_SESSION (agent->session)),
+ agent->unique_system_bus_name,
+ agent->object_path,
+ agent->locale);
+
/* this works because we have exactly one agent per session */
g_hash_table_remove (priv->hash_session_to_authentication_agent, agent->session);
}
More information about the hal-commit
mailing list