use std::sync::Arc;
use crate::core::client::{VimClient, Result};
#[derive(Clone)]
pub struct TaskManager {
client: Arc<dyn VimClient>,
mo_id: String,
}
impl TaskManager {
pub fn new(client: Arc<dyn VimClient>, mo_id: &str) -> Self {
Self {
client,
mo_id: mo_id.to_string(),
}
}
pub async fn read_next_tasks_by_view_spec(&self, view_spec: &dyn crate::types::traits::TaskManagerTaskViewSpecTrait, filter_spec: &crate::types::structs::TaskFilterSpec, info_filter_spec: Option<&crate::types::structs::TaskInfoFilterSpec>) -> Result<Option<Vec<crate::types::structs::TaskInfo>>> {
let input = ReadNextTasksByViewSpecRequestType {view_spec, filter_spec, info_filter_spec, };
let bytes_opt = self.client.invoke_optional("", "TaskManager", &self.mo_id, "ReadNextTasksByViewSpec", 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 create_collector_for_tasks(&self, filter: &crate::types::structs::TaskFilterSpec) -> Result<crate::types::structs::ManagedObjectReference> {
let input = CreateCollectorForTasksRequestType {filter, };
let bytes = self.client.invoke("", "TaskManager", &self.mo_id, "CreateCollectorForTasks", Some(&input)).await?;
let result: crate::types::structs::ManagedObjectReference = crate::core::client::unmarshal(self.client.transport(), &bytes)?;
Ok(result)
}
pub async fn create_collector_with_info_filter_for_tasks(&self, filter: &crate::types::structs::TaskFilterSpec, info_filter: Option<&crate::types::structs::TaskInfoFilterSpec>) -> Result<crate::types::structs::ManagedObjectReference> {
let input = CreateCollectorWithInfoFilterForTasksRequestType {filter, info_filter, };
let bytes = self.client.invoke("", "TaskManager", &self.mo_id, "CreateCollectorWithInfoFilterForTasks", Some(&input)).await?;
let result: crate::types::structs::ManagedObjectReference = crate::core::client::unmarshal(self.client.transport(), &bytes)?;
Ok(result)
}
pub async fn create_task(&self, obj: &crate::types::structs::ManagedObjectReference, task_type_id: &str, initiated_by: Option<&str>, cancelable: bool, parent_task_key: Option<&str>, activation_id: Option<&str>) -> Result<crate::types::structs::TaskInfo> {
let input = CreateTaskRequestType {obj, task_type_id, initiated_by, cancelable, parent_task_key, activation_id, };
let bytes = self.client.invoke("", "TaskManager", &self.mo_id, "CreateTask", Some(&input)).await?;
let result: crate::types::structs::TaskInfo = crate::core::client::unmarshal(self.client.transport(), &bytes)?;
Ok(result)
}
pub async fn description(&self) -> Result<crate::types::structs::TaskDescription> {
let pv_opt = self.client.fetch_property_raw("", "TaskManager", &self.mo_id, "description").await?;
let pv = pv_opt.ok_or_else(|| crate::core::client::VimError::ParseError("property description was empty".to_string()))?;
let result: crate::types::structs::TaskDescription = crate::core::client::extract_property(pv)?;
Ok(result)
}
pub async fn max_collector(&self) -> Result<i32> {
let pv_opt = self.client.fetch_property_raw("", "TaskManager", &self.mo_id, "maxCollector").await?;
let pv = pv_opt.ok_or_else(|| crate::core::client::VimError::ParseError("property maxCollector was empty".to_string()))?;
let result: i32 = crate::core::client::extract_property(pv)?;
Ok(result)
}
pub async fn recent_task(&self) -> Result<Option<Vec<crate::types::structs::ManagedObjectReference>>> {
let pv_opt = self.client.fetch_property_raw("", "TaskManager", &self.mo_id, "recentTask").await?;
match pv_opt {
Some(pv) => Ok(Some(crate::core::client::extract_property(pv)?)),
None => Ok(None),
}
}
}
struct ReadNextTasksByViewSpecRequestType<'a> {
view_spec: &'a dyn crate::types::traits::TaskManagerTaskViewSpecTrait,
filter_spec: &'a crate::types::structs::TaskFilterSpec,
info_filter_spec: Option<&'a crate::types::structs::TaskInfoFilterSpec>,
}
impl<'a> miniserde::Serialize for ReadNextTasksByViewSpecRequestType<'a> {
fn begin(&self) -> miniserde::ser::Fragment<'_> {
miniserde::ser::Fragment::Map(Box::new(ReadNextTasksByViewSpecRequestTypeSer { data: self, seq: 0 }))
}
}
struct ReadNextTasksByViewSpecRequestTypeSer<'b, 'a> {
data: &'b ReadNextTasksByViewSpecRequestType<'a>,
seq: usize,
}
impl<'b, 'a> miniserde::ser::Map for ReadNextTasksByViewSpecRequestTypeSer<'b, 'a> {
fn next(&mut self) -> Option<(std::borrow::Cow<'_, str>, &dyn miniserde::Serialize)> {
loop {
let seq = self.seq;
self.seq += 1;
match seq {
0 => return Some((std::borrow::Cow::Borrowed("_typeName"), &"ReadNextTasksByViewSpecRequestType")),
1 => return Some((std::borrow::Cow::Borrowed("viewSpec"), &self.data.view_spec as &dyn miniserde::Serialize)),
2 => return Some((std::borrow::Cow::Borrowed("filterSpec"), &self.data.filter_spec as &dyn miniserde::Serialize)),
3 => {
let Some(ref val) = self.data.info_filter_spec else { continue; };
return Some((std::borrow::Cow::Borrowed("infoFilterSpec"), val as &dyn miniserde::Serialize));
}
_ => return None,
}
}
}
}
struct CreateCollectorForTasksRequestType<'a> {
filter: &'a crate::types::structs::TaskFilterSpec,
}
impl<'a> miniserde::Serialize for CreateCollectorForTasksRequestType<'a> {
fn begin(&self) -> miniserde::ser::Fragment<'_> {
miniserde::ser::Fragment::Map(Box::new(CreateCollectorForTasksRequestTypeSer { data: self, seq: 0 }))
}
}
struct CreateCollectorForTasksRequestTypeSer<'b, 'a> {
data: &'b CreateCollectorForTasksRequestType<'a>,
seq: usize,
}
impl<'b, 'a> miniserde::ser::Map for CreateCollectorForTasksRequestTypeSer<'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"), &"CreateCollectorForTasksRequestType")),
1 => return Some((std::borrow::Cow::Borrowed("filter"), &self.data.filter as &dyn miniserde::Serialize)),
_ => return None,
}
}
}
struct CreateCollectorWithInfoFilterForTasksRequestType<'a> {
filter: &'a crate::types::structs::TaskFilterSpec,
info_filter: Option<&'a crate::types::structs::TaskInfoFilterSpec>,
}
impl<'a> miniserde::Serialize for CreateCollectorWithInfoFilterForTasksRequestType<'a> {
fn begin(&self) -> miniserde::ser::Fragment<'_> {
miniserde::ser::Fragment::Map(Box::new(CreateCollectorWithInfoFilterForTasksRequestTypeSer { data: self, seq: 0 }))
}
}
struct CreateCollectorWithInfoFilterForTasksRequestTypeSer<'b, 'a> {
data: &'b CreateCollectorWithInfoFilterForTasksRequestType<'a>,
seq: usize,
}
impl<'b, 'a> miniserde::ser::Map for CreateCollectorWithInfoFilterForTasksRequestTypeSer<'b, 'a> {
fn next(&mut self) -> Option<(std::borrow::Cow<'_, str>, &dyn miniserde::Serialize)> {
loop {
let seq = self.seq;
self.seq += 1;
match seq {
0 => return Some((std::borrow::Cow::Borrowed("_typeName"), &"CreateCollectorWithInfoFilterForTasksRequestType")),
1 => return Some((std::borrow::Cow::Borrowed("filter"), &self.data.filter as &dyn miniserde::Serialize)),
2 => {
let Some(ref val) = self.data.info_filter else { continue; };
return Some((std::borrow::Cow::Borrowed("infoFilter"), val as &dyn miniserde::Serialize));
}
_ => return None,
}
}
}
}
struct CreateTaskRequestType<'a> {
obj: &'a crate::types::structs::ManagedObjectReference,
task_type_id: &'a str,
initiated_by: Option<&'a str>,
cancelable: bool,
parent_task_key: Option<&'a str>,
activation_id: Option<&'a str>,
}
impl<'a> miniserde::Serialize for CreateTaskRequestType<'a> {
fn begin(&self) -> miniserde::ser::Fragment<'_> {
miniserde::ser::Fragment::Map(Box::new(CreateTaskRequestTypeSer { data: self, seq: 0 }))
}
}
struct CreateTaskRequestTypeSer<'b, 'a> {
data: &'b CreateTaskRequestType<'a>,
seq: usize,
}
impl<'b, 'a> miniserde::ser::Map for CreateTaskRequestTypeSer<'b, 'a> {
fn next(&mut self) -> Option<(std::borrow::Cow<'_, str>, &dyn miniserde::Serialize)> {
loop {
let seq = self.seq;
self.seq += 1;
match seq {
0 => return Some((std::borrow::Cow::Borrowed("_typeName"), &"CreateTaskRequestType")),
1 => return Some((std::borrow::Cow::Borrowed("obj"), &self.data.obj as &dyn miniserde::Serialize)),
2 => return Some((std::borrow::Cow::Borrowed("taskTypeId"), &self.data.task_type_id as &dyn miniserde::Serialize)),
3 => {
let Some(ref val) = self.data.initiated_by else { continue; };
return Some((std::borrow::Cow::Borrowed("initiatedBy"), val as &dyn miniserde::Serialize));
}
4 => return Some((std::borrow::Cow::Borrowed("cancelable"), &self.data.cancelable as &dyn miniserde::Serialize)),
5 => {
let Some(ref val) = self.data.parent_task_key else { continue; };
return Some((std::borrow::Cow::Borrowed("parentTaskKey"), val as &dyn miniserde::Serialize));
}
6 => {
let Some(ref val) = self.data.activation_id else { continue; };
return Some((std::borrow::Cow::Borrowed("activationId"), val as &dyn miniserde::Serialize));
}
_ => return None,
}
}
}
}