use std::sync::Arc;
use crate::core::client::{VimClient, Result};
#[derive(Clone)]
pub struct EventHistoryCollector {
client: Arc<dyn VimClient>,
mo_id: String,
}
impl EventHistoryCollector {
pub fn new(client: Arc<dyn VimClient>, mo_id: &str) -> Self {
Self {
client,
mo_id: mo_id.to_string(),
}
}
pub async fn read_next_events(&self, max_count: i32) -> Result<Option<Vec<crate::types::structs::Event>>> {
let input = ReadNextEventsRequestType {max_count, };
let bytes_opt = self.client.invoke_optional("", "EventHistoryCollector", &self.mo_id, "ReadNextEvents", Some(&input)).await?;
match bytes_opt {
Some(ref b) => Ok(Some(crate::core::client::unmarshal_array(self.client.transport(), b)?)),
None => Ok(None),
}
}
pub async fn read_previous_events(&self, max_count: i32) -> Result<Option<Vec<crate::types::structs::Event>>> {
let input = ReadPreviousEventsRequestType {max_count, };
let bytes_opt = self.client.invoke_optional("", "EventHistoryCollector", &self.mo_id, "ReadPreviousEvents", Some(&input)).await?;
match bytes_opt {
Some(ref b) => Ok(Some(crate::core::client::unmarshal_array(self.client.transport(), b)?)),
None => Ok(None),
}
}
pub async fn destroy_collector(&self) -> Result<()> {
self.client.invoke_void("", "EventHistoryCollector", &self.mo_id, "DestroyCollector", None).await
}
pub async fn reset_collector(&self) -> Result<()> {
self.client.invoke_void("", "EventHistoryCollector", &self.mo_id, "ResetCollector", None).await
}
pub async fn rewind_collector(&self) -> Result<()> {
self.client.invoke_void("", "EventHistoryCollector", &self.mo_id, "RewindCollector", None).await
}
pub async fn set_collector_page_size(&self, max_count: i32) -> Result<()> {
let input = SetCollectorPageSizeRequestType {max_count, };
self.client.invoke_void("", "EventHistoryCollector", &self.mo_id, "SetCollectorPageSize", Some(&input)).await
}
pub async fn filter(&self) -> Result<crate::types::vim_any::VimAny> {
let pv_opt = self.client.fetch_property_raw("", "EventHistoryCollector", &self.mo_id, "filter").await?;
let pv = pv_opt.ok_or_else(|| crate::core::client::VimError::ParseError("property filter was empty".to_string()))?;
let result: crate::types::vim_any::VimAny = crate::core::client::extract_property(pv)?;
Ok(result)
}
pub async fn initialized(&self) -> Result<Option<bool>> {
let pv_opt = self.client.fetch_property_raw("", "EventHistoryCollector", &self.mo_id, "initialized").await?;
match pv_opt {
Some(pv) => Ok(Some(crate::core::client::extract_property(pv)?)),
None => Ok(None),
}
}
pub async fn latest_page(&self) -> Result<Option<Vec<crate::types::structs::Event>>> {
let pv_opt = self.client.fetch_property_raw("", "EventHistoryCollector", &self.mo_id, "latestPage").await?;
match pv_opt {
Some(pv) => Ok(Some(crate::core::client::extract_property(pv)?)),
None => Ok(None),
}
}
}
struct ReadNextEventsRequestType {
max_count: i32,
}
impl miniserde::Serialize for ReadNextEventsRequestType {
fn begin(&self) -> miniserde::ser::Fragment<'_> {
miniserde::ser::Fragment::Map(Box::new(ReadNextEventsRequestTypeSer { data: self, seq: 0 }))
}
}
struct ReadNextEventsRequestTypeSer<'b> {
data: &'b ReadNextEventsRequestType,
seq: usize,
}
impl<'b> miniserde::ser::Map for ReadNextEventsRequestTypeSer<'b> {
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"), &"ReadNextEventsRequestType")),
1 => return Some((std::borrow::Cow::Borrowed("maxCount"), &self.data.max_count as &dyn miniserde::Serialize)),
_ => return None,
}
}
}
struct ReadPreviousEventsRequestType {
max_count: i32,
}
impl miniserde::Serialize for ReadPreviousEventsRequestType {
fn begin(&self) -> miniserde::ser::Fragment<'_> {
miniserde::ser::Fragment::Map(Box::new(ReadPreviousEventsRequestTypeSer { data: self, seq: 0 }))
}
}
struct ReadPreviousEventsRequestTypeSer<'b> {
data: &'b ReadPreviousEventsRequestType,
seq: usize,
}
impl<'b> miniserde::ser::Map for ReadPreviousEventsRequestTypeSer<'b> {
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"), &"ReadPreviousEventsRequestType")),
1 => return Some((std::borrow::Cow::Borrowed("maxCount"), &self.data.max_count as &dyn miniserde::Serialize)),
_ => return None,
}
}
}
struct SetCollectorPageSizeRequestType {
max_count: i32,
}
impl miniserde::Serialize for SetCollectorPageSizeRequestType {
fn begin(&self) -> miniserde::ser::Fragment<'_> {
miniserde::ser::Fragment::Map(Box::new(SetCollectorPageSizeRequestTypeSer { data: self, seq: 0 }))
}
}
struct SetCollectorPageSizeRequestTypeSer<'b> {
data: &'b SetCollectorPageSizeRequestType,
seq: usize,
}
impl<'b> miniserde::ser::Map for SetCollectorPageSizeRequestTypeSer<'b> {
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"), &"SetCollectorPageSizeRequestType")),
1 => return Some((std::borrow::Cow::Borrowed("maxCount"), &self.data.max_count as &dyn miniserde::Serialize)),
_ => return None,
}
}
}