confighelper: remove "orig section" tracking

This isn't necessary as we don't add new sections to the
original config object when parsing supplemental data.

Signed-off-by:  Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
Eric Callahan 2022-04-04 20:44:50 -04:00
parent 5f5f40293e
commit f27daac4f4
No known key found for this signature in database
GPG Key ID: 7027245FBBDDF59A
1 changed files with 14 additions and 19 deletions

View File

@ -47,13 +47,11 @@ class ConfigHelper:
server: Server, server: Server,
config: configparser.ConfigParser, config: configparser.ConfigParser,
section: str, section: str,
orig_sects: List[str],
parsed: Dict[str, Dict[str, ConfigVal]] = {} parsed: Dict[str, Dict[str, ConfigVal]] = {}
) -> None: ) -> None:
self.server = server self.server = server
self.config = config self.config = config
self.section = section self.section = section
self.orig_sections = orig_sects
self.parsed = parsed self.parsed = parsed
if self.section not in self.parsed: if self.section not in self.parsed:
self.parsed[self.section] = {} self.parsed[self.section] = {}
@ -94,8 +92,7 @@ class ConfigHelper:
def getsection(self, section: str) -> ConfigHelper: def getsection(self, section: str) -> ConfigHelper:
if section not in self.config: if section not in self.config:
raise ConfigError(f"No section [{section}] in config") raise ConfigError(f"No section [{section}] in config")
return ConfigHelper(self.server, self.config, section, return ConfigHelper(self.server, self.config, section, self.parsed)
self.orig_sections, self.parsed)
def _get_option(self, def _get_option(self,
func: Callable[..., Any], func: Callable[..., Any],
@ -126,16 +123,15 @@ class ConfigHelper:
"deprecated, see the configuration documention " "deprecated, see the configuration documention "
"at https://moonraker.readthedocs.io") "at https://moonraker.readthedocs.io")
self._check_option(option, val, above, below, minval, maxval) self._check_option(option, val, above, below, minval, maxval)
if self.section in self.orig_sections: # Only track sections included in the original config
# Only track sections included in the original config if (
if ( val is None or
val is None or isinstance(val, (int, float, bool, str, dict, list))
isinstance(val, (int, float, bool, str, dict, list)) ):
): self.parsed[self.section][option] = val
self.parsed[self.section][option] = val else:
else: # If the item cannot be encoded to json serialize to a string
# If the item cannot be encoded to json serialize to a string self.parsed[self.section][option] = str(val)
self.parsed[self.section][option] = str(val)
return val return val
def _check_option(self, def _check_option(self,
@ -383,7 +379,7 @@ class ConfigHelper:
except Exception: except Exception:
raise ConfigError("Error Reading Object") raise ConfigError("Error Reading Object")
sections = sup_cfg.sections() sections = sup_cfg.sections()
return ConfigHelper(self.server, sup_cfg, sections[0], sections) return ConfigHelper(self.server, sup_cfg, sections[0])
def read_supplemental_config(self, file_name: str) -> ConfigHelper: def read_supplemental_config(self, file_name: str) -> ConfigHelper:
cfg_file_path = os.path.normpath(os.path.expanduser(file_name)) cfg_file_path = os.path.normpath(os.path.expanduser(file_name))
@ -396,7 +392,7 @@ class ConfigHelper:
except Exception: except Exception:
raise ConfigError(f"Error Reading Config: '{cfg_file_path}'") raise ConfigError(f"Error Reading Config: '{cfg_file_path}'")
sections = sup_cfg.sections() sections = sup_cfg.sections()
return ConfigHelper(self.server, sup_cfg, sections[0], sections) return ConfigHelper(self.server, sup_cfg, sections[0])
def write_config(self, file_obj: IO[str]) -> None: def write_config(self, file_obj: IO[str]) -> None:
self.config.write(file_obj) self.config.write(file_obj)
@ -405,7 +401,7 @@ class ConfigHelper:
return dict(self.parsed) return dict(self.parsed)
def validate_config(self) -> None: def validate_config(self) -> None:
for sect in self.orig_sections: for sect in self.config.sections():
if sect not in self.parsed: if sect not in self.parsed:
self.server.add_warning( self.server.add_warning(
f"Unparsed config section [{sect}] detected. This " f"Unparsed config section [{sect}] detected. This "
@ -442,8 +438,7 @@ def get_configuration(server: Server,
raise ConfigError(f"Error Reading Config: '{cfg_file_path}'") from e raise ConfigError(f"Error Reading Config: '{cfg_file_path}'") from e
if not config.has_section('server'): if not config.has_section('server'):
raise ConfigError("No section [server] in config") raise ConfigError("No section [server] in config")
orig_sections = config.sections() return ConfigHelper(server, config, 'server')
return ConfigHelper(server, config, 'server', orig_sections)
def backup_config(cfg_path: str) -> None: def backup_config(cfg_path: str) -> None:
cfg = pathlib.Path(cfg_path).expanduser().resolve() cfg = pathlib.Path(cfg_path).expanduser().resolve()