From: Stefan Hanreich <s.hanreich@proxmox.com>
To: pve-devel@lists.proxmox.com
Subject: [pve-devel] [PATCH proxmox-ve-rs 1/2] firewall: alias: lowercase names of aliases
Date: Mon, 25 Nov 2024 17:12:48 +0100 [thread overview]
Message-ID: <20241125161249.211552-1-s.hanreich@proxmox.com> (raw)
pve-firewall lowercases the names of aliases when reading from the
configuration as well as when comparing source / destination entries
with the entries in the parsed aliases. In order to stay
backwards-compatible we also need to lowercase any parsed alias name.
I decided to this in the constructor and switch all call sites to the
new constructor, so there's only one place where we have to handle
lowercasing the string.
Signed-off-by: Stefan Hanreich <s.hanreich@proxmox.com>
---
In order for this to be fixed in proxmox-firewall, it needs to be
built with the new version of proxmox-ve-config of course.
proxmox-ve-config/src/firewall/types/alias.rs | 44 ++++++++++++++-----
1 file changed, 33 insertions(+), 11 deletions(-)
diff --git a/proxmox-ve-config/src/firewall/types/alias.rs b/proxmox-ve-config/src/firewall/types/alias.rs
index 5dfaa41..08e4d77 100644
--- a/proxmox-ve-config/src/firewall/types/alias.rs
+++ b/proxmox-ve-config/src/firewall/types/alias.rs
@@ -53,10 +53,7 @@ impl FromStr for AliasName {
fn from_str(s: &str) -> Result<Self, Self::Err> {
match s.split_once('/') {
- Some((prefix, name)) if !name.is_empty() => Ok(Self {
- scope: prefix.parse()?,
- name: name.to_string(),
- }),
+ Some((prefix, name)) if !name.is_empty() => Ok(Self::new(prefix.parse()?, name)),
_ => {
bail!("Invalid Alias name!")
}
@@ -65,10 +62,18 @@ impl FromStr for AliasName {
}
impl AliasName {
+ /// Creates a new [`AliasName`].
+ ///
+ /// It will convert any ASCII characters contained in the name into lowercase. This is for
+ /// maintaining backwards-compatiblity with pve-firewall, where all aliases are lowercased when
+ /// reading from the config.
pub fn new(scope: AliasScope, name: impl Into<String>) -> Self {
+ let mut lowercase_name = name.into();
+ lowercase_name.make_ascii_lowercase();
+
Self {
scope,
- name: name.into(),
+ name: lowercase_name,
}
}
@@ -90,13 +95,21 @@ pub struct Alias {
}
impl Alias {
+ /// Creates a new [`Alias`].
+ ///
+ /// It will convert any ASCII characters contained in the name into lowercase. This is for
+ /// maintaining backwards-compatiblity with pve-firewall, where all aliases are lowercased when
+ /// reading from the config.
pub fn new(
name: impl Into<String>,
address: impl Into<Cidr>,
comment: impl Into<Option<String>>,
) -> Self {
+ let mut lowercase_name = name.into();
+ lowercase_name.make_ascii_lowercase();
+
Self {
- name: name.into(),
+ name: lowercase_name,
address: address.into(),
comment: comment.into(),
}
@@ -135,11 +148,7 @@ impl FromStr for Alias {
None => None,
};
- Ok(Alias {
- name: name.to_string(),
- address,
- comment,
- })
+ Ok(Alias::new(name, address, comment))
}
}
@@ -159,6 +168,11 @@ mod tests {
for alias in ["-- 10.0.0.1/32", "0asd 10.0.0.1/32", "__test 10.0.0.0/32"] {
alias.parse::<Alias>().expect_err("invalid alias");
}
+
+ let alias = "pRoxMox 10.0.0.0/32 # a comment".parse::<Alias>().expect("valid alias");
+ assert_eq!(alias.name(), "proxmox");
+ assert_eq!(alias.address(), &Cidr::new_v4([10, 0, 0, 0], 32).expect("valid CIDR"));
+ assert_eq!(alias.comment(), Some("a comment"));
}
#[test]
@@ -171,4 +185,12 @@ mod tests {
name.parse::<AliasName>().expect_err("invalid alias name");
}
}
+
+ #[test]
+ fn test_parse_alias_case() {
+ for name in ["dc/PROxMoX", "guest/PROXMOX"] {
+ let alias_name = name.parse::<AliasName>().expect("valid alias name");
+ assert_eq!(alias_name.name(), "proxmox");
+ }
+ }
}
--
2.39.5
_______________________________________________
pve-devel mailing list
pve-devel@lists.proxmox.com
https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel
next reply other threads:[~2024-11-25 16:12 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-11-25 16:12 Stefan Hanreich [this message]
2024-11-25 16:12 ` [pve-devel] [PATCH proxmox-ve-rs 2/2] firewall: alias: document difference between Alias and AliasName Stefan Hanreich
2024-11-25 16:26 ` [pve-devel] [PATCH proxmox-ve-rs 1/2] firewall: alias: lowercase names of aliases Stefan Hanreich
2024-11-25 17:05 ` Stefan Hanreich
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20241125161249.211552-1-s.hanreich@proxmox.com \
--to=s.hanreich@proxmox.com \
--cc=pve-devel@lists.proxmox.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox