From cc791a864561d9e67a1d1a26ef1d224c00e793b2 Mon Sep 17 00:00:00 2001 From: Jarrett Tierney Date: Wed, 20 Mar 2024 09:24:27 -0700 Subject: [PATCH] prairiedog: address if the configuration file does not exist --- sources/api/prairiedog/src/bootconfig.rs | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/sources/api/prairiedog/src/bootconfig.rs b/sources/api/prairiedog/src/bootconfig.rs index 567531f6ffe..f55bdfbdfaa 100644 --- a/sources/api/prairiedog/src/bootconfig.rs +++ b/sources/api/prairiedog/src/bootconfig.rs @@ -6,6 +6,7 @@ use serde::{Deserialize, Serialize}; use snafu::{ensure, ResultExt}; use std::collections::HashMap; use std::convert::TryInto; +use std::io::ErrorKind; use std::path::Path; use std::{fs, io}; @@ -117,10 +118,20 @@ fn get_boot_config_settings

(config_path: P) -> Result> where P: AsRef, { - let config_str = fs::read_to_string(config_path.as_ref()).context(error::ReadFileSnafu { - path: config_path.as_ref().to_path_buf(), - })?; - toml::from_str(config_str.as_str()).context(error::InputTomlSnafu) + let config_path = config_path.as_ref(); + match fs::read_to_string(config_path) { + Ok(config_str) => toml::from_str(config_str.as_str()).context(error::InputTomlSnafu), + Err(e) => { + if e.kind() == ErrorKind::NotFound { + Ok(None) + } else { + Err(error::Error::ReadFile { + source: e, + path: config_path.to_path_buf(), + }) + } + } + } } /// Reads `/proc/bootconfig`. Not having any boot config is ignored.