From: Wolfgang Bumiller <w.bumiller@proxmox.com>
To: Gabriel Goller <g.goller@proxmox.com>
Cc: pbs-devel@lists.proxmox.com
Subject: Re: [pbs-devel] [PATCH v4 proxmox-backup 4/5] node: status: declutter kernel-version
Date: Wed, 29 Nov 2023 11:23:34 +0100 [thread overview]
Message-ID: <e7zx65tjgetshodlko2rfc5yfsbnj2glhtcom3gqvyx3jacuck@xhu5a4jcge7w> (raw)
In-Reply-To: <20231129090746.38798-5-g.goller@proxmox.com>
On Wed, Nov 29, 2023 at 10:07:45AM +0100, Gabriel Goller wrote:
> Return a struct with all the components of the kernel version like it
> has been done in pve. Also return the legacy `kversion` to keep
> backwards compat.
>
> Signed-off-by: Gabriel Goller <g.goller@proxmox.com>
> ---
> pbs-api-types/src/node.rs | 47 ++++++++++++++++++++++++++++++++++++++-
> src/api2/node/status.rs | 18 +++++++--------
> 2 files changed, 55 insertions(+), 10 deletions(-)
>
> diff --git a/pbs-api-types/src/node.rs b/pbs-api-types/src/node.rs
> index ab626157..fd1fbe3b 100644
> --- a/pbs-api-types/src/node.rs
> +++ b/pbs-api-types/src/node.rs
> @@ -1,3 +1,5 @@
> +use std::ffi::OsStr;
> +
> use proxmox_schema::*;
> use serde::{Deserialize, Serialize};
>
> @@ -38,6 +40,47 @@ pub struct NodeInformation {
> pub fingerprint: String,
> }
>
> +#[api]
> +#[derive(Serialize, Deserialize, Default)]
> +#[serde(rename_all = "lowercase")]
> +/// The current kernel version (output of `uname`)
> +pub struct KernelVersionInformation {
> + /// The systemname/nodename
> + pub sysname: String,
> + /// The kernel release number
> + pub release: String,
> + /// The kernel version
> + pub version: String,
> + /// The machine architecture
> + pub machine: String,
> +}
> +
> +impl KernelVersionInformation {
> + pub fn from_ostr(sysname: &OsStr, release: &OsStr, version: &OsStr, machine: &OsStr) -> Self {
from_ostr is a bit of a weird name for a public method taking 4
parameters.
consider a `From<&UtsName>` implementation.
> + KernelVersionInformation {
> + sysname: sysname
> + .to_os_string()
> + .into_string()
> + .unwrap_or("".to_string()),
.unwrap_or_default(), also, whenver you think "".to_string(), type
String::new() instead ;-)
also, you first convert to an owned string - this always works, and then
do the fallible `into_string()`, so even if it's not a valid string you
clone and discard, instead, do:
sysname
.to_str()
.map(String::from)
.unwrap_or_default()
this way there's no string copying if it's not valid utf-8 becausee that
is checked first
same for the cases below
> + release: release
> + .to_os_string()
> + .into_string()
> + .unwrap_or("".to_string()),
> + version: version
> + .to_os_string()
> + .into_string()
> + .unwrap_or("".to_string()),
> + machine: machine
> + .to_os_string()
> + .into_string()
> + .unwrap_or("".to_string()),
> + }
> + }
> +
> + pub fn get_legacy(&self) -> String {
> + format!("{} {} {}", self.sysname, self.release, self.version)
> + }
> +}
>
> #[api]
> #[derive(Serialize, Deserialize, Copy, Clone)]
> @@ -111,7 +154,9 @@ pub struct NodeStatus {
> pub uptime: u64,
> /// Load for 1, 5 and 15 minutes.
> pub loadavg: [f64; 3],
> - /// The current kernel version.
> + /// The current kernel version (NEW struct type).
> + pub current_kernel: KernelVersionInformation,
> + /// The current kernel version (LEGACY string type).
> pub kversion: String,
> /// Total CPU usage since last query.
> pub cpu: f64,
> diff --git a/src/api2/node/status.rs b/src/api2/node/status.rs
> index 17b9aff3..8b4d1638 100644
> --- a/src/api2/node/status.rs
> +++ b/src/api2/node/status.rs
> @@ -1,4 +1,3 @@
> -use std::os::unix::ffi::OsStrExt;
> use std::process::Command;
>
> use anyhow::{bail, format_err, Error};
> @@ -11,8 +10,8 @@ use proxmox_router::{ApiMethod, Permission, Router, RpcEnvironment};
> use proxmox_schema::api;
>
> use pbs_api_types::{
> - BootModeInformation, NodePowerCommand, StorageStatus, NODE_SCHEMA, PRIV_SYS_AUDIT,
> - PRIV_SYS_POWER_MANAGEMENT,
> + BootModeInformation, KernelVersionInformation, NodePowerCommand, StorageStatus, NODE_SCHEMA,
> + PRIV_SYS_AUDIT, PRIV_SYS_POWER_MANAGEMENT,
> };
>
> use pbs_api_types::{
> @@ -92,11 +91,11 @@ async fn get_status(
> let cpuinfo = procfs_to_node_cpu_info(cpuinfo);
>
> let uname = nix::sys::utsname::uname()?;
> - let kversion = format!(
> - "{} {} {}",
> - std::str::from_utf8(uname.sysname().as_bytes())?,
> - std::str::from_utf8(uname.release().as_bytes())?,
> - std::str::from_utf8(uname.version().as_bytes())?
> + let kernel_version = KernelVersionInformation::from_ostr(
> + uname.sysname(),
> + uname.release(),
> + uname.version(),
> + uname.machine(),
> );
>
> let disk = crate::tools::fs::fs_info_static(proxmox_lang::c_str!("/")).await?;
> @@ -113,7 +112,8 @@ async fn get_status(
> },
> uptime: procfs::read_proc_uptime()?.0 as u64,
> loadavg,
> - kversion,
> + kversion: kernel_version.get_legacy(),
> + current_kernel: kernel_version,
> cpuinfo,
> cpu,
> wait,
> --
> 2.39.2
>
>
>
> _______________________________________________
> pbs-devel mailing list
> pbs-devel@lists.proxmox.com
> https://lists.proxmox.com/cgi-bin/mailman/listinfo/pbs-devel
>
>
next prev parent reply other threads:[~2023-11-29 10:23 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-11-29 9:07 [pbs-devel] [PATCH v4 proxmox{, -backup} 0/5] Add boot_mode, improve kernel version Gabriel Goller
2023-11-29 9:07 ` [pbs-devel] [PATCH v4 proxmox 1/5] sys: add helper to get bootmode and secureboot status Gabriel Goller
2023-11-29 10:13 ` Wolfgang Bumiller
2023-11-29 9:07 ` [pbs-devel] [PATCH v4 proxmox-backup 2/5] node: status: added bootmode Gabriel Goller
2023-11-29 10:18 ` Wolfgang Bumiller
2023-11-29 12:44 ` Gabriel Goller
2023-11-29 9:07 ` [pbs-devel] [PATCH v4 proxmox-backup 3/5] ui: dashboard: show the bootmode Gabriel Goller
2023-11-29 9:07 ` [pbs-devel] [PATCH v4 proxmox-backup 4/5] node: status: declutter kernel-version Gabriel Goller
2023-11-29 10:23 ` Wolfgang Bumiller [this message]
2023-11-29 12:50 ` Gabriel Goller
2023-11-29 13:05 ` Wolfgang Bumiller
2023-11-29 9:07 ` [pbs-devel] [PATCH v4 proxmox-backup 5/5] ui: dashboard: nicely display kernel version Gabriel Goller
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=e7zx65tjgetshodlko2rfc5yfsbnj2glhtcom3gqvyx3jacuck@xhu5a4jcge7w \
--to=w.bumiller@proxmox.com \
--cc=g.goller@proxmox.com \
--cc=pbs-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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.