pub mod node;
#[derive(Debug, Clone)]
pub struct NodesClient<T> {
client: T,
path: String,
}
impl<T> NodesClient<T>
where
T: crate::client::Client,
{
pub fn new(client: T) -> Self {
Self {
client,
path: "/nodes".to_string(),
}
}
}
impl<T> NodesClient<T>
where
T: crate::client::Client,
{
#[doc = "Cluster node index."]
#[doc = ""]
pub async fn get(&self) -> Result<Vec<GetOutputItems>, T::Error> {
let path = self.path.to_string();
let optional_vec: Option<Vec<GetOutputItems>> = self.client.get(&path, &()).await?;
Ok(optional_vec.unwrap_or_default())
}
}
impl GetOutputItems {
pub fn new(node: String, status: Status) -> Self {
Self {
node,
status,
cpu: ::std::default::Default::default(),
level: ::std::default::Default::default(),
maxcpu: ::std::default::Default::default(),
maxmem: ::std::default::Default::default(),
mem: ::std::default::Default::default(),
ssl_fingerprint: ::std::default::Default::default(),
uptime: ::std::default::Default::default(),
additional_properties: ::std::default::Default::default(),
}
}
}
#[derive(Clone, Debug, :: serde :: Serialize, :: serde :: Deserialize)]
pub struct GetOutputItems {
#[serde(
serialize_with = "crate::types::serialize_number_optional",
deserialize_with = "crate::types::deserialize_number_optional"
)]
#[serde(skip_serializing_if = "Option::is_none", default)]
#[doc = "CPU utilization."]
#[doc = ""]
pub cpu: Option<f64>,
#[serde(skip_serializing_if = "Option::is_none", default)]
#[doc = "Support level."]
#[doc = ""]
pub level: Option<String>,
#[serde(
serialize_with = "crate::types::serialize_int_optional",
deserialize_with = "crate::types::deserialize_int_optional"
)]
#[serde(skip_serializing_if = "Option::is_none", default)]
#[doc = "Number of available CPUs."]
#[doc = ""]
pub maxcpu: Option<i64>,
#[serde(
serialize_with = "crate::types::serialize_int_optional",
deserialize_with = "crate::types::deserialize_int_optional"
)]
#[serde(skip_serializing_if = "Option::is_none", default)]
#[doc = "Number of available memory in bytes."]
#[doc = ""]
pub maxmem: Option<i64>,
#[serde(
serialize_with = "crate::types::serialize_int_optional",
deserialize_with = "crate::types::deserialize_int_optional"
)]
#[serde(skip_serializing_if = "Option::is_none", default)]
#[doc = "Used memory in bytes."]
#[doc = ""]
pub mem: Option<i64>,
#[doc = "The cluster node name."]
#[doc = ""]
pub node: String,
#[serde(skip_serializing_if = "Option::is_none", default)]
#[doc = "The SSL fingerprint for the node certificate."]
#[doc = ""]
pub ssl_fingerprint: Option<String>,
#[doc = "Node status."]
#[doc = ""]
pub status: Status,
#[serde(
serialize_with = "crate::types::serialize_int_optional",
deserialize_with = "crate::types::deserialize_int_optional"
)]
#[serde(skip_serializing_if = "Option::is_none", default)]
#[doc = "Node uptime in seconds."]
#[doc = ""]
pub uptime: Option<i64>,
#[serde(
flatten,
default,
skip_serializing_if = "::std::collections::HashMap::is_empty"
)]
pub additional_properties: ::std::collections::HashMap<String, ::serde_json::Value>,
}
#[derive(Clone, Debug, :: serde :: Serialize, :: serde :: Deserialize, PartialEq)]
#[doc = "Node status."]
#[doc = ""]
pub enum Status {
#[serde(rename = "offline")]
Offline,
#[serde(rename = "online")]
Online,
#[serde(rename = "unknown")]
Unknown,
}
impl TryFrom<&str> for Status {
type Error = String;
fn try_from(value: &str) -> Result<Self, <Self as TryFrom<&str>>::Error> {
match value {
"offline" => Ok(Self::Offline),
"online" => Ok(Self::Online),
"unknown" => Ok(Self::Unknown),
v => Err(format!("Unknown variant {v}")),
}
}
}
impl<T> NodesClient<T>
where
T: crate::client::Client,
{
pub fn node(&self, node: &str) -> node::NodeClient<T> {
node::NodeClient::<T>::new(self.client.clone(), &self.path, node)
}
}