blob: 425cc8ac296c4d39eb67921029c886313613c19f [file] [log] [blame]
/*
*
* Connection Manager
*
* Copyright (C) 2007-2009 Intel Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*
* 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 St, Fifth Floor, Boston, MA 02110-1301 USA
*
*/
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include "connman.h"
#define _DBG_SECURITY(fmt, arg...) DBG(DBG_SECURITY, fmt, ## arg)
static GSList *security_list = NULL;
static gint compare_priority(gconstpointer a, gconstpointer b)
{
const struct connman_security *security1 = a;
const struct connman_security *security2 = b;
return security2->priority - security1->priority;
}
/**
* connman_security_register:
* @security: security module
*
* Register a new security module
*
* Returns: %0 on success
*/
int connman_security_register(struct connman_security *security)
{
_DBG_SECURITY("security %p name %s", security, security->name);
security_list = g_slist_insert_sorted(security_list, security,
compare_priority);
return 0;
}
/**
* connman_security_unregister:
* @security: security module
*
* Remove a previously registered security module
*/
void connman_security_unregister(struct connman_security *security)
{
_DBG_SECURITY("security %p name %s", security, security->name);
security_list = g_slist_remove(security_list, security);
}
int __connman_security_check_privilege(DBusMessage *message,
enum connman_security_privilege privilege)
{
GSList *list;
const char *sender;
int err = 0;
_DBG_SECURITY("message %p", message);
sender = dbus_message_get_sender(message);
for (list = security_list; list; list = list->next) {
struct connman_security *security = list->data;
_DBG_SECURITY("%s", security->name);
if (security->authorize_sender) {
err = security->authorize_sender(sender, privilege);
break;
}
}
return err;
}
/* A security object that does not authorize anyone to retrieve secrets */
static int connman_security_authorize_no_secrets(const char *sender,
enum connman_security_privilege privilege)
{
if (privilege == CONNMAN_SECURITY_PRIVILEGE_READ_SECRET) {
return -EACCES;
} else {
return 0;
}
}
static struct connman_security connman_security_authorize_no_secrets_policy = {
"connman_security_authorize_no_secrets",
CONNMAN_SECURITY_PRIORITY_DEFAULT,
connman_security_authorize_no_secrets
};
int __connman_security_init(void)
{
/* NB: Not a plugin so that it cannot be trivially disabled */
connman_security_register(&connman_security_authorize_no_secrets_policy);
return 0;
}