ClonerConfig + tests
Signed-off-by: Václav Valíček <valicek1994@gmail.com>
This commit is contained in:
42
repo_cloner/lib/cloner_config.py
Normal file
42
repo_cloner/lib/cloner_config.py
Normal file
@@ -0,0 +1,42 @@
|
||||
from repo_cloner.lib.default_cloner_config import DefaultClonerConfig
|
||||
|
||||
|
||||
class ClonerConfig(DefaultClonerConfig):
|
||||
def __init__(self):
|
||||
super().__init__()
|
||||
self.__properties = list(filter(self.has_property, dir(self)))
|
||||
self.__values = {}
|
||||
|
||||
def __try_default(self, key: str, default_value):
|
||||
if not self.has_property(key):
|
||||
raise KeyError(f"{key} is not recognized config option")
|
||||
if key in self.__values:
|
||||
return self.__values[key]
|
||||
return default_value
|
||||
|
||||
@property
|
||||
def cloner_project_name(self) -> str:
|
||||
return self.__try_default("cloner_project_name", super(ClonerConfig, self).cloner_project_name)
|
||||
|
||||
@property
|
||||
def cloner_repo_url(self) -> str:
|
||||
return self.__try_default("cloner_repo_url", super(ClonerConfig, self).cloner_repo_url)
|
||||
|
||||
@property
|
||||
def cloner_interval(self) -> int:
|
||||
return self.__try_default("cloner_interval", super(ClonerConfig, self).cloner_interval)
|
||||
|
||||
@property
|
||||
def cloner_submodules(self) -> bool:
|
||||
return self.__try_default("cloner_submodules", super(ClonerConfig, self).cloner_submodules)
|
||||
|
||||
@property
|
||||
def cloner_submodule_depth(self) -> int:
|
||||
return self.__try_default("cloner_submodule_depth", super(ClonerConfig, self).cloner_submodule_depth)
|
||||
|
||||
def _set_property(self, key: str, value):
|
||||
if not self.has_property(key):
|
||||
raise KeyError(f"{key} is not recognized config option")
|
||||
if not isinstance(value, type(self.__getattribute__(key))):
|
||||
raise ValueError(f"Invalid value for key {key}: type is {type(value)}")
|
||||
self.__values[key] = value
|
||||
@@ -1,6 +1,6 @@
|
||||
class DefaultClonerConfig:
|
||||
def __init__(self):
|
||||
properties = list(filter(lambda prop: not str(prop).startswith("__"), dir(self)))
|
||||
properties = list(filter(lambda prop: not str(prop).startswith("_"), dir(self)))
|
||||
self.__properties: list = properties
|
||||
|
||||
@property
|
||||
|
||||
@@ -1,8 +1,25 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
import argparse
|
||||
import os
|
||||
|
||||
from repo_cloner.lib.repo_dir_structure import RepoDirStructure
|
||||
from git.config import GitConfigParser
|
||||
import logging as l
|
||||
|
||||
l.basicConfig(level = 0)
|
||||
|
||||
|
||||
def config_try_override(config_writer: GitConfigParser, section: str, option: str, value: str):
|
||||
if not section in config_writer.sections():
|
||||
l.debug(f"CFG Creating section: {section}")
|
||||
config_writer.add_section(section)
|
||||
if not config_writer.has_option(section, option):
|
||||
l.debug(f"CFG Creating option: {option}")
|
||||
config_writer.add_value(section, option, "")
|
||||
|
||||
l.debug(f"Setting {section}.{option} = {value}")
|
||||
config_writer.set(section, option, value)
|
||||
|
||||
|
||||
def main():
|
||||
@@ -13,9 +30,27 @@ def main():
|
||||
args = parser.parse_args()
|
||||
|
||||
dirs = RepoDirStructure(args.base_dir)
|
||||
print(dirs)
|
||||
dirs.exists
|
||||
|
||||
os.environ['XDG_CONFIG_HOME'] = dirs.conf_dir
|
||||
|
||||
from git import Repo
|
||||
r = Repo("/home/vasek/dev/repo-cloner")
|
||||
path: str = r._get_config_path("user")
|
||||
print(path)
|
||||
path = os.path.dirname(path)
|
||||
print(path)
|
||||
if not os.path.isdir(path):
|
||||
os.mkdir(path)
|
||||
|
||||
cred_store: str = os.path.join(path, "git-credentials")
|
||||
ssh_identity: str = os.path.join(dirs.conf_dir, "ssh", "identity")
|
||||
|
||||
with r.config_writer("user") as cfgw:
|
||||
config_try_override(cfgw, "credential", "helper", f"store --file={cred_store}")
|
||||
config_try_override(cfgw, "core", "sshcommand",
|
||||
f"ssh -i {ssh_identity} -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o BatchMode=yes -q")
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
|
||||
main()
|
||||
|
||||
Reference in New Issue
Block a user