Improve error messages on missing config

This commit is contained in:
Nadja Reitzenstein 2022-07-24 17:51:12 +02:00
parent 9346e433e1
commit e3423c7786
3 changed files with 60 additions and 20 deletions

View File

@ -12,8 +12,8 @@ use crate::authorization::roles::Role;
use crate::capnp::{Listen, TlsListen}; use crate::capnp::{Listen, TlsListen};
use crate::logging::LogConfig; use crate::logging::LogConfig;
use std::path::Path;
use miette::IntoDiagnostic; use miette::IntoDiagnostic;
use std::path::Path;
#[derive(Debug)] #[derive(Debug)]
struct DhallConfig<'a> { struct DhallConfig<'a> {

View File

@ -1,10 +1,50 @@
mod dhall; use std::path::Path;
pub use dhall::read_config_file as read;
pub use dhall::{Config, ModuleConfig, MachineDescription}; use miette::Diagnostic;
use thiserror::Error;
pub(crate) use dhall::deser_option; pub(crate) use dhall::deser_option;
pub use dhall::{Config, MachineDescription, ModuleConfig};
mod dhall;
struct ConfigBuilder; #[derive(Debug, Error, Diagnostic)]
impl ConfigBuilder { pub enum ConfigError {
#[error("The config file '{0}' does not exist or is not readable")]
#[diagnostic(
code(config::notfound),
help("Make sure the config file and the directory it's in are readable by the user running bffh")
)]
NotFound(String),
#[error("The path '{0}' does not point to a file")]
#[diagnostic(
code(config::notafile),
help("The config must be a file in the dhall format")
)]
NotAFile(String),
#[error("failed to parse config: {0}")]
#[diagnostic(code(config::parse))]
Parse(
#[from]
#[source]
serde_dhall::Error,
),
} }
pub fn read(file: impl AsRef<Path>) -> Result<Config, ConfigError> {
let path = file.as_ref();
if !path.exists() {
return Err(ConfigError::NotFound(path.to_string_lossy().to_string()));
}
if !path.is_file() {
return Err(ConfigError::NotAFile(path.to_string_lossy().to_string()));
}
let mut config = dhall::read_config_file(file)?;
for (envvar, value) in std::env::vars() {
match envvar.as_str() {
// Do things like this?
// "BFFH_LOG" => config.logging.filter = Some(value),
_ => {}
}
}
Ok(config)
}

View File

@ -135,7 +135,7 @@ fn main() -> miette::Result<()> {
} }
} }
let mut config = config::read(&PathBuf::from_str(configpath).unwrap()).unwrap(); let mut config = config::read(&PathBuf::from_str(configpath).unwrap())?;
if matches.is_present("dump") { if matches.is_present("dump") {
return Err(miette::miette!("DB Dumping is currently not implemented, except for the users db, using `--dump-users`")); return Err(miette::miette!("DB Dumping is currently not implemented, except for the users db, using `--dump-users`"));