From: Christoph Heiss <c.heiss@proxmox.com>
To: pdm-devel@lists.proxmox.com
Subject: [PATCH installer v3 38/38] auto: drop now-dead answer file definitions
Date: Fri, 3 Apr 2026 18:54:10 +0200 [thread overview]
Message-ID: <20260403165437.2166551-39-c.heiss@proxmox.com> (raw)
In-Reply-To: <20260403165437.2166551-1-c.heiss@proxmox.com>
These types are now wholly unused, so drop them.
No functional changes.
Signed-off-by: Christoph Heiss <c.heiss@proxmox.com>
---
Changes v2 -> v3:
* new patch
proxmox-auto-installer/src/answer.rs | 511 -------------------------
proxmox-auto-installer/src/lib.rs | 2 -
proxmox-auto-installer/src/udevinfo.rs | 11 -
3 files changed, 524 deletions(-)
delete mode 100644 proxmox-auto-installer/src/answer.rs
delete mode 100644 proxmox-auto-installer/src/udevinfo.rs
diff --git a/proxmox-auto-installer/src/answer.rs b/proxmox-auto-installer/src/answer.rs
deleted file mode 100644
index c7e7298..0000000
--- a/proxmox-auto-installer/src/answer.rs
+++ /dev/null
@@ -1,511 +0,0 @@
-use anyhow::{Result, bail, format_err};
-use serde::{Deserialize, Serialize};
-use std::{
- collections::{BTreeMap, HashMap},
- io::BufRead,
- net::IpAddr,
-};
-
-use proxmox_installer_common::options::NetworkInterfacePinningOptions;
-use proxmox_installer_types::answer::{
- BtrfsCompressOption, BtrfsRaidLevel, FilesystemType, ZfsChecksumOption, ZfsCompressOption,
- ZfsRaidLevel,
-};
-use proxmox_network_types::{Cidr, fqdn::Fqdn};
-
-// NOTE New answer file properties must use kebab-case, but should allow snake_case for backwards
-// compatibility. TODO Remove the snake_cased variants in a future major version (e.g. PVE 10).
-
-// BTreeMap is used to store filters as the order of the filters will be stable, compared to
-// storing them in a HashMap
-
-#[derive(Clone, Deserialize, Debug)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub struct Answer {
- pub global: Global,
- pub network: Network,
- #[serde(rename = "disk-setup")]
- pub disks: Disks,
- pub post_installation_webhook: Option<PostNotificationHookInfo>,
- pub first_boot: Option<FirstBootHookInfo>,
-}
-
-impl Answer {
- pub fn try_from_reader(reader: impl BufRead) -> Result<Self> {
- let mut buffer = String::new();
- let lines = reader.lines();
- for line in lines {
- buffer.push_str(&line.unwrap());
- buffer.push('\n');
- }
-
- toml::from_str(&buffer).map_err(|err| format_err!("Failed parsing answer file: {err}"))
- }
-}
-
-#[derive(Clone, Deserialize, Debug)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub struct Global {
- pub country: String,
- /// FQDN to set for the installed system.
- pub fqdn: FqdnConfig,
- pub keyboard: KeyboardLayout,
- pub mailto: String,
- pub timezone: String,
- #[serde(alias = "root_password")]
- pub root_password: Option<String>,
- #[serde(alias = "root_password_hashed")]
- pub root_password_hashed: Option<String>,
- #[serde(alias = "reboot_on_error", default)]
- pub reboot_on_error: bool,
- #[serde(alias = "reboot_mode", default)]
- pub reboot_mode: RebootMode,
- #[serde(alias = "root_ssh_keys", default)]
- pub root_ssh_keys: Vec<String>,
-}
-
-#[derive(Copy, Clone, Deserialize, Serialize, Debug, Default, PartialEq, Eq)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub enum RebootMode {
- #[default]
- Reboot,
- PowerOff,
-}
-
-/// Allow the user to either set the FQDN of the installation to either some
-/// fixed value or retrieve it dynamically via e.g.DHCP.
-#[derive(Clone, Deserialize, Debug)]
-#[serde(
- untagged,
- expecting = "either a fully-qualified domain name or extendend configuration for usage with DHCP must be specified"
-)]
-pub enum FqdnConfig {
- /// Sets the FQDN to the exact value.
- Simple(Fqdn),
- /// Extended configuration, e.g. to use hostname and domain from DHCP.
- Extended(FqdnExtendedConfig),
-}
-
-/// Extended configuration for retrieving the FQDN from external sources.
-#[derive(Clone, Deserialize, Debug)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub struct FqdnExtendedConfig {
- /// Source to gather the FQDN from.
- #[serde(default)]
- pub source: FqdnSourceMode,
- /// Domain to use if none is received via DHCP.
- #[serde(default, deserialize_with = "deserialize_non_empty_string_maybe")]
- pub domain: Option<String>,
-}
-
-/// Describes the source to retrieve the FQDN of the installation.
-#[derive(Clone, Deserialize, Debug, Default, PartialEq)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub enum FqdnSourceMode {
- #[default]
- FromDhcp,
-}
-
-#[derive(Clone, Deserialize, Debug)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub struct PostNotificationHookInfo {
- /// URL to send a POST request to
- pub url: String,
- /// SHA256 cert fingerprint if certificate pinning should be used.
- #[serde(alias = "cert_fingerprint")]
- pub cert_fingerprint: Option<String>,
-}
-
-/// Possible sources for the optional first-boot hook script/executable file.
-#[derive(Clone, Deserialize, Debug, PartialEq)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub enum FirstBootHookSourceMode {
- /// Fetch the executable file from an URL, specified in the parent.
- FromUrl,
- /// The executable file has been baked into the ISO at a known location,
- /// and should be retrieved from there.
- FromIso,
-}
-
-/// Possible orderings for the `proxmox-first-boot` systemd service.
-///
-/// Determines the final value of `Unit.Before` and `Unit.Wants` in the service
-/// file.
-// Must be kept in sync with Proxmox::Install::Config and the service files in the
-// proxmox-first-boot package.
-#[derive(Clone, Default, Deserialize, Debug, PartialEq)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub enum FirstBootHookServiceOrdering {
- /// Needed for bringing up the network itself, runs before any networking is attempted.
- BeforeNetwork,
- /// Network needs to be already online, runs after networking was brought up.
- NetworkOnline,
- /// Runs after the system has successfully booted up completely.
- #[default]
- FullyUp,
-}
-
-impl FirstBootHookServiceOrdering {
- /// Maps the enum to the appropriate systemd target name, without the '.target' suffix.
- pub fn as_systemd_target_name(&self) -> &str {
- match self {
- FirstBootHookServiceOrdering::BeforeNetwork => "network-pre",
- FirstBootHookServiceOrdering::NetworkOnline => "network-online",
- FirstBootHookServiceOrdering::FullyUp => "multi-user",
- }
- }
-}
-
-/// Describes from where to fetch the first-boot hook script, either being baked into the ISO or
-/// from a URL.
-#[derive(Clone, Deserialize, Debug)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub struct FirstBootHookInfo {
- /// Mode how to retrieve the first-boot executable file, either from an URL or from the ISO if
- /// it has been baked-in.
- pub source: FirstBootHookSourceMode,
- /// Determines the service order when the hook will run on first boot.
- #[serde(default)]
- pub ordering: FirstBootHookServiceOrdering,
- /// Retrieve the post-install script from a URL, if source == "from-url".
- pub url: Option<String>,
- /// SHA256 cert fingerprint if certificate pinning should be used, if source == "from-url".
- #[serde(alias = "cert_fingerprint")]
- pub cert_fingerprint: Option<String>,
-}
-
-#[derive(Clone, Deserialize, Debug, Default, PartialEq)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-enum NetworkConfigMode {
- #[default]
- FromDhcp,
- FromAnswer,
-}
-
-/// Options controlling the behaviour of the network interface pinning (by
-/// creating appropriate systemd.link files) during the installation.
-#[derive(Clone, Debug, Default, PartialEq, Deserialize)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub struct NetworkInterfacePinningOptionsAnswer {
- /// Whether interfaces should be pinned during the installation.
- pub enabled: bool,
- /// Maps MAC address to custom name
- #[serde(default)]
- pub mapping: HashMap<String, String>,
-}
-
-#[derive(Clone, Deserialize, Debug)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-struct NetworkInAnswer {
- #[serde(default)]
- pub source: NetworkConfigMode,
- pub cidr: Option<Cidr>,
- pub dns: Option<IpAddr>,
- pub gateway: Option<IpAddr>,
- #[serde(default)]
- pub filter: BTreeMap<String, String>,
- /// Controls network interface pinning behaviour during installation.
- /// Off by default. Allowed for both `from-dhcp` and `from-answer` modes.
- #[serde(default)]
- pub interface_name_pinning: Option<NetworkInterfacePinningOptionsAnswer>,
-}
-
-#[derive(Clone, Deserialize, Debug)]
-#[serde(try_from = "NetworkInAnswer", deny_unknown_fields)]
-pub struct Network {
- pub network_settings: NetworkSettings,
- /// Controls network interface pinning behaviour during installation.
- pub interface_name_pinning: Option<NetworkInterfacePinningOptions>,
-}
-
-impl TryFrom<NetworkInAnswer> for Network {
- type Error = anyhow::Error;
-
- fn try_from(network: NetworkInAnswer) -> Result<Self> {
- let interface_name_pinning = match network.interface_name_pinning {
- Some(opts) if opts.enabled => {
- let opts = NetworkInterfacePinningOptions {
- mapping: opts
- .mapping
- .iter()
- .map(|(k, v)| (k.to_lowercase(), v.clone()))
- .collect(),
- };
-
- opts.verify()?;
- Some(opts)
- }
- _ => None,
- };
-
- if network.source == NetworkConfigMode::FromAnswer {
- if network.cidr.is_none() {
- bail!("Field 'cidr' must be set.");
- }
- if network.dns.is_none() {
- bail!("Field 'dns' must be set.");
- }
- if network.gateway.is_none() {
- bail!("Field 'gateway' must be set.");
- }
- if network.filter.is_empty() {
- bail!("Field 'filter' must be set.");
- }
-
- Ok(Network {
- network_settings: NetworkSettings::Manual(NetworkManual {
- cidr: network.cidr.unwrap(),
- dns: network.dns.unwrap(),
- gateway: network.gateway.unwrap(),
- filter: network.filter,
- }),
- interface_name_pinning,
- })
- } else {
- if network.cidr.is_some() {
- bail!("Field 'cidr' not supported for 'from-dhcp' config.");
- }
- if network.dns.is_some() {
- bail!("Field 'dns' not supported for 'from-dhcp' config.");
- }
- if network.gateway.is_some() {
- bail!("Field 'gateway' not supported for 'from-dhcp' config.");
- }
- if !network.filter.is_empty() {
- bail!("Field 'filter' not supported for 'from-dhcp' config.");
- }
-
- Ok(Network {
- network_settings: NetworkSettings::FromDhcp,
- interface_name_pinning,
- })
- }
- }
-}
-
-#[derive(Clone, Debug)]
-pub enum NetworkSettings {
- FromDhcp,
- Manual(NetworkManual),
-}
-
-#[derive(Clone, Debug)]
-pub struct NetworkManual {
- pub cidr: Cidr,
- pub dns: IpAddr,
- pub gateway: IpAddr,
- pub filter: BTreeMap<String, String>,
-}
-
-#[derive(Clone, Debug, Deserialize)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub struct DiskSetup {
- pub filesystem: Filesystem,
- #[serde(alias = "disk_list", default)]
- pub disk_list: Vec<String>,
- #[serde(default)]
- pub filter: BTreeMap<String, String>,
- #[serde(alias = "filter_match")]
- pub filter_match: Option<FilterMatch>,
- pub zfs: Option<ZfsOptions>,
- pub lvm: Option<LvmOptions>,
- pub btrfs: Option<BtrfsOptions>,
-}
-
-#[derive(Clone, Debug, Deserialize)]
-#[serde(try_from = "DiskSetup", deny_unknown_fields)]
-pub struct Disks {
- pub fs_type: FilesystemType,
- pub disk_selection: DiskSelection,
- pub filter_match: Option<FilterMatch>,
- pub fs_options: FsOptions,
-}
-
-impl TryFrom<DiskSetup> for Disks {
- type Error = &'static str;
-
- fn try_from(source: DiskSetup) -> Result<Self, Self::Error> {
- if source.disk_list.is_empty() && source.filter.is_empty() {
- return Err("Need either 'disk-list' or 'filter' set");
- }
- if !source.disk_list.is_empty() && !source.filter.is_empty() {
- return Err("Cannot use both, 'disk-list' and 'filter'");
- }
-
- let disk_selection = if !source.disk_list.is_empty() {
- DiskSelection::Selection(source.disk_list.clone())
- } else {
- DiskSelection::Filter(source.filter.clone())
- };
-
- let lvm_checks = |source: &DiskSetup| -> Result<(), Self::Error> {
- if source.zfs.is_some() || source.btrfs.is_some() {
- return Err("make sure only 'lvm' options are set");
- }
- if source.disk_list.len() > 1 {
- return Err("make sure to define only one disk for ext4 and xfs");
- }
- Ok(())
- };
- // TODO: improve checks for foreign FS options. E.g. less verbose and handling new FS types
- // automatically
- let (fs, fs_options) = match source.filesystem {
- Filesystem::Xfs => {
- lvm_checks(&source)?;
- (
- FilesystemType::Xfs,
- FsOptions::LVM(source.lvm.unwrap_or_default()),
- )
- }
- Filesystem::Ext4 => {
- lvm_checks(&source)?;
- (
- FilesystemType::Ext4,
- FsOptions::LVM(source.lvm.unwrap_or_default()),
- )
- }
- Filesystem::Zfs => {
- if source.lvm.is_some() || source.btrfs.is_some() {
- return Err("make sure only 'zfs' options are set");
- }
- match source.zfs {
- None | Some(ZfsOptions { raid: None, .. }) => {
- return Err("ZFS raid level 'zfs.raid' must be set");
- }
- Some(opts) => (
- FilesystemType::Zfs(opts.raid.unwrap()),
- FsOptions::ZFS(opts),
- ),
- }
- }
- Filesystem::Btrfs => {
- if source.zfs.is_some() || source.lvm.is_some() {
- return Err("make sure only 'btrfs' options are set");
- }
- match source.btrfs {
- None | Some(BtrfsOptions { raid: None, .. }) => {
- return Err("BTRFS raid level 'btrfs.raid' must be set");
- }
- Some(opts) => (
- FilesystemType::Btrfs(opts.raid.unwrap()),
- FsOptions::BTRFS(opts),
- ),
- }
- }
- };
-
- let res = Disks {
- fs_type: fs,
- disk_selection,
- filter_match: source.filter_match,
- fs_options,
- };
- Ok(res)
- }
-}
-
-#[derive(Clone, Debug)]
-pub enum FsOptions {
- LVM(LvmOptions),
- ZFS(ZfsOptions),
- BTRFS(BtrfsOptions),
-}
-
-#[derive(Clone, Debug)]
-pub enum DiskSelection {
- Selection(Vec<String>),
- Filter(BTreeMap<String, String>),
-}
-
-#[derive(Clone, Deserialize, Debug, PartialEq)]
-#[serde(rename_all = "lowercase", deny_unknown_fields)]
-pub enum FilterMatch {
- Any,
- All,
-}
-
-serde_plain::derive_fromstr_from_deserialize!(FilterMatch);
-
-#[derive(Clone, Deserialize, Serialize, Debug, PartialEq)]
-#[serde(rename_all = "lowercase", deny_unknown_fields)]
-pub enum Filesystem {
- Ext4,
- Xfs,
- Zfs,
- Btrfs,
-}
-
-#[derive(Clone, Copy, Default, Deserialize, Debug)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub struct ZfsOptions {
- pub raid: Option<ZfsRaidLevel>,
- pub ashift: Option<usize>,
- #[serde(alias = "arc_max")]
- pub arc_max: Option<usize>,
- pub checksum: Option<ZfsChecksumOption>,
- pub compress: Option<ZfsCompressOption>,
- pub copies: Option<usize>,
- pub hdsize: Option<f64>,
-}
-
-#[derive(Clone, Copy, Default, Deserialize, Serialize, Debug)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub struct LvmOptions {
- pub hdsize: Option<f64>,
- pub swapsize: Option<f64>,
- pub maxroot: Option<f64>,
- pub maxvz: Option<f64>,
- pub minfree: Option<f64>,
-}
-
-#[derive(Clone, Copy, Default, Deserialize, Debug)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub struct BtrfsOptions {
- pub hdsize: Option<f64>,
- pub raid: Option<BtrfsRaidLevel>,
- pub compress: Option<BtrfsCompressOption>,
-}
-
-#[derive(Clone, Deserialize, Serialize, Debug, PartialEq)]
-#[serde(rename_all = "kebab-case", deny_unknown_fields)]
-pub enum KeyboardLayout {
- De,
- DeCh,
- Dk,
- EnGb,
- EnUs,
- Es,
- Fi,
- Fr,
- FrBe,
- FrCa,
- FrCh,
- Hu,
- Is,
- It,
- Jp,
- Lt,
- Mk,
- Nl,
- No,
- Pl,
- Pt,
- PtBr,
- Se,
- Si,
- Tr,
-}
-
-serde_plain::derive_display_from_serialize!(KeyboardLayout);
-
-fn deserialize_non_empty_string_maybe<'de, D>(deserializer: D) -> Result<Option<String>, D::Error>
-where
- D: serde::Deserializer<'de>,
-{
- let val: Option<String> = Deserialize::deserialize(deserializer)?;
-
- match val {
- Some(s) if !s.is_empty() => Ok(Some(s)),
- _ => Ok(None),
- }
-}
diff --git a/proxmox-auto-installer/src/lib.rs b/proxmox-auto-installer/src/lib.rs
index 3bdf0b5..8c51a07 100644
--- a/proxmox-auto-installer/src/lib.rs
+++ b/proxmox-auto-installer/src/lib.rs
@@ -1,5 +1,3 @@
-pub mod answer;
pub mod log;
pub mod sysinfo;
-pub mod udevinfo;
pub mod utils;
diff --git a/proxmox-auto-installer/src/udevinfo.rs b/proxmox-auto-installer/src/udevinfo.rs
deleted file mode 100644
index 677f3f6..0000000
--- a/proxmox-auto-installer/src/udevinfo.rs
+++ /dev/null
@@ -1,11 +0,0 @@
-use serde::Deserialize;
-use std::collections::BTreeMap;
-
-/// Uses a BTreeMap to have the keys sorted
-pub type UdevProperties = BTreeMap<String, String>;
-
-#[derive(Clone, Deserialize, Debug)]
-pub struct UdevInfo {
- pub disks: BTreeMap<String, UdevProperties>,
- pub nics: BTreeMap<String, UdevProperties>,
-}
--
2.53.0
prev parent reply other threads:[~2026-04-03 16:57 UTC|newest]
Thread overview: 39+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-04-03 16:53 [PATCH proxmox/yew-pwt/datacenter-manager/installer v3 00/38] add auto-installer integration Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 01/38] api-macro: allow $ in identifier name Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 02/38] schema: oneOf: allow single string variant Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 03/38] schema: implement UpdaterType for HashMap and BTreeMap Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 04/38] network-types: move `Fqdn` type from proxmox-installer-common Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 05/38] network-types: implement api type for Fqdn Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 06/38] network-types: add api wrapper type for std::net::IpAddr Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 07/38] network-types: cidr: implement generic `IpAddr::new` constructor Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 08/38] network-types: fqdn: implement standard library Error for Fqdn Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 09/38] node-status: make KernelVersionInformation Clone + PartialEq Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 10/38] installer-types: add common types used by the installer Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 11/38] installer-types: add types used by the auto-installer Christoph Heiss
2026-04-03 16:53 ` [PATCH proxmox v3 12/38] installer-types: implement api type for all externally-used types Christoph Heiss
2026-04-03 16:53 ` [PATCH yew-widget-toolkit v3 13/38] widget: kvlist: add widget for user-modifiable data tables Christoph Heiss
2026-04-03 16:53 ` [PATCH datacenter-manager v3 14/38] api-types, cli: use ReturnType::new() instead of constructing it manually Christoph Heiss
2026-04-03 16:53 ` [PATCH datacenter-manager v3 15/38] api-types: add api types for auto-installer integration Christoph Heiss
2026-04-03 16:53 ` [PATCH datacenter-manager v3 16/38] config: add auto-installer configuration module Christoph Heiss
2026-04-03 16:53 ` [PATCH datacenter-manager v3 17/38] acl: wire up new /system/auto-installation acl path Christoph Heiss
2026-04-03 16:53 ` [PATCH datacenter-manager v3 18/38] server: api: add auto-installer integration module Christoph Heiss
2026-04-03 16:53 ` [PATCH datacenter-manager v3 19/38] server: api: auto-installer: add access token management endpoints Christoph Heiss
2026-04-03 16:53 ` [PATCH datacenter-manager v3 20/38] client: add bindings for auto-installer endpoints Christoph Heiss
2026-04-03 16:53 ` [PATCH datacenter-manager v3 21/38] ui: auto-installer: add installations overview panel Christoph Heiss
2026-04-03 16:53 ` [PATCH datacenter-manager v3 22/38] ui: auto-installer: add prepared answer configuration panel Christoph Heiss
2026-04-03 16:53 ` [PATCH datacenter-manager v3 23/38] ui: auto-installer: add access token " Christoph Heiss
2026-04-03 16:53 ` [PATCH datacenter-manager v3 24/38] docs: add documentation for auto-installer integration Christoph Heiss
2026-04-03 16:53 ` [PATCH installer v3 25/38] install: iso env: use JSON boolean literals for product config Christoph Heiss
2026-04-03 16:53 ` [PATCH installer v3 26/38] common: http: allow passing custom headers to post() Christoph Heiss
2026-04-03 16:53 ` [PATCH installer v3 27/38] common: options: move regex construction out of loop Christoph Heiss
2026-04-03 16:54 ` [PATCH installer v3 28/38] assistant: support adding an authorization token for HTTP-based answers Christoph Heiss
2026-04-03 16:54 ` [PATCH installer v3 29/38] tree-wide: used moved `Fqdn` type to proxmox-network-types Christoph Heiss
2026-04-03 16:54 ` [PATCH installer v3 30/38] tree-wide: use `Cidr` type from proxmox-network-types Christoph Heiss
2026-04-03 16:54 ` [PATCH installer v3 31/38] tree-wide: switch to filesystem types from proxmox-installer-types Christoph Heiss
2026-04-03 16:54 ` [PATCH installer v3 32/38] post-hook: switch to types in proxmox-installer-types Christoph Heiss
2026-04-03 16:54 ` [PATCH installer v3 33/38] auto: sysinfo: switch to types from proxmox-installer-types Christoph Heiss
2026-04-03 16:54 ` [PATCH installer v3 34/38] fetch-answer: " Christoph Heiss
2026-04-03 16:54 ` [PATCH installer v3 35/38] fetch-answer: http: prefer json over toml for answer format Christoph Heiss
2026-04-03 16:54 ` [PATCH installer v3 36/38] fetch-answer: send auto-installer HTTP authorization token if set Christoph Heiss
2026-04-03 16:54 ` [PATCH installer v3 37/38] tree-wide: switch out `Answer` -> `AutoInstallerConfig` types Christoph Heiss
2026-04-03 16:54 ` Christoph Heiss [this message]
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=20260403165437.2166551-39-c.heiss@proxmox.com \
--to=c.heiss@proxmox.com \
--cc=pdm-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