/* * libvirt-gconfig-storage-pool-target.c: libvirt storage pool target 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_POOL_TARGET_GET_PRIVATE(obj) \ (G_TYPE_INSTANCE_GET_PRIVATE((obj), GVIR_CONFIG_TYPE_STORAGE_POOL_TARGET, GVirConfigStoragePoolTargetPrivate)) struct _GVirConfigStoragePoolTargetPrivate { gboolean unused; }; G_DEFINE_TYPE_WITH_PRIVATE(GVirConfigStoragePoolTarget, gvir_config_storage_pool_target, GVIR_CONFIG_TYPE_OBJECT); static void gvir_config_storage_pool_target_class_init(GVirConfigStoragePoolTargetClass *klass G_GNUC_UNUSED) { } static void gvir_config_storage_pool_target_init(GVirConfigStoragePoolTarget *target) { target->priv = GVIR_CONFIG_STORAGE_POOL_TARGET_GET_PRIVATE(target); } GVirConfigStoragePoolTarget *gvir_config_storage_pool_target_new(void) { GVirConfigObject *object; object = gvir_config_object_new(GVIR_CONFIG_TYPE_STORAGE_POOL_TARGET, "target", NULL); return GVIR_CONFIG_STORAGE_POOL_TARGET(object); } GVirConfigStoragePoolTarget *gvir_config_storage_pool_target_new_from_xml(const gchar *xml, GError **error) { GVirConfigObject *object; object = gvir_config_object_new_from_xml(GVIR_CONFIG_TYPE_STORAGE_POOL_TARGET, "target", NULL, xml, error); return GVIR_CONFIG_STORAGE_POOL_TARGET(object); } /** * gvir_config_storage_pool_target_get_path: * @target: a #GVirConfigStoragePoolTarget * * Provides the location at which the storage pool associated with @target * will be mapped into the local filesystem namespace. * * Returns: local filesystem path the storage pool is mapped at. */ const char *gvir_config_storage_pool_target_get_path(GVirConfigStoragePoolTarget *target) { g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_TARGET(target), NULL); return gvir_config_object_get_node_content(GVIR_CONFIG_OBJECT(target), "path"); } /** * gvir_config_storage_pool_target_set_path: * @path: (allow-none): */ void gvir_config_storage_pool_target_set_path(GVirConfigStoragePoolTarget *target, const char *path) { g_return_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_TARGET(target)); gvir_config_object_set_node_content(GVIR_CONFIG_OBJECT(target), "path", path); } /** * gvir_config_storage_pool_target_get_permissions: * @target: a #GVirConfigStoragePoolTarget * * Gets the permissions associated with @target * * Returns: (transfer full): a new #GVirConfigStoragePoolPermissions instance. */ GVirConfigStoragePermissions *gvir_config_storage_pool_target_get_permissions(GVirConfigStoragePoolTarget *target) { GVirConfigObject *object; g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_TARGET(target), NULL); object = gvir_config_object_get_child_with_type (GVIR_CONFIG_OBJECT(target), "permissions", GVIR_CONFIG_TYPE_STORAGE_PERMISSIONS); return GVIR_CONFIG_STORAGE_PERMISSIONS(object); } /** * gvir_config_storage_pool_perms_set_permissions: * @perms: (allow-none): */ void gvir_config_storage_pool_target_set_permissions(GVirConfigStoragePoolTarget *target, GVirConfigStoragePermissions *perms) { g_return_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_TARGET(target)); g_return_if_fail(perms == NULL || GVIR_CONFIG_IS_STORAGE_PERMISSIONS(perms)); gvir_config_object_attach_replace(GVIR_CONFIG_OBJECT(target), "permissions", GVIR_CONFIG_OBJECT(perms)); }