icinga2_api/api/action/
schedule_downtime.rsuse serde::{Deserialize, Serialize};
use crate::serde::{
deserialize_icinga_timestamp, deserialize_optional_seconds_as_duration,
serialize_icinga_timestamp, serialize_optional_duration_as_seconds,
};
use crate::types::action::StatusResponse;
use crate::types::enums::downtime_child_options::IcingaDowntimeChildOptions;
use crate::types::enums::object_type::IcingaObjectType;
use crate::types::filter::IcingaFilter;
use crate::types::names::IcingaDowntimeName;
use crate::types::query::ResultsWrapper;
use crate::types::rest::{RestApiEndpoint, RestApiResponse};
#[derive(Debug, Clone, derive_builder::Builder, Serialize, Deserialize)]
#[builder(
build_fn(error = "crate::error::Error", validate = "Self::validate"),
derive(Debug)
)]
pub struct ScheduleDowntime {
author: String,
comment: String,
#[serde(
serialize_with = "serialize_icinga_timestamp",
deserialize_with = "deserialize_icinga_timestamp"
)]
start_time: time::OffsetDateTime,
#[serde(
serialize_with = "serialize_icinga_timestamp",
deserialize_with = "deserialize_icinga_timestamp"
)]
end_time: time::OffsetDateTime,
fixed: Option<bool>,
#[serde(
serialize_with = "serialize_optional_duration_as_seconds",
deserialize_with = "deserialize_optional_seconds_as_duration"
)]
duration: Option<time::Duration>,
all_services: Option<bool>,
trigger_name: Option<IcingaDowntimeName>,
child_options: Option<IcingaDowntimeChildOptions>,
#[builder(default, setter(strip_option, into))]
#[serde(flatten)]
filter: Option<IcingaFilter>,
}
impl ScheduleDowntime {
#[must_use]
pub fn builder() -> ScheduleDowntimeBuilder {
ScheduleDowntimeBuilder::default()
}
}
impl ScheduleDowntimeBuilder {
pub fn validate(&self) -> Result<(), crate::error::Error> {
if let Some(Some(false)) = &self.fixed {
if self.duration.is_none() {
return Err(crate::error::Error::DurationRequiredOnFlexibleDowntime);
}
}
if let Some(Some(filter)) = &self.filter {
if filter.object_type != IcingaObjectType::Host
&& filter.object_type != IcingaObjectType::Service
{
return Err(crate::error::Error::FilterObjectTypeMismatch(
vec![IcingaObjectType::Host, IcingaObjectType::Service],
filter.object_type.to_owned(),
));
}
if filter.object_type == IcingaObjectType::Service {
return Err(crate::error::Error::AllServicesInvalidOnServiceDowntime);
}
}
Ok(())
}
}
impl RestApiEndpoint for ScheduleDowntime {
type RequestBody = ScheduleDowntime;
fn method(&self) -> Result<reqwest::Method, crate::error::Error> {
Ok(reqwest::Method::POST)
}
fn url(&self, base_url: &url::Url) -> Result<url::Url, crate::error::Error> {
base_url
.join("v1/actions/schedule-downtime")
.map_err(crate::error::Error::CouldNotParseUrlFragment)
}
fn request_body(
&self,
) -> Result<Option<std::borrow::Cow<Self::RequestBody>>, crate::error::Error>
where
Self::RequestBody: Clone + serde::Serialize + std::fmt::Debug,
{
Ok(Some(std::borrow::Cow::Borrowed(self)))
}
}
impl RestApiResponse<ScheduleDowntime> for ResultsWrapper<StatusResponse> {}