[bot-base] Faut pas sauvegarder quand on initialise les valeurs par défaut, sinon ca sert à rien de sauvegarder une config

[config] Ajout de la possibilité de ne pas sauvegarder
This commit is contained in:
Louis Chauvet 2020-04-27 13:35:26 +02:00
parent 517b5fed23
commit 8dd9ff86a3
Signed by: fomys
GPG Key ID: 1ECA046A9615ABA0
5 changed files with 45 additions and 22 deletions

View File

@ -12,6 +12,7 @@ toml = "*"
pytest = "*" pytest = "*"
sphinx = "*" sphinx = "*"
sphinx-rtd-theme = "*" sphinx-rtd-theme = "*"
watchgod = "*"
[requires] [requires]
python_version = "3.8" python_version = "3.8"

10
Pipfile.lock generated
View File

@ -1,7 +1,7 @@
{ {
"_meta": { "_meta": {
"hash": { "hash": {
"sha256": "56274993c51b422f6d178e8a21bbf669b8b508facb513d6c63f3373ebf707863" "sha256": "267e2db73eae9033f8531715235a968fe4ddd2ca4f09ccc266d5f6da869acb23"
}, },
"pipfile-spec": 6, "pipfile-spec": 6,
"requires": { "requires": {
@ -486,6 +486,14 @@
], ],
"version": "==1.25.9" "version": "==1.25.9"
}, },
"watchgod": {
"hashes": [
"sha256:59700dab7445aa8e6067a5b94f37bae90fc367554549b1ed2e9d0f4f38a90d2a",
"sha256:e9cca0ab9c63f17fc85df9fd8bd18156ff00aff04ebe5976cee473f4968c6858"
],
"index": "pypi",
"version": "==0.6"
},
"wcwidth": { "wcwidth": {
"hashes": [ "hashes": [
"sha256:cafe2186b3c009a04067022ce1dcd79cb38d8d65ee4f4791b8888d6599d1bbe1", "sha256:cafe2186b3c009a04067022ce1dcd79cb38d8d65ee4f4791b8888d6599d1bbe1",

View File

@ -45,7 +45,7 @@ class BotBase(discord.Client):
"modules": [], "modules": [],
"data_folder": data_folder, "data_folder": data_folder,
"modules_folder": modules_folder, "modules_folder": modules_folder,
}) }, no_save=True)
self.config.load() self.config.load()

View File

@ -15,7 +15,7 @@ class Config:
#: :class:`typing.Type` [:class:`BaseType`]: Current fields #: :class:`typing.Type` [:class:`BaseType`]: Current fields
fields: typing.Dict[str, BaseType] fields: typing.Dict[str, BaseType]
def __init__(self, path: str) -> None: def __init__(self, path: typing.Optional[str]) -> None:
""" """
Create config object Create config object
@ -45,7 +45,7 @@ class Config:
name: type_() name: type_()
}) })
def set(self, values: dict) -> None: def set(self, values: dict, no_save: bool = False) -> None:
""" """
Set all parameters with values (and override old ones) Set all parameters with values (and override old ones)
@ -54,17 +54,21 @@ class Config:
>>> from config.config_types import factory, Int >>> from config.config_types import factory, Int
>>> config = Config("doctest_config.toml") >>> config = Config("doctest_config.toml")
>>> config.register("my_parameter", factory(Int)) >>> config.register("my_parameter", factory(Int))
>>> config.set({"my_parameter": 3}) >>> config.set({"my_parameter": 3}) #doctest: +SKIP
>>> config.set({"my_parameter": 4}, no_save=True)
:type values: dict :type values: dict
:param values: dict of parameters :param values: dict of parameters
""" """
for k, v in values.items(): for k, v in values.items():
try: try:
self.fields[k].set(v) self.fields[k].set(v)
except KeyError: except KeyError:
# TODO: trouver un moyen de warn # TODO: trouver un moyen de warn
pass pass
if not no_save:
self.save()
def save(self) -> None: def save(self) -> None:
""" """
@ -75,12 +79,13 @@ class Config:
>>> from config.config_types import factory, Int >>> from config.config_types import factory, Int
>>> config = Config("doctest_config.toml") >>> config = Config("doctest_config.toml")
>>> config.register("my_parameter", factory(Int)) >>> config.register("my_parameter", factory(Int))
>>> config.set({"my_parameter": 3}) >>> config.set({"my_parameter": 3}) #doctest: +SKIP
>>> config.save() #doctest: +SKIP >>> config.save() #doctest: +SKIP
""" """
os.makedirs(os.path.dirname(self.path), exist_ok=True) if self.path is not None:
with open(self.path, 'w') as file: os.makedirs(os.path.dirname(self.path), exist_ok=True)
toml.dump({k: v.to_save() for k, v in self.fields.items()}, file) with open(self.path, 'w') as file:
toml.dump({k: v.to_save() for k, v in self.fields.items()}, file)
def load(self) -> None: def load(self) -> None:
""" """
@ -91,7 +96,7 @@ class Config:
>>> from config.config_types import factory, Int >>> from config.config_types import factory, Int
>>> config = Config("doctest_config.toml") >>> config = Config("doctest_config.toml")
>>> config.register("my_parameter", factory(Int)) >>> config.register("my_parameter", factory(Int))
>>> config.set({"my_parameter": 3}) >>> config.set({"my_parameter": 3}) #doctest: +SKIP
>>> config.save() #doctest: +SKIP >>> config.save() #doctest: +SKIP
>>> new_config = Config("doctest_config.toml") >>> new_config = Config("doctest_config.toml")
>>> new_config.register("my_parameter", factory(Int)) >>> new_config.register("my_parameter", factory(Int))
@ -101,12 +106,13 @@ class Config:
:return: None :return: None
""" """
try: if self.path is not None:
with open(self.path, 'r') as file: try:
self.set(toml.load(file)) with open(self.path, 'r') as file:
except FileNotFoundError: self.set(toml.load(file))
pass except FileNotFoundError:
self.save() pass
self.save()
def __getitem__(self, item: str) -> typing.Any: def __getitem__(self, item: str) -> typing.Any:
""" """
@ -119,8 +125,12 @@ class Config:
>>> from config.config_types import factory, Int >>> from config.config_types import factory, Int
>>> config = Config("doctest_config.toml") >>> config = Config("doctest_config.toml")
>>> config.register("my_parameter", factory(Int)) >>> config.register("my_parameter", factory(Int))
>>> config.set({"my_parameter": 3}) >>> config.set({"my_parameter": 3}) #doctest: +SKIP
>>> print(config["my_parameter"]) >>> print(config["my_parameter"]) #doctest: +SKIP
3 3
""" """
self.load()
return self.fields[item].get() return self.fields[item].get()
def __str__(self):
return f"<Config with fields <{', '.join(f'{k} = {v}' for k, v in self.fields.items())}>>"

View File

@ -22,10 +22,10 @@ def setup_logging(default_path='data/log_config.json', default_level=logging.INF
logging.basicConfig(level=default_level) logging.basicConfig(level=default_level)
setup_logging() def main():
setup_logging()
if __name__ == "__main__": client = BotBase(max_messages=500000, data_folder="datas",
client = BotBase(max_messages=500000, data_folder="datas", modules_folder=os.environ.get("LOCAL_MODULES", "modules")) modules_folder=os.environ.get("LOCAL_MODULES", "modules"))
async def start_bot(): async def start_bot():
await client.start(os.environ.get("DISCORD_TOKEN")) await client.start(os.environ.get("DISCORD_TOKEN"))
@ -33,3 +33,7 @@ if __name__ == "__main__":
loop = asyncio.get_event_loop() loop = asyncio.get_event_loop()
loop.create_task(start_bot()) loop.create_task(start_bot())
loop.run_forever() loop.run_forever()
if __name__ == "__main__":
main()