£Á°èZ¨Ä…–K§‚«“ô4“ÒÙ´dîfUÙÃÅ WKbyʦ•ꎅȮFÒ¿ÊÎóCozá¬S@6{Í:›œêZÌ:Š•_%:¢¾¾~;‘Ã~芩ÊÇí`ÔÑ©ú뙵'5I¿fš×WO%ø9¾«¾DK|€ùÍD”Ýs]nHÕ¶ê×Ӽ㞪éUWŸÈË%DÒÕ¬ï‘]/Åcx ‰ï2ß]ä6G[]S£Ôϯrs{úëóµmÒï#UQxo·õÞCe]"±/aÙ&Eã4ú9Jé_ÞåëdãöKë)AÞ ¯¹ægƒÛowÐø^d™ý½ßB7áyMä9ÜÖUã
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
"""
This program is free software: you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License,
or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see .
Copyright © 2019 Cloud Linux Software Inc.
This software is also available under ImunifyAV commercial license,
see
"""
import configparser
from pathlib import Path
from typing import Optional
class PatchmanConfig:
PATH = Path("/etc/patchman/patchman.ini")
@classmethod
def _get_config(cls) -> dict:
conf = configparser.ConfigParser()
if cls.PATH.exists():
conf.read(cls.PATH)
return conf
@classmethod
def get(cls, section: str, option: str, default=None) -> Optional[str]:
"""
Return *option* value in *section* in config if exist,
None otherwise.
"""
conf = cls._get_config()
try:
return conf.get(section, option)
except configparser.Error:
return default
@classmethod
def set(cls, section: str, option: str, value: str) -> None:
"""
Set *value* for the *option* of the corresponding *section*
in the patchman config.
"""
conf = cls._get_config()
if not conf.has_section(section):
conf.add_section(section)
conf.set(section, option, value)
with cls.PATH.open("w") as config_file:
conf.write(config_file)