nmstate 2.2.60

Library for networking management in a declarative manner
Documentation
// SPDX-License-Identifier: Apache-2.0

use std::collections::HashMap;

use serde::{Deserialize, Serialize};

use super::{NetworkCaptureRules, NetworkStateTemplate};
use crate::{NetworkState, NmstateError};

#[derive(Clone, Debug, Deserialize, Serialize, Default, PartialEq, Eq)]
#[serde(deny_unknown_fields)]
#[non_exhaustive]
pub struct NetworkPolicy {
    #[serde(skip_serializing_if = "NetworkCaptureRules::is_empty", default)]
    /// Capture rules for matching current network state
    pub capture: NetworkCaptureRules,
    /// Template of desired state, will apply capture results
    #[serde(alias = "desiredState", default)]
    pub desired: NetworkStateTemplate,
    /// Current network state which the capture rules should run against
    #[serde(default, skip_serializing_if = "Option::is_none")]
    pub current: Option<NetworkState>,
}

impl TryFrom<NetworkPolicy> for NetworkState {
    type Error = NmstateError;

    fn try_from(policy: NetworkPolicy) -> Result<Self, NmstateError> {
        if policy.is_empty() {
            return Ok(NetworkState::new());
        }

        if policy.capture.is_empty() {
            policy.desired.fill_with_captured_data(&HashMap::new())
        } else {
            let current = if let Some(c) = policy.current {
                c
            } else {
                let mut current = NetworkState::new();
                current.retrieve()?;
                current
            };
            let capture_results = policy.capture.execute(&current)?;
            let desired_state =
                policy.desired.fill_with_captured_data(&capture_results)?;
            desired_state.gen_diff(&current)
        }
    }
}

impl NetworkPolicy {
    pub fn is_empty(&self) -> bool {
        self.capture.is_empty() && self.desired.is_empty()
    }
}