From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from firstgate.proxmox.com (firstgate.proxmox.com [212.224.123.68]) by lore.proxmox.com (Postfix) with ESMTPS id 83E011FF13C for ; Thu, 19 Feb 2026 15:56:03 +0100 (CET) Received: from firstgate.proxmox.com (localhost [127.0.0.1]) by firstgate.proxmox.com (Proxmox) with ESMTP id 5E5D218199; Thu, 19 Feb 2026 15:56:59 +0100 (CET) From: Stefan Hanreich To: pve-devel@lists.proxmox.com Subject: [PATCH proxmox-ve-rs 3/9] sdn-types: add wireguard-specific PersistentKeepalive api type Date: Thu, 19 Feb 2026 15:56:22 +0100 Message-ID: <20260219145649.441418-6-s.hanreich@proxmox.com> X-Mailer: git-send-email 2.47.3 In-Reply-To: <20260219145649.441418-1-s.hanreich@proxmox.com> References: <20260219145649.441418-1-s.hanreich@proxmox.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SPAM-LEVEL: Spam detection results: 0 AWL -0.177 Adjusted score from AWL reputation of From: address BAYES_00 -1.9 Bayes spam probability is 0 to 1% DMARC_MISSING 0.1 Missing DMARC policy KAM_DMARC_STATUS 0.01 Test Rule for DKIM or SPF Failure with Strict Alignment KAM_LAZY_DOMAIN_SECURITY 1 Sending domain does not have any anti-forgery methods RDNS_NONE 0.793 Delivered to internal network by a host with no rDNS SPF_HELO_NONE 0.001 SPF: HELO does not publish an SPF Record SPF_NONE 0.001 SPF: sender does not publish an SPF Record Message-ID-Hash: IDDXPKLERY4NEQO74ZPBO263YA5THPLV X-Message-ID-Hash: IDDXPKLERY4NEQO74ZPBO263YA5THPLV X-MailFrom: hoan@cray.proxmox.com X-Mailman-Rule-Misses: dmarc-mitigation; no-senders; approved; loop; banned-address; emergency; member-moderation; nonmember-moderation; administrivia; implicit-dest; max-recipients; max-size; news-moderation; no-subject; digests; suspicious-header X-Mailman-Version: 3.3.10 Precedence: list List-Id: Proxmox VE development discussion List-Help: List-Owner: List-Post: List-Subscribe: List-Unsubscribe: From: Christoph Heiss Signed-off-by: Christoph Heiss --- proxmox-sdn-types/src/lib.rs | 1 + proxmox-sdn-types/src/wireguard.rs | 43 ++++++++++++++++++++++++++++++ 2 files changed, 44 insertions(+) create mode 100644 proxmox-sdn-types/src/wireguard.rs diff --git a/proxmox-sdn-types/src/lib.rs b/proxmox-sdn-types/src/lib.rs index 1656f1d..3328b45 100644 --- a/proxmox-sdn-types/src/lib.rs +++ b/proxmox-sdn-types/src/lib.rs @@ -1,3 +1,4 @@ pub mod area; pub mod net; pub mod openfabric; +pub mod wireguard; diff --git a/proxmox-sdn-types/src/wireguard.rs b/proxmox-sdn-types/src/wireguard.rs new file mode 100644 index 0000000..4c79b50 --- /dev/null +++ b/proxmox-sdn-types/src/wireguard.rs @@ -0,0 +1,43 @@ +//! API types for the WireGuard fabric. + +use std::fmt::Display; + +use proxmox_schema::{api, UpdaterType}; +use serde::{Deserialize, Serialize}; + +/// Persistent keep-alive interval. Specifies how often a authenticated, empty +/// packet will be sent to the peer to keep e.g. stateful firewall open or NAT +/// mappings. +/// +/// Interval in seconds, between 1 and 65536 inclusive. +#[api( + type: Integer, + minimum: 1, +)] +#[derive(Serialize, Deserialize, Hash, Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord)] +#[serde(transparent)] +pub struct PersistentKeepalive( + #[serde(deserialize_with = "proxmox_serde::perl::deserialize_u16")] u16, +); + +impl PersistentKeepalive { + /// Determines whether the given `PersistentKeepalive` value means that it is + /// turned off. + pub fn is_off(&self) -> bool { + self.0 == 0 + } + + pub fn raw(&self) -> u16 { + self.0 + } +} + +impl UpdaterType for PersistentKeepalive { + type Updater = Option; +} + +impl Display for PersistentKeepalive { + fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { + self.0.fmt(f) + } +} -- 2.47.3