|
Packit |
366192 |
/* Copyright (C) 2005 Red Hat, Inc. */
|
|
Packit |
366192 |
|
|
Packit |
366192 |
/* Object: semanage_user_extra_t (SELinux User/Class Extra Data)
|
|
Packit |
366192 |
* Object: semanage_user_extra_key_t (SELinux User/Class Key)
|
|
Packit |
366192 |
* Implements: record_t (Database Record)
|
|
Packit |
366192 |
* Implements: record_key_t (Database Record Key)
|
|
Packit |
366192 |
*/
|
|
Packit |
366192 |
|
|
Packit |
366192 |
#include <sepol/user_record.h>
|
|
Packit |
366192 |
|
|
Packit |
366192 |
typedef sepol_user_key_t semanage_user_key_t;
|
|
Packit |
366192 |
#define _SEMANAGE_USER_KEY_DEFINED_
|
|
Packit |
366192 |
|
|
Packit |
366192 |
struct semanage_user_extra;
|
|
Packit |
366192 |
typedef struct semanage_user_extra record_t;
|
|
Packit |
366192 |
typedef semanage_user_key_t record_key_t;
|
|
Packit |
366192 |
#define DBASE_RECORD_DEFINED
|
|
Packit |
366192 |
|
|
Packit |
366192 |
#include <semanage/handle.h>
|
|
Packit |
366192 |
#include <stdlib.h>
|
|
Packit |
366192 |
#include <string.h>
|
|
Packit |
366192 |
#include "user_internal.h"
|
|
Packit |
366192 |
#include "debug.h"
|
|
Packit |
366192 |
#include "database.h"
|
|
Packit |
366192 |
|
|
Packit |
366192 |
struct semanage_user_extra {
|
|
Packit |
366192 |
/* This user's name */
|
|
Packit |
366192 |
char *name;
|
|
Packit |
366192 |
|
|
Packit |
366192 |
/* Labeling prefix */
|
|
Packit |
366192 |
char *prefix;
|
|
Packit |
366192 |
};
|
|
Packit |
366192 |
|
|
Packit |
366192 |
static int semanage_user_extra_key_extract(semanage_handle_t * handle,
|
|
Packit |
366192 |
const semanage_user_extra_t *
|
|
Packit |
366192 |
user_extra,
|
|
Packit |
366192 |
semanage_user_key_t ** key_ptr)
|
|
Packit |
366192 |
{
|
|
Packit |
366192 |
|
|
Packit |
366192 |
if (semanage_user_key_create(handle, user_extra->name, key_ptr) < 0)
|
|
Packit |
366192 |
goto err;
|
|
Packit |
366192 |
|
|
Packit |
366192 |
return STATUS_SUCCESS;
|
|
Packit |
366192 |
|
|
Packit |
366192 |
err:
|
|
Packit |
366192 |
ERR(handle, "could not extract key from user extra record");
|
|
Packit |
366192 |
return STATUS_ERR;
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
static int semanage_user_extra_compare(const semanage_user_extra_t * user_extra,
|
|
Packit |
366192 |
const semanage_user_key_t * key)
|
|
Packit |
366192 |
{
|
|
Packit |
366192 |
|
|
Packit |
366192 |
const char *name;
|
|
Packit |
366192 |
semanage_user_key_unpack(key, &name);
|
|
Packit |
366192 |
|
|
Packit |
366192 |
return strcmp(user_extra->name, name);
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
static int semanage_user_extra_compare2(const semanage_user_extra_t *
|
|
Packit |
366192 |
user_extra,
|
|
Packit |
366192 |
const semanage_user_extra_t *
|
|
Packit |
366192 |
user_extra2)
|
|
Packit |
366192 |
{
|
|
Packit |
366192 |
|
|
Packit |
366192 |
return strcmp(user_extra->name, user_extra2->name);
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
static int semanage_user_extra_compare2_qsort(const semanage_user_extra_t **
|
|
Packit |
366192 |
user_extra,
|
|
Packit |
366192 |
const semanage_user_extra_t **
|
|
Packit |
366192 |
user_extra2)
|
|
Packit |
366192 |
{
|
|
Packit |
366192 |
|
|
Packit |
366192 |
return strcmp((*user_extra)->name, (*user_extra2)->name);
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
/* Name */
|
|
Packit |
366192 |
hidden const char *semanage_user_extra_get_name(const semanage_user_extra_t *
|
|
Packit |
366192 |
user_extra)
|
|
Packit |
366192 |
{
|
|
Packit |
366192 |
|
|
Packit |
366192 |
return user_extra->name;
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
hidden int semanage_user_extra_set_name(semanage_handle_t * handle,
|
|
Packit |
366192 |
semanage_user_extra_t * user_extra,
|
|
Packit |
366192 |
const char *name)
|
|
Packit |
366192 |
{
|
|
Packit |
366192 |
|
|
Packit |
366192 |
char *tmp_name = strdup(name);
|
|
Packit |
366192 |
if (!tmp_name) {
|
|
Packit |
366192 |
ERR(handle, "out of memory, could not set name %s "
|
|
Packit |
366192 |
"for user extra data", name);
|
|
Packit |
366192 |
return STATUS_ERR;
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
free(user_extra->name);
|
|
Packit |
366192 |
user_extra->name = tmp_name;
|
|
Packit |
366192 |
return STATUS_SUCCESS;
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
/* Labeling prefix */
|
|
Packit |
366192 |
hidden const char *semanage_user_extra_get_prefix(const semanage_user_extra_t *
|
|
Packit |
366192 |
user_extra)
|
|
Packit |
366192 |
{
|
|
Packit |
366192 |
|
|
Packit |
366192 |
return user_extra->prefix;
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
hidden int semanage_user_extra_set_prefix(semanage_handle_t * handle,
|
|
Packit |
366192 |
semanage_user_extra_t * user_extra,
|
|
Packit |
366192 |
const char *prefix)
|
|
Packit |
366192 |
{
|
|
Packit |
366192 |
|
|
Packit |
366192 |
char *tmp_prefix = strdup(prefix);
|
|
Packit |
366192 |
if (!tmp_prefix) {
|
|
Packit |
366192 |
ERR(handle, "out of memory, could not set prefix %s "
|
|
Packit |
366192 |
"for user %s", prefix, user_extra->name);
|
|
Packit |
366192 |
return STATUS_ERR;
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
free(user_extra->prefix);
|
|
Packit |
366192 |
user_extra->prefix = tmp_prefix;
|
|
Packit |
366192 |
return STATUS_SUCCESS;
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
/* Create */
|
|
Packit |
366192 |
hidden int semanage_user_extra_create(semanage_handle_t * handle,
|
|
Packit |
366192 |
semanage_user_extra_t ** user_extra_ptr)
|
|
Packit |
366192 |
{
|
|
Packit |
366192 |
|
|
Packit |
366192 |
semanage_user_extra_t *user_extra =
|
|
Packit |
366192 |
(semanage_user_extra_t *) malloc(sizeof(semanage_user_extra_t));
|
|
Packit |
366192 |
|
|
Packit |
366192 |
if (!user_extra) {
|
|
Packit |
366192 |
ERR(handle, "out of memory, could not "
|
|
Packit |
366192 |
"create user extra data record");
|
|
Packit |
366192 |
return STATUS_ERR;
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
user_extra->name = NULL;
|
|
Packit |
366192 |
user_extra->prefix = NULL;
|
|
Packit |
366192 |
|
|
Packit |
366192 |
*user_extra_ptr = user_extra;
|
|
Packit |
366192 |
return STATUS_SUCCESS;
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
/* Destroy */
|
|
Packit |
366192 |
hidden void semanage_user_extra_free(semanage_user_extra_t * user_extra)
|
|
Packit |
366192 |
{
|
|
Packit |
366192 |
|
|
Packit |
366192 |
if (!user_extra)
|
|
Packit |
366192 |
return;
|
|
Packit |
366192 |
|
|
Packit |
366192 |
free(user_extra->name);
|
|
Packit |
366192 |
free(user_extra->prefix);
|
|
Packit |
366192 |
free(user_extra);
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
/* Deep copy clone */
|
|
Packit |
366192 |
hidden int semanage_user_extra_clone(semanage_handle_t * handle,
|
|
Packit |
366192 |
const semanage_user_extra_t * user_extra,
|
|
Packit |
366192 |
semanage_user_extra_t ** user_extra_ptr)
|
|
Packit |
366192 |
{
|
|
Packit |
366192 |
|
|
Packit |
366192 |
semanage_user_extra_t *new_user_extra = NULL;
|
|
Packit |
366192 |
|
|
Packit |
366192 |
if (semanage_user_extra_create(handle, &new_user_extra) < 0)
|
|
Packit |
366192 |
goto err;
|
|
Packit |
366192 |
|
|
Packit |
366192 |
if (semanage_user_extra_set_name
|
|
Packit |
366192 |
(handle, new_user_extra, user_extra->name) < 0)
|
|
Packit |
366192 |
goto err;
|
|
Packit |
366192 |
|
|
Packit |
366192 |
if (semanage_user_extra_set_prefix
|
|
Packit |
366192 |
(handle, new_user_extra, user_extra->prefix) < 0)
|
|
Packit |
366192 |
goto err;
|
|
Packit |
366192 |
|
|
Packit |
366192 |
*user_extra_ptr = new_user_extra;
|
|
Packit |
366192 |
return STATUS_SUCCESS;
|
|
Packit |
366192 |
|
|
Packit |
366192 |
err:
|
|
Packit |
366192 |
ERR(handle, "could not clone extra data for user %s", user_extra->name);
|
|
Packit |
366192 |
semanage_user_extra_free(new_user_extra);
|
|
Packit |
366192 |
return STATUS_ERR;
|
|
Packit |
366192 |
}
|
|
Packit |
366192 |
|
|
Packit |
366192 |
/* Record base functions */
|
|
Packit |
366192 |
record_table_t SEMANAGE_USER_EXTRA_RTABLE = {
|
|
Packit |
366192 |
.create = semanage_user_extra_create,
|
|
Packit |
366192 |
.key_extract = semanage_user_extra_key_extract,
|
|
Packit |
366192 |
.key_free = semanage_user_key_free,
|
|
Packit |
366192 |
.clone = semanage_user_extra_clone,
|
|
Packit |
366192 |
.compare = semanage_user_extra_compare,
|
|
Packit |
366192 |
.compare2 = semanage_user_extra_compare2,
|
|
Packit |
366192 |
.compare2_qsort = semanage_user_extra_compare2_qsort,
|
|
Packit |
366192 |
.free = semanage_user_extra_free,
|
|
Packit |
366192 |
};
|