proxmox-api 0.2.0

Rust bindings for the Proxmox VE HTTP API
Documentation
pub mod acl;
pub mod domains;
pub mod groups;
pub mod openid;
pub mod password;
pub mod permissions;
pub mod roles;
pub mod tfa;
pub mod ticket;
pub mod users;
pub mod vncticket;
#[derive(Debug, Clone)]
pub struct AccessClient<T> {
    client: T,
    path: String,
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn new(client: T) -> Self {
        Self {
            client,
            path: "/access".to_string(),
        }
    }
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    #[doc = "Directory 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(subdir: String) -> Self {
        Self {
            subdir,
            additional_properties: ::std::default::Default::default(),
        }
    }
}
#[derive(Clone, Debug, :: serde :: Serialize, :: serde :: Deserialize)]
pub struct GetOutputItems {
    pub subdir: String,
    #[serde(
        flatten,
        default,
        skip_serializing_if = "::std::collections::HashMap::is_empty"
    )]
    pub additional_properties: ::std::collections::HashMap<String, ::serde_json::Value>,
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn users(&self) -> users::UsersClient<T> {
        users::UsersClient::<T>::new(self.client.clone(), &self.path)
    }
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn groups(&self) -> groups::GroupsClient<T> {
        groups::GroupsClient::<T>::new(self.client.clone(), &self.path)
    }
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn roles(&self) -> roles::RolesClient<T> {
        roles::RolesClient::<T>::new(self.client.clone(), &self.path)
    }
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn acl(&self) -> acl::AclClient<T> {
        acl::AclClient::<T>::new(self.client.clone(), &self.path)
    }
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn domains(&self) -> domains::DomainsClient<T> {
        domains::DomainsClient::<T>::new(self.client.clone(), &self.path)
    }
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn openid(&self) -> openid::OpenidClient<T> {
        openid::OpenidClient::<T>::new(self.client.clone(), &self.path)
    }
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn tfa(&self) -> tfa::TfaClient<T> {
        tfa::TfaClient::<T>::new(self.client.clone(), &self.path)
    }
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn ticket(&self) -> ticket::TicketClient<T> {
        ticket::TicketClient::<T>::new(self.client.clone(), &self.path)
    }
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn vncticket(&self) -> vncticket::VncticketClient<T> {
        vncticket::VncticketClient::<T>::new(self.client.clone(), &self.path)
    }
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn password(&self) -> password::PasswordClient<T> {
        password::PasswordClient::<T>::new(self.client.clone(), &self.path)
    }
}
impl<T> AccessClient<T>
where
    T: crate::client::Client,
{
    pub fn permissions(&self) -> permissions::PermissionsClient<T> {
        permissions::PermissionsClient::<T>::new(self.client.clone(), &self.path)
    }
}