/*
* libvirt-gconfig-storage-pool-source.c: libvirt storage pool source 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
* <http://www.gnu.org/licenses/>.
*
* Author: Christophe Fergeau <cfergeau@redhat.com>
*/
#include <config.h>
#include "libvirt-gconfig/libvirt-gconfig.h"
#include "libvirt-gconfig/libvirt-gconfig-private.h"
#define GVIR_CONFIG_STORAGE_POOL_SOURCE_GET_PRIVATE(obj) \
(G_TYPE_INSTANCE_GET_PRIVATE((obj), GVIR_CONFIG_TYPE_STORAGE_POOL_SOURCE, GVirConfigStoragePoolSourcePrivate))
struct _GVirConfigStoragePoolSourcePrivate
{
gboolean unused;
};
G_DEFINE_TYPE_WITH_PRIVATE(GVirConfigStoragePoolSource, gvir_config_storage_pool_source, GVIR_CONFIG_TYPE_OBJECT);
static void gvir_config_storage_pool_source_class_init(GVirConfigStoragePoolSourceClass *klass G_GNUC_UNUSED)
{
}
static void gvir_config_storage_pool_source_init(GVirConfigStoragePoolSource *source)
{
source->priv = GVIR_CONFIG_STORAGE_POOL_SOURCE_GET_PRIVATE(source);
}
GVirConfigStoragePoolSource *gvir_config_storage_pool_source_new(void)
{
GVirConfigObject *object;
object = gvir_config_object_new(GVIR_CONFIG_TYPE_STORAGE_POOL_SOURCE,
"source", NULL);
return GVIR_CONFIG_STORAGE_POOL_SOURCE(object);
}
GVirConfigStoragePoolSource *gvir_config_storage_pool_source_new_from_xml(const gchar *xml,
GError **error)
{
GVirConfigObject *object;
object = gvir_config_object_new_from_xml(GVIR_CONFIG_TYPE_STORAGE_POOL_SOURCE,
"source", NULL,
xml, error);
return GVIR_CONFIG_STORAGE_POOL_SOURCE(object);
}
/**
* gvir_config_storage_pool_source_get_adapter:
* @source: a #GVirConfigStoragePoolSource
*
* For pools backed by a SCSI adapter, returns the SCSI adapter name
*
* Returns: the SCSI adapter name.
*/
const char *gvir_config_storage_pool_source_get_adapter(GVirConfigStoragePoolSource *source)
{
g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source), NULL);
return gvir_config_object_get_attribute(GVIR_CONFIG_OBJECT(source),
"adapter",
"name");
}
void gvir_config_storage_pool_source_set_adapter(GVirConfigStoragePoolSource *source,
const char *adapter)
{
GVirConfigObject *node;
g_return_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source));
node = gvir_config_object_replace_child(GVIR_CONFIG_OBJECT(source), "adapter");
g_return_if_fail(GVIR_CONFIG_IS_OBJECT(node));
gvir_config_object_set_attribute(node, "name", adapter, NULL);
g_object_unref(G_OBJECT(node));
}
/**
* gvir_config_storage_pool_source_get_device_path:
* @source: a #GVirConfigStoragePoolSource
*
* For pools backed by a physical device, returns the path to the block
* device node
*
* Returns: fully qualified path to the block device node.
*/
const char *gvir_config_storage_pool_source_get_device_path(GVirConfigStoragePoolSource *source)
{
g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source), NULL);
return gvir_config_object_get_attribute(GVIR_CONFIG_OBJECT(source),
"device",
"path");
}
void gvir_config_storage_pool_source_set_device_path(GVirConfigStoragePoolSource *source,
const char *device_path)
{
GVirConfigObject *node;
g_return_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source));
node = gvir_config_object_add_child(GVIR_CONFIG_OBJECT(source), "device");
g_return_if_fail(GVIR_CONFIG_IS_OBJECT(node));
gvir_config_object_set_attribute(node, "path", device_path, NULL);
g_object_unref(G_OBJECT(node));
}
/**
* gvir_config_storage_pool_source_get_directory:
* @source: a #GVirConfigStoragePoolSource
*
* For pools backed by a directory, returns the path to the backing directory
*
* Returns: path to the directory backing directory.
*/
const char *gvir_config_storage_pool_source_get_directory(GVirConfigStoragePoolSource *source)
{
g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source), NULL);
return gvir_config_object_get_attribute(GVIR_CONFIG_OBJECT(source),
"directory",
"path");
}
void gvir_config_storage_pool_source_set_directory(GVirConfigStoragePoolSource *source,
const char *directory)
{
GVirConfigObject *node;
g_return_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source));
node = gvir_config_object_replace_child(GVIR_CONFIG_OBJECT(source), "directory");
g_return_if_fail(GVIR_CONFIG_IS_OBJECT(node));
gvir_config_object_set_attribute(node, "path", directory, NULL);
g_object_unref(G_OBJECT(node));
}
/**
* gvir_config_storage_pool_source_get_format:
* @source: a #GVirConfigStoragePoolSource
*
* Provides information about the format of the pool. This format is
* backend-specific but is typically used to indicate filesystem type, or
* network filesystem type, or partition table type, or LVM metadata type.
*
* Returns: the storage pool format.
*/
const char *gvir_config_storage_pool_source_get_format(GVirConfigStoragePoolSource *source)
{
g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source), NULL);
return gvir_config_object_get_attribute(GVIR_CONFIG_OBJECT(source),
"format",
"type");
}
void gvir_config_storage_pool_source_set_format(GVirConfigStoragePoolSource *source,
const char *format)
{
GVirConfigObject *node;
g_return_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source));
node = gvir_config_object_replace_child(GVIR_CONFIG_OBJECT(source), "format");
g_return_if_fail(GVIR_CONFIG_IS_OBJECT(node));
gvir_config_object_set_attribute(node, "type", format, NULL);
g_object_unref(G_OBJECT(node));
}
/**
* gvir_config_storage_pool_source_get_host:
* @source: a #GVirConfigStoragePoolSource
*
* For pools backed by storage from remote server, returns the hostname
* of the remote server.
*
* Returns: hostname or IP address of the remote server.
*/
const char *gvir_config_storage_pool_source_get_host(GVirConfigStoragePoolSource *source)
{
g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source), NULL);
return gvir_config_object_get_attribute(GVIR_CONFIG_OBJECT(source),
"host",
"name");
}
void gvir_config_storage_pool_source_set_host(GVirConfigStoragePoolSource *source,
const char *host)
{
GVirConfigObject *node;
g_return_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source));
node = gvir_config_object_replace_child(GVIR_CONFIG_OBJECT(source), "host");
g_return_if_fail(GVIR_CONFIG_IS_OBJECT(node));
gvir_config_object_set_attribute(node, "name", host, NULL);
g_object_unref(G_OBJECT(node));
}
/**
* gvir_config_storage_pool_source_get_name:
* @source: a #GVirConfigStoragePoolSource
*
* For pools backed by storage from a named element (for example, LV
* groups), returns the name of the element
*
* Returns: name of the element used by @source
*/
const char *gvir_config_storage_pool_source_get_name(GVirConfigStoragePoolSource *source)
{
g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source), NULL);
return gvir_config_object_get_node_content(GVIR_CONFIG_OBJECT(source),
"name");
}
/**
* gvir_config_storage_pool_source_set_name:
* @name: (allow-none):
*/
void gvir_config_storage_pool_source_set_name(GVirConfigStoragePoolSource *source,
const char *name)
{
g_return_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source));
gvir_config_object_set_node_content(GVIR_CONFIG_OBJECT(source),
"name", name);
}
/**
* gvir_config_storage_pool_source_get_product:
* @source: a #GVirConfigStoragePoolSource
*
* Gets the product name of the storage device.
*
* Returns: product name of the storage device.
*/
const char *gvir_config_storage_pool_source_get_product(GVirConfigStoragePoolSource *source)
{
g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source), NULL);
return gvir_config_object_get_attribute(GVIR_CONFIG_OBJECT(source),
"product",
"name");
}
void gvir_config_storage_pool_source_set_product(GVirConfigStoragePoolSource *source,
const char *product)
{
GVirConfigObject *node;
g_return_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source));
node = gvir_config_object_replace_child(GVIR_CONFIG_OBJECT(source), "product");
g_return_if_fail(GVIR_CONFIG_IS_OBJECT(node));
gvir_config_object_set_attribute(node, "name", product, NULL);
g_object_unref(G_OBJECT(node));
}
/**
* gvir_config_storage_pool_source_get_vendor:
* @source: a #GVirConfigStoragePoolSource
*
* Gets the vendor name of the storage device.
*
* Returns: vendor name of the storage device.
*/
const char *gvir_config_storage_pool_source_get_vendor(GVirConfigStoragePoolSource *source)
{
g_return_val_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source), NULL);
return gvir_config_object_get_attribute(GVIR_CONFIG_OBJECT(source),
"vendor",
"name");
}
void gvir_config_storage_pool_source_set_vendor(GVirConfigStoragePoolSource *source,
const char *vendor)
{
GVirConfigObject *node;
g_return_if_fail(GVIR_CONFIG_IS_STORAGE_POOL_SOURCE(source));
node = gvir_config_object_replace_child(GVIR_CONFIG_OBJECT(source), "vendor");
g_return_if_fail(GVIR_CONFIG_IS_OBJECT(node));
gvir_config_object_set_attribute(node, "name", vendor, NULL);
g_object_unref(G_OBJECT(node));
}