/* * 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 System.ComponentModel; using System.Globalization; using Newtonsoft.Json; using Newtonsoft.Json.Converters; namespace XenAPI { /// /// A physical host /// First published in XenServer 4.0. /// public partial class Host : XenObject { public Host() { } public Host(string uuid, string name_label, string name_description, long memory_overhead, List allowed_operations, Dictionary current_operations, long API_version_major, long API_version_minor, string API_version_vendor, Dictionary API_version_vendor_implementation, bool enabled, Dictionary software_version, Dictionary other_config, string[] capabilities, Dictionary cpu_configuration, string sched_policy, string[] supported_bootloaders, List> resident_VMs, Dictionary logging, List> PIFs, XenRef suspend_image_sr, XenRef crash_dump_sr, List> crashdumps, List> patches, List> updates, List> PBDs, List> host_CPUs, Dictionary cpu_info, string hostname, string address, XenRef metrics, Dictionary license_params, string[] ha_statefiles, string[] ha_network_peers, Dictionary> blobs, string[] tags, string external_auth_type, string external_auth_service_name, Dictionary external_auth_configuration, string edition, Dictionary license_server, Dictionary bios_strings, string power_on_mode, Dictionary power_on_config, XenRef local_cache_sr, Dictionary chipset_info, List> PCIs, List> PGPUs, List> PUSBs, bool ssl_legacy, Dictionary guest_VCPUs_params, host_display display, long[] virtual_hardware_platform_versions, XenRef control_domain, List> updates_requiring_reboot, List> features, string iscsi_iqn, bool multipathing) { this.uuid = uuid; this.name_label = name_label; this.name_description = name_description; this.memory_overhead = memory_overhead; this.allowed_operations = allowed_operations; this.current_operations = current_operations; this.API_version_major = API_version_major; this.API_version_minor = API_version_minor; this.API_version_vendor = API_version_vendor; this.API_version_vendor_implementation = API_version_vendor_implementation; this.enabled = enabled; this.software_version = software_version; this.other_config = other_config; this.capabilities = capabilities; this.cpu_configuration = cpu_configuration; this.sched_policy = sched_policy; this.supported_bootloaders = supported_bootloaders; this.resident_VMs = resident_VMs; this.logging = logging; this.PIFs = PIFs; this.suspend_image_sr = suspend_image_sr; this.crash_dump_sr = crash_dump_sr; this.crashdumps = crashdumps; this.patches = patches; this.updates = updates; this.PBDs = PBDs; this.host_CPUs = host_CPUs; this.cpu_info = cpu_info; this.hostname = hostname; this.address = address; this.metrics = metrics; this.license_params = license_params; this.ha_statefiles = ha_statefiles; this.ha_network_peers = ha_network_peers; this.blobs = blobs; this.tags = tags; this.external_auth_type = external_auth_type; this.external_auth_service_name = external_auth_service_name; this.external_auth_configuration = external_auth_configuration; this.edition = edition; this.license_server = license_server; this.bios_strings = bios_strings; this.power_on_mode = power_on_mode; this.power_on_config = power_on_config; this.local_cache_sr = local_cache_sr; this.chipset_info = chipset_info; this.PCIs = PCIs; this.PGPUs = PGPUs; this.PUSBs = PUSBs; this.ssl_legacy = ssl_legacy; this.guest_VCPUs_params = guest_VCPUs_params; this.display = display; this.virtual_hardware_platform_versions = virtual_hardware_platform_versions; this.control_domain = control_domain; this.updates_requiring_reboot = updates_requiring_reboot; this.features = features; this.iscsi_iqn = iscsi_iqn; this.multipathing = multipathing; } /// /// Creates a new Host from a Proxy_Host. /// /// public Host(Proxy_Host proxy) { this.UpdateFromProxy(proxy); } /// /// Updates each field of this instance with the value of /// the corresponding field of a given Host. /// public override void UpdateFrom(Host update) { uuid = update.uuid; name_label = update.name_label; name_description = update.name_description; memory_overhead = update.memory_overhead; allowed_operations = update.allowed_operations; current_operations = update.current_operations; API_version_major = update.API_version_major; API_version_minor = update.API_version_minor; API_version_vendor = update.API_version_vendor; API_version_vendor_implementation = update.API_version_vendor_implementation; enabled = update.enabled; software_version = update.software_version; other_config = update.other_config; capabilities = update.capabilities; cpu_configuration = update.cpu_configuration; sched_policy = update.sched_policy; supported_bootloaders = update.supported_bootloaders; resident_VMs = update.resident_VMs; logging = update.logging; PIFs = update.PIFs; suspend_image_sr = update.suspend_image_sr; crash_dump_sr = update.crash_dump_sr; crashdumps = update.crashdumps; patches = update.patches; updates = update.updates; PBDs = update.PBDs; host_CPUs = update.host_CPUs; cpu_info = update.cpu_info; hostname = update.hostname; address = update.address; metrics = update.metrics; license_params = update.license_params; ha_statefiles = update.ha_statefiles; ha_network_peers = update.ha_network_peers; blobs = update.blobs; tags = update.tags; external_auth_type = update.external_auth_type; external_auth_service_name = update.external_auth_service_name; external_auth_configuration = update.external_auth_configuration; edition = update.edition; license_server = update.license_server; bios_strings = update.bios_strings; power_on_mode = update.power_on_mode; power_on_config = update.power_on_config; local_cache_sr = update.local_cache_sr; chipset_info = update.chipset_info; PCIs = update.PCIs; PGPUs = update.PGPUs; PUSBs = update.PUSBs; ssl_legacy = update.ssl_legacy; guest_VCPUs_params = update.guest_VCPUs_params; display = update.display; virtual_hardware_platform_versions = update.virtual_hardware_platform_versions; control_domain = update.control_domain; updates_requiring_reboot = update.updates_requiring_reboot; features = update.features; iscsi_iqn = update.iscsi_iqn; multipathing = update.multipathing; } internal void UpdateFromProxy(Proxy_Host 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; memory_overhead = proxy.memory_overhead == null ? 0 : long.Parse((string)proxy.memory_overhead); allowed_operations = proxy.allowed_operations == null ? null : Helper.StringArrayToEnumList(proxy.allowed_operations); current_operations = proxy.current_operations == null ? null : Maps.convert_from_proxy_string_host_allowed_operations(proxy.current_operations); API_version_major = proxy.API_version_major == null ? 0 : long.Parse((string)proxy.API_version_major); API_version_minor = proxy.API_version_minor == null ? 0 : long.Parse((string)proxy.API_version_minor); API_version_vendor = proxy.API_version_vendor == null ? null : (string)proxy.API_version_vendor; API_version_vendor_implementation = proxy.API_version_vendor_implementation == null ? null : Maps.convert_from_proxy_string_string(proxy.API_version_vendor_implementation); enabled = (bool)proxy.enabled; software_version = proxy.software_version == null ? null : Maps.convert_from_proxy_string_string(proxy.software_version); other_config = proxy.other_config == null ? null : Maps.convert_from_proxy_string_string(proxy.other_config); capabilities = proxy.capabilities == null ? new string[] {} : (string [])proxy.capabilities; cpu_configuration = proxy.cpu_configuration == null ? null : Maps.convert_from_proxy_string_string(proxy.cpu_configuration); sched_policy = proxy.sched_policy == null ? null : (string)proxy.sched_policy; supported_bootloaders = proxy.supported_bootloaders == null ? new string[] {} : (string [])proxy.supported_bootloaders; resident_VMs = proxy.resident_VMs == null ? null : XenRef.Create(proxy.resident_VMs); logging = proxy.logging == null ? null : Maps.convert_from_proxy_string_string(proxy.logging); PIFs = proxy.PIFs == null ? null : XenRef.Create(proxy.PIFs); 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); crashdumps = proxy.crashdumps == null ? null : XenRef.Create(proxy.crashdumps); patches = proxy.patches == null ? null : XenRef.Create(proxy.patches); updates = proxy.updates == null ? null : XenRef.Create(proxy.updates); PBDs = proxy.PBDs == null ? null : XenRef.Create(proxy.PBDs); host_CPUs = proxy.host_CPUs == null ? null : XenRef.Create(proxy.host_CPUs); cpu_info = proxy.cpu_info == null ? null : Maps.convert_from_proxy_string_string(proxy.cpu_info); hostname = proxy.hostname == null ? null : (string)proxy.hostname; address = proxy.address == null ? null : (string)proxy.address; metrics = proxy.metrics == null ? null : XenRef.Create(proxy.metrics); license_params = proxy.license_params == null ? null : Maps.convert_from_proxy_string_string(proxy.license_params); ha_statefiles = proxy.ha_statefiles == null ? new string[] {} : (string [])proxy.ha_statefiles; ha_network_peers = proxy.ha_network_peers == null ? new string[] {} : (string [])proxy.ha_network_peers; blobs = proxy.blobs == null ? null : Maps.convert_from_proxy_string_XenRefBlob(proxy.blobs); tags = proxy.tags == null ? new string[] {} : (string [])proxy.tags; external_auth_type = proxy.external_auth_type == null ? null : (string)proxy.external_auth_type; external_auth_service_name = proxy.external_auth_service_name == null ? null : (string)proxy.external_auth_service_name; external_auth_configuration = proxy.external_auth_configuration == null ? null : Maps.convert_from_proxy_string_string(proxy.external_auth_configuration); edition = proxy.edition == null ? null : (string)proxy.edition; license_server = proxy.license_server == null ? null : Maps.convert_from_proxy_string_string(proxy.license_server); bios_strings = proxy.bios_strings == null ? null : Maps.convert_from_proxy_string_string(proxy.bios_strings); power_on_mode = proxy.power_on_mode == null ? null : (string)proxy.power_on_mode; power_on_config = proxy.power_on_config == null ? null : Maps.convert_from_proxy_string_string(proxy.power_on_config); local_cache_sr = proxy.local_cache_sr == null ? null : XenRef.Create(proxy.local_cache_sr); chipset_info = proxy.chipset_info == null ? null : Maps.convert_from_proxy_string_string(proxy.chipset_info); PCIs = proxy.PCIs == null ? null : XenRef.Create(proxy.PCIs); PGPUs = proxy.PGPUs == null ? null : XenRef.Create(proxy.PGPUs); PUSBs = proxy.PUSBs == null ? null : XenRef.Create(proxy.PUSBs); ssl_legacy = (bool)proxy.ssl_legacy; guest_VCPUs_params = proxy.guest_VCPUs_params == null ? null : Maps.convert_from_proxy_string_string(proxy.guest_VCPUs_params); display = proxy.display == null ? (host_display) 0 : (host_display)Helper.EnumParseDefault(typeof(host_display), (string)proxy.display); virtual_hardware_platform_versions = proxy.virtual_hardware_platform_versions == null ? null : Helper.StringArrayToLongArray(proxy.virtual_hardware_platform_versions); control_domain = proxy.control_domain == null ? null : XenRef.Create(proxy.control_domain); updates_requiring_reboot = proxy.updates_requiring_reboot == null ? null : XenRef.Create(proxy.updates_requiring_reboot); features = proxy.features == null ? null : XenRef.Create(proxy.features); iscsi_iqn = proxy.iscsi_iqn == null ? null : (string)proxy.iscsi_iqn; multipathing = (bool)proxy.multipathing; } public Proxy_Host ToProxy() { Proxy_Host result_ = new Proxy_Host(); result_.uuid = uuid ?? ""; result_.name_label = name_label ?? ""; result_.name_description = name_description ?? ""; result_.memory_overhead = memory_overhead.ToString(); result_.allowed_operations = (allowed_operations != null) ? Helper.ObjectListToStringArray(allowed_operations) : new string[] {}; result_.current_operations = Maps.convert_to_proxy_string_host_allowed_operations(current_operations); result_.API_version_major = API_version_major.ToString(); result_.API_version_minor = API_version_minor.ToString(); result_.API_version_vendor = API_version_vendor ?? ""; result_.API_version_vendor_implementation = Maps.convert_to_proxy_string_string(API_version_vendor_implementation); result_.enabled = enabled; result_.software_version = Maps.convert_to_proxy_string_string(software_version); result_.other_config = Maps.convert_to_proxy_string_string(other_config); result_.capabilities = capabilities; result_.cpu_configuration = Maps.convert_to_proxy_string_string(cpu_configuration); result_.sched_policy = sched_policy ?? ""; result_.supported_bootloaders = supported_bootloaders; result_.resident_VMs = (resident_VMs != null) ? Helper.RefListToStringArray(resident_VMs) : new string[] {}; result_.logging = Maps.convert_to_proxy_string_string(logging); result_.PIFs = (PIFs != null) ? Helper.RefListToStringArray(PIFs) : new string[] {}; result_.suspend_image_sr = suspend_image_sr ?? ""; result_.crash_dump_sr = crash_dump_sr ?? ""; result_.crashdumps = (crashdumps != null) ? Helper.RefListToStringArray(crashdumps) : new string[] {}; result_.patches = (patches != null) ? Helper.RefListToStringArray(patches) : new string[] {}; result_.updates = (updates != null) ? Helper.RefListToStringArray(updates) : new string[] {}; result_.PBDs = (PBDs != null) ? Helper.RefListToStringArray(PBDs) : new string[] {}; result_.host_CPUs = (host_CPUs != null) ? Helper.RefListToStringArray(host_CPUs) : new string[] {}; result_.cpu_info = Maps.convert_to_proxy_string_string(cpu_info); result_.hostname = hostname ?? ""; result_.address = address ?? ""; result_.metrics = metrics ?? ""; result_.license_params = Maps.convert_to_proxy_string_string(license_params); result_.ha_statefiles = ha_statefiles; result_.ha_network_peers = ha_network_peers; result_.blobs = Maps.convert_to_proxy_string_XenRefBlob(blobs); result_.tags = tags; result_.external_auth_type = external_auth_type ?? ""; result_.external_auth_service_name = external_auth_service_name ?? ""; result_.external_auth_configuration = Maps.convert_to_proxy_string_string(external_auth_configuration); result_.edition = edition ?? ""; result_.license_server = Maps.convert_to_proxy_string_string(license_server); result_.bios_strings = Maps.convert_to_proxy_string_string(bios_strings); result_.power_on_mode = power_on_mode ?? ""; result_.power_on_config = Maps.convert_to_proxy_string_string(power_on_config); result_.local_cache_sr = local_cache_sr ?? ""; result_.chipset_info = Maps.convert_to_proxy_string_string(chipset_info); result_.PCIs = (PCIs != null) ? Helper.RefListToStringArray(PCIs) : new string[] {}; result_.PGPUs = (PGPUs != null) ? Helper.RefListToStringArray(PGPUs) : new string[] {}; result_.PUSBs = (PUSBs != null) ? Helper.RefListToStringArray(PUSBs) : new string[] {}; result_.ssl_legacy = ssl_legacy; result_.guest_VCPUs_params = Maps.convert_to_proxy_string_string(guest_VCPUs_params); result_.display = host_display_helper.ToString(display); result_.virtual_hardware_platform_versions = (virtual_hardware_platform_versions != null) ? Helper.LongArrayToStringArray(virtual_hardware_platform_versions) : new string[] {}; result_.control_domain = control_domain ?? ""; result_.updates_requiring_reboot = (updates_requiring_reboot != null) ? Helper.RefListToStringArray(updates_requiring_reboot) : new string[] {}; result_.features = (features != null) ? Helper.RefListToStringArray(features) : new string[] {}; result_.iscsi_iqn = iscsi_iqn ?? ""; result_.multipathing = multipathing; return result_; } /// /// Creates a new Host from a Hashtable. /// Note that the fields not contained in the Hashtable /// will be created with their default values. /// /// public Host(Hashtable table) : this() { UpdateFrom(table); } /// /// Given a Hashtable with field-value pairs, it updates the fields of this Host /// with the values listed in the Hashtable. Note that only the fields contained /// in the Hashtable will be updated and the rest will remain the same. /// /// public void UpdateFrom(Hashtable table) { if (table.ContainsKey("uuid")) uuid = Marshalling.ParseString(table, "uuid"); if (table.ContainsKey("name_label")) name_label = Marshalling.ParseString(table, "name_label"); if (table.ContainsKey("name_description")) name_description = Marshalling.ParseString(table, "name_description"); if (table.ContainsKey("memory_overhead")) memory_overhead = Marshalling.ParseLong(table, "memory_overhead"); if (table.ContainsKey("allowed_operations")) allowed_operations = Helper.StringArrayToEnumList(Marshalling.ParseStringArray(table, "allowed_operations")); if (table.ContainsKey("current_operations")) current_operations = Maps.convert_from_proxy_string_host_allowed_operations(Marshalling.ParseHashTable(table, "current_operations")); if (table.ContainsKey("API_version_major")) API_version_major = Marshalling.ParseLong(table, "API_version_major"); if (table.ContainsKey("API_version_minor")) API_version_minor = Marshalling.ParseLong(table, "API_version_minor"); if (table.ContainsKey("API_version_vendor")) API_version_vendor = Marshalling.ParseString(table, "API_version_vendor"); if (table.ContainsKey("API_version_vendor_implementation")) API_version_vendor_implementation = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "API_version_vendor_implementation")); if (table.ContainsKey("enabled")) enabled = Marshalling.ParseBool(table, "enabled"); if (table.ContainsKey("software_version")) software_version = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "software_version")); if (table.ContainsKey("other_config")) other_config = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "other_config")); if (table.ContainsKey("capabilities")) capabilities = Marshalling.ParseStringArray(table, "capabilities"); if (table.ContainsKey("cpu_configuration")) cpu_configuration = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "cpu_configuration")); if (table.ContainsKey("sched_policy")) sched_policy = Marshalling.ParseString(table, "sched_policy"); if (table.ContainsKey("supported_bootloaders")) supported_bootloaders = Marshalling.ParseStringArray(table, "supported_bootloaders"); if (table.ContainsKey("resident_VMs")) resident_VMs = Marshalling.ParseSetRef(table, "resident_VMs"); if (table.ContainsKey("logging")) logging = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "logging")); if (table.ContainsKey("PIFs")) PIFs = Marshalling.ParseSetRef(table, "PIFs"); if (table.ContainsKey("suspend_image_sr")) suspend_image_sr = Marshalling.ParseRef(table, "suspend_image_sr"); if (table.ContainsKey("crash_dump_sr")) crash_dump_sr = Marshalling.ParseRef(table, "crash_dump_sr"); if (table.ContainsKey("crashdumps")) crashdumps = Marshalling.ParseSetRef(table, "crashdumps"); if (table.ContainsKey("patches")) patches = Marshalling.ParseSetRef(table, "patches"); if (table.ContainsKey("updates")) updates = Marshalling.ParseSetRef(table, "updates"); if (table.ContainsKey("PBDs")) PBDs = Marshalling.ParseSetRef(table, "PBDs"); if (table.ContainsKey("host_CPUs")) host_CPUs = Marshalling.ParseSetRef(table, "host_CPUs"); if (table.ContainsKey("cpu_info")) cpu_info = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "cpu_info")); if (table.ContainsKey("hostname")) hostname = Marshalling.ParseString(table, "hostname"); if (table.ContainsKey("address")) address = Marshalling.ParseString(table, "address"); if (table.ContainsKey("metrics")) metrics = Marshalling.ParseRef(table, "metrics"); if (table.ContainsKey("license_params")) license_params = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "license_params")); if (table.ContainsKey("ha_statefiles")) ha_statefiles = Marshalling.ParseStringArray(table, "ha_statefiles"); if (table.ContainsKey("ha_network_peers")) ha_network_peers = Marshalling.ParseStringArray(table, "ha_network_peers"); if (table.ContainsKey("blobs")) blobs = Maps.convert_from_proxy_string_XenRefBlob(Marshalling.ParseHashTable(table, "blobs")); if (table.ContainsKey("tags")) tags = Marshalling.ParseStringArray(table, "tags"); if (table.ContainsKey("external_auth_type")) external_auth_type = Marshalling.ParseString(table, "external_auth_type"); if (table.ContainsKey("external_auth_service_name")) external_auth_service_name = Marshalling.ParseString(table, "external_auth_service_name"); if (table.ContainsKey("external_auth_configuration")) external_auth_configuration = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "external_auth_configuration")); if (table.ContainsKey("edition")) edition = Marshalling.ParseString(table, "edition"); if (table.ContainsKey("license_server")) license_server = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "license_server")); if (table.ContainsKey("bios_strings")) bios_strings = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "bios_strings")); if (table.ContainsKey("power_on_mode")) power_on_mode = Marshalling.ParseString(table, "power_on_mode"); if (table.ContainsKey("power_on_config")) power_on_config = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "power_on_config")); if (table.ContainsKey("local_cache_sr")) local_cache_sr = Marshalling.ParseRef(table, "local_cache_sr"); if (table.ContainsKey("chipset_info")) chipset_info = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "chipset_info")); if (table.ContainsKey("PCIs")) PCIs = Marshalling.ParseSetRef(table, "PCIs"); if (table.ContainsKey("PGPUs")) PGPUs = Marshalling.ParseSetRef(table, "PGPUs"); if (table.ContainsKey("PUSBs")) PUSBs = Marshalling.ParseSetRef(table, "PUSBs"); if (table.ContainsKey("ssl_legacy")) ssl_legacy = Marshalling.ParseBool(table, "ssl_legacy"); if (table.ContainsKey("guest_VCPUs_params")) guest_VCPUs_params = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "guest_VCPUs_params")); if (table.ContainsKey("display")) display = (host_display)Helper.EnumParseDefault(typeof(host_display), Marshalling.ParseString(table, "display")); if (table.ContainsKey("virtual_hardware_platform_versions")) virtual_hardware_platform_versions = Marshalling.ParseLongArray(table, "virtual_hardware_platform_versions"); if (table.ContainsKey("control_domain")) control_domain = Marshalling.ParseRef(table, "control_domain"); if (table.ContainsKey("updates_requiring_reboot")) updates_requiring_reboot = Marshalling.ParseSetRef(table, "updates_requiring_reboot"); if (table.ContainsKey("features")) features = Marshalling.ParseSetRef(table, "features"); if (table.ContainsKey("iscsi_iqn")) iscsi_iqn = Marshalling.ParseString(table, "iscsi_iqn"); if (table.ContainsKey("multipathing")) multipathing = Marshalling.ParseBool(table, "multipathing"); } public bool DeepEquals(Host 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._memory_overhead, other._memory_overhead) && Helper.AreEqual2(this._allowed_operations, other._allowed_operations) && Helper.AreEqual2(this._API_version_major, other._API_version_major) && Helper.AreEqual2(this._API_version_minor, other._API_version_minor) && Helper.AreEqual2(this._API_version_vendor, other._API_version_vendor) && Helper.AreEqual2(this._API_version_vendor_implementation, other._API_version_vendor_implementation) && Helper.AreEqual2(this._enabled, other._enabled) && Helper.AreEqual2(this._software_version, other._software_version) && Helper.AreEqual2(this._other_config, other._other_config) && Helper.AreEqual2(this._capabilities, other._capabilities) && Helper.AreEqual2(this._cpu_configuration, other._cpu_configuration) && Helper.AreEqual2(this._sched_policy, other._sched_policy) && Helper.AreEqual2(this._supported_bootloaders, other._supported_bootloaders) && Helper.AreEqual2(this._resident_VMs, other._resident_VMs) && Helper.AreEqual2(this._logging, other._logging) && Helper.AreEqual2(this._PIFs, other._PIFs) && Helper.AreEqual2(this._suspend_image_sr, other._suspend_image_sr) && Helper.AreEqual2(this._crash_dump_sr, other._crash_dump_sr) && Helper.AreEqual2(this._crashdumps, other._crashdumps) && Helper.AreEqual2(this._patches, other._patches) && Helper.AreEqual2(this._updates, other._updates) && Helper.AreEqual2(this._PBDs, other._PBDs) && Helper.AreEqual2(this._host_CPUs, other._host_CPUs) && Helper.AreEqual2(this._cpu_info, other._cpu_info) && Helper.AreEqual2(this._hostname, other._hostname) && Helper.AreEqual2(this._address, other._address) && Helper.AreEqual2(this._metrics, other._metrics) && Helper.AreEqual2(this._license_params, other._license_params) && Helper.AreEqual2(this._ha_statefiles, other._ha_statefiles) && Helper.AreEqual2(this._ha_network_peers, other._ha_network_peers) && Helper.AreEqual2(this._blobs, other._blobs) && Helper.AreEqual2(this._tags, other._tags) && Helper.AreEqual2(this._external_auth_type, other._external_auth_type) && Helper.AreEqual2(this._external_auth_service_name, other._external_auth_service_name) && Helper.AreEqual2(this._external_auth_configuration, other._external_auth_configuration) && Helper.AreEqual2(this._edition, other._edition) && Helper.AreEqual2(this._license_server, other._license_server) && Helper.AreEqual2(this._bios_strings, other._bios_strings) && Helper.AreEqual2(this._power_on_mode, other._power_on_mode) && Helper.AreEqual2(this._power_on_config, other._power_on_config) && Helper.AreEqual2(this._local_cache_sr, other._local_cache_sr) && Helper.AreEqual2(this._chipset_info, other._chipset_info) && Helper.AreEqual2(this._PCIs, other._PCIs) && Helper.AreEqual2(this._PGPUs, other._PGPUs) && Helper.AreEqual2(this._PUSBs, other._PUSBs) && Helper.AreEqual2(this._ssl_legacy, other._ssl_legacy) && Helper.AreEqual2(this._guest_VCPUs_params, other._guest_VCPUs_params) && Helper.AreEqual2(this._display, other._display) && Helper.AreEqual2(this._virtual_hardware_platform_versions, other._virtual_hardware_platform_versions) && Helper.AreEqual2(this._control_domain, other._control_domain) && Helper.AreEqual2(this._updates_requiring_reboot, other._updates_requiring_reboot) && Helper.AreEqual2(this._features, other._features) && Helper.AreEqual2(this._iscsi_iqn, other._iscsi_iqn) && Helper.AreEqual2(this._multipathing, other._multipathing); } internal static List ProxyArrayToObjectList(Proxy_Host[] input) { var result = new List(); foreach (var item in input) result.Add(new Host(item)); return result; } public override string SaveChanges(Session session, string opaqueRef, Host 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)) { Host.set_name_label(session, opaqueRef, _name_label); } if (!Helper.AreEqual2(_name_description, server._name_description)) { Host.set_name_description(session, opaqueRef, _name_description); } if (!Helper.AreEqual2(_other_config, server._other_config)) { Host.set_other_config(session, opaqueRef, _other_config); } if (!Helper.AreEqual2(_logging, server._logging)) { Host.set_logging(session, opaqueRef, _logging); } if (!Helper.AreEqual2(_suspend_image_sr, server._suspend_image_sr)) { Host.set_suspend_image_sr(session, opaqueRef, _suspend_image_sr); } if (!Helper.AreEqual2(_crash_dump_sr, server._crash_dump_sr)) { Host.set_crash_dump_sr(session, opaqueRef, _crash_dump_sr); } if (!Helper.AreEqual2(_hostname, server._hostname)) { Host.set_hostname(session, opaqueRef, _hostname); } if (!Helper.AreEqual2(_address, server._address)) { Host.set_address(session, opaqueRef, _address); } if (!Helper.AreEqual2(_tags, server._tags)) { Host.set_tags(session, opaqueRef, _tags); } if (!Helper.AreEqual2(_license_server, server._license_server)) { Host.set_license_server(session, opaqueRef, _license_server); } if (!Helper.AreEqual2(_guest_VCPUs_params, server._guest_VCPUs_params)) { Host.set_guest_VCPUs_params(session, opaqueRef, _guest_VCPUs_params); } if (!Helper.AreEqual2(_display, server._display)) { Host.set_display(session, opaqueRef, _display); } if (!Helper.AreEqual2(_ssl_legacy, server._ssl_legacy)) { Host.set_ssl_legacy(session, opaqueRef, _ssl_legacy); } if (!Helper.AreEqual2(_iscsi_iqn, server._iscsi_iqn)) { Host.set_iscsi_iqn(session, opaqueRef, _iscsi_iqn); } if (!Helper.AreEqual2(_multipathing, server._multipathing)) { Host.set_multipathing(session, opaqueRef, _multipathing); } return null; } } /// /// Get a record containing the current state of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static Host get_record(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_record(session.opaque_ref, _host); else return new Host((Proxy_Host)session.proxy.host_get_record(session.opaque_ref, _host ?? "").parse()); } /// /// Get a reference to the host 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) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_by_uuid(session.opaque_ref, _uuid); else return XenRef.Create(session.proxy.host_get_by_uuid(session.opaque_ref, _uuid ?? "").parse()); } /// /// Get all the host instances with the given label. /// First published in XenServer 4.0. /// /// The session /// label of object to return public static List> get_by_name_label(Session session, string _label) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_by_name_label(session.opaque_ref, _label); else return XenRef.Create(session.proxy.host_get_by_name_label(session.opaque_ref, _label ?? "").parse()); } /// /// Get the uuid field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string get_uuid(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_uuid(session.opaque_ref, _host); else return (string)session.proxy.host_get_uuid(session.opaque_ref, _host ?? "").parse(); } /// /// Get the name/label field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string get_name_label(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_name_label(session.opaque_ref, _host); else return (string)session.proxy.host_get_name_label(session.opaque_ref, _host ?? "").parse(); } /// /// Get the name/description field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string get_name_description(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_name_description(session.opaque_ref, _host); else return (string)session.proxy.host_get_name_description(session.opaque_ref, _host ?? "").parse(); } /// /// Get the memory/overhead field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static long get_memory_overhead(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_memory_overhead(session.opaque_ref, _host); else return long.Parse((string)session.proxy.host_get_memory_overhead(session.opaque_ref, _host ?? "").parse()); } /// /// Get the allowed_operations field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static List get_allowed_operations(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_allowed_operations(session.opaque_ref, _host); else return Helper.StringArrayToEnumList(session.proxy.host_get_allowed_operations(session.opaque_ref, _host ?? "").parse()); } /// /// Get the current_operations field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static Dictionary get_current_operations(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_current_operations(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_host_allowed_operations(session.proxy.host_get_current_operations(session.opaque_ref, _host ?? "").parse()); } /// /// Get the API_version/major field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static long get_API_version_major(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_api_version_major(session.opaque_ref, _host); else return long.Parse((string)session.proxy.host_get_api_version_major(session.opaque_ref, _host ?? "").parse()); } /// /// Get the API_version/minor field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static long get_API_version_minor(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_api_version_minor(session.opaque_ref, _host); else return long.Parse((string)session.proxy.host_get_api_version_minor(session.opaque_ref, _host ?? "").parse()); } /// /// Get the API_version/vendor field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string get_API_version_vendor(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_api_version_vendor(session.opaque_ref, _host); else return (string)session.proxy.host_get_api_version_vendor(session.opaque_ref, _host ?? "").parse(); } /// /// Get the API_version/vendor_implementation field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static Dictionary get_API_version_vendor_implementation(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_api_version_vendor_implementation(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_api_version_vendor_implementation(session.opaque_ref, _host ?? "").parse()); } /// /// Get the enabled field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static bool get_enabled(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_enabled(session.opaque_ref, _host); else return (bool)session.proxy.host_get_enabled(session.opaque_ref, _host ?? "").parse(); } /// /// Get the software_version field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static Dictionary get_software_version(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_software_version(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_software_version(session.opaque_ref, _host ?? "").parse()); } /// /// Get the other_config field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static Dictionary get_other_config(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_other_config(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_other_config(session.opaque_ref, _host ?? "").parse()); } /// /// Get the capabilities field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string[] get_capabilities(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_capabilities(session.opaque_ref, _host); else return (string [])session.proxy.host_get_capabilities(session.opaque_ref, _host ?? "").parse(); } /// /// Get the cpu_configuration field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static Dictionary get_cpu_configuration(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_cpu_configuration(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_cpu_configuration(session.opaque_ref, _host ?? "").parse()); } /// /// Get the sched_policy field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string get_sched_policy(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_sched_policy(session.opaque_ref, _host); else return (string)session.proxy.host_get_sched_policy(session.opaque_ref, _host ?? "").parse(); } /// /// Get the supported_bootloaders field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string[] get_supported_bootloaders(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_supported_bootloaders(session.opaque_ref, _host); else return (string [])session.proxy.host_get_supported_bootloaders(session.opaque_ref, _host ?? "").parse(); } /// /// Get the resident_VMs field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static List> get_resident_VMs(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_resident_vms(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_resident_vms(session.opaque_ref, _host ?? "").parse()); } /// /// Get the logging field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static Dictionary get_logging(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_logging(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_logging(session.opaque_ref, _host ?? "").parse()); } /// /// Get the PIFs field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static List> get_PIFs(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_pifs(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_pifs(session.opaque_ref, _host ?? "").parse()); } /// /// Get the suspend_image_sr field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef get_suspend_image_sr(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_suspend_image_sr(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_suspend_image_sr(session.opaque_ref, _host ?? "").parse()); } /// /// Get the crash_dump_sr field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef get_crash_dump_sr(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_crash_dump_sr(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_crash_dump_sr(session.opaque_ref, _host ?? "").parse()); } /// /// Get the crashdumps field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static List> get_crashdumps(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_crashdumps(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_crashdumps(session.opaque_ref, _host ?? "").parse()); } /// /// Get the patches field of the given host. /// First published in XenServer 4.0. /// Deprecated since XenServer 7.1. /// /// The session /// The opaque_ref of the given host [Deprecated("XenServer 7.1")] public static List> get_patches(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_patches(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_patches(session.opaque_ref, _host ?? "").parse()); } /// /// Get the updates field of the given host. /// First published in XenServer 7.1. /// /// The session /// The opaque_ref of the given host public static List> get_updates(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_updates(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_updates(session.opaque_ref, _host ?? "").parse()); } /// /// Get the PBDs field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static List> get_PBDs(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_pbds(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_pbds(session.opaque_ref, _host ?? "").parse()); } /// /// Get the host_CPUs field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static List> get_host_CPUs(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_host_cpus(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_host_cpus(session.opaque_ref, _host ?? "").parse()); } /// /// Get the cpu_info field of the given host. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host public static Dictionary get_cpu_info(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_cpu_info(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_cpu_info(session.opaque_ref, _host ?? "").parse()); } /// /// Get the hostname field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string get_hostname(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_hostname(session.opaque_ref, _host); else return (string)session.proxy.host_get_hostname(session.opaque_ref, _host ?? "").parse(); } /// /// Get the address field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string get_address(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_address(session.opaque_ref, _host); else return (string)session.proxy.host_get_address(session.opaque_ref, _host ?? "").parse(); } /// /// Get the metrics field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef get_metrics(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_metrics(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_metrics(session.opaque_ref, _host ?? "").parse()); } /// /// Get the license_params field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static Dictionary get_license_params(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_license_params(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_license_params(session.opaque_ref, _host ?? "").parse()); } /// /// Get the ha_statefiles field of the given host. /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static string[] get_ha_statefiles(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_ha_statefiles(session.opaque_ref, _host); else return (string [])session.proxy.host_get_ha_statefiles(session.opaque_ref, _host ?? "").parse(); } /// /// Get the ha_network_peers field of the given host. /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static string[] get_ha_network_peers(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_ha_network_peers(session.opaque_ref, _host); else return (string [])session.proxy.host_get_ha_network_peers(session.opaque_ref, _host ?? "").parse(); } /// /// Get the blobs field of the given host. /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static Dictionary> get_blobs(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_blobs(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_XenRefBlob(session.proxy.host_get_blobs(session.opaque_ref, _host ?? "").parse()); } /// /// Get the tags field of the given host. /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static string[] get_tags(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_tags(session.opaque_ref, _host); else return (string [])session.proxy.host_get_tags(session.opaque_ref, _host ?? "").parse(); } /// /// Get the external_auth_type field of the given host. /// First published in XenServer 5.5. /// /// The session /// The opaque_ref of the given host public static string get_external_auth_type(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_external_auth_type(session.opaque_ref, _host); else return (string)session.proxy.host_get_external_auth_type(session.opaque_ref, _host ?? "").parse(); } /// /// Get the external_auth_service_name field of the given host. /// First published in XenServer 5.5. /// /// The session /// The opaque_ref of the given host public static string get_external_auth_service_name(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_external_auth_service_name(session.opaque_ref, _host); else return (string)session.proxy.host_get_external_auth_service_name(session.opaque_ref, _host ?? "").parse(); } /// /// Get the external_auth_configuration field of the given host. /// First published in XenServer 5.5. /// /// The session /// The opaque_ref of the given host public static Dictionary get_external_auth_configuration(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_external_auth_configuration(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_external_auth_configuration(session.opaque_ref, _host ?? "").parse()); } /// /// Get the edition field of the given host. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host public static string get_edition(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_edition(session.opaque_ref, _host); else return (string)session.proxy.host_get_edition(session.opaque_ref, _host ?? "").parse(); } /// /// Get the license_server field of the given host. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host public static Dictionary get_license_server(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_license_server(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_license_server(session.opaque_ref, _host ?? "").parse()); } /// /// Get the bios_strings field of the given host. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host public static Dictionary get_bios_strings(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_bios_strings(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_bios_strings(session.opaque_ref, _host ?? "").parse()); } /// /// Get the power_on_mode field of the given host. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host public static string get_power_on_mode(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_power_on_mode(session.opaque_ref, _host); else return (string)session.proxy.host_get_power_on_mode(session.opaque_ref, _host ?? "").parse(); } /// /// Get the power_on_config field of the given host. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host public static Dictionary get_power_on_config(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_power_on_config(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_power_on_config(session.opaque_ref, _host ?? "").parse()); } /// /// Get the local_cache_sr field of the given host. /// First published in XenServer 5.6 FP1. /// /// The session /// The opaque_ref of the given host public static XenRef get_local_cache_sr(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_local_cache_sr(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_local_cache_sr(session.opaque_ref, _host ?? "").parse()); } /// /// Get the chipset_info field of the given host. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given host public static Dictionary get_chipset_info(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_chipset_info(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_chipset_info(session.opaque_ref, _host ?? "").parse()); } /// /// Get the PCIs field of the given host. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given host public static List> get_PCIs(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_pcis(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_pcis(session.opaque_ref, _host ?? "").parse()); } /// /// Get the PGPUs field of the given host. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given host public static List> get_PGPUs(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_pgpus(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_pgpus(session.opaque_ref, _host ?? "").parse()); } /// /// Get the PUSBs field of the given host. /// First published in XenServer 7.3. /// /// The session /// The opaque_ref of the given host public static List> get_PUSBs(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_pusbs(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_pusbs(session.opaque_ref, _host ?? "").parse()); } /// /// Get the ssl_legacy field of the given host. /// First published in XenServer 7.0. /// /// The session /// The opaque_ref of the given host public static bool get_ssl_legacy(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_ssl_legacy(session.opaque_ref, _host); else return (bool)session.proxy.host_get_ssl_legacy(session.opaque_ref, _host ?? "").parse(); } /// /// Get the guest_VCPUs_params field of the given host. /// First published in XenServer 6.1. /// /// The session /// The opaque_ref of the given host public static Dictionary get_guest_VCPUs_params(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_guest_vcpus_params(session.opaque_ref, _host); else return Maps.convert_from_proxy_string_string(session.proxy.host_get_guest_vcpus_params(session.opaque_ref, _host ?? "").parse()); } /// /// Get the display field of the given host. /// First published in XenServer 6.5 SP1. /// /// The session /// The opaque_ref of the given host public static host_display get_display(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_display(session.opaque_ref, _host); else return (host_display)Helper.EnumParseDefault(typeof(host_display), (string)session.proxy.host_get_display(session.opaque_ref, _host ?? "").parse()); } /// /// Get the virtual_hardware_platform_versions field of the given host. /// First published in XenServer 6.5 SP1. /// /// The session /// The opaque_ref of the given host public static long[] get_virtual_hardware_platform_versions(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_virtual_hardware_platform_versions(session.opaque_ref, _host); else return Helper.StringArrayToLongArray(session.proxy.host_get_virtual_hardware_platform_versions(session.opaque_ref, _host ?? "").parse()); } /// /// Get the control_domain field of the given host. /// First published in XenServer 7.1. /// /// The session /// The opaque_ref of the given host public static XenRef get_control_domain(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_control_domain(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_control_domain(session.opaque_ref, _host ?? "").parse()); } /// /// Get the updates_requiring_reboot field of the given host. /// First published in XenServer 7.1. /// /// The session /// The opaque_ref of the given host public static List> get_updates_requiring_reboot(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_updates_requiring_reboot(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_updates_requiring_reboot(session.opaque_ref, _host ?? "").parse()); } /// /// Get the features field of the given host. /// First published in XenServer 7.2. /// /// The session /// The opaque_ref of the given host public static List> get_features(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_features(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_features(session.opaque_ref, _host ?? "").parse()); } /// /// Get the iscsi_iqn field of the given host. /// First published in Unreleased. /// /// The session /// The opaque_ref of the given host public static string get_iscsi_iqn(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_iscsi_iqn(session.opaque_ref, _host); else return (string)session.proxy.host_get_iscsi_iqn(session.opaque_ref, _host ?? "").parse(); } /// /// Get the multipathing field of the given host. /// First published in Unreleased. /// /// The session /// The opaque_ref of the given host public static bool get_multipathing(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_multipathing(session.opaque_ref, _host); else return (bool)session.proxy.host_get_multipathing(session.opaque_ref, _host ?? "").parse(); } /// /// Set the name/label field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_name_label(Session session, string _host, string _label) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_name_label(session.opaque_ref, _host, _label); else session.proxy.host_set_name_label(session.opaque_ref, _host ?? "", _label ?? "").parse(); } /// /// Set the name/description field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_name_description(Session session, string _host, string _description) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_name_description(session.opaque_ref, _host, _description); else session.proxy.host_set_name_description(session.opaque_ref, _host ?? "", _description ?? "").parse(); } /// /// Set the other_config field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_other_config(Session session, string _host, Dictionary _other_config) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_other_config(session.opaque_ref, _host, _other_config); else session.proxy.host_set_other_config(session.opaque_ref, _host ?? "", Maps.convert_to_proxy_string_string(_other_config)).parse(); } /// /// Add the given key-value pair to the other_config field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// Key to add /// Value to add public static void add_to_other_config(Session session, string _host, string _key, string _value) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_add_to_other_config(session.opaque_ref, _host, _key, _value); else session.proxy.host_add_to_other_config(session.opaque_ref, _host ?? "", _key ?? "", _value ?? "").parse(); } /// /// Remove the given key and its corresponding value from the other_config field of the given host. 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 host /// Key to remove public static void remove_from_other_config(Session session, string _host, string _key) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_remove_from_other_config(session.opaque_ref, _host, _key); else session.proxy.host_remove_from_other_config(session.opaque_ref, _host ?? "", _key ?? "").parse(); } /// /// Set the logging field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_logging(Session session, string _host, Dictionary _logging) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_logging(session.opaque_ref, _host, _logging); else session.proxy.host_set_logging(session.opaque_ref, _host ?? "", Maps.convert_to_proxy_string_string(_logging)).parse(); } /// /// Add the given key-value pair to the logging field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// Key to add /// Value to add public static void add_to_logging(Session session, string _host, string _key, string _value) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_add_to_logging(session.opaque_ref, _host, _key, _value); else session.proxy.host_add_to_logging(session.opaque_ref, _host ?? "", _key ?? "", _value ?? "").parse(); } /// /// Remove the given key and its corresponding value from the logging field of the given host. 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 host /// Key to remove public static void remove_from_logging(Session session, string _host, string _key) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_remove_from_logging(session.opaque_ref, _host, _key); else session.proxy.host_remove_from_logging(session.opaque_ref, _host ?? "", _key ?? "").parse(); } /// /// Set the suspend_image_sr field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_suspend_image_sr(Session session, string _host, string _suspend_image_sr) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_suspend_image_sr(session.opaque_ref, _host, _suspend_image_sr); else session.proxy.host_set_suspend_image_sr(session.opaque_ref, _host ?? "", _suspend_image_sr ?? "").parse(); } /// /// Set the crash_dump_sr field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_crash_dump_sr(Session session, string _host, string _crash_dump_sr) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_crash_dump_sr(session.opaque_ref, _host, _crash_dump_sr); else session.proxy.host_set_crash_dump_sr(session.opaque_ref, _host ?? "", _crash_dump_sr ?? "").parse(); } /// /// Set the hostname field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_hostname(Session session, string _host, string _hostname) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_hostname(session.opaque_ref, _host, _hostname); else session.proxy.host_set_hostname(session.opaque_ref, _host ?? "", _hostname ?? "").parse(); } /// /// Set the address field of the given host. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_address(Session session, string _host, string _address) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_address(session.opaque_ref, _host, _address); else session.proxy.host_set_address(session.opaque_ref, _host ?? "", _address ?? "").parse(); } /// /// Set the tags field of the given host. /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_tags(Session session, string _host, string[] _tags) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_tags(session.opaque_ref, _host, _tags); else session.proxy.host_set_tags(session.opaque_ref, _host ?? "", _tags).parse(); } /// /// Add the given value to the tags field of the given host. 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 host /// New value to add public static void add_tags(Session session, string _host, string _value) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_add_tags(session.opaque_ref, _host, _value); else session.proxy.host_add_tags(session.opaque_ref, _host ?? "", _value ?? "").parse(); } /// /// Remove the given value from the tags field of the given host. 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 host /// Value to remove public static void remove_tags(Session session, string _host, string _value) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_remove_tags(session.opaque_ref, _host, _value); else session.proxy.host_remove_tags(session.opaque_ref, _host ?? "", _value ?? "").parse(); } /// /// Set the license_server field of the given host. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_license_server(Session session, string _host, Dictionary _license_server) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_license_server(session.opaque_ref, _host, _license_server); else session.proxy.host_set_license_server(session.opaque_ref, _host ?? "", Maps.convert_to_proxy_string_string(_license_server)).parse(); } /// /// Add the given key-value pair to the license_server field of the given host. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host /// Key to add /// Value to add public static void add_to_license_server(Session session, string _host, string _key, string _value) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_add_to_license_server(session.opaque_ref, _host, _key, _value); else session.proxy.host_add_to_license_server(session.opaque_ref, _host ?? "", _key ?? "", _value ?? "").parse(); } /// /// Remove the given key and its corresponding value from the license_server field of the given host. If the key is not in that Map, then do nothing. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host /// Key to remove public static void remove_from_license_server(Session session, string _host, string _key) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_remove_from_license_server(session.opaque_ref, _host, _key); else session.proxy.host_remove_from_license_server(session.opaque_ref, _host ?? "", _key ?? "").parse(); } /// /// Set the guest_VCPUs_params field of the given host. /// First published in XenServer 6.1. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_guest_VCPUs_params(Session session, string _host, Dictionary _guest_vcpus_params) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_guest_vcpus_params(session.opaque_ref, _host, _guest_vcpus_params); else session.proxy.host_set_guest_vcpus_params(session.opaque_ref, _host ?? "", Maps.convert_to_proxy_string_string(_guest_vcpus_params)).parse(); } /// /// Add the given key-value pair to the guest_VCPUs_params field of the given host. /// First published in XenServer 6.1. /// /// The session /// The opaque_ref of the given host /// Key to add /// Value to add public static void add_to_guest_VCPUs_params(Session session, string _host, string _key, string _value) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_add_to_guest_vcpus_params(session.opaque_ref, _host, _key, _value); else session.proxy.host_add_to_guest_vcpus_params(session.opaque_ref, _host ?? "", _key ?? "", _value ?? "").parse(); } /// /// Remove the given key and its corresponding value from the guest_VCPUs_params field of the given host. If the key is not in that Map, then do nothing. /// First published in XenServer 6.1. /// /// The session /// The opaque_ref of the given host /// Key to remove public static void remove_from_guest_VCPUs_params(Session session, string _host, string _key) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_remove_from_guest_vcpus_params(session.opaque_ref, _host, _key); else session.proxy.host_remove_from_guest_vcpus_params(session.opaque_ref, _host ?? "", _key ?? "").parse(); } /// /// Set the display field of the given host. /// First published in XenServer 6.5 SP1. /// /// The session /// The opaque_ref of the given host /// New value to set public static void set_display(Session session, string _host, host_display _display) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_display(session.opaque_ref, _host, _display); else session.proxy.host_set_display(session.opaque_ref, _host ?? "", host_display_helper.ToString(_display)).parse(); } /// /// Puts the host into a state in which no new VMs can be started. Currently active VMs on the host continue to execute. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static void disable(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_disable(session.opaque_ref, _host); else session.proxy.host_disable(session.opaque_ref, _host ?? "").parse(); } /// /// Puts the host into a state in which no new VMs can be started. Currently active VMs on the host continue to execute. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_disable(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_disable(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_disable(session.opaque_ref, _host ?? "").parse()); } /// /// Puts the host into a state in which new VMs can be started. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static void enable(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_enable(session.opaque_ref, _host); else session.proxy.host_enable(session.opaque_ref, _host ?? "").parse(); } /// /// Puts the host into a state in which new VMs can be started. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_enable(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_enable(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_enable(session.opaque_ref, _host ?? "").parse()); } /// /// Shutdown the host. (This function can only be called if there are no currently running VMs on the host and it is disabled.) /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static void shutdown(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_shutdown(session.opaque_ref, _host); else session.proxy.host_shutdown(session.opaque_ref, _host ?? "").parse(); } /// /// Shutdown the host. (This function can only be called if there are no currently running VMs on the host and it is disabled.) /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_shutdown(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_shutdown(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_shutdown(session.opaque_ref, _host ?? "").parse()); } /// /// Reboot the host. (This function can only be called if there are no currently running VMs on the host and it is disabled.) /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static void reboot(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_reboot(session.opaque_ref, _host); else session.proxy.host_reboot(session.opaque_ref, _host ?? "").parse(); } /// /// Reboot the host. (This function can only be called if there are no currently running VMs on the host and it is disabled.) /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_reboot(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_reboot(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_reboot(session.opaque_ref, _host ?? "").parse()); } /// /// Get the host xen dmesg. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string dmesg(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_dmesg(session.opaque_ref, _host); else return (string)session.proxy.host_dmesg(session.opaque_ref, _host ?? "").parse(); } /// /// Get the host xen dmesg. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_dmesg(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_dmesg(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_dmesg(session.opaque_ref, _host ?? "").parse()); } /// /// Get the host xen dmesg, and clear the buffer. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string dmesg_clear(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_dmesg_clear(session.opaque_ref, _host); else return (string)session.proxy.host_dmesg_clear(session.opaque_ref, _host ?? "").parse(); } /// /// Get the host xen dmesg, and clear the buffer. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_dmesg_clear(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_dmesg_clear(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_dmesg_clear(session.opaque_ref, _host ?? "").parse()); } /// /// Get the host's log file /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static string get_log(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_log(session.opaque_ref, _host); else return (string)session.proxy.host_get_log(session.opaque_ref, _host ?? "").parse(); } /// /// Get the host's log file /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_get_log(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_get_log(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_get_log(session.opaque_ref, _host ?? "").parse()); } /// /// Inject the given string as debugging keys into Xen /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// The keys to send public static void send_debug_keys(Session session, string _host, string _keys) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_send_debug_keys(session.opaque_ref, _host, _keys); else session.proxy.host_send_debug_keys(session.opaque_ref, _host ?? "", _keys ?? "").parse(); } /// /// Inject the given string as debugging keys into Xen /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// The keys to send public static XenRef async_send_debug_keys(Session session, string _host, string _keys) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_send_debug_keys(session.opaque_ref, _host, _keys); else return XenRef.Create(session.proxy.async_host_send_debug_keys(session.opaque_ref, _host ?? "", _keys ?? "").parse()); } /// /// Run xen-bugtool --yestoall and upload the output to support /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// The URL to upload to /// Extra configuration operations public static void bugreport_upload(Session session, string _host, string _url, Dictionary _options) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_bugreport_upload(session.opaque_ref, _host, _url, _options); else session.proxy.host_bugreport_upload(session.opaque_ref, _host ?? "", _url ?? "", Maps.convert_to_proxy_string_string(_options)).parse(); } /// /// Run xen-bugtool --yestoall and upload the output to support /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// The URL to upload to /// Extra configuration operations public static XenRef async_bugreport_upload(Session session, string _host, string _url, Dictionary _options) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_bugreport_upload(session.opaque_ref, _host, _url, _options); else return XenRef.Create(session.proxy.async_host_bugreport_upload(session.opaque_ref, _host ?? "", _url ?? "", Maps.convert_to_proxy_string_string(_options)).parse()); } /// /// List all supported methods /// First published in XenServer 4.0. /// /// The session public static string[] list_methods(Session session) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_list_methods(session.opaque_ref); else return (string [])session.proxy.host_list_methods(session.opaque_ref).parse(); } /// /// Apply a new license to a host /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// The contents of the license file, base64 encoded public static void license_apply(Session session, string _host, string _contents) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_license_apply(session.opaque_ref, _host, _contents); else session.proxy.host_license_apply(session.opaque_ref, _host ?? "", _contents ?? "").parse(); } /// /// Apply a new license to a host /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host /// The contents of the license file, base64 encoded public static XenRef async_license_apply(Session session, string _host, string _contents) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_license_apply(session.opaque_ref, _host, _contents); else return XenRef.Create(session.proxy.async_host_license_apply(session.opaque_ref, _host ?? "", _contents ?? "").parse()); } /// /// Apply a new license to a host /// First published in XenServer 6.5 SP1 Hotfix 31. /// /// The session /// The opaque_ref of the given host /// The contents of the license file, base64 encoded public static void license_add(Session session, string _host, string _contents) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_license_add(session.opaque_ref, _host, _contents); else session.proxy.host_license_add(session.opaque_ref, _host ?? "", _contents ?? "").parse(); } /// /// Apply a new license to a host /// First published in XenServer 6.5 SP1 Hotfix 31. /// /// The session /// The opaque_ref of the given host /// The contents of the license file, base64 encoded public static XenRef async_license_add(Session session, string _host, string _contents) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_license_add(session.opaque_ref, _host, _contents); else return XenRef.Create(session.proxy.async_host_license_add(session.opaque_ref, _host ?? "", _contents ?? "").parse()); } /// /// Remove any license file from the specified host, and switch that host to the unlicensed edition /// First published in XenServer 6.5 SP1 Hotfix 31. /// /// The session /// The opaque_ref of the given host public static void license_remove(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_license_remove(session.opaque_ref, _host); else session.proxy.host_license_remove(session.opaque_ref, _host ?? "").parse(); } /// /// Remove any license file from the specified host, and switch that host to the unlicensed edition /// First published in XenServer 6.5 SP1 Hotfix 31. /// /// The session /// The opaque_ref of the given host public static XenRef async_license_remove(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_license_remove(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_license_remove(session.opaque_ref, _host ?? "").parse()); } /// /// Destroy specified host record in database /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static void destroy(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_destroy(session.opaque_ref, _host); else session.proxy.host_destroy(session.opaque_ref, _host ?? "").parse(); } /// /// Destroy specified host record in database /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_destroy(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_destroy(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_destroy(session.opaque_ref, _host ?? "").parse()); } /// /// Attempt to power-on the host (if the capability exists). /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static void power_on(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_power_on(session.opaque_ref, _host); else session.proxy.host_power_on(session.opaque_ref, _host ?? "").parse(); } /// /// Attempt to power-on the host (if the capability exists). /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_power_on(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_power_on(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_power_on(session.opaque_ref, _host ?? "").parse()); } /// /// This call disables HA on the local host. This should only be used with extreme care. /// First published in XenServer 5.0. /// /// The session /// Disable HA temporarily, revert upon host reboot or further changes, idempotent First published in XenServer 7.1. public static void emergency_ha_disable(Session session, bool _soft) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_emergency_ha_disable(session.opaque_ref, _soft); else session.proxy.host_emergency_ha_disable(session.opaque_ref, _soft).parse(); } /// /// /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static List get_data_sources(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_data_sources(session.opaque_ref, _host); else return Data_source.ProxyArrayToObjectList(session.proxy.host_get_data_sources(session.opaque_ref, _host ?? "").parse()); } /// /// Start recording the specified data source /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host /// The data source to record public static void record_data_source(Session session, string _host, string _data_source) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_record_data_source(session.opaque_ref, _host, _data_source); else session.proxy.host_record_data_source(session.opaque_ref, _host ?? "", _data_source ?? "").parse(); } /// /// Query the latest value of the specified data source /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host /// The data source to query public static double query_data_source(Session session, string _host, string _data_source) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_query_data_source(session.opaque_ref, _host, _data_source); else return Convert.ToDouble(session.proxy.host_query_data_source(session.opaque_ref, _host ?? "", _data_source ?? "").parse()); } /// /// Forget the recorded statistics related to the specified data source /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host /// The data source whose archives are to be forgotten public static void forget_data_source_archives(Session session, string _host, string _data_source) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_forget_data_source_archives(session.opaque_ref, _host, _data_source); else session.proxy.host_forget_data_source_archives(session.opaque_ref, _host ?? "", _data_source ?? "").parse(); } /// /// Check this host can be evacuated. /// First published in XenServer 4.1. /// /// The session /// The opaque_ref of the given host public static void assert_can_evacuate(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_assert_can_evacuate(session.opaque_ref, _host); else session.proxy.host_assert_can_evacuate(session.opaque_ref, _host ?? "").parse(); } /// /// Check this host can be evacuated. /// First published in XenServer 4.1. /// /// The session /// The opaque_ref of the given host public static XenRef async_assert_can_evacuate(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_assert_can_evacuate(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_assert_can_evacuate(session.opaque_ref, _host ?? "").parse()); } /// /// Return a set of VMs which prevent the host being evacuated, with per-VM error codes /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static Dictionary, string[]> get_vms_which_prevent_evacuation(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_vms_which_prevent_evacuation(session.opaque_ref, _host); else return Maps.convert_from_proxy_XenRefVM_string_array(session.proxy.host_get_vms_which_prevent_evacuation(session.opaque_ref, _host ?? "").parse()); } /// /// Return a set of VMs which prevent the host being evacuated, with per-VM error codes /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_get_vms_which_prevent_evacuation(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_get_vms_which_prevent_evacuation(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_get_vms_which_prevent_evacuation(session.opaque_ref, _host ?? "").parse()); } /// /// Return a set of VMs which are not co-operating with the host's memory control system /// First published in XenServer 5.6. /// Deprecated since XenServer 6.1. /// /// The session /// The opaque_ref of the given host [Deprecated("XenServer 6.1")] public static List> get_uncooperative_resident_VMs(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_uncooperative_resident_vms(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_uncooperative_resident_vms(session.opaque_ref, _host ?? "").parse()); } /// /// Return a set of VMs which are not co-operating with the host's memory control system /// First published in XenServer 5.6. /// Deprecated since XenServer 6.1. /// /// The session /// The opaque_ref of the given host [Deprecated("XenServer 6.1")] public static XenRef async_get_uncooperative_resident_VMs(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_get_uncooperative_resident_vms(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_get_uncooperative_resident_vms(session.opaque_ref, _host ?? "").parse()); } /// /// Migrate all VMs off of this host, where possible. /// First published in XenServer 4.1. /// /// The session /// The opaque_ref of the given host public static void evacuate(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_evacuate(session.opaque_ref, _host); else session.proxy.host_evacuate(session.opaque_ref, _host ?? "").parse(); } /// /// Migrate all VMs off of this host, where possible. /// First published in XenServer 4.1. /// /// The session /// The opaque_ref of the given host public static XenRef async_evacuate(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_evacuate(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_evacuate(session.opaque_ref, _host ?? "").parse()); } /// /// Re-configure syslog logging /// First published in XenServer 4.1. /// /// The session /// The opaque_ref of the given host public static void syslog_reconfigure(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_syslog_reconfigure(session.opaque_ref, _host); else session.proxy.host_syslog_reconfigure(session.opaque_ref, _host ?? "").parse(); } /// /// Re-configure syslog logging /// First published in XenServer 4.1. /// /// The session /// The opaque_ref of the given host public static XenRef async_syslog_reconfigure(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_syslog_reconfigure(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_syslog_reconfigure(session.opaque_ref, _host ?? "").parse()); } /// /// Reconfigure the management network interface /// First published in XenServer 4.1. /// /// The session /// reference to a PIF object corresponding to the management interface public static void management_reconfigure(Session session, string _pif) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_management_reconfigure(session.opaque_ref, _pif); else session.proxy.host_management_reconfigure(session.opaque_ref, _pif ?? "").parse(); } /// /// Reconfigure the management network interface /// First published in XenServer 4.1. /// /// The session /// reference to a PIF object corresponding to the management interface public static XenRef async_management_reconfigure(Session session, string _pif) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_management_reconfigure(session.opaque_ref, _pif); else return XenRef.Create(session.proxy.async_host_management_reconfigure(session.opaque_ref, _pif ?? "").parse()); } /// /// Reconfigure the management network interface. Should only be used if Host.management_reconfigure is impossible because the network configuration is broken. /// First published in XenServer 4.1. /// /// The session /// name of the interface to use as a management interface public static void local_management_reconfigure(Session session, string _interface) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_local_management_reconfigure(session.opaque_ref, _interface); else session.proxy.host_local_management_reconfigure(session.opaque_ref, _interface ?? "").parse(); } /// /// Disable the management network interface /// First published in XenServer 4.1. /// /// The session public static void management_disable(Session session) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_management_disable(session.opaque_ref); else session.proxy.host_management_disable(session.opaque_ref).parse(); } /// /// Returns the management interface for the specified host /// Experimental. First published in XenServer 6.1. /// /// The session /// The opaque_ref of the given host public static XenRef get_management_interface(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_management_interface(session.opaque_ref, _host); else return XenRef.Create(session.proxy.host_get_management_interface(session.opaque_ref, _host ?? "").parse()); } /// /// Returns the management interface for the specified host /// Experimental. First published in XenServer 6.1. /// /// The session /// The opaque_ref of the given host public static XenRef async_get_management_interface(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_get_management_interface(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_get_management_interface(session.opaque_ref, _host ?? "").parse()); } /// /// /// First published in XenServer 4.1. /// /// The session /// The opaque_ref of the given host public static string get_system_status_capabilities(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_system_status_capabilities(session.opaque_ref, _host); else return (string)session.proxy.host_get_system_status_capabilities(session.opaque_ref, _host ?? "").parse(); } /// /// Restarts the agent after a 10 second pause. WARNING: this is a dangerous operation. Any operations in progress will be aborted, and unrecoverable data loss may occur. The caller is responsible for ensuring that there are no operations in progress when this method is called. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static void restart_agent(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_restart_agent(session.opaque_ref, _host); else session.proxy.host_restart_agent(session.opaque_ref, _host ?? "").parse(); } /// /// Restarts the agent after a 10 second pause. WARNING: this is a dangerous operation. Any operations in progress will be aborted, and unrecoverable data loss may occur. The caller is responsible for ensuring that there are no operations in progress when this method is called. /// First published in XenServer 4.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_restart_agent(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_restart_agent(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_restart_agent(session.opaque_ref, _host ?? "").parse()); } /// /// Shuts the agent down after a 10 second pause. WARNING: this is a dangerous operation. Any operations in progress will be aborted, and unrecoverable data loss may occur. The caller is responsible for ensuring that there are no operations in progress when this method is called. /// First published in XenServer 5.0. /// /// The session public static void shutdown_agent(Session session) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_shutdown_agent(session.opaque_ref); else session.proxy.host_shutdown_agent(session.opaque_ref).parse(); } /// /// Sets the host name to the specified string. Both the API and lower-level system hostname are changed immediately. /// First published in XenServer 4.1. /// /// The session /// The opaque_ref of the given host /// The new host name public static void set_hostname_live(Session session, string _host, string _hostname) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_hostname_live(session.opaque_ref, _host, _hostname); else session.proxy.host_set_hostname_live(session.opaque_ref, _host ?? "", _hostname ?? "").parse(); } /// /// Computes the amount of free memory on the host. /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static long compute_free_memory(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_compute_free_memory(session.opaque_ref, _host); else return long.Parse((string)session.proxy.host_compute_free_memory(session.opaque_ref, _host ?? "").parse()); } /// /// Computes the amount of free memory on the host. /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static XenRef async_compute_free_memory(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_compute_free_memory(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_compute_free_memory(session.opaque_ref, _host ?? "").parse()); } /// /// Computes the virtualization memory overhead of a host. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host public static long compute_memory_overhead(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_compute_memory_overhead(session.opaque_ref, _host); else return long.Parse((string)session.proxy.host_compute_memory_overhead(session.opaque_ref, _host ?? "").parse()); } /// /// Computes the virtualization memory overhead of a host. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host public static XenRef async_compute_memory_overhead(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_compute_memory_overhead(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_compute_memory_overhead(session.opaque_ref, _host ?? "").parse()); } /// /// This causes the synchronisation of the non-database data (messages, RRDs and so on) stored on the master to be synchronised with the host /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static void sync_data(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_sync_data(session.opaque_ref, _host); else session.proxy.host_sync_data(session.opaque_ref, _host ?? "").parse(); } /// /// This causes the RRDs to be backed up to the master /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host /// Delay in seconds from when the call is received to perform the backup public static void backup_rrds(Session session, string _host, double _delay) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_backup_rrds(session.opaque_ref, _host, _delay); else session.proxy.host_backup_rrds(session.opaque_ref, _host ?? "", _delay).parse(); } /// /// Create a placeholder for a named binary blob of data that is associated with this host /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host /// 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 _host, string _name, string _mime_type) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_create_new_blob(session.opaque_ref, _host, _name, _mime_type); else return XenRef.Create(session.proxy.host_create_new_blob(session.opaque_ref, _host ?? "", _name ?? "", _mime_type ?? "").parse()); } /// /// Create a placeholder for a named binary blob of data that is associated with this host /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host /// 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 _host, string _name, string _mime_type) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_create_new_blob(session.opaque_ref, _host, _name, _mime_type); else return XenRef.Create(session.proxy.async_host_create_new_blob(session.opaque_ref, _host ?? "", _name ?? "", _mime_type ?? "").parse()); } /// /// Create a placeholder for a named binary blob of data that is associated with this host /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host /// 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 _host, string _name, string _mime_type, bool _public) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_create_new_blob(session.opaque_ref, _host, _name, _mime_type, _public); else return XenRef.Create(session.proxy.host_create_new_blob(session.opaque_ref, _host ?? "", _name ?? "", _mime_type ?? "", _public).parse()); } /// /// Create a placeholder for a named binary blob of data that is associated with this host /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host /// 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 _host, string _name, string _mime_type, bool _public) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_create_new_blob(session.opaque_ref, _host, _name, _mime_type, _public); else return XenRef.Create(session.proxy.async_host_create_new_blob(session.opaque_ref, _host ?? "", _name ?? "", _mime_type ?? "", _public).parse()); } /// /// Call a XenAPI plugin on this host /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host /// The name of the plugin /// The name of the function within the plugin /// Arguments for the function public static string call_plugin(Session session, string _host, string _plugin, string _fn, Dictionary _args) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_call_plugin(session.opaque_ref, _host, _plugin, _fn, _args); else return (string)session.proxy.host_call_plugin(session.opaque_ref, _host ?? "", _plugin ?? "", _fn ?? "", Maps.convert_to_proxy_string_string(_args)).parse(); } /// /// Call a XenAPI plugin on this host /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host /// The name of the plugin /// The name of the function within the plugin /// Arguments for the function public static XenRef async_call_plugin(Session session, string _host, string _plugin, string _fn, Dictionary _args) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_call_plugin(session.opaque_ref, _host, _plugin, _fn, _args); else return XenRef.Create(session.proxy.async_host_call_plugin(session.opaque_ref, _host ?? "", _plugin ?? "", _fn ?? "", Maps.convert_to_proxy_string_string(_args)).parse()); } /// /// Return true if the extension is available on the host /// First published in XenServer 7.1. /// /// The session /// The opaque_ref of the given host /// The name of the API call public static bool has_extension(Session session, string _host, string _name) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_has_extension(session.opaque_ref, _host, _name); else return (bool)session.proxy.host_has_extension(session.opaque_ref, _host ?? "", _name ?? "").parse(); } /// /// Return true if the extension is available on the host /// First published in XenServer 7.1. /// /// The session /// The opaque_ref of the given host /// The name of the API call public static XenRef async_has_extension(Session session, string _host, string _name) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_has_extension(session.opaque_ref, _host, _name); else return XenRef.Create(session.proxy.async_host_has_extension(session.opaque_ref, _host ?? "", _name ?? "").parse()); } /// /// Call a XenAPI extension on this host /// First published in XenServer 7.1. /// /// The session /// The opaque_ref of the given host /// Rpc call for the extension public static string call_extension(Session session, string _host, string _call) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_call_extension(session.opaque_ref, _host, _call); else return (string)session.proxy.host_call_extension(session.opaque_ref, _host ?? "", _call ?? "").parse(); } /// /// This call queries the host's clock for the current time /// First published in XenServer 5.0. /// /// The session /// The opaque_ref of the given host public static DateTime get_servertime(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_servertime(session.opaque_ref, _host); else return session.proxy.host_get_servertime(session.opaque_ref, _host ?? "").parse(); } /// /// This call queries the host's clock for the current time in the host's local timezone /// First published in XenServer 5.6 FP1. /// /// The session /// The opaque_ref of the given host public static DateTime get_server_localtime(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_server_localtime(session.opaque_ref, _host); else return session.proxy.host_get_server_localtime(session.opaque_ref, _host ?? "").parse(); } /// /// This call enables external authentication on a host /// First published in XenServer 5.5. /// /// The session /// The opaque_ref of the given host /// 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 _host, Dictionary _config, string _service_name, string _auth_type) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_enable_external_auth(session.opaque_ref, _host, _config, _service_name, _auth_type); else session.proxy.host_enable_external_auth(session.opaque_ref, _host ?? "", Maps.convert_to_proxy_string_string(_config), _service_name ?? "", _auth_type ?? "").parse(); } /// /// This call disables external authentication on the local host /// First published in XenServer 5.5. /// /// The session /// The opaque_ref of the given host /// Optional parameters as a list of key-values containing the configuration data public static void disable_external_auth(Session session, string _host, Dictionary _config) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_disable_external_auth(session.opaque_ref, _host, _config); else session.proxy.host_disable_external_auth(session.opaque_ref, _host ?? "", Maps.convert_to_proxy_string_string(_config)).parse(); } /// /// Retrieves recommended host migrations to perform when evacuating the host from the wlb server. If a VM cannot be migrated from the host the reason is listed instead of a recommendation. /// First published in XenServer 5.5. /// /// The session /// The opaque_ref of the given host public static Dictionary, string[]> retrieve_wlb_evacuate_recommendations(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_retrieve_wlb_evacuate_recommendations(session.opaque_ref, _host); else return Maps.convert_from_proxy_XenRefVM_string_array(session.proxy.host_retrieve_wlb_evacuate_recommendations(session.opaque_ref, _host ?? "").parse()); } /// /// Retrieves recommended host migrations to perform when evacuating the host from the wlb server. If a VM cannot be migrated from the host the reason is listed instead of a recommendation. /// First published in XenServer 5.5. /// /// The session /// The opaque_ref of the given host public static XenRef async_retrieve_wlb_evacuate_recommendations(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_retrieve_wlb_evacuate_recommendations(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_retrieve_wlb_evacuate_recommendations(session.opaque_ref, _host ?? "").parse()); } /// /// Get the installed server public TLS certificate. /// First published in XenServer 5.5. /// /// The session /// The opaque_ref of the given host public static string get_server_certificate(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_server_certificate(session.opaque_ref, _host); else return (string)session.proxy.host_get_server_certificate(session.opaque_ref, _host ?? "").parse(); } /// /// Get the installed server public TLS certificate. /// First published in XenServer 5.5. /// /// The session /// The opaque_ref of the given host public static XenRef async_get_server_certificate(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_get_server_certificate(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_get_server_certificate(session.opaque_ref, _host ?? "").parse()); } /// /// Change to another edition, or reactivate the current edition after a license has expired. This may be subject to the successful checkout of an appropriate license. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host /// The requested edition public static void apply_edition(Session session, string _host, string _edition) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_apply_edition(session.opaque_ref, _host, _edition); else session.proxy.host_apply_edition(session.opaque_ref, _host ?? "", _edition ?? "").parse(); } /// /// Change to another edition, or reactivate the current edition after a license has expired. This may be subject to the successful checkout of an appropriate license. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host /// The requested edition /// Update the license params even if the apply call fails First published in XenServer 6.2. public static void apply_edition(Session session, string _host, string _edition, bool _force) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_apply_edition(session.opaque_ref, _host, _edition, _force); else session.proxy.host_apply_edition(session.opaque_ref, _host ?? "", _edition ?? "", _force).parse(); } /// /// Refresh the list of installed Supplemental Packs. /// First published in XenServer 5.6. /// Deprecated since XenServer 7.1. /// /// The session /// The opaque_ref of the given host [Deprecated("XenServer 7.1")] public static void refresh_pack_info(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_refresh_pack_info(session.opaque_ref, _host); else session.proxy.host_refresh_pack_info(session.opaque_ref, _host ?? "").parse(); } /// /// Refresh the list of installed Supplemental Packs. /// First published in XenServer 5.6. /// Deprecated since XenServer 7.1. /// /// The session /// The opaque_ref of the given host [Deprecated("XenServer 7.1")] public static XenRef async_refresh_pack_info(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_refresh_pack_info(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_refresh_pack_info(session.opaque_ref, _host ?? "").parse()); } /// /// Set the power-on-mode, host, user and password /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host /// power-on-mode can be empty,iLO,wake-on-lan, DRAC or other /// Power on config public static void set_power_on_mode(Session session, string _host, string _power_on_mode, Dictionary _power_on_config) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_power_on_mode(session.opaque_ref, _host, _power_on_mode, _power_on_config); else session.proxy.host_set_power_on_mode(session.opaque_ref, _host ?? "", _power_on_mode ?? "", Maps.convert_to_proxy_string_string(_power_on_config)).parse(); } /// /// Set the power-on-mode, host, user and password /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host /// power-on-mode can be empty,iLO,wake-on-lan, DRAC or other /// Power on config public static XenRef async_set_power_on_mode(Session session, string _host, string _power_on_mode, Dictionary _power_on_config) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_set_power_on_mode(session.opaque_ref, _host, _power_on_mode, _power_on_config); else return XenRef.Create(session.proxy.async_host_set_power_on_mode(session.opaque_ref, _host ?? "", _power_on_mode ?? "", Maps.convert_to_proxy_string_string(_power_on_config)).parse()); } /// /// Set the CPU features to be used after a reboot, if the given features string is valid. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host /// The features string (32 hexadecimal digits) public static void set_cpu_features(Session session, string _host, string _features) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_cpu_features(session.opaque_ref, _host, _features); else session.proxy.host_set_cpu_features(session.opaque_ref, _host ?? "", _features ?? "").parse(); } /// /// Remove the feature mask, such that after a reboot all features of the CPU are enabled. /// First published in XenServer 5.6. /// /// The session /// The opaque_ref of the given host public static void reset_cpu_features(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_reset_cpu_features(session.opaque_ref, _host); else session.proxy.host_reset_cpu_features(session.opaque_ref, _host ?? "").parse(); } /// /// Enable the use of a local SR for caching purposes /// First published in XenServer 5.6 FP1. /// /// The session /// The opaque_ref of the given host /// The SR to use as a local cache public static void enable_local_storage_caching(Session session, string _host, string _sr) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_enable_local_storage_caching(session.opaque_ref, _host, _sr); else session.proxy.host_enable_local_storage_caching(session.opaque_ref, _host ?? "", _sr ?? "").parse(); } /// /// Disable the use of a local SR for caching purposes /// First published in XenServer 5.6 FP1. /// /// The session /// The opaque_ref of the given host public static void disable_local_storage_caching(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_disable_local_storage_caching(session.opaque_ref, _host); else session.proxy.host_disable_local_storage_caching(session.opaque_ref, _host ?? "").parse(); } /// /// Prepare to receive a VM, returning a token which can be passed to VM.migrate. /// First published in XenServer 6.1. /// /// The session /// The opaque_ref of the given host /// The network through which migration traffic should be received. /// Extra configuration operations public static Dictionary migrate_receive(Session session, string _host, string _network, Dictionary _options) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_migrate_receive(session.opaque_ref, _host, _network, _options); else return Maps.convert_from_proxy_string_string(session.proxy.host_migrate_receive(session.opaque_ref, _host ?? "", _network ?? "", Maps.convert_to_proxy_string_string(_options)).parse()); } /// /// Prepare to receive a VM, returning a token which can be passed to VM.migrate. /// First published in XenServer 6.1. /// /// The session /// The opaque_ref of the given host /// The network through which migration traffic should be received. /// Extra configuration operations public static XenRef async_migrate_receive(Session session, string _host, string _network, Dictionary _options) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_migrate_receive(session.opaque_ref, _host, _network, _options); else return XenRef.Create(session.proxy.async_host_migrate_receive(session.opaque_ref, _host ?? "", _network ?? "", Maps.convert_to_proxy_string_string(_options)).parse()); } /// /// Declare that a host is dead. This is a dangerous operation, and should only be called if the administrator is absolutely sure the host is definitely dead /// First published in XenServer 6.2. /// /// The session /// The opaque_ref of the given host public static void declare_dead(Session session, string _host) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_declare_dead(session.opaque_ref, _host); else session.proxy.host_declare_dead(session.opaque_ref, _host ?? "").parse(); } /// /// Declare that a host is dead. This is a dangerous operation, and should only be called if the administrator is absolutely sure the host is definitely dead /// First published in XenServer 6.2. /// /// The session /// The opaque_ref of the given host public static XenRef async_declare_dead(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_declare_dead(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_declare_dead(session.opaque_ref, _host ?? "").parse()); } /// /// Enable console output to the physical display device next time this host boots /// First published in XenServer 6.5 SP1. /// /// The session /// The opaque_ref of the given host public static host_display enable_display(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_enable_display(session.opaque_ref, _host); else return (host_display)Helper.EnumParseDefault(typeof(host_display), (string)session.proxy.host_enable_display(session.opaque_ref, _host ?? "").parse()); } /// /// Enable console output to the physical display device next time this host boots /// First published in XenServer 6.5 SP1. /// /// The session /// The opaque_ref of the given host public static XenRef async_enable_display(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_enable_display(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_enable_display(session.opaque_ref, _host ?? "").parse()); } /// /// Disable console output to the physical display device next time this host boots /// First published in XenServer 6.5 SP1. /// /// The session /// The opaque_ref of the given host public static host_display disable_display(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_disable_display(session.opaque_ref, _host); else return (host_display)Helper.EnumParseDefault(typeof(host_display), (string)session.proxy.host_disable_display(session.opaque_ref, _host ?? "").parse()); } /// /// Disable console output to the physical display device next time this host boots /// First published in XenServer 6.5 SP1. /// /// The session /// The opaque_ref of the given host public static XenRef async_disable_display(Session session, string _host) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_disable_display(session.opaque_ref, _host); else return XenRef.Create(session.proxy.async_host_disable_display(session.opaque_ref, _host ?? "").parse()); } /// /// Enable/disable SSLv3 for interoperability with older versions of XenServer. When this is set to a different value, the host immediately restarts its SSL/TLS listening service; typically this takes less than a second but existing connections to it will be broken. XenAPI login sessions will remain valid. /// First published in XenServer 7.0. /// /// The session /// The opaque_ref of the given host /// True to allow SSLv3 and ciphersuites as used in old XenServer versions public static void set_ssl_legacy(Session session, string _host, bool _value) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_ssl_legacy(session.opaque_ref, _host, _value); else session.proxy.host_set_ssl_legacy(session.opaque_ref, _host ?? "", _value).parse(); } /// /// Enable/disable SSLv3 for interoperability with older versions of XenServer. When this is set to a different value, the host immediately restarts its SSL/TLS listening service; typically this takes less than a second but existing connections to it will be broken. XenAPI login sessions will remain valid. /// First published in XenServer 7.0. /// /// The session /// The opaque_ref of the given host /// True to allow SSLv3 and ciphersuites as used in old XenServer versions public static XenRef async_set_ssl_legacy(Session session, string _host, bool _value) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_set_ssl_legacy(session.opaque_ref, _host, _value); else return XenRef.Create(session.proxy.async_host_set_ssl_legacy(session.opaque_ref, _host ?? "", _value).parse()); } /// /// Sets the initiator IQN for the host /// First published in Unreleased. /// /// The session /// The opaque_ref of the given host /// The value to which the IQN should be set public static void set_iscsi_iqn(Session session, string _host, string _value) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_iscsi_iqn(session.opaque_ref, _host, _value); else session.proxy.host_set_iscsi_iqn(session.opaque_ref, _host ?? "", _value ?? "").parse(); } /// /// Sets the initiator IQN for the host /// First published in Unreleased. /// /// The session /// The opaque_ref of the given host /// The value to which the IQN should be set public static XenRef async_set_iscsi_iqn(Session session, string _host, string _value) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_set_iscsi_iqn(session.opaque_ref, _host, _value); else return XenRef.Create(session.proxy.async_host_set_iscsi_iqn(session.opaque_ref, _host ?? "", _value ?? "").parse()); } /// /// Specifies whether multipathing is enabled /// First published in Unreleased. /// /// The session /// The opaque_ref of the given host /// Whether multipathing should be enabled public static void set_multipathing(Session session, string _host, bool _value) { if (session.JsonRpcClient != null) session.JsonRpcClient.host_set_multipathing(session.opaque_ref, _host, _value); else session.proxy.host_set_multipathing(session.opaque_ref, _host ?? "", _value).parse(); } /// /// Specifies whether multipathing is enabled /// First published in Unreleased. /// /// The session /// The opaque_ref of the given host /// Whether multipathing should be enabled public static XenRef async_set_multipathing(Session session, string _host, bool _value) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_host_set_multipathing(session.opaque_ref, _host, _value); else return XenRef.Create(session.proxy.async_host_set_multipathing(session.opaque_ref, _host ?? "", _value).parse()); } /// /// Return a list of all the hosts known to the system. /// First published in XenServer 4.0. /// /// The session public static List> get_all(Session session) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_all(session.opaque_ref); else return XenRef.Create(session.proxy.host_get_all(session.opaque_ref).parse()); } /// /// Get all the host Records at once, in a single XML RPC call /// First published in XenServer 4.0. /// /// The session public static Dictionary, Host> get_all_records(Session session) { if (session.JsonRpcClient != null) return session.JsonRpcClient.host_get_all_records(session.opaque_ref); else return XenRef.Create(session.proxy.host_get_all_records(session.opaque_ref).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 = ""; /// /// a human-readable 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 = ""; /// /// a notes field containing human-readable 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 = ""; /// /// Virtualization memory overhead (bytes). /// public virtual long memory_overhead { get { return _memory_overhead; } set { if (!Helper.AreEqual(value, _memory_overhead)) { _memory_overhead = value; Changed = true; NotifyPropertyChanged("memory_overhead"); } } } private long _memory_overhead = 0; /// /// 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 = new List() {}; /// /// 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 = new Dictionary() {}; /// /// major version number /// public virtual long API_version_major { get { return _API_version_major; } set { if (!Helper.AreEqual(value, _API_version_major)) { _API_version_major = value; Changed = true; NotifyPropertyChanged("API_version_major"); } } } private long _API_version_major; /// /// minor version number /// public virtual long API_version_minor { get { return _API_version_minor; } set { if (!Helper.AreEqual(value, _API_version_minor)) { _API_version_minor = value; Changed = true; NotifyPropertyChanged("API_version_minor"); } } } private long _API_version_minor; /// /// identification of vendor /// public virtual string API_version_vendor { get { return _API_version_vendor; } set { if (!Helper.AreEqual(value, _API_version_vendor)) { _API_version_vendor = value; Changed = true; NotifyPropertyChanged("API_version_vendor"); } } } private string _API_version_vendor = ""; /// /// details of vendor implementation /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary API_version_vendor_implementation { get { return _API_version_vendor_implementation; } set { if (!Helper.AreEqual(value, _API_version_vendor_implementation)) { _API_version_vendor_implementation = value; Changed = true; NotifyPropertyChanged("API_version_vendor_implementation"); } } } private Dictionary _API_version_vendor_implementation = new Dictionary() {}; /// /// True if the host is currently enabled /// public virtual bool enabled { get { return _enabled; } set { if (!Helper.AreEqual(value, _enabled)) { _enabled = value; Changed = true; NotifyPropertyChanged("enabled"); } } } private bool _enabled; /// /// version strings /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary software_version { get { return _software_version; } set { if (!Helper.AreEqual(value, _software_version)) { _software_version = value; Changed = true; NotifyPropertyChanged("software_version"); } } } private Dictionary _software_version = new Dictionary() {}; /// /// additional configuration /// [JsonConverter(typeof(StringStringMapConverter))] 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 = new Dictionary() {}; /// /// Xen capabilities /// public virtual string[] capabilities { get { return _capabilities; } set { if (!Helper.AreEqual(value, _capabilities)) { _capabilities = value; Changed = true; NotifyPropertyChanged("capabilities"); } } } private string[] _capabilities = {}; /// /// The CPU configuration on this host. May contain keys such as "nr_nodes", "sockets_per_node", "cores_per_socket", or "threads_per_core" /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary cpu_configuration { get { return _cpu_configuration; } set { if (!Helper.AreEqual(value, _cpu_configuration)) { _cpu_configuration = value; Changed = true; NotifyPropertyChanged("cpu_configuration"); } } } private Dictionary _cpu_configuration = new Dictionary() {}; /// /// Scheduler policy currently in force on this host /// public virtual string sched_policy { get { return _sched_policy; } set { if (!Helper.AreEqual(value, _sched_policy)) { _sched_policy = value; Changed = true; NotifyPropertyChanged("sched_policy"); } } } private string _sched_policy = ""; /// /// a list of the bootloaders installed on the machine /// public virtual string[] supported_bootloaders { get { return _supported_bootloaders; } set { if (!Helper.AreEqual(value, _supported_bootloaders)) { _supported_bootloaders = value; Changed = true; NotifyPropertyChanged("supported_bootloaders"); } } } private string[] _supported_bootloaders = {}; /// /// list of VMs currently resident on host /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> resident_VMs { get { return _resident_VMs; } set { if (!Helper.AreEqual(value, _resident_VMs)) { _resident_VMs = value; Changed = true; NotifyPropertyChanged("resident_VMs"); } } } private List> _resident_VMs = new List>() {}; /// /// logging configuration /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary logging { get { return _logging; } set { if (!Helper.AreEqual(value, _logging)) { _logging = value; Changed = true; NotifyPropertyChanged("logging"); } } } private Dictionary _logging = new Dictionary() {}; /// /// physical network interfaces /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> PIFs { get { return _PIFs; } set { if (!Helper.AreEqual(value, _PIFs)) { _PIFs = value; Changed = true; NotifyPropertyChanged("PIFs"); } } } private List> _PIFs = new List>() {}; /// /// The SR in which VDIs for suspend images are created /// [JsonConverter(typeof(XenRefConverter))] 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 = new XenRef(Helper.NullOpaqueRef); /// /// The SR in which VDIs for crash dumps are created /// [JsonConverter(typeof(XenRefConverter))] 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 = new XenRef(Helper.NullOpaqueRef); /// /// Set of host crash dumps /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> crashdumps { get { return _crashdumps; } set { if (!Helper.AreEqual(value, _crashdumps)) { _crashdumps = value; Changed = true; NotifyPropertyChanged("crashdumps"); } } } private List> _crashdumps = new List>() {}; /// /// Set of host patches /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> patches { get { return _patches; } set { if (!Helper.AreEqual(value, _patches)) { _patches = value; Changed = true; NotifyPropertyChanged("patches"); } } } private List> _patches = new List>() {}; /// /// Set of updates /// First published in XenServer 7.1. /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> updates { get { return _updates; } set { if (!Helper.AreEqual(value, _updates)) { _updates = value; Changed = true; NotifyPropertyChanged("updates"); } } } private List> _updates = new List>() {}; /// /// physical blockdevices /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> PBDs { get { return _PBDs; } set { if (!Helper.AreEqual(value, _PBDs)) { _PBDs = value; Changed = true; NotifyPropertyChanged("PBDs"); } } } private List> _PBDs = new List>() {}; /// /// The physical CPUs on this host /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> host_CPUs { get { return _host_CPUs; } set { if (!Helper.AreEqual(value, _host_CPUs)) { _host_CPUs = value; Changed = true; NotifyPropertyChanged("host_CPUs"); } } } private List> _host_CPUs = new List>() {}; /// /// Details about the physical CPUs on this host /// First published in XenServer 5.6. /// [JsonConverter(typeof(StringStringMapConverter))] 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 = new Dictionary() {}; /// /// The hostname of this host /// public virtual string hostname { get { return _hostname; } set { if (!Helper.AreEqual(value, _hostname)) { _hostname = value; Changed = true; NotifyPropertyChanged("hostname"); } } } private string _hostname = ""; /// /// The address by which this host can be contacted from any other host in the pool /// public virtual string address { get { return _address; } set { if (!Helper.AreEqual(value, _address)) { _address = value; Changed = true; NotifyPropertyChanged("address"); } } } private string _address = ""; /// /// metrics associated with this host /// [JsonConverter(typeof(XenRefConverter))] public virtual XenRef metrics { get { return _metrics; } set { if (!Helper.AreEqual(value, _metrics)) { _metrics = value; Changed = true; NotifyPropertyChanged("metrics"); } } } private XenRef _metrics = new XenRef(Helper.NullOpaqueRef); /// /// State of the current license /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary license_params { get { return _license_params; } set { if (!Helper.AreEqual(value, _license_params)) { _license_params = value; Changed = true; NotifyPropertyChanged("license_params"); } } } private Dictionary _license_params = new Dictionary() {}; /// /// The set of statefiles accessible from this host /// 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 = {}; /// /// The set of hosts visible via the network from this host /// First published in XenServer 5.0. /// public virtual string[] ha_network_peers { get { return _ha_network_peers; } set { if (!Helper.AreEqual(value, _ha_network_peers)) { _ha_network_peers = value; Changed = true; NotifyPropertyChanged("ha_network_peers"); } } } private string[] _ha_network_peers = {}; /// /// Binary blobs associated with this host /// First published in XenServer 5.0. /// [JsonConverter(typeof(StringXenRefMapConverter))] public virtual Dictionary> blobs { get { return _blobs; } set { if (!Helper.AreEqual(value, _blobs)) { _blobs = value; Changed = true; NotifyPropertyChanged("blobs"); } } } private Dictionary> _blobs = new Dictionary>() {}; /// /// 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 = {}; /// /// type of external authentication service configured; empty if none configured. /// First published in XenServer 5.5. /// public virtual string external_auth_type { get { return _external_auth_type; } set { if (!Helper.AreEqual(value, _external_auth_type)) { _external_auth_type = value; Changed = true; NotifyPropertyChanged("external_auth_type"); } } } private string _external_auth_type = ""; /// /// name of external authentication service configured; empty if none configured. /// First published in XenServer 5.5. /// public virtual string external_auth_service_name { get { return _external_auth_service_name; } set { if (!Helper.AreEqual(value, _external_auth_service_name)) { _external_auth_service_name = value; Changed = true; NotifyPropertyChanged("external_auth_service_name"); } } } private string _external_auth_service_name = ""; /// /// configuration specific to external authentication service /// First published in XenServer 5.5. /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary external_auth_configuration { get { return _external_auth_configuration; } set { if (!Helper.AreEqual(value, _external_auth_configuration)) { _external_auth_configuration = value; Changed = true; NotifyPropertyChanged("external_auth_configuration"); } } } private Dictionary _external_auth_configuration = new Dictionary() {}; /// /// Product edition /// First published in XenServer 5.6. /// public virtual string edition { get { return _edition; } set { if (!Helper.AreEqual(value, _edition)) { _edition = value; Changed = true; NotifyPropertyChanged("edition"); } } } private string _edition = ""; /// /// Contact information of the license server /// First published in XenServer 5.6. /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary license_server { get { return _license_server; } set { if (!Helper.AreEqual(value, _license_server)) { _license_server = value; Changed = true; NotifyPropertyChanged("license_server"); } } } private Dictionary _license_server = new Dictionary() {{"address", "localhost"}, {"port", "27000"}}; /// /// BIOS strings /// First published in XenServer 5.6. /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary bios_strings { get { return _bios_strings; } set { if (!Helper.AreEqual(value, _bios_strings)) { _bios_strings = value; Changed = true; NotifyPropertyChanged("bios_strings"); } } } private Dictionary _bios_strings = new Dictionary() {}; /// /// The power on mode /// First published in XenServer 5.6. /// public virtual string power_on_mode { get { return _power_on_mode; } set { if (!Helper.AreEqual(value, _power_on_mode)) { _power_on_mode = value; Changed = true; NotifyPropertyChanged("power_on_mode"); } } } private string _power_on_mode = ""; /// /// The power on config /// First published in XenServer 5.6. /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary power_on_config { get { return _power_on_config; } set { if (!Helper.AreEqual(value, _power_on_config)) { _power_on_config = value; Changed = true; NotifyPropertyChanged("power_on_config"); } } } private Dictionary _power_on_config = new Dictionary() {}; /// /// The SR that is used as a local cache /// First published in XenServer 5.6 FP1. /// [JsonConverter(typeof(XenRefConverter))] public virtual XenRef local_cache_sr { get { return _local_cache_sr; } set { if (!Helper.AreEqual(value, _local_cache_sr)) { _local_cache_sr = value; Changed = true; NotifyPropertyChanged("local_cache_sr"); } } } private XenRef _local_cache_sr = new XenRef("OpaqueRef:NULL"); /// /// Information about chipset features /// First published in XenServer 6.0. /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary chipset_info { get { return _chipset_info; } set { if (!Helper.AreEqual(value, _chipset_info)) { _chipset_info = value; Changed = true; NotifyPropertyChanged("chipset_info"); } } } private Dictionary _chipset_info = new Dictionary() {}; /// /// List of PCI devices in the host /// First published in XenServer 6.0. /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> PCIs { get { return _PCIs; } set { if (!Helper.AreEqual(value, _PCIs)) { _PCIs = value; Changed = true; NotifyPropertyChanged("PCIs"); } } } private List> _PCIs = new List>() {}; /// /// List of physical GPUs in the host /// First published in XenServer 6.0. /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> PGPUs { get { return _PGPUs; } set { if (!Helper.AreEqual(value, _PGPUs)) { _PGPUs = value; Changed = true; NotifyPropertyChanged("PGPUs"); } } } private List> _PGPUs = new List>() {}; /// /// List of physical USBs in the host /// First published in XenServer 7.3. /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> PUSBs { get { return _PUSBs; } set { if (!Helper.AreEqual(value, _PUSBs)) { _PUSBs = value; Changed = true; NotifyPropertyChanged("PUSBs"); } } } private List> _PUSBs = new List>() {}; /// /// Allow SSLv3 protocol and ciphersuites as used by older XenServers. This controls both incoming and outgoing connections. When this is set to a different value, the host immediately restarts its SSL/TLS listening service; typically this takes less than a second but existing connections to it will be broken. XenAPI login sessions will remain valid. /// First published in XenServer 7.0. /// public virtual bool ssl_legacy { get { return _ssl_legacy; } set { if (!Helper.AreEqual(value, _ssl_legacy)) { _ssl_legacy = value; Changed = true; NotifyPropertyChanged("ssl_legacy"); } } } private bool _ssl_legacy = true; /// /// VCPUs params to apply to all resident guests /// First published in XenServer 6.1. /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary guest_VCPUs_params { get { return _guest_VCPUs_params; } set { if (!Helper.AreEqual(value, _guest_VCPUs_params)) { _guest_VCPUs_params = value; Changed = true; NotifyPropertyChanged("guest_VCPUs_params"); } } } private Dictionary _guest_VCPUs_params = new Dictionary() {}; /// /// indicates whether the host is configured to output its console to a physical display device /// First published in XenServer 6.5 SP1. /// [JsonConverter(typeof(host_displayConverter))] public virtual host_display display { get { return _display; } set { if (!Helper.AreEqual(value, _display)) { _display = value; Changed = true; NotifyPropertyChanged("display"); } } } private host_display _display = host_display.enabled; /// /// The set of versions of the virtual hardware platform that the host can offer to its guests /// First published in XenServer 6.5 SP1. /// public virtual long[] virtual_hardware_platform_versions { get { return _virtual_hardware_platform_versions; } set { if (!Helper.AreEqual(value, _virtual_hardware_platform_versions)) { _virtual_hardware_platform_versions = value; Changed = true; NotifyPropertyChanged("virtual_hardware_platform_versions"); } } } private long[] _virtual_hardware_platform_versions = {0}; /// /// The control domain (domain 0) /// First published in XenServer 7.1. /// [JsonConverter(typeof(XenRefConverter))] public virtual XenRef control_domain { get { return _control_domain; } set { if (!Helper.AreEqual(value, _control_domain)) { _control_domain = value; Changed = true; NotifyPropertyChanged("control_domain"); } } } private XenRef _control_domain = new XenRef("OpaqueRef:NULL"); /// /// List of updates which require reboot /// First published in XenServer 7.1. /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> updates_requiring_reboot { get { return _updates_requiring_reboot; } set { if (!Helper.AreEqual(value, _updates_requiring_reboot)) { _updates_requiring_reboot = value; Changed = true; NotifyPropertyChanged("updates_requiring_reboot"); } } } private List> _updates_requiring_reboot = new List>() {}; /// /// List of features available on this host /// First published in XenServer 7.2. /// [JsonConverter(typeof(XenRefListConverter))] public virtual List> features { get { return _features; } set { if (!Helper.AreEqual(value, _features)) { _features = value; Changed = true; NotifyPropertyChanged("features"); } } } private List> _features = new List>() {}; /// /// The initiator IQN for the host /// First published in Unreleased. /// public virtual string iscsi_iqn { get { return _iscsi_iqn; } set { if (!Helper.AreEqual(value, _iscsi_iqn)) { _iscsi_iqn = value; Changed = true; NotifyPropertyChanged("iscsi_iqn"); } } } private string _iscsi_iqn = ""; /// /// Specifies whether multipathing is enabled /// First published in Unreleased. /// public virtual bool multipathing { get { return _multipathing; } set { if (!Helper.AreEqual(value, _multipathing)) { _multipathing = value; Changed = true; NotifyPropertyChanged("multipathing"); } } } private bool _multipathing = false; } }