/*
* Copyright (c) Citrix Systems, Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1) Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2) Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials
* provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE.
*/
using System;
using System.Collections;
using System.Collections.Generic;
using CookComputing.XmlRpc;
namespace XenAPI
{
///
/// Pool-wide information
/// First published in XenServer 4.0.
///
public partial class Pool : XenObject
{
public Pool()
{
}
public Pool(string uuid,
string name_label,
string name_description,
XenRef master,
XenRef default_SR,
XenRef suspend_image_SR,
XenRef crash_dump_SR,
Dictionary other_config,
bool ha_enabled,
Dictionary ha_configuration,
string[] ha_statefiles,
long ha_host_failures_to_tolerate,
long ha_plan_exists_for,
bool ha_allow_overcommit,
bool ha_overcommitted,
Dictionary> blobs,
string[] tags,
Dictionary gui_config,
Dictionary health_check_config,
string wlb_url,
string wlb_username,
bool wlb_enabled,
bool wlb_verify_cert,
bool redo_log_enabled,
XenRef redo_log_vdi,
string vswitch_controller,
Dictionary restrictions,
List> metadata_VDIs,
string ha_cluster_stack,
List allowed_operations,
Dictionary current_operations,
Dictionary guest_agent_config,
Dictionary cpu_info,
bool policy_no_vendor_device,
bool live_patching_disabled)
{
this.uuid = uuid;
this.name_label = name_label;
this.name_description = name_description;
this.master = master;
this.default_SR = default_SR;
this.suspend_image_SR = suspend_image_SR;
this.crash_dump_SR = crash_dump_SR;
this.other_config = other_config;
this.ha_enabled = ha_enabled;
this.ha_configuration = ha_configuration;
this.ha_statefiles = ha_statefiles;
this.ha_host_failures_to_tolerate = ha_host_failures_to_tolerate;
this.ha_plan_exists_for = ha_plan_exists_for;
this.ha_allow_overcommit = ha_allow_overcommit;
this.ha_overcommitted = ha_overcommitted;
this.blobs = blobs;
this.tags = tags;
this.gui_config = gui_config;
this.health_check_config = health_check_config;
this.wlb_url = wlb_url;
this.wlb_username = wlb_username;
this.wlb_enabled = wlb_enabled;
this.wlb_verify_cert = wlb_verify_cert;
this.redo_log_enabled = redo_log_enabled;
this.redo_log_vdi = redo_log_vdi;
this.vswitch_controller = vswitch_controller;
this.restrictions = restrictions;
this.metadata_VDIs = metadata_VDIs;
this.ha_cluster_stack = ha_cluster_stack;
this.allowed_operations = allowed_operations;
this.current_operations = current_operations;
this.guest_agent_config = guest_agent_config;
this.cpu_info = cpu_info;
this.policy_no_vendor_device = policy_no_vendor_device;
this.live_patching_disabled = live_patching_disabled;
}
///
/// Creates a new Pool from a Proxy_Pool.
///
///
public Pool(Proxy_Pool proxy)
{
this.UpdateFromProxy(proxy);
}
public override void UpdateFrom(Pool update)
{
uuid = update.uuid;
name_label = update.name_label;
name_description = update.name_description;
master = update.master;
default_SR = update.default_SR;
suspend_image_SR = update.suspend_image_SR;
crash_dump_SR = update.crash_dump_SR;
other_config = update.other_config;
ha_enabled = update.ha_enabled;
ha_configuration = update.ha_configuration;
ha_statefiles = update.ha_statefiles;
ha_host_failures_to_tolerate = update.ha_host_failures_to_tolerate;
ha_plan_exists_for = update.ha_plan_exists_for;
ha_allow_overcommit = update.ha_allow_overcommit;
ha_overcommitted = update.ha_overcommitted;
blobs = update.blobs;
tags = update.tags;
gui_config = update.gui_config;
health_check_config = update.health_check_config;
wlb_url = update.wlb_url;
wlb_username = update.wlb_username;
wlb_enabled = update.wlb_enabled;
wlb_verify_cert = update.wlb_verify_cert;
redo_log_enabled = update.redo_log_enabled;
redo_log_vdi = update.redo_log_vdi;
vswitch_controller = update.vswitch_controller;
restrictions = update.restrictions;
metadata_VDIs = update.metadata_VDIs;
ha_cluster_stack = update.ha_cluster_stack;
allowed_operations = update.allowed_operations;
current_operations = update.current_operations;
guest_agent_config = update.guest_agent_config;
cpu_info = update.cpu_info;
policy_no_vendor_device = update.policy_no_vendor_device;
live_patching_disabled = update.live_patching_disabled;
}
internal void UpdateFromProxy(Proxy_Pool proxy)
{
uuid = proxy.uuid == null ? null : (string)proxy.uuid;
name_label = proxy.name_label == null ? null : (string)proxy.name_label;
name_description = proxy.name_description == null ? null : (string)proxy.name_description;
master = proxy.master == null ? null : XenRef.Create(proxy.master);
default_SR = proxy.default_SR == null ? null : XenRef.Create(proxy.default_SR);
suspend_image_SR = proxy.suspend_image_SR == null ? null : XenRef.Create(proxy.suspend_image_SR);
crash_dump_SR = proxy.crash_dump_SR == null ? null : XenRef.Create(proxy.crash_dump_SR);
other_config = proxy.other_config == null ? null : Maps.convert_from_proxy_string_string(proxy.other_config);
ha_enabled = (bool)proxy.ha_enabled;
ha_configuration = proxy.ha_configuration == null ? null : Maps.convert_from_proxy_string_string(proxy.ha_configuration);
ha_statefiles = proxy.ha_statefiles == null ? new string[] {} : (string [])proxy.ha_statefiles;
ha_host_failures_to_tolerate = proxy.ha_host_failures_to_tolerate == null ? 0 : long.Parse((string)proxy.ha_host_failures_to_tolerate);
ha_plan_exists_for = proxy.ha_plan_exists_for == null ? 0 : long.Parse((string)proxy.ha_plan_exists_for);
ha_allow_overcommit = (bool)proxy.ha_allow_overcommit;
ha_overcommitted = (bool)proxy.ha_overcommitted;
blobs = proxy.blobs == null ? null : Maps.convert_from_proxy_string_XenRefBlob(proxy.blobs);
tags = proxy.tags == null ? new string[] {} : (string [])proxy.tags;
gui_config = proxy.gui_config == null ? null : Maps.convert_from_proxy_string_string(proxy.gui_config);
health_check_config = proxy.health_check_config == null ? null : Maps.convert_from_proxy_string_string(proxy.health_check_config);
wlb_url = proxy.wlb_url == null ? null : (string)proxy.wlb_url;
wlb_username = proxy.wlb_username == null ? null : (string)proxy.wlb_username;
wlb_enabled = (bool)proxy.wlb_enabled;
wlb_verify_cert = (bool)proxy.wlb_verify_cert;
redo_log_enabled = (bool)proxy.redo_log_enabled;
redo_log_vdi = proxy.redo_log_vdi == null ? null : XenRef.Create(proxy.redo_log_vdi);
vswitch_controller = proxy.vswitch_controller == null ? null : (string)proxy.vswitch_controller;
restrictions = proxy.restrictions == null ? null : Maps.convert_from_proxy_string_string(proxy.restrictions);
metadata_VDIs = proxy.metadata_VDIs == null ? null : XenRef.Create(proxy.metadata_VDIs);
ha_cluster_stack = proxy.ha_cluster_stack == null ? null : (string)proxy.ha_cluster_stack;
allowed_operations = proxy.allowed_operations == null ? null : Helper.StringArrayToEnumList(proxy.allowed_operations);
current_operations = proxy.current_operations == null ? null : Maps.convert_from_proxy_string_pool_allowed_operations(proxy.current_operations);
guest_agent_config = proxy.guest_agent_config == null ? null : Maps.convert_from_proxy_string_string(proxy.guest_agent_config);
cpu_info = proxy.cpu_info == null ? null : Maps.convert_from_proxy_string_string(proxy.cpu_info);
policy_no_vendor_device = (bool)proxy.policy_no_vendor_device;
live_patching_disabled = (bool)proxy.live_patching_disabled;
}
public Proxy_Pool ToProxy()
{
Proxy_Pool result_ = new Proxy_Pool();
result_.uuid = (uuid != null) ? uuid : "";
result_.name_label = (name_label != null) ? name_label : "";
result_.name_description = (name_description != null) ? name_description : "";
result_.master = (master != null) ? master : "";
result_.default_SR = (default_SR != null) ? default_SR : "";
result_.suspend_image_SR = (suspend_image_SR != null) ? suspend_image_SR : "";
result_.crash_dump_SR = (crash_dump_SR != null) ? crash_dump_SR : "";
result_.other_config = Maps.convert_to_proxy_string_string(other_config);
result_.ha_enabled = ha_enabled;
result_.ha_configuration = Maps.convert_to_proxy_string_string(ha_configuration);
result_.ha_statefiles = ha_statefiles;
result_.ha_host_failures_to_tolerate = ha_host_failures_to_tolerate.ToString();
result_.ha_plan_exists_for = ha_plan_exists_for.ToString();
result_.ha_allow_overcommit = ha_allow_overcommit;
result_.ha_overcommitted = ha_overcommitted;
result_.blobs = Maps.convert_to_proxy_string_XenRefBlob(blobs);
result_.tags = tags;
result_.gui_config = Maps.convert_to_proxy_string_string(gui_config);
result_.health_check_config = Maps.convert_to_proxy_string_string(health_check_config);
result_.wlb_url = (wlb_url != null) ? wlb_url : "";
result_.wlb_username = (wlb_username != null) ? wlb_username : "";
result_.wlb_enabled = wlb_enabled;
result_.wlb_verify_cert = wlb_verify_cert;
result_.redo_log_enabled = redo_log_enabled;
result_.redo_log_vdi = (redo_log_vdi != null) ? redo_log_vdi : "";
result_.vswitch_controller = (vswitch_controller != null) ? vswitch_controller : "";
result_.restrictions = Maps.convert_to_proxy_string_string(restrictions);
result_.metadata_VDIs = (metadata_VDIs != null) ? Helper.RefListToStringArray(metadata_VDIs) : new string[] {};
result_.ha_cluster_stack = (ha_cluster_stack != null) ? ha_cluster_stack : "";
result_.allowed_operations = (allowed_operations != null) ? Helper.ObjectListToStringArray(allowed_operations) : new string[] {};
result_.current_operations = Maps.convert_to_proxy_string_pool_allowed_operations(current_operations);
result_.guest_agent_config = Maps.convert_to_proxy_string_string(guest_agent_config);
result_.cpu_info = Maps.convert_to_proxy_string_string(cpu_info);
result_.policy_no_vendor_device = policy_no_vendor_device;
result_.live_patching_disabled = live_patching_disabled;
return result_;
}
///
/// Creates a new Pool from a Hashtable.
///
///
public Pool(Hashtable table)
{
uuid = Marshalling.ParseString(table, "uuid");
name_label = Marshalling.ParseString(table, "name_label");
name_description = Marshalling.ParseString(table, "name_description");
master = Marshalling.ParseRef(table, "master");
default_SR = Marshalling.ParseRef(table, "default_SR");
suspend_image_SR = Marshalling.ParseRef(table, "suspend_image_SR");
crash_dump_SR = Marshalling.ParseRef(table, "crash_dump_SR");
other_config = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "other_config"));
ha_enabled = Marshalling.ParseBool(table, "ha_enabled");
ha_configuration = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "ha_configuration"));
ha_statefiles = Marshalling.ParseStringArray(table, "ha_statefiles");
ha_host_failures_to_tolerate = Marshalling.ParseLong(table, "ha_host_failures_to_tolerate");
ha_plan_exists_for = Marshalling.ParseLong(table, "ha_plan_exists_for");
ha_allow_overcommit = Marshalling.ParseBool(table, "ha_allow_overcommit");
ha_overcommitted = Marshalling.ParseBool(table, "ha_overcommitted");
blobs = Maps.convert_from_proxy_string_XenRefBlob(Marshalling.ParseHashTable(table, "blobs"));
tags = Marshalling.ParseStringArray(table, "tags");
gui_config = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "gui_config"));
health_check_config = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "health_check_config"));
wlb_url = Marshalling.ParseString(table, "wlb_url");
wlb_username = Marshalling.ParseString(table, "wlb_username");
wlb_enabled = Marshalling.ParseBool(table, "wlb_enabled");
wlb_verify_cert = Marshalling.ParseBool(table, "wlb_verify_cert");
redo_log_enabled = Marshalling.ParseBool(table, "redo_log_enabled");
redo_log_vdi = Marshalling.ParseRef(table, "redo_log_vdi");
vswitch_controller = Marshalling.ParseString(table, "vswitch_controller");
restrictions = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "restrictions"));
metadata_VDIs = Marshalling.ParseSetRef(table, "metadata_VDIs");
ha_cluster_stack = Marshalling.ParseString(table, "ha_cluster_stack");
allowed_operations = Helper.StringArrayToEnumList(Marshalling.ParseStringArray(table, "allowed_operations"));
current_operations = Maps.convert_from_proxy_string_pool_allowed_operations(Marshalling.ParseHashTable(table, "current_operations"));
guest_agent_config = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "guest_agent_config"));
cpu_info = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "cpu_info"));
policy_no_vendor_device = Marshalling.ParseBool(table, "policy_no_vendor_device");
live_patching_disabled = Marshalling.ParseBool(table, "live_patching_disabled");
}
public bool DeepEquals(Pool other, bool ignoreCurrentOperations)
{
if (ReferenceEquals(null, other))
return false;
if (ReferenceEquals(this, other))
return true;
if (!ignoreCurrentOperations && !Helper.AreEqual2(this.current_operations, other.current_operations))
return false;
return Helper.AreEqual2(this._uuid, other._uuid) &&
Helper.AreEqual2(this._name_label, other._name_label) &&
Helper.AreEqual2(this._name_description, other._name_description) &&
Helper.AreEqual2(this._master, other._master) &&
Helper.AreEqual2(this._default_SR, other._default_SR) &&
Helper.AreEqual2(this._suspend_image_SR, other._suspend_image_SR) &&
Helper.AreEqual2(this._crash_dump_SR, other._crash_dump_SR) &&
Helper.AreEqual2(this._other_config, other._other_config) &&
Helper.AreEqual2(this._ha_enabled, other._ha_enabled) &&
Helper.AreEqual2(this._ha_configuration, other._ha_configuration) &&
Helper.AreEqual2(this._ha_statefiles, other._ha_statefiles) &&
Helper.AreEqual2(this._ha_host_failures_to_tolerate, other._ha_host_failures_to_tolerate) &&
Helper.AreEqual2(this._ha_plan_exists_for, other._ha_plan_exists_for) &&
Helper.AreEqual2(this._ha_allow_overcommit, other._ha_allow_overcommit) &&
Helper.AreEqual2(this._ha_overcommitted, other._ha_overcommitted) &&
Helper.AreEqual2(this._blobs, other._blobs) &&
Helper.AreEqual2(this._tags, other._tags) &&
Helper.AreEqual2(this._gui_config, other._gui_config) &&
Helper.AreEqual2(this._health_check_config, other._health_check_config) &&
Helper.AreEqual2(this._wlb_url, other._wlb_url) &&
Helper.AreEqual2(this._wlb_username, other._wlb_username) &&
Helper.AreEqual2(this._wlb_enabled, other._wlb_enabled) &&
Helper.AreEqual2(this._wlb_verify_cert, other._wlb_verify_cert) &&
Helper.AreEqual2(this._redo_log_enabled, other._redo_log_enabled) &&
Helper.AreEqual2(this._redo_log_vdi, other._redo_log_vdi) &&
Helper.AreEqual2(this._vswitch_controller, other._vswitch_controller) &&
Helper.AreEqual2(this._restrictions, other._restrictions) &&
Helper.AreEqual2(this._metadata_VDIs, other._metadata_VDIs) &&
Helper.AreEqual2(this._ha_cluster_stack, other._ha_cluster_stack) &&
Helper.AreEqual2(this._allowed_operations, other._allowed_operations) &&
Helper.AreEqual2(this._guest_agent_config, other._guest_agent_config) &&
Helper.AreEqual2(this._cpu_info, other._cpu_info) &&
Helper.AreEqual2(this._policy_no_vendor_device, other._policy_no_vendor_device) &&
Helper.AreEqual2(this._live_patching_disabled, other._live_patching_disabled);
}
public override string SaveChanges(Session session, string opaqueRef, Pool server)
{
if (opaqueRef == null)
{
System.Diagnostics.Debug.Assert(false, "Cannot create instances of this type on the server");
return "";
}
else
{
if (!Helper.AreEqual2(_name_label, server._name_label))
{
Pool.set_name_label(session, opaqueRef, _name_label);
}
if (!Helper.AreEqual2(_name_description, server._name_description))
{
Pool.set_name_description(session, opaqueRef, _name_description);
}
if (!Helper.AreEqual2(_default_SR, server._default_SR))
{
Pool.set_default_SR(session, opaqueRef, _default_SR);
}
if (!Helper.AreEqual2(_suspend_image_SR, server._suspend_image_SR))
{
Pool.set_suspend_image_SR(session, opaqueRef, _suspend_image_SR);
}
if (!Helper.AreEqual2(_crash_dump_SR, server._crash_dump_SR))
{
Pool.set_crash_dump_SR(session, opaqueRef, _crash_dump_SR);
}
if (!Helper.AreEqual2(_other_config, server._other_config))
{
Pool.set_other_config(session, opaqueRef, _other_config);
}
if (!Helper.AreEqual2(_ha_allow_overcommit, server._ha_allow_overcommit))
{
Pool.set_ha_allow_overcommit(session, opaqueRef, _ha_allow_overcommit);
}
if (!Helper.AreEqual2(_tags, server._tags))
{
Pool.set_tags(session, opaqueRef, _tags);
}
if (!Helper.AreEqual2(_gui_config, server._gui_config))
{
Pool.set_gui_config(session, opaqueRef, _gui_config);
}
if (!Helper.AreEqual2(_health_check_config, server._health_check_config))
{
Pool.set_health_check_config(session, opaqueRef, _health_check_config);
}
if (!Helper.AreEqual2(_wlb_enabled, server._wlb_enabled))
{
Pool.set_wlb_enabled(session, opaqueRef, _wlb_enabled);
}
if (!Helper.AreEqual2(_wlb_verify_cert, server._wlb_verify_cert))
{
Pool.set_wlb_verify_cert(session, opaqueRef, _wlb_verify_cert);
}
if (!Helper.AreEqual2(_policy_no_vendor_device, server._policy_no_vendor_device))
{
Pool.set_policy_no_vendor_device(session, opaqueRef, _policy_no_vendor_device);
}
if (!Helper.AreEqual2(_live_patching_disabled, server._live_patching_disabled))
{
Pool.set_live_patching_disabled(session, opaqueRef, _live_patching_disabled);
}
return null;
}
}
///
/// Get a record containing the current state of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
public static Pool get_record(Session session, string _pool)
{
return new Pool((Proxy_Pool)session.proxy.pool_get_record(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get a reference to the pool instance with the specified UUID.
/// First published in XenServer 4.0.
///
/// The session
/// UUID of object to return
public static XenRef get_by_uuid(Session session, string _uuid)
{
return XenRef.Create(session.proxy.pool_get_by_uuid(session.uuid, (_uuid != null) ? _uuid : "").parse());
}
///
/// Get the uuid field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
public static string get_uuid(Session session, string _pool)
{
return (string)session.proxy.pool_get_uuid(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the name_label field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
public static string get_name_label(Session session, string _pool)
{
return (string)session.proxy.pool_get_name_label(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the name_description field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
public static string get_name_description(Session session, string _pool)
{
return (string)session.proxy.pool_get_name_description(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the master field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
public static XenRef get_master(Session session, string _pool)
{
return XenRef.Create(session.proxy.pool_get_master(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the default_SR field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
public static XenRef get_default_SR(Session session, string _pool)
{
return XenRef.Create(session.proxy.pool_get_default_sr(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the suspend_image_SR field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
public static XenRef get_suspend_image_SR(Session session, string _pool)
{
return XenRef.Create(session.proxy.pool_get_suspend_image_sr(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the crash_dump_SR field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
public static XenRef get_crash_dump_SR(Session session, string _pool)
{
return XenRef.Create(session.proxy.pool_get_crash_dump_sr(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the other_config field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
public static Dictionary get_other_config(Session session, string _pool)
{
return Maps.convert_from_proxy_string_string(session.proxy.pool_get_other_config(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the ha_enabled field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
public static bool get_ha_enabled(Session session, string _pool)
{
return (bool)session.proxy.pool_get_ha_enabled(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the ha_configuration field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
public static Dictionary get_ha_configuration(Session session, string _pool)
{
return Maps.convert_from_proxy_string_string(session.proxy.pool_get_ha_configuration(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the ha_statefiles field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
public static string[] get_ha_statefiles(Session session, string _pool)
{
return (string [])session.proxy.pool_get_ha_statefiles(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the ha_host_failures_to_tolerate field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
public static long get_ha_host_failures_to_tolerate(Session session, string _pool)
{
return long.Parse((string)session.proxy.pool_get_ha_host_failures_to_tolerate(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the ha_plan_exists_for field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
public static long get_ha_plan_exists_for(Session session, string _pool)
{
return long.Parse((string)session.proxy.pool_get_ha_plan_exists_for(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the ha_allow_overcommit field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
public static bool get_ha_allow_overcommit(Session session, string _pool)
{
return (bool)session.proxy.pool_get_ha_allow_overcommit(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the ha_overcommitted field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
public static bool get_ha_overcommitted(Session session, string _pool)
{
return (bool)session.proxy.pool_get_ha_overcommitted(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the blobs field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
public static Dictionary> get_blobs(Session session, string _pool)
{
return Maps.convert_from_proxy_string_XenRefBlob(session.proxy.pool_get_blobs(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the tags field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
public static string[] get_tags(Session session, string _pool)
{
return (string [])session.proxy.pool_get_tags(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the gui_config field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
public static Dictionary get_gui_config(Session session, string _pool)
{
return Maps.convert_from_proxy_string_string(session.proxy.pool_get_gui_config(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the health_check_config field of the given pool.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
public static Dictionary get_health_check_config(Session session, string _pool)
{
return Maps.convert_from_proxy_string_string(session.proxy.pool_get_health_check_config(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the wlb_url field of the given pool.
/// First published in XenServer 5.5.
///
/// The session
/// The opaque_ref of the given pool
public static string get_wlb_url(Session session, string _pool)
{
return (string)session.proxy.pool_get_wlb_url(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the wlb_username field of the given pool.
/// First published in XenServer 5.5.
///
/// The session
/// The opaque_ref of the given pool
public static string get_wlb_username(Session session, string _pool)
{
return (string)session.proxy.pool_get_wlb_username(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the wlb_enabled field of the given pool.
/// First published in XenServer 5.5.
///
/// The session
/// The opaque_ref of the given pool
public static bool get_wlb_enabled(Session session, string _pool)
{
return (bool)session.proxy.pool_get_wlb_enabled(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the wlb_verify_cert field of the given pool.
/// First published in XenServer 5.5.
///
/// The session
/// The opaque_ref of the given pool
public static bool get_wlb_verify_cert(Session session, string _pool)
{
return (bool)session.proxy.pool_get_wlb_verify_cert(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the redo_log_enabled field of the given pool.
/// First published in XenServer 5.6.
///
/// The session
/// The opaque_ref of the given pool
public static bool get_redo_log_enabled(Session session, string _pool)
{
return (bool)session.proxy.pool_get_redo_log_enabled(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the redo_log_vdi field of the given pool.
/// First published in XenServer 5.6.
///
/// The session
/// The opaque_ref of the given pool
public static XenRef get_redo_log_vdi(Session session, string _pool)
{
return XenRef.Create(session.proxy.pool_get_redo_log_vdi(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the vswitch_controller field of the given pool.
/// First published in XenServer 5.6.
/// Deprecated since .
///
/// The session
/// The opaque_ref of the given pool
[Deprecated("")]
public static string get_vswitch_controller(Session session, string _pool)
{
return (string)session.proxy.pool_get_vswitch_controller(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the restrictions field of the given pool.
/// First published in XenServer 5.6.
///
/// The session
/// The opaque_ref of the given pool
public static Dictionary get_restrictions(Session session, string _pool)
{
return Maps.convert_from_proxy_string_string(session.proxy.pool_get_restrictions(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the metadata_VDIs field of the given pool.
/// First published in XenServer 6.0.
///
/// The session
/// The opaque_ref of the given pool
public static List> get_metadata_VDIs(Session session, string _pool)
{
return XenRef.Create(session.proxy.pool_get_metadata_vdis(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the ha_cluster_stack field of the given pool.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
public static string get_ha_cluster_stack(Session session, string _pool)
{
return (string)session.proxy.pool_get_ha_cluster_stack(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the allowed_operations field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
public static List get_allowed_operations(Session session, string _pool)
{
return Helper.StringArrayToEnumList(session.proxy.pool_get_allowed_operations(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the current_operations field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
public static Dictionary get_current_operations(Session session, string _pool)
{
return Maps.convert_from_proxy_string_pool_allowed_operations(session.proxy.pool_get_current_operations(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the guest_agent_config field of the given pool.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
public static Dictionary get_guest_agent_config(Session session, string _pool)
{
return Maps.convert_from_proxy_string_string(session.proxy.pool_get_guest_agent_config(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the cpu_info field of the given pool.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
public static Dictionary get_cpu_info(Session session, string _pool)
{
return Maps.convert_from_proxy_string_string(session.proxy.pool_get_cpu_info(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Get the policy_no_vendor_device field of the given pool.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
public static bool get_policy_no_vendor_device(Session session, string _pool)
{
return (bool)session.proxy.pool_get_policy_no_vendor_device(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Get the live_patching_disabled field of the given pool.
/// First published in .
///
/// The session
/// The opaque_ref of the given pool
public static bool get_live_patching_disabled(Session session, string _pool)
{
return (bool)session.proxy.pool_get_live_patching_disabled(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Set the name_label field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_name_label(Session session, string _pool, string _name_label)
{
session.proxy.pool_set_name_label(session.uuid, (_pool != null) ? _pool : "", (_name_label != null) ? _name_label : "").parse();
}
///
/// Set the name_description field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_name_description(Session session, string _pool, string _name_description)
{
session.proxy.pool_set_name_description(session.uuid, (_pool != null) ? _pool : "", (_name_description != null) ? _name_description : "").parse();
}
///
/// Set the default_SR field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_default_SR(Session session, string _pool, string _default_sr)
{
session.proxy.pool_set_default_sr(session.uuid, (_pool != null) ? _pool : "", (_default_sr != null) ? _default_sr : "").parse();
}
///
/// Set the suspend_image_SR field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_suspend_image_SR(Session session, string _pool, string _suspend_image_sr)
{
session.proxy.pool_set_suspend_image_sr(session.uuid, (_pool != null) ? _pool : "", (_suspend_image_sr != null) ? _suspend_image_sr : "").parse();
}
///
/// Set the crash_dump_SR field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_crash_dump_SR(Session session, string _pool, string _crash_dump_sr)
{
session.proxy.pool_set_crash_dump_sr(session.uuid, (_pool != null) ? _pool : "", (_crash_dump_sr != null) ? _crash_dump_sr : "").parse();
}
///
/// Set the other_config field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_other_config(Session session, string _pool, Dictionary _other_config)
{
session.proxy.pool_set_other_config(session.uuid, (_pool != null) ? _pool : "", Maps.convert_to_proxy_string_string(_other_config)).parse();
}
///
/// Add the given key-value pair to the other_config field of the given pool.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
/// Key to add
/// Value to add
public static void add_to_other_config(Session session, string _pool, string _key, string _value)
{
session.proxy.pool_add_to_other_config(session.uuid, (_pool != null) ? _pool : "", (_key != null) ? _key : "", (_value != null) ? _value : "").parse();
}
///
/// Remove the given key and its corresponding value from the other_config field of the given pool. If the key is not in that Map, then do nothing.
/// First published in XenServer 4.0.
///
/// The session
/// The opaque_ref of the given pool
/// Key to remove
public static void remove_from_other_config(Session session, string _pool, string _key)
{
session.proxy.pool_remove_from_other_config(session.uuid, (_pool != null) ? _pool : "", (_key != null) ? _key : "").parse();
}
///
/// Set the ha_allow_overcommit field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_ha_allow_overcommit(Session session, string _pool, bool _ha_allow_overcommit)
{
session.proxy.pool_set_ha_allow_overcommit(session.uuid, (_pool != null) ? _pool : "", _ha_allow_overcommit).parse();
}
///
/// Set the tags field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_tags(Session session, string _pool, string[] _tags)
{
session.proxy.pool_set_tags(session.uuid, (_pool != null) ? _pool : "", _tags).parse();
}
///
/// Add the given value to the tags field of the given pool. If the value is already in that Set, then do nothing.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// New value to add
public static void add_tags(Session session, string _pool, string _value)
{
session.proxy.pool_add_tags(session.uuid, (_pool != null) ? _pool : "", (_value != null) ? _value : "").parse();
}
///
/// Remove the given value from the tags field of the given pool. If the value is not in that Set, then do nothing.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// Value to remove
public static void remove_tags(Session session, string _pool, string _value)
{
session.proxy.pool_remove_tags(session.uuid, (_pool != null) ? _pool : "", (_value != null) ? _value : "").parse();
}
///
/// Set the gui_config field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_gui_config(Session session, string _pool, Dictionary _gui_config)
{
session.proxy.pool_set_gui_config(session.uuid, (_pool != null) ? _pool : "", Maps.convert_to_proxy_string_string(_gui_config)).parse();
}
///
/// Add the given key-value pair to the gui_config field of the given pool.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// Key to add
/// Value to add
public static void add_to_gui_config(Session session, string _pool, string _key, string _value)
{
session.proxy.pool_add_to_gui_config(session.uuid, (_pool != null) ? _pool : "", (_key != null) ? _key : "", (_value != null) ? _value : "").parse();
}
///
/// Remove the given key and its corresponding value from the gui_config field of the given pool. If the key is not in that Map, then do nothing.
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// Key to remove
public static void remove_from_gui_config(Session session, string _pool, string _key)
{
session.proxy.pool_remove_from_gui_config(session.uuid, (_pool != null) ? _pool : "", (_key != null) ? _key : "").parse();
}
///
/// Set the health_check_config field of the given pool.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_health_check_config(Session session, string _pool, Dictionary _health_check_config)
{
session.proxy.pool_set_health_check_config(session.uuid, (_pool != null) ? _pool : "", Maps.convert_to_proxy_string_string(_health_check_config)).parse();
}
///
/// Add the given key-value pair to the health_check_config field of the given pool.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
/// Key to add
/// Value to add
public static void add_to_health_check_config(Session session, string _pool, string _key, string _value)
{
session.proxy.pool_add_to_health_check_config(session.uuid, (_pool != null) ? _pool : "", (_key != null) ? _key : "", (_value != null) ? _value : "").parse();
}
///
/// Remove the given key and its corresponding value from the health_check_config field of the given pool. If the key is not in that Map, then do nothing.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
/// Key to remove
public static void remove_from_health_check_config(Session session, string _pool, string _key)
{
session.proxy.pool_remove_from_health_check_config(session.uuid, (_pool != null) ? _pool : "", (_key != null) ? _key : "").parse();
}
///
/// Set the wlb_enabled field of the given pool.
/// First published in XenServer 5.5.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_wlb_enabled(Session session, string _pool, bool _wlb_enabled)
{
session.proxy.pool_set_wlb_enabled(session.uuid, (_pool != null) ? _pool : "", _wlb_enabled).parse();
}
///
/// Set the wlb_verify_cert field of the given pool.
/// First published in XenServer 5.5.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_wlb_verify_cert(Session session, string _pool, bool _wlb_verify_cert)
{
session.proxy.pool_set_wlb_verify_cert(session.uuid, (_pool != null) ? _pool : "", _wlb_verify_cert).parse();
}
///
/// Set the policy_no_vendor_device field of the given pool.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_policy_no_vendor_device(Session session, string _pool, bool _policy_no_vendor_device)
{
session.proxy.pool_set_policy_no_vendor_device(session.uuid, (_pool != null) ? _pool : "", _policy_no_vendor_device).parse();
}
///
/// Set the live_patching_disabled field of the given pool.
/// First published in .
///
/// The session
/// The opaque_ref of the given pool
/// New value to set
public static void set_live_patching_disabled(Session session, string _pool, bool _live_patching_disabled)
{
session.proxy.pool_set_live_patching_disabled(session.uuid, (_pool != null) ? _pool : "", _live_patching_disabled).parse();
}
///
/// Instruct host to join a new pool
/// First published in XenServer 4.0.
///
/// The session
/// The hostname of the master of the pool to join
/// The username of the master (for initial authentication)
/// The password for the master (for initial authentication)
public static void join(Session session, string _master_address, string _master_username, string _master_password)
{
session.proxy.pool_join(session.uuid, (_master_address != null) ? _master_address : "", (_master_username != null) ? _master_username : "", (_master_password != null) ? _master_password : "").parse();
}
///
/// Instruct host to join a new pool
/// First published in XenServer 4.0.
///
/// The session
/// The hostname of the master of the pool to join
/// The username of the master (for initial authentication)
/// The password for the master (for initial authentication)
public static XenRef async_join(Session session, string _master_address, string _master_username, string _master_password)
{
return XenRef.Create(session.proxy.async_pool_join(session.uuid, (_master_address != null) ? _master_address : "", (_master_username != null) ? _master_username : "", (_master_password != null) ? _master_password : "").parse());
}
///
/// Instruct host to join a new pool
/// First published in XenServer 4.0.
///
/// The session
/// The hostname of the master of the pool to join
/// The username of the master (for initial authentication)
/// The password for the master (for initial authentication)
public static void join_force(Session session, string _master_address, string _master_username, string _master_password)
{
session.proxy.pool_join_force(session.uuid, (_master_address != null) ? _master_address : "", (_master_username != null) ? _master_username : "", (_master_password != null) ? _master_password : "").parse();
}
///
/// Instruct host to join a new pool
/// First published in XenServer 4.0.
///
/// The session
/// The hostname of the master of the pool to join
/// The username of the master (for initial authentication)
/// The password for the master (for initial authentication)
public static XenRef async_join_force(Session session, string _master_address, string _master_username, string _master_password)
{
return XenRef.Create(session.proxy.async_pool_join_force(session.uuid, (_master_address != null) ? _master_address : "", (_master_username != null) ? _master_username : "", (_master_password != null) ? _master_password : "").parse());
}
///
/// Instruct a pool master to eject a host from the pool
/// First published in XenServer 4.0.
///
/// The session
/// The host to eject
public static void eject(Session session, string _host)
{
session.proxy.pool_eject(session.uuid, (_host != null) ? _host : "").parse();
}
///
/// Instruct a pool master to eject a host from the pool
/// First published in XenServer 4.0.
///
/// The session
/// The host to eject
public static XenRef async_eject(Session session, string _host)
{
return XenRef.Create(session.proxy.async_pool_eject(session.uuid, (_host != null) ? _host : "").parse());
}
///
/// Instruct host that's currently a slave to transition to being master
/// First published in XenServer 4.0.
///
/// The session
public static void emergency_transition_to_master(Session session)
{
session.proxy.pool_emergency_transition_to_master(session.uuid).parse();
}
///
/// Instruct a slave already in a pool that the master has changed
/// First published in XenServer 4.0.
///
/// The session
/// The hostname of the master
public static void emergency_reset_master(Session session, string _master_address)
{
session.proxy.pool_emergency_reset_master(session.uuid, (_master_address != null) ? _master_address : "").parse();
}
///
/// Instruct a pool master, M, to try and contact its slaves and, if slaves are in emergency mode, reset their master address to M.
/// First published in XenServer 4.0.
///
/// The session
public static List> recover_slaves(Session session)
{
return XenRef.Create(session.proxy.pool_recover_slaves(session.uuid).parse());
}
///
/// Instruct a pool master, M, to try and contact its slaves and, if slaves are in emergency mode, reset their master address to M.
/// First published in XenServer 4.0.
///
/// The session
public static XenRef async_recover_slaves(Session session)
{
return XenRef.Create(session.proxy.async_pool_recover_slaves(session.uuid).parse());
}
///
/// Create PIFs, mapping a network to the same physical interface/VLAN on each host. This call is deprecated: use Pool.create_VLAN_from_PIF instead.
/// First published in XenServer 4.0.
///
/// The session
/// physical interface on which to create the VLAN interface
/// network to which this interface should be connected
/// VLAN tag for the new interface
public static List> create_VLAN(Session session, string _device, string _network, long _vlan)
{
return XenRef.Create(session.proxy.pool_create_vlan(session.uuid, (_device != null) ? _device : "", (_network != null) ? _network : "", _vlan.ToString()).parse());
}
///
/// Create PIFs, mapping a network to the same physical interface/VLAN on each host. This call is deprecated: use Pool.create_VLAN_from_PIF instead.
/// First published in XenServer 4.0.
///
/// The session
/// physical interface on which to create the VLAN interface
/// network to which this interface should be connected
/// VLAN tag for the new interface
public static XenRef async_create_VLAN(Session session, string _device, string _network, long _vlan)
{
return XenRef.Create(session.proxy.async_pool_create_vlan(session.uuid, (_device != null) ? _device : "", (_network != null) ? _network : "", _vlan.ToString()).parse());
}
///
/// Create a pool-wide VLAN by taking the PIF.
/// First published in XenServer 4.0.
///
/// The session
/// physical interface on any particular host, that identifies the PIF on which to create the (pool-wide) VLAN interface
/// network to which this interface should be connected
/// VLAN tag for the new interface
public static List> create_VLAN_from_PIF(Session session, string _pif, string _network, long _vlan)
{
return XenRef.Create(session.proxy.pool_create_vlan_from_pif(session.uuid, (_pif != null) ? _pif : "", (_network != null) ? _network : "", _vlan.ToString()).parse());
}
///
/// Create a pool-wide VLAN by taking the PIF.
/// First published in XenServer 4.0.
///
/// The session
/// physical interface on any particular host, that identifies the PIF on which to create the (pool-wide) VLAN interface
/// network to which this interface should be connected
/// VLAN tag for the new interface
public static XenRef async_create_VLAN_from_PIF(Session session, string _pif, string _network, long _vlan)
{
return XenRef.Create(session.proxy.async_pool_create_vlan_from_pif(session.uuid, (_pif != null) ? _pif : "", (_network != null) ? _network : "", _vlan.ToString()).parse());
}
///
/// Turn on High Availability mode
/// First published in XenServer 4.1.
///
/// The session
/// Set of SRs to use for storage heartbeating
/// Detailed HA configuration to apply
public static void enable_ha(Session session, List> _heartbeat_srs, Dictionary _configuration)
{
session.proxy.pool_enable_ha(session.uuid, (_heartbeat_srs != null) ? Helper.RefListToStringArray(_heartbeat_srs) : new string[] {}, Maps.convert_to_proxy_string_string(_configuration)).parse();
}
///
/// Turn on High Availability mode
/// First published in XenServer 4.1.
///
/// The session
/// Set of SRs to use for storage heartbeating
/// Detailed HA configuration to apply
public static XenRef async_enable_ha(Session session, List> _heartbeat_srs, Dictionary _configuration)
{
return XenRef.Create(session.proxy.async_pool_enable_ha(session.uuid, (_heartbeat_srs != null) ? Helper.RefListToStringArray(_heartbeat_srs) : new string[] {}, Maps.convert_to_proxy_string_string(_configuration)).parse());
}
///
/// Turn off High Availability mode
/// First published in XenServer 4.1.
///
/// The session
public static void disable_ha(Session session)
{
session.proxy.pool_disable_ha(session.uuid).parse();
}
///
/// Turn off High Availability mode
/// First published in XenServer 4.1.
///
/// The session
public static XenRef async_disable_ha(Session session)
{
return XenRef.Create(session.proxy.async_pool_disable_ha(session.uuid).parse());
}
///
/// Forcibly synchronise the database now
/// First published in XenServer 4.0.
///
/// The session
public static void sync_database(Session session)
{
session.proxy.pool_sync_database(session.uuid).parse();
}
///
/// Forcibly synchronise the database now
/// First published in XenServer 4.0.
///
/// The session
public static XenRef async_sync_database(Session session)
{
return XenRef.Create(session.proxy.async_pool_sync_database(session.uuid).parse());
}
///
/// Perform an orderly handover of the role of master to the referenced host.
/// First published in XenServer 4.1.
///
/// The session
/// The host who should become the new master
public static void designate_new_master(Session session, string _host)
{
session.proxy.pool_designate_new_master(session.uuid, (_host != null) ? _host : "").parse();
}
///
/// Perform an orderly handover of the role of master to the referenced host.
/// First published in XenServer 4.1.
///
/// The session
/// The host who should become the new master
public static XenRef async_designate_new_master(Session session, string _host)
{
return XenRef.Create(session.proxy.async_pool_designate_new_master(session.uuid, (_host != null) ? _host : "").parse());
}
///
/// When this call returns the VM restart logic will not run for the requested number of seconds. If the argument is zero then the restart thread is immediately unblocked
/// First published in XenServer 5.0 Update 1.
///
/// The session
/// The number of seconds to block the restart thread for
public static void ha_prevent_restarts_for(Session session, long _seconds)
{
session.proxy.pool_ha_prevent_restarts_for(session.uuid, _seconds.ToString()).parse();
}
///
/// Returns true if a VM failover plan exists for up to 'n' host failures
/// First published in XenServer 5.0.
///
/// The session
/// The number of host failures to plan for
public static bool ha_failover_plan_exists(Session session, long _n)
{
return (bool)session.proxy.pool_ha_failover_plan_exists(session.uuid, _n.ToString()).parse();
}
///
/// Returns the maximum number of host failures we could tolerate before we would be unable to restart configured VMs
/// First published in XenServer 5.0.
///
/// The session
public static long ha_compute_max_host_failures_to_tolerate(Session session)
{
return long.Parse((string)session.proxy.pool_ha_compute_max_host_failures_to_tolerate(session.uuid).parse());
}
///
/// Returns the maximum number of host failures we could tolerate before we would be unable to restart the provided VMs
/// First published in XenServer 5.0.
///
/// The session
/// Map of protected VM reference to restart priority
public static long ha_compute_hypothetical_max_host_failures_to_tolerate(Session session, Dictionary, string> _configuration)
{
return long.Parse((string)session.proxy.pool_ha_compute_hypothetical_max_host_failures_to_tolerate(session.uuid, Maps.convert_to_proxy_XenRefVM_string(_configuration)).parse());
}
///
/// Return a VM failover plan assuming a given subset of hosts fail
/// First published in XenServer 5.0.
///
/// The session
/// The set of hosts to assume have failed
/// The set of VMs to restart
public static Dictionary, Dictionary> ha_compute_vm_failover_plan(Session session, List> _failed_hosts, List> _failed_vms)
{
return Maps.convert_from_proxy_XenRefVM_Dictionary_string_string(session.proxy.pool_ha_compute_vm_failover_plan(session.uuid, (_failed_hosts != null) ? Helper.RefListToStringArray(_failed_hosts) : new string[] {}, (_failed_vms != null) ? Helper.RefListToStringArray(_failed_vms) : new string[] {}).parse());
}
///
/// Set the maximum number of host failures to consider in the HA VM restart planner
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// New number of host failures to consider
public static void set_ha_host_failures_to_tolerate(Session session, string _pool, long _value)
{
session.proxy.pool_set_ha_host_failures_to_tolerate(session.uuid, (_pool != null) ? _pool : "", _value.ToString()).parse();
}
///
/// Set the maximum number of host failures to consider in the HA VM restart planner
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// New number of host failures to consider
public static XenRef async_set_ha_host_failures_to_tolerate(Session session, string _pool, long _value)
{
return XenRef.Create(session.proxy.async_pool_set_ha_host_failures_to_tolerate(session.uuid, (_pool != null) ? _pool : "", _value.ToString()).parse());
}
///
/// Create a placeholder for a named binary blob of data that is associated with this pool
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// The name associated with the blob
/// The mime type for the data. Empty string translates to application/octet-stream
public static XenRef create_new_blob(Session session, string _pool, string _name, string _mime_type)
{
return XenRef.Create(session.proxy.pool_create_new_blob(session.uuid, (_pool != null) ? _pool : "", (_name != null) ? _name : "", (_mime_type != null) ? _mime_type : "").parse());
}
///
/// Create a placeholder for a named binary blob of data that is associated with this pool
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// The name associated with the blob
/// The mime type for the data. Empty string translates to application/octet-stream
public static XenRef async_create_new_blob(Session session, string _pool, string _name, string _mime_type)
{
return XenRef.Create(session.proxy.async_pool_create_new_blob(session.uuid, (_pool != null) ? _pool : "", (_name != null) ? _name : "", (_mime_type != null) ? _mime_type : "").parse());
}
///
/// Create a placeholder for a named binary blob of data that is associated with this pool
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// The name associated with the blob
/// The mime type for the data. Empty string translates to application/octet-stream
/// True if the blob should be publicly available First published in XenServer 6.1.
public static XenRef create_new_blob(Session session, string _pool, string _name, string _mime_type, bool _public)
{
return XenRef.Create(session.proxy.pool_create_new_blob(session.uuid, (_pool != null) ? _pool : "", (_name != null) ? _name : "", (_mime_type != null) ? _mime_type : "", _public).parse());
}
///
/// Create a placeholder for a named binary blob of data that is associated with this pool
/// First published in XenServer 5.0.
///
/// The session
/// The opaque_ref of the given pool
/// The name associated with the blob
/// The mime type for the data. Empty string translates to application/octet-stream
/// True if the blob should be publicly available First published in XenServer 6.1.
public static XenRef async_create_new_blob(Session session, string _pool, string _name, string _mime_type, bool _public)
{
return XenRef.Create(session.proxy.async_pool_create_new_blob(session.uuid, (_pool != null) ? _pool : "", (_name != null) ? _name : "", (_mime_type != null) ? _mime_type : "", _public).parse());
}
///
/// This call enables external authentication on all the hosts of the pool
/// First published in XenServer 5.5.
///
/// The session
/// The opaque_ref of the given pool
/// A list of key-values containing the configuration data
/// The name of the service
/// The type of authentication (e.g. AD for Active Directory)
public static void enable_external_auth(Session session, string _pool, Dictionary _config, string _service_name, string _auth_type)
{
session.proxy.pool_enable_external_auth(session.uuid, (_pool != null) ? _pool : "", Maps.convert_to_proxy_string_string(_config), (_service_name != null) ? _service_name : "", (_auth_type != null) ? _auth_type : "").parse();
}
///
/// This call disables external authentication on all the hosts of the pool
/// First published in XenServer 5.5.
///
/// The session
/// The opaque_ref of the given pool
/// Optional parameters as a list of key-values containing the configuration data
public static void disable_external_auth(Session session, string _pool, Dictionary _config)
{
session.proxy.pool_disable_external_auth(session.uuid, (_pool != null) ? _pool : "", Maps.convert_to_proxy_string_string(_config)).parse();
}
///
/// This call asynchronously detects if the external authentication configuration in any slave is different from that in the master and raises appropriate alerts
/// First published in XenServer 5.5.
///
/// The session
/// The opaque_ref of the given pool
public static void detect_nonhomogeneous_external_auth(Session session, string _pool)
{
session.proxy.pool_detect_nonhomogeneous_external_auth(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Initializes workload balancing monitoring on this pool with the specified wlb server
/// First published in XenServer 5.5.
///
/// The session
/// The ip address and port to use when accessing the wlb server
/// The username used to authenticate with the wlb server
/// The password used to authenticate with the wlb server
/// The username used by the wlb server to authenticate with the xenserver
/// The password used by the wlb server to authenticate with the xenserver
public static void initialize_wlb(Session session, string _wlb_url, string _wlb_username, string _wlb_password, string _xenserver_username, string _xenserver_password)
{
session.proxy.pool_initialize_wlb(session.uuid, (_wlb_url != null) ? _wlb_url : "", (_wlb_username != null) ? _wlb_username : "", (_wlb_password != null) ? _wlb_password : "", (_xenserver_username != null) ? _xenserver_username : "", (_xenserver_password != null) ? _xenserver_password : "").parse();
}
///
/// Initializes workload balancing monitoring on this pool with the specified wlb server
/// First published in XenServer 5.5.
///
/// The session
/// The ip address and port to use when accessing the wlb server
/// The username used to authenticate with the wlb server
/// The password used to authenticate with the wlb server
/// The username used by the wlb server to authenticate with the xenserver
/// The password used by the wlb server to authenticate with the xenserver
public static XenRef async_initialize_wlb(Session session, string _wlb_url, string _wlb_username, string _wlb_password, string _xenserver_username, string _xenserver_password)
{
return XenRef.Create(session.proxy.async_pool_initialize_wlb(session.uuid, (_wlb_url != null) ? _wlb_url : "", (_wlb_username != null) ? _wlb_username : "", (_wlb_password != null) ? _wlb_password : "", (_xenserver_username != null) ? _xenserver_username : "", (_xenserver_password != null) ? _xenserver_password : "").parse());
}
///
/// Permanently deconfigures workload balancing monitoring on this pool
/// First published in XenServer 5.5.
///
/// The session
public static void deconfigure_wlb(Session session)
{
session.proxy.pool_deconfigure_wlb(session.uuid).parse();
}
///
/// Permanently deconfigures workload balancing monitoring on this pool
/// First published in XenServer 5.5.
///
/// The session
public static XenRef async_deconfigure_wlb(Session session)
{
return XenRef.Create(session.proxy.async_pool_deconfigure_wlb(session.uuid).parse());
}
///
/// Sets the pool optimization criteria for the workload balancing server
/// First published in XenServer 5.5.
///
/// The session
/// The configuration to use in optimizing this pool
public static void send_wlb_configuration(Session session, Dictionary _config)
{
session.proxy.pool_send_wlb_configuration(session.uuid, Maps.convert_to_proxy_string_string(_config)).parse();
}
///
/// Sets the pool optimization criteria for the workload balancing server
/// First published in XenServer 5.5.
///
/// The session
/// The configuration to use in optimizing this pool
public static XenRef async_send_wlb_configuration(Session session, Dictionary _config)
{
return XenRef.Create(session.proxy.async_pool_send_wlb_configuration(session.uuid, Maps.convert_to_proxy_string_string(_config)).parse());
}
///
/// Retrieves the pool optimization criteria from the workload balancing server
/// First published in XenServer 5.5.
///
/// The session
public static Dictionary retrieve_wlb_configuration(Session session)
{
return Maps.convert_from_proxy_string_string(session.proxy.pool_retrieve_wlb_configuration(session.uuid).parse());
}
///
/// Retrieves the pool optimization criteria from the workload balancing server
/// First published in XenServer 5.5.
///
/// The session
public static XenRef async_retrieve_wlb_configuration(Session session)
{
return XenRef.Create(session.proxy.async_pool_retrieve_wlb_configuration(session.uuid).parse());
}
///
/// Retrieves vm migrate recommendations for the pool from the workload balancing server
/// First published in XenServer 5.5.
///
/// The session
public static Dictionary, string[]> retrieve_wlb_recommendations(Session session)
{
return Maps.convert_from_proxy_XenRefVM_string_array(session.proxy.pool_retrieve_wlb_recommendations(session.uuid).parse());
}
///
/// Retrieves vm migrate recommendations for the pool from the workload balancing server
/// First published in XenServer 5.5.
///
/// The session
public static XenRef async_retrieve_wlb_recommendations(Session session)
{
return XenRef.Create(session.proxy.async_pool_retrieve_wlb_recommendations(session.uuid).parse());
}
///
/// Send the given body to the given host and port, using HTTPS, and print the response. This is used for debugging the SSL layer.
/// First published in XenServer 5.5.
///
/// The session
///
///
///
public static string send_test_post(Session session, string _host, long _port, string _body)
{
return (string)session.proxy.pool_send_test_post(session.uuid, (_host != null) ? _host : "", _port.ToString(), (_body != null) ? _body : "").parse();
}
///
/// Send the given body to the given host and port, using HTTPS, and print the response. This is used for debugging the SSL layer.
/// First published in XenServer 5.5.
///
/// The session
///
///
///
public static XenRef async_send_test_post(Session session, string _host, long _port, string _body)
{
return XenRef.Create(session.proxy.async_pool_send_test_post(session.uuid, (_host != null) ? _host : "", _port.ToString(), (_body != null) ? _body : "").parse());
}
///
/// Install an SSL certificate pool-wide.
/// First published in XenServer 5.5.
///
/// The session
/// A name to give the certificate
/// The certificate
public static void certificate_install(Session session, string _name, string _cert)
{
session.proxy.pool_certificate_install(session.uuid, (_name != null) ? _name : "", (_cert != null) ? _cert : "").parse();
}
///
/// Install an SSL certificate pool-wide.
/// First published in XenServer 5.5.
///
/// The session
/// A name to give the certificate
/// The certificate
public static XenRef async_certificate_install(Session session, string _name, string _cert)
{
return XenRef.Create(session.proxy.async_pool_certificate_install(session.uuid, (_name != null) ? _name : "", (_cert != null) ? _cert : "").parse());
}
///
/// Remove an SSL certificate.
/// First published in XenServer 5.5.
///
/// The session
/// The certificate name
public static void certificate_uninstall(Session session, string _name)
{
session.proxy.pool_certificate_uninstall(session.uuid, (_name != null) ? _name : "").parse();
}
///
/// Remove an SSL certificate.
/// First published in XenServer 5.5.
///
/// The session
/// The certificate name
public static XenRef async_certificate_uninstall(Session session, string _name)
{
return XenRef.Create(session.proxy.async_pool_certificate_uninstall(session.uuid, (_name != null) ? _name : "").parse());
}
///
/// List all installed SSL certificates.
/// First published in XenServer 5.5.
///
/// The session
public static string[] certificate_list(Session session)
{
return (string [])session.proxy.pool_certificate_list(session.uuid).parse();
}
///
/// List all installed SSL certificates.
/// First published in XenServer 5.5.
///
/// The session
public static XenRef async_certificate_list(Session session)
{
return XenRef.Create(session.proxy.async_pool_certificate_list(session.uuid).parse());
}
///
/// Install an SSL certificate revocation list, pool-wide.
/// First published in XenServer 5.5.
///
/// The session
/// A name to give the CRL
/// The CRL
public static void crl_install(Session session, string _name, string _cert)
{
session.proxy.pool_crl_install(session.uuid, (_name != null) ? _name : "", (_cert != null) ? _cert : "").parse();
}
///
/// Install an SSL certificate revocation list, pool-wide.
/// First published in XenServer 5.5.
///
/// The session
/// A name to give the CRL
/// The CRL
public static XenRef async_crl_install(Session session, string _name, string _cert)
{
return XenRef.Create(session.proxy.async_pool_crl_install(session.uuid, (_name != null) ? _name : "", (_cert != null) ? _cert : "").parse());
}
///
/// Remove an SSL certificate revocation list.
/// First published in XenServer 5.5.
///
/// The session
/// The CRL name
public static void crl_uninstall(Session session, string _name)
{
session.proxy.pool_crl_uninstall(session.uuid, (_name != null) ? _name : "").parse();
}
///
/// Remove an SSL certificate revocation list.
/// First published in XenServer 5.5.
///
/// The session
/// The CRL name
public static XenRef async_crl_uninstall(Session session, string _name)
{
return XenRef.Create(session.proxy.async_pool_crl_uninstall(session.uuid, (_name != null) ? _name : "").parse());
}
///
/// List all installed SSL certificate revocation lists.
/// First published in XenServer 5.5.
///
/// The session
public static string[] crl_list(Session session)
{
return (string [])session.proxy.pool_crl_list(session.uuid).parse();
}
///
/// List all installed SSL certificate revocation lists.
/// First published in XenServer 5.5.
///
/// The session
public static XenRef async_crl_list(Session session)
{
return XenRef.Create(session.proxy.async_pool_crl_list(session.uuid).parse());
}
///
/// Sync SSL certificates from master to slaves.
/// First published in XenServer 5.5.
///
/// The session
public static void certificate_sync(Session session)
{
session.proxy.pool_certificate_sync(session.uuid).parse();
}
///
/// Sync SSL certificates from master to slaves.
/// First published in XenServer 5.5.
///
/// The session
public static XenRef async_certificate_sync(Session session)
{
return XenRef.Create(session.proxy.async_pool_certificate_sync(session.uuid).parse());
}
///
/// Enable the redo log on the given SR and start using it, unless HA is enabled.
/// First published in XenServer 5.6.
///
/// The session
/// SR to hold the redo log.
public static void enable_redo_log(Session session, string _sr)
{
session.proxy.pool_enable_redo_log(session.uuid, (_sr != null) ? _sr : "").parse();
}
///
/// Enable the redo log on the given SR and start using it, unless HA is enabled.
/// First published in XenServer 5.6.
///
/// The session
/// SR to hold the redo log.
public static XenRef async_enable_redo_log(Session session, string _sr)
{
return XenRef.Create(session.proxy.async_pool_enable_redo_log(session.uuid, (_sr != null) ? _sr : "").parse());
}
///
/// Disable the redo log if in use, unless HA is enabled.
/// First published in XenServer 5.6.
///
/// The session
public static void disable_redo_log(Session session)
{
session.proxy.pool_disable_redo_log(session.uuid).parse();
}
///
/// Disable the redo log if in use, unless HA is enabled.
/// First published in XenServer 5.6.
///
/// The session
public static XenRef async_disable_redo_log(Session session)
{
return XenRef.Create(session.proxy.async_pool_disable_redo_log(session.uuid).parse());
}
///
/// Set the IP address of the vswitch controller.
/// First published in XenServer 5.6.
/// Deprecated since .
///
/// The session
/// IP address of the vswitch controller.
[Deprecated("")]
public static void set_vswitch_controller(Session session, string _address)
{
session.proxy.pool_set_vswitch_controller(session.uuid, (_address != null) ? _address : "").parse();
}
///
/// Set the IP address of the vswitch controller.
/// First published in XenServer 5.6.
/// Deprecated since .
///
/// The session
/// IP address of the vswitch controller.
[Deprecated("")]
public static XenRef async_set_vswitch_controller(Session session, string _address)
{
return XenRef.Create(session.proxy.async_pool_set_vswitch_controller(session.uuid, (_address != null) ? _address : "").parse());
}
///
/// This call tests if a location is valid
/// First published in XenServer 5.6 FP1.
///
/// The session
/// The opaque_ref of the given pool
/// Location config settings to test
public static string test_archive_target(Session session, string _pool, Dictionary _config)
{
return (string)session.proxy.pool_test_archive_target(session.uuid, (_pool != null) ? _pool : "", Maps.convert_to_proxy_string_string(_config)).parse();
}
///
/// This call attempts to enable pool-wide local storage caching
/// First published in XenServer 5.6 FP1.
///
/// The session
/// The opaque_ref of the given pool
public static void enable_local_storage_caching(Session session, string _pool)
{
session.proxy.pool_enable_local_storage_caching(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// This call attempts to enable pool-wide local storage caching
/// First published in XenServer 5.6 FP1.
///
/// The session
/// The opaque_ref of the given pool
public static XenRef async_enable_local_storage_caching(Session session, string _pool)
{
return XenRef.Create(session.proxy.async_pool_enable_local_storage_caching(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// This call disables pool-wide local storage caching
/// First published in XenServer 5.6 FP1.
///
/// The session
/// The opaque_ref of the given pool
public static void disable_local_storage_caching(Session session, string _pool)
{
session.proxy.pool_disable_local_storage_caching(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// This call disables pool-wide local storage caching
/// First published in XenServer 5.6 FP1.
///
/// The session
/// The opaque_ref of the given pool
public static XenRef async_disable_local_storage_caching(Session session, string _pool)
{
return XenRef.Create(session.proxy.async_pool_disable_local_storage_caching(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// This call returns the license state for the pool
/// First published in XenServer 6.2.
///
/// The session
/// The opaque_ref of the given pool
public static Dictionary get_license_state(Session session, string _pool)
{
return Maps.convert_from_proxy_string_string(session.proxy.pool_get_license_state(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// This call returns the license state for the pool
/// First published in XenServer 6.2.
///
/// The session
/// The opaque_ref of the given pool
public static XenRef async_get_license_state(Session session, string _pool)
{
return XenRef.Create(session.proxy.async_pool_get_license_state(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Apply an edition to all hosts in the pool
/// First published in XenServer 6.2.
///
/// The session
/// The opaque_ref of the given pool
/// The requested edition
public static void apply_edition(Session session, string _pool, string _edition)
{
session.proxy.pool_apply_edition(session.uuid, (_pool != null) ? _pool : "", (_edition != null) ? _edition : "").parse();
}
///
/// Apply an edition to all hosts in the pool
/// First published in XenServer 6.2.
///
/// The session
/// The opaque_ref of the given pool
/// The requested edition
public static XenRef async_apply_edition(Session session, string _pool, string _edition)
{
return XenRef.Create(session.proxy.async_pool_apply_edition(session.uuid, (_pool != null) ? _pool : "", (_edition != null) ? _edition : "").parse());
}
///
/// Sets ssl_legacy true on each host, pool-master last. See Host.ssl_legacy and Host.set_ssl_legacy.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
public static void enable_ssl_legacy(Session session, string _pool)
{
session.proxy.pool_enable_ssl_legacy(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Sets ssl_legacy true on each host, pool-master last. See Host.ssl_legacy and Host.set_ssl_legacy.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
public static XenRef async_enable_ssl_legacy(Session session, string _pool)
{
return XenRef.Create(session.proxy.async_pool_enable_ssl_legacy(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Sets ssl_legacy true on each host, pool-master last. See Host.ssl_legacy and Host.set_ssl_legacy.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
public static void disable_ssl_legacy(Session session, string _pool)
{
session.proxy.pool_disable_ssl_legacy(session.uuid, (_pool != null) ? _pool : "").parse();
}
///
/// Sets ssl_legacy true on each host, pool-master last. See Host.ssl_legacy and Host.set_ssl_legacy.
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
public static XenRef async_disable_ssl_legacy(Session session, string _pool)
{
return XenRef.Create(session.proxy.async_pool_disable_ssl_legacy(session.uuid, (_pool != null) ? _pool : "").parse());
}
///
/// Return true if the extension is available on the pool
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
/// The name of the API call
public static bool has_extension(Session session, string _pool, string _name)
{
return (bool)session.proxy.pool_has_extension(session.uuid, (_pool != null) ? _pool : "", (_name != null) ? _name : "").parse();
}
///
/// Return true if the extension is available on the pool
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
/// The name of the API call
public static XenRef async_has_extension(Session session, string _pool, string _name)
{
return XenRef.Create(session.proxy.async_pool_has_extension(session.uuid, (_pool != null) ? _pool : "", (_name != null) ? _name : "").parse());
}
///
/// Add a key-value pair to the pool-wide guest agent configuration
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
/// The key to add
/// The value to add
public static void add_to_guest_agent_config(Session session, string _pool, string _key, string _value)
{
session.proxy.pool_add_to_guest_agent_config(session.uuid, (_pool != null) ? _pool : "", (_key != null) ? _key : "", (_value != null) ? _value : "").parse();
}
///
/// Add a key-value pair to the pool-wide guest agent configuration
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
/// The key to add
/// The value to add
public static XenRef async_add_to_guest_agent_config(Session session, string _pool, string _key, string _value)
{
return XenRef.Create(session.proxy.async_pool_add_to_guest_agent_config(session.uuid, (_pool != null) ? _pool : "", (_key != null) ? _key : "", (_value != null) ? _value : "").parse());
}
///
/// Remove a key-value pair from the pool-wide guest agent configuration
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
/// The key to remove
public static void remove_from_guest_agent_config(Session session, string _pool, string _key)
{
session.proxy.pool_remove_from_guest_agent_config(session.uuid, (_pool != null) ? _pool : "", (_key != null) ? _key : "").parse();
}
///
/// Remove a key-value pair from the pool-wide guest agent configuration
/// First published in XenServer Dundee.
///
/// The session
/// The opaque_ref of the given pool
/// The key to remove
public static XenRef async_remove_from_guest_agent_config(Session session, string _pool, string _key)
{
return XenRef.Create(session.proxy.async_pool_remove_from_guest_agent_config(session.uuid, (_pool != null) ? _pool : "", (_key != null) ? _key : "").parse());
}
///
/// Return a list of all the pools known to the system.
/// First published in XenServer 4.0.
///
/// The session
public static List> get_all(Session session)
{
return XenRef.Create(session.proxy.pool_get_all(session.uuid).parse());
}
///
/// Get all the pool Records at once, in a single XML RPC call
/// First published in XenServer 4.0.
///
/// The session
public static Dictionary, Pool> get_all_records(Session session)
{
return XenRef.Create(session.proxy.pool_get_all_records(session.uuid).parse());
}
///
/// Unique identifier/object reference
///
public virtual string uuid
{
get { return _uuid; }
set
{
if (!Helper.AreEqual(value, _uuid))
{
_uuid = value;
Changed = true;
NotifyPropertyChanged("uuid");
}
}
}
private string _uuid;
///
/// Short name
///
public virtual string name_label
{
get { return _name_label; }
set
{
if (!Helper.AreEqual(value, _name_label))
{
_name_label = value;
Changed = true;
NotifyPropertyChanged("name_label");
}
}
}
private string _name_label;
///
/// Description
///
public virtual string name_description
{
get { return _name_description; }
set
{
if (!Helper.AreEqual(value, _name_description))
{
_name_description = value;
Changed = true;
NotifyPropertyChanged("name_description");
}
}
}
private string _name_description;
///
/// The host that is pool master
///
public virtual XenRef master
{
get { return _master; }
set
{
if (!Helper.AreEqual(value, _master))
{
_master = value;
Changed = true;
NotifyPropertyChanged("master");
}
}
}
private XenRef _master;
///
/// Default SR for VDIs
///
public virtual XenRef default_SR
{
get { return _default_SR; }
set
{
if (!Helper.AreEqual(value, _default_SR))
{
_default_SR = value;
Changed = true;
NotifyPropertyChanged("default_SR");
}
}
}
private XenRef _default_SR;
///
/// The SR in which VDIs for suspend images are created
///
public virtual XenRef suspend_image_SR
{
get { return _suspend_image_SR; }
set
{
if (!Helper.AreEqual(value, _suspend_image_SR))
{
_suspend_image_SR = value;
Changed = true;
NotifyPropertyChanged("suspend_image_SR");
}
}
}
private XenRef _suspend_image_SR;
///
/// The SR in which VDIs for crash dumps are created
///
public virtual XenRef crash_dump_SR
{
get { return _crash_dump_SR; }
set
{
if (!Helper.AreEqual(value, _crash_dump_SR))
{
_crash_dump_SR = value;
Changed = true;
NotifyPropertyChanged("crash_dump_SR");
}
}
}
private XenRef _crash_dump_SR;
///
/// additional configuration
///
public virtual Dictionary other_config
{
get { return _other_config; }
set
{
if (!Helper.AreEqual(value, _other_config))
{
_other_config = value;
Changed = true;
NotifyPropertyChanged("other_config");
}
}
}
private Dictionary _other_config;
///
/// true if HA is enabled on the pool, false otherwise
/// First published in XenServer 5.0.
///
public virtual bool ha_enabled
{
get { return _ha_enabled; }
set
{
if (!Helper.AreEqual(value, _ha_enabled))
{
_ha_enabled = value;
Changed = true;
NotifyPropertyChanged("ha_enabled");
}
}
}
private bool _ha_enabled;
///
/// The current HA configuration
/// First published in XenServer 5.0.
///
public virtual Dictionary ha_configuration
{
get { return _ha_configuration; }
set
{
if (!Helper.AreEqual(value, _ha_configuration))
{
_ha_configuration = value;
Changed = true;
NotifyPropertyChanged("ha_configuration");
}
}
}
private Dictionary _ha_configuration;
///
/// HA statefile VDIs in use
/// First published in XenServer 5.0.
///
public virtual string[] ha_statefiles
{
get { return _ha_statefiles; }
set
{
if (!Helper.AreEqual(value, _ha_statefiles))
{
_ha_statefiles = value;
Changed = true;
NotifyPropertyChanged("ha_statefiles");
}
}
}
private string[] _ha_statefiles;
///
/// Number of host failures to tolerate before the Pool is declared to be overcommitted
/// First published in XenServer 5.0.
///
public virtual long ha_host_failures_to_tolerate
{
get { return _ha_host_failures_to_tolerate; }
set
{
if (!Helper.AreEqual(value, _ha_host_failures_to_tolerate))
{
_ha_host_failures_to_tolerate = value;
Changed = true;
NotifyPropertyChanged("ha_host_failures_to_tolerate");
}
}
}
private long _ha_host_failures_to_tolerate;
///
/// Number of future host failures we have managed to find a plan for. Once this reaches zero any future host failures will cause the failure of protected VMs.
/// First published in XenServer 5.0.
///
public virtual long ha_plan_exists_for
{
get { return _ha_plan_exists_for; }
set
{
if (!Helper.AreEqual(value, _ha_plan_exists_for))
{
_ha_plan_exists_for = value;
Changed = true;
NotifyPropertyChanged("ha_plan_exists_for");
}
}
}
private long _ha_plan_exists_for;
///
/// If set to false then operations which would cause the Pool to become overcommitted will be blocked.
/// First published in XenServer 5.0.
///
public virtual bool ha_allow_overcommit
{
get { return _ha_allow_overcommit; }
set
{
if (!Helper.AreEqual(value, _ha_allow_overcommit))
{
_ha_allow_overcommit = value;
Changed = true;
NotifyPropertyChanged("ha_allow_overcommit");
}
}
}
private bool _ha_allow_overcommit;
///
/// True if the Pool is considered to be overcommitted i.e. if there exist insufficient physical resources to tolerate the configured number of host failures
/// First published in XenServer 5.0.
///
public virtual bool ha_overcommitted
{
get { return _ha_overcommitted; }
set
{
if (!Helper.AreEqual(value, _ha_overcommitted))
{
_ha_overcommitted = value;
Changed = true;
NotifyPropertyChanged("ha_overcommitted");
}
}
}
private bool _ha_overcommitted;
///
/// Binary blobs associated with this pool
/// First published in XenServer 5.0.
///
public virtual Dictionary> blobs
{
get { return _blobs; }
set
{
if (!Helper.AreEqual(value, _blobs))
{
_blobs = value;
Changed = true;
NotifyPropertyChanged("blobs");
}
}
}
private Dictionary> _blobs;
///
/// user-specified tags for categorization purposes
/// First published in XenServer 5.0.
///
public virtual string[] tags
{
get { return _tags; }
set
{
if (!Helper.AreEqual(value, _tags))
{
_tags = value;
Changed = true;
NotifyPropertyChanged("tags");
}
}
}
private string[] _tags;
///
/// gui-specific configuration for pool
/// First published in XenServer 5.0.
///
public virtual Dictionary gui_config
{
get { return _gui_config; }
set
{
if (!Helper.AreEqual(value, _gui_config))
{
_gui_config = value;
Changed = true;
NotifyPropertyChanged("gui_config");
}
}
}
private Dictionary _gui_config;
///
/// Configuration for the automatic health check feature
/// First published in XenServer Dundee.
///
public virtual Dictionary health_check_config
{
get { return _health_check_config; }
set
{
if (!Helper.AreEqual(value, _health_check_config))
{
_health_check_config = value;
Changed = true;
NotifyPropertyChanged("health_check_config");
}
}
}
private Dictionary _health_check_config;
///
/// Url for the configured workload balancing host
/// First published in XenServer 5.5.
///
public virtual string wlb_url
{
get { return _wlb_url; }
set
{
if (!Helper.AreEqual(value, _wlb_url))
{
_wlb_url = value;
Changed = true;
NotifyPropertyChanged("wlb_url");
}
}
}
private string _wlb_url;
///
/// Username for accessing the workload balancing host
/// First published in XenServer 5.5.
///
public virtual string wlb_username
{
get { return _wlb_username; }
set
{
if (!Helper.AreEqual(value, _wlb_username))
{
_wlb_username = value;
Changed = true;
NotifyPropertyChanged("wlb_username");
}
}
}
private string _wlb_username;
///
/// true if workload balancing is enabled on the pool, false otherwise
/// First published in XenServer 5.5.
///
public virtual bool wlb_enabled
{
get { return _wlb_enabled; }
set
{
if (!Helper.AreEqual(value, _wlb_enabled))
{
_wlb_enabled = value;
Changed = true;
NotifyPropertyChanged("wlb_enabled");
}
}
}
private bool _wlb_enabled;
///
/// true if communication with the WLB server should enforce SSL certificate verification.
/// First published in XenServer 5.5.
///
public virtual bool wlb_verify_cert
{
get { return _wlb_verify_cert; }
set
{
if (!Helper.AreEqual(value, _wlb_verify_cert))
{
_wlb_verify_cert = value;
Changed = true;
NotifyPropertyChanged("wlb_verify_cert");
}
}
}
private bool _wlb_verify_cert;
///
/// true a redo-log is to be used other than when HA is enabled, false otherwise
/// First published in XenServer 5.6.
///
public virtual bool redo_log_enabled
{
get { return _redo_log_enabled; }
set
{
if (!Helper.AreEqual(value, _redo_log_enabled))
{
_redo_log_enabled = value;
Changed = true;
NotifyPropertyChanged("redo_log_enabled");
}
}
}
private bool _redo_log_enabled;
///
/// indicates the VDI to use for the redo-log other than when HA is enabled
/// First published in XenServer 5.6.
///
public virtual XenRef redo_log_vdi
{
get { return _redo_log_vdi; }
set
{
if (!Helper.AreEqual(value, _redo_log_vdi))
{
_redo_log_vdi = value;
Changed = true;
NotifyPropertyChanged("redo_log_vdi");
}
}
}
private XenRef _redo_log_vdi;
///
/// address of the vswitch controller
/// First published in XenServer 5.6.
///
public virtual string vswitch_controller
{
get { return _vswitch_controller; }
set
{
if (!Helper.AreEqual(value, _vswitch_controller))
{
_vswitch_controller = value;
Changed = true;
NotifyPropertyChanged("vswitch_controller");
}
}
}
private string _vswitch_controller;
///
/// Pool-wide restrictions currently in effect
/// First published in XenServer 5.6.
///
public virtual Dictionary restrictions
{
get { return _restrictions; }
set
{
if (!Helper.AreEqual(value, _restrictions))
{
_restrictions = value;
Changed = true;
NotifyPropertyChanged("restrictions");
}
}
}
private Dictionary _restrictions;
///
/// The set of currently known metadata VDIs for this pool
/// First published in XenServer 6.0.
///
public virtual List> metadata_VDIs
{
get { return _metadata_VDIs; }
set
{
if (!Helper.AreEqual(value, _metadata_VDIs))
{
_metadata_VDIs = value;
Changed = true;
NotifyPropertyChanged("metadata_VDIs");
}
}
}
private List> _metadata_VDIs;
///
/// The HA cluster stack that is currently in use. Only valid when HA is enabled.
/// First published in XenServer Dundee.
///
public virtual string ha_cluster_stack
{
get { return _ha_cluster_stack; }
set
{
if (!Helper.AreEqual(value, _ha_cluster_stack))
{
_ha_cluster_stack = value;
Changed = true;
NotifyPropertyChanged("ha_cluster_stack");
}
}
}
private string _ha_cluster_stack;
///
/// list of the operations allowed in this state. This list is advisory only and the server state may have changed by the time this field is read by a client.
///
public virtual List allowed_operations
{
get { return _allowed_operations; }
set
{
if (!Helper.AreEqual(value, _allowed_operations))
{
_allowed_operations = value;
Changed = true;
NotifyPropertyChanged("allowed_operations");
}
}
}
private List _allowed_operations;
///
/// links each of the running tasks using this object (by reference) to a current_operation enum which describes the nature of the task.
///
public virtual Dictionary current_operations
{
get { return _current_operations; }
set
{
if (!Helper.AreEqual(value, _current_operations))
{
_current_operations = value;
Changed = true;
NotifyPropertyChanged("current_operations");
}
}
}
private Dictionary _current_operations;
///
/// Pool-wide guest agent configuration information
/// First published in XenServer Dundee.
///
public virtual Dictionary guest_agent_config
{
get { return _guest_agent_config; }
set
{
if (!Helper.AreEqual(value, _guest_agent_config))
{
_guest_agent_config = value;
Changed = true;
NotifyPropertyChanged("guest_agent_config");
}
}
}
private Dictionary _guest_agent_config;
///
/// Details about the physical CPUs on the pool
/// First published in XenServer Dundee.
///
public virtual Dictionary cpu_info
{
get { return _cpu_info; }
set
{
if (!Helper.AreEqual(value, _cpu_info))
{
_cpu_info = value;
Changed = true;
NotifyPropertyChanged("cpu_info");
}
}
}
private Dictionary _cpu_info;
///
/// The pool-wide policy for clients on whether to use the vendor device or not on newly created VMs. This field will also be consulted if the 'has_vendor_device' field is not specified in the VM.create call.
/// First published in XenServer Dundee.
///
public virtual bool policy_no_vendor_device
{
get { return _policy_no_vendor_device; }
set
{
if (!Helper.AreEqual(value, _policy_no_vendor_device))
{
_policy_no_vendor_device = value;
Changed = true;
NotifyPropertyChanged("policy_no_vendor_device");
}
}
}
private bool _policy_no_vendor_device;
///
/// The pool-wide flag to show if the live patching feauture is disabled or not.
/// First published in .
///
public virtual bool live_patching_disabled
{
get { return _live_patching_disabled; }
set
{
if (!Helper.AreEqual(value, _live_patching_disabled))
{
_live_patching_disabled = value;
Changed = true;
NotifyPropertyChanged("live_patching_disabled");
}
}
}
private bool _live_patching_disabled;
}
}