[pve-devel] [PATCH proxmox-ve-rs 14/17] ve-config: add FRR conversion helpers for openfabric and ospf
Gabriel Goller
g.goller at proxmox.com
Fri Mar 28 18:13:03 CET 2025
Add conversion helpers for FRR interfaces. We can't put these in eg.
`TryInto` implementations, as we need a tupel and tupels are foreign
types. Create a simple conversion function that converts the OpenFabric
and OSPF interfaces to FRR interfaces.
Signed-off-by: Gabriel Goller <g.goller at proxmox.com>
---
.../src/sdn/fabric/openfabric/frr.rs | 24 +++++++++++++++
proxmox-ve-config/src/sdn/fabric/ospf/frr.rs | 29 +++++++++++++++++++
2 files changed, 53 insertions(+)
create mode 100644 proxmox-ve-config/src/sdn/fabric/openfabric/frr.rs
create mode 100644 proxmox-ve-config/src/sdn/fabric/ospf/frr.rs
diff --git a/proxmox-ve-config/src/sdn/fabric/openfabric/frr.rs b/proxmox-ve-config/src/sdn/fabric/openfabric/frr.rs
new file mode 100644
index 000000000000..682fe62ab72f
--- /dev/null
+++ b/proxmox-ve-config/src/sdn/fabric/openfabric/frr.rs
@@ -0,0 +1,24 @@
+use proxmox_frr::{
+ openfabric::{OpenFabricInterface, OpenFabricInterfaceError},
+ FrrWord,
+};
+
+use super::{FabricId, InterfaceProperties};
+
+impl InterfaceProperties {
+ pub fn to_frr_interface(
+ &self,
+ fabric_id: &FabricId,
+ is_ipv6: bool,
+ ) -> Result<OpenFabricInterface, OpenFabricInterfaceError> {
+ let frr_word = FrrWord::new(fabric_id.to_string())?;
+ Ok(OpenFabricInterface {
+ fabric_id: frr_word.into(),
+ passive: self.passive(),
+ hello_interval: self.hello_interval,
+ csnp_interval: self.csnp_interval,
+ hello_multiplier: self.hello_multiplier,
+ is_ipv6,
+ })
+ }
+}
diff --git a/proxmox-ve-config/src/sdn/fabric/ospf/frr.rs b/proxmox-ve-config/src/sdn/fabric/ospf/frr.rs
new file mode 100644
index 000000000000..9d493b60efd5
--- /dev/null
+++ b/proxmox-ve-config/src/sdn/fabric/ospf/frr.rs
@@ -0,0 +1,29 @@
+use proxmox_frr::{
+ ospf::{NetworkType, OspfInterface, OspfInterfaceError, OspfRouter},
+ FrrWord,
+};
+
+use super::{Area, InterfaceProperties, NodeSection};
+
+impl From<NodeSection> for OspfRouter {
+ fn from(val: NodeSection) -> Self {
+ OspfRouter {
+ router_id: val.router_id,
+ }
+ }
+}
+
+impl InterfaceProperties {
+ pub fn to_frr_interface(&self, area: &Area) -> Result<OspfInterface, OspfInterfaceError> {
+ let frr_word = FrrWord::new(area.to_string())?;
+ Ok(OspfInterface {
+ area: frr_word.try_into()?,
+ passive: self.passive,
+ network_type: if let Some(true) = self.unnumbered {
+ Some(NetworkType::PointToPoint)
+ } else {
+ None
+ },
+ })
+ }
+}
--
2.39.5
More information about the pve-devel
mailing list