/* * libvirt-gconfig-storage-permissions.c: libvirt storage permissions configuration * * Copyright (C) 2011 Red Hat, Inc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library. If not, see * . * * Author: Christophe Fergeau */ #include #include "libvirt-gconfig/libvirt-gconfig.h" #include "libvirt-gconfig/libvirt-gconfig-private.h" #define GVIR_CONFIG_STORAGE_PERMISSIONS_GET_PRIVATE(obj) \ (G_TYPE_INSTANCE_GET_PRIVATE((obj), GVIR_CONFIG_TYPE_STORAGE_PERMISSIONS, GVirConfigStoragePermissionsPrivate)) struct _GVirConfigStoragePermissionsPrivate { gboolean unused; }; G_DEFINE_TYPE_WITH_PRIVATE(GVirConfigStoragePermissions, gvir_config_storage_permissions, GVIR_CONFIG_TYPE_OBJECT); static void gvir_config_storage_permissions_class_init(GVirConfigStoragePermissionsClass *klass G_GNUC_UNUSED) { } static void gvir_config_storage_permissions_init(GVirConfigStoragePermissions *perms) { perms->priv = GVIR_CONFIG_STORAGE_PERMISSIONS_GET_PRIVATE(perms); } GVirConfigStoragePermissions *gvir_config_storage_permissions_new(void) { GVirConfigObject *object; object = gvir_config_object_new(GVIR_CONFIG_TYPE_STORAGE_PERMISSIONS, "permissions", NULL); return GVIR_CONFIG_STORAGE_PERMISSIONS(object); } GVirConfigStoragePermissions *gvir_config_storage_permissions_new_from_xml(const gchar *xml, GError **error) { GVirConfigObject *object; object = gvir_config_object_new_from_xml(GVIR_CONFIG_TYPE_STORAGE_PERMISSIONS, "permissions", NULL, xml, error); return GVIR_CONFIG_STORAGE_PERMISSIONS(object); } /** * gvir_config_storage_permissions_get_group: * @perms: a #GVirConfigStoragePermissions * * Gets the numeric group ID associated with @perms. * * Returns: numeric group ID */ guint gvir_config_storage_permissions_get_group(GVirConfigStoragePermissions *perms) { g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_PERMISSIONS(perms), 0); return gvir_config_object_get_node_content_uint64(GVIR_CONFIG_OBJECT(perms), "group"); } void gvir_config_storage_permissions_set_group(GVirConfigStoragePermissions *perms, guint group) { g_return_if_fail(GVIR_CONFIG_IS_STORAGE_PERMISSIONS(perms)); gvir_config_object_set_node_content_uint64(GVIR_CONFIG_OBJECT(perms), "group", group); } /** * gvir_config_storage_permissions_get_label: * @perms: a #GVirConfigStoragePermissions * * Gets the MAC label string associated with @perms. * * Returns: MAC label string. */ const char *gvir_config_storage_permissions_get_label(GVirConfigStoragePermissions *perms) { g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_PERMISSIONS(perms), NULL); return gvir_config_object_get_node_content(GVIR_CONFIG_OBJECT(perms), "label"); } /** * gvir_config_storage_permissions_set_label: * @label: (allow-none): */ void gvir_config_storage_permissions_set_label(GVirConfigStoragePermissions *perms, const char *label) { g_return_if_fail(GVIR_CONFIG_IS_STORAGE_PERMISSIONS(perms)); gvir_config_object_set_node_content(GVIR_CONFIG_OBJECT(perms), "label", label); } /** * gvir_config_storage_permissions_get_mode: * @perms: a #GVirConfigStoragePermissions * * Gets the octal permission set associated with @perms. * * Returns: permission set */ guint gvir_config_storage_permissions_get_mode(GVirConfigStoragePermissions *perms) { g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_PERMISSIONS(perms), 0); return gvir_config_object_get_node_content_uint64(GVIR_CONFIG_OBJECT(perms), "mode"); } void gvir_config_storage_permissions_set_mode(GVirConfigStoragePermissions *perms, guint mode) { g_return_if_fail(GVIR_CONFIG_IS_STORAGE_PERMISSIONS(perms)); gvir_config_object_set_node_content_uint64(GVIR_CONFIG_OBJECT(perms), "mode", mode); } /** * gvir_config_storage_permissions_get_owner: * @perms: a #GVirConfigStoragePermissions * * Gets the numeric user ID associated with @perms. * * Returns: numeric user ID. */ guint gvir_config_storage_permissions_get_owner(GVirConfigStoragePermissions *perms) { g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_PERMISSIONS(perms), 0); return gvir_config_object_get_node_content_uint64(GVIR_CONFIG_OBJECT(perms), "owner"); } void gvir_config_storage_permissions_set_owner(GVirConfigStoragePermissions *perms, guint owner) { g_return_if_fail(GVIR_CONFIG_IS_STORAGE_PERMISSIONS(perms)); gvir_config_object_set_node_content_uint64(GVIR_CONFIG_OBJECT(perms), "owner", owner); }