icinga2_api/api/action/
send_custom_notification.rsuse serde::{Deserialize, Serialize};
use crate::types::action::StatusResponse;
use crate::types::enums::object_type::IcingaObjectType;
use crate::types::filter::IcingaFilter;
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 SendCustomNotification {
author: String,
comment: String,
force: Option<bool>,
#[builder(default, setter(strip_option, into))]
#[serde(flatten)]
filter: Option<IcingaFilter>,
}
impl SendCustomNotification {
#[must_use]
pub fn builder() -> SendCustomNotificationBuilder {
SendCustomNotificationBuilder::default()
}
}
impl SendCustomNotificationBuilder {
pub fn validate(&self) -> Result<(), crate::error::Error> {
if let Some(Some(filter)) = &self.filter {
if filter.object_type != IcingaObjectType::Host
&& filter.object_type != IcingaObjectType::Service
{
Err(crate::error::Error::FilterObjectTypeMismatch(
vec![IcingaObjectType::Host, IcingaObjectType::Service],
filter.object_type.to_owned(),
))
} else {
Ok(())
}
} else {
Ok(())
}
}
}
impl RestApiEndpoint for SendCustomNotification {
type RequestBody = SendCustomNotification;
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/send-custom-notification")
.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<SendCustomNotification> for ResultsWrapper<StatusResponse> {}