serde: more ignore-if-empty

This commit is contained in:
Mikaël Cluseau
2025-11-16 16:31:51 +01:00
parent d7dfea2dec
commit 3fe6fc9222

View File

@ -14,20 +14,22 @@ pub struct Config {
#[serde(skip_serializing_if = "Option::is_none")] #[serde(skip_serializing_if = "Option::is_none")]
pub resolv_conf: Option<String>, pub resolv_conf: Option<String>,
#[serde(default)] #[serde(default, skip_serializing_if = "Map::is_empty")]
pub vpns: Map<String, String>, pub vpns: Map<String, String>,
#[serde(default, skip_serializing_if = "Vec::is_empty")]
pub networks: Vec<Network>, pub networks: Vec<Network>,
#[serde(default, skip_serializing_if = "Vec::is_empty")]
pub auths: Vec<Auth>, pub auths: Vec<Auth>,
#[serde(default)] #[serde(default)]
pub ssh: SSHServer, pub ssh: SSHServer,
#[serde(default)] #[serde(default, skip_serializing_if = "Vec::is_empty")]
pub pre_lvm_crypt: Vec<CryptDev>, pub pre_lvm_crypt: Vec<CryptDev>,
#[serde(default)] #[serde(default, skip_serializing_if = "Vec::is_empty")]
pub lvm: Vec<LvmVG>, pub lvm: Vec<LvmVG>,
#[serde(default)] #[serde(default, skip_serializing_if = "Vec::is_empty")]
pub crypt: Vec<CryptDev>, pub crypt: Vec<CryptDev>,
#[serde(skip_serializing_if = "Option::is_none")] #[serde(skip_serializing_if = "Option::is_none")]
@ -250,5 +252,6 @@ pub struct Raid {
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)] #[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
pub struct Bootstrap { pub struct Bootstrap {
pub dev: String, pub dev: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub seed: Option<String>, pub seed: Option<String>,
} }