From 6d0e300e44af787030b1d3723350571350e335eb Mon Sep 17 00:00:00 2001 From: Ishan Jain Date: Tue, 21 Jan 2025 16:28:32 +0530 Subject: [PATCH] fix: create default json config if none exists --- geofw/src/main.rs | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/geofw/src/main.rs b/geofw/src/main.rs index cfe9ea7..d63d533 100644 --- a/geofw/src/main.rs +++ b/geofw/src/main.rs @@ -14,7 +14,7 @@ use maxmind::{Data, ProcessedDb}; use serde_derive::{Deserialize, Serialize}; use std::{ fs::File, - io::{BufReader, ErrorKind, Read}, + io::{BufReader, ErrorKind, Read, Write}, path::PathBuf, }; use tar::Archive; @@ -67,10 +67,18 @@ fn read_config(path: &str) -> Result { serde_json::from_slice(&contents).map_err(|e| e.to_string()) } Err(e) if e.kind() == ErrorKind::NotFound => { - if let Err(e) = File::create(path) { - warn!("error in writing config to {}: {}", path, e); + let def: Config = Default::default(); + match File::create(path) { + Ok(mut f) => { + let json = serde_json::to_string_pretty(&def) + .expect("error in marshalling config to json"); + if let Err(e) = f.write_all(json.as_bytes()) { + warn!("error in writing default config to disk: {}", e); + } + } + Err(e) => warn!("error in writing config to {}: {}", path, e), } - Ok(Default::default()) + Ok(def) } Err(e) => Err(format!("permission denied reading {}: {}", path, e)), }