use http::Method;
use crate::Result;
use crate::api::ActionResponse;
use crate::types::{Collection, Manager, OdataId, ResetType, actions::ResetRequest};
#[cfg(feature = "_blocking")]
use crate::BlockingClient;
#[cfg(feature = "_async")]
use crate::Client;
#[derive(Debug, Clone, Copy)]
pub struct ManagersService<'a, C> {
client: &'a C,
}
impl<'a, C> ManagersService<'a, C> {
pub(crate) fn new(client: &'a C) -> Self {
Self { client }
}
}
#[cfg(feature = "_async")]
impl<'a> ManagersService<'a, Client> {
pub async fn list(&self) -> Result<Collection<OdataId>> {
let url = self.client.redfish_url(&["Managers"])?;
self.client.get_json(url).await
}
pub async fn get(&self, manager_id: &str) -> Result<Manager> {
let url = self.client.redfish_url(&["Managers", manager_id])?;
self.client.get_json(url).await
}
pub async fn reset(
&self,
manager_id: &str,
reset_type: ResetType,
) -> Result<ActionResponse<serde_json::Value>> {
let url = self
.client
.redfish_url(&["Managers", manager_id, "Actions", "Manager.Reset"])?;
let req = ResetRequest { reset_type };
let raw = self.client.post_json_raw(url.clone(), &req).await?;
ActionResponse::<serde_json::Value>::from_raw_json(
Method::POST,
&url,
raw,
self.client.body_snippet_limit(),
)
}
}
#[cfg(feature = "_blocking")]
impl<'a> ManagersService<'a, BlockingClient> {
pub fn list(&self) -> Result<Collection<OdataId>> {
let url = self.client.redfish_url(&["Managers"])?;
self.client.get_json(url)
}
pub fn get(&self, manager_id: &str) -> Result<Manager> {
let url = self.client.redfish_url(&["Managers", manager_id])?;
self.client.get_json(url)
}
pub fn reset(
&self,
manager_id: &str,
reset_type: ResetType,
) -> Result<ActionResponse<serde_json::Value>> {
let url = self
.client
.redfish_url(&["Managers", manager_id, "Actions", "Manager.Reset"])?;
let req = ResetRequest { reset_type };
let raw = self.client.post_json_raw(url.clone(), &req)?;
ActionResponse::<serde_json::Value>::from_raw_json(
Method::POST,
&url,
raw,
self.client.body_snippet_limit(),
)
}
}