use std::sync::Arc;
use crate::core::client::{VimClient, Result};
#[derive(Clone)]
pub struct HostAssignableHardwareManager {
client: Arc<dyn VimClient>,
mo_id: String,
}
impl HostAssignableHardwareManager {
pub fn new(client: Arc<dyn VimClient>, mo_id: &str) -> Self {
Self {
client,
mo_id: mo_id.to_string(),
}
}
pub async fn download_description_tree(&self) -> Result<Vec<u8>> {
let bytes = self.client.invoke("", "HostAssignableHardwareManager", &self.mo_id, "DownloadDescriptionTree", None).await?;
let result: Vec<u8> = crate::core::client::unmarshal(self.client.transport(), &bytes)?;
Ok(result)
}
pub async fn retrieve_dynamic_passthrough_info(&self) -> Result<Option<Vec<crate::types::structs::VirtualMachineDynamicPassthroughInfo>>> {
let bytes_opt = self.client.invoke_optional("", "HostAssignableHardwareManager", &self.mo_id, "RetrieveDynamicPassthroughInfo", None).await?;
match bytes_opt {
Some(ref b) => Ok(Some(crate::core::client::unmarshal_array(self.client.transport(), b)?)),
None => Ok(None),
}
}
pub async fn retrieve_vendor_device_group_info(&self) -> Result<Option<Vec<crate::types::structs::VirtualMachineVendorDeviceGroupInfo>>> {
let bytes_opt = self.client.invoke_optional("", "HostAssignableHardwareManager", &self.mo_id, "RetrieveVendorDeviceGroupInfo", None).await?;
match bytes_opt {
Some(ref b) => Ok(Some(crate::core::client::unmarshal_array(self.client.transport(), b)?)),
None => Ok(None),
}
}
pub async fn update_assignable_hardware_config(&self, config: &crate::types::structs::HostAssignableHardwareConfig) -> Result<()> {
let input = UpdateAssignableHardwareConfigRequestType {config, };
self.client.invoke_void("", "HostAssignableHardwareManager", &self.mo_id, "UpdateAssignableHardwareConfig", Some(&input)).await
}
pub async fn binding(&self) -> Result<Option<Vec<crate::types::structs::HostAssignableHardwareBinding>>> {
let pv_opt = self.client.fetch_property_raw("", "HostAssignableHardwareManager", &self.mo_id, "binding").await?;
match pv_opt {
Some(pv) => Ok(Some(crate::core::client::extract_property(pv)?)),
None => Ok(None),
}
}
pub async fn config(&self) -> Result<crate::types::structs::HostAssignableHardwareConfig> {
let pv_opt = self.client.fetch_property_raw("", "HostAssignableHardwareManager", &self.mo_id, "config").await?;
let pv = pv_opt.ok_or_else(|| crate::core::client::VimError::ParseError("property config was empty".to_string()))?;
let result: crate::types::structs::HostAssignableHardwareConfig = crate::core::client::extract_property(pv)?;
Ok(result)
}
}
struct UpdateAssignableHardwareConfigRequestType<'a> {
config: &'a crate::types::structs::HostAssignableHardwareConfig,
}
impl<'a> miniserde::Serialize for UpdateAssignableHardwareConfigRequestType<'a> {
fn begin(&self) -> miniserde::ser::Fragment<'_> {
miniserde::ser::Fragment::Map(Box::new(UpdateAssignableHardwareConfigRequestTypeSer { data: self, seq: 0 }))
}
}
struct UpdateAssignableHardwareConfigRequestTypeSer<'b, 'a> {
data: &'b UpdateAssignableHardwareConfigRequestType<'a>,
seq: usize,
}
impl<'b, 'a> miniserde::ser::Map for UpdateAssignableHardwareConfigRequestTypeSer<'b, 'a> {
fn next(&mut self) -> Option<(std::borrow::Cow<'_, str>, &dyn miniserde::Serialize)> {
let seq = self.seq;
self.seq += 1;
match seq {
0 => return Some((std::borrow::Cow::Borrowed("_typeName"), &"UpdateAssignableHardwareConfigRequestType")),
1 => return Some((std::borrow::Cow::Borrowed("config"), &self.data.config as &dyn miniserde::Serialize)),
_ => return None,
}
}
}