Merge pull request #56 from fishyboteso/feature/config-backup

Config backup system
This commit is contained in:
Semjon Kerner 2021-04-07 21:31:06 +02:00 committed by GitHub
commit 757a245b3c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 109 additions and 44 deletions

View File

@ -68,6 +68,7 @@ def initialize(window_to_hide):
def main():
config.init()
splash.start()
print("launching please wait...")
@ -90,6 +91,7 @@ def main():
gui_window.start()
bot.start_event_handler()
config.stop()
if __name__ == "__main__":

View File

@ -7,7 +7,7 @@ from fishy.helper.config import config
from fishy.helper import helper
def show():
def show(win_loc):
dim=(300,200)
top = Tk()
@ -25,8 +25,10 @@ def show():
canvas.create_image(0, 0, anchor=NW, image=top.image)
# Position splash at the center of the main window
win_loc = config.get("win_loc", str(top.winfo_reqwidth())+"+"+str(top.winfo_reqheight())+"+"+"0"+"0").split("+")[1:]
top.geometry("{}x{}+{}+{}".format(dim[0], dim[1], int(win_loc[0])+int(dim[0]/2), int(win_loc[1])+int(dim[1]/2)))
default_loc = (str(top.winfo_reqwidth())+"+"+str(top.winfo_reqheight())+"+"+"0"+"0")
loc = (win_loc or default_loc).split("+")[1:]
top.geometry("{}x{}+{}+{}".format(dim[0], dim[1], int(loc[0])+int(dim[0]/2), int(loc[1])+int(dim[1]/2)))
top.update()
time.sleep(3)
@ -34,4 +36,4 @@ def show():
def start():
Process(target=show).start()
Process(target=show, args=(config.get("win_loc"),)).start()

View File

@ -3,9 +3,12 @@ config.py
Saves configuration in file as json file
"""
import json
import logging
import os
# path to save the configuration file
from typing import Optional
from event_scheduler import EventScheduler
def filename():
@ -18,53 +21,60 @@ def filename():
return os.path.join(get_documents(), name)
temp_file = os.path.join(os.environ["TEMP"], "fishy_config.BAK")
class Config:
def __init__(self):
"""
cache the configuration in a dict for faster access,
if file is not found initialize the dict
"""
self.config_dict = json.loads(open(filename()).read()) if os.path.exists(filename()) else dict()
self._config_dict: Optional[dict] = None
self._scheduler: Optional[EventScheduler] = None
def get(self, key, default=None):
"""
gets a value from configuration,
if it is not found, return the default configuration
:param key: key of the config
:param default: default value to return if key is not found
:return: config value
"""
return self.config_dict[key] if key in self.config_dict else default
def __getitem__(self, item):
return self._config_dict.get(item)
def set(self, key, value, save=True):
"""
saves the configuration is cache (and saves it in file if needed)
:param key: key to save
:param value: value to save
:param save: False if don't want to save right away
"""
self.config_dict[key] = value
if save:
self.save_config()
def __setitem__(self, key, value):
self._config_dict[key] = value
def __delitem__(self, key):
del self._config_dict[key]
def initialize(self):
self._scheduler = EventScheduler()
if os.path.exists(filename()):
def delete(self, key):
"""
deletes a key from config
:param key: key to delete
"""
try:
del self.config_dict[key]
self._config_dict = json.loads(open(filename()).read())
except json.JSONDecodeError:
try:
print("Config file got corrupted, trying to restore backup")
self._config_dict = json.loads(open(temp_file).read())
self.save_config()
except KeyError:
pass
except (FileNotFoundError, json.JSONDecodeError):
print("couldn't restore, creating new")
os.remove(filename())
self._config_dict = dict()
else:
self._config_dict = dict()
self._create_backup()
self._scheduler.start()
self._scheduler.enter_recurring(5 * 60, 1, self._create_backup)
def stop(self):
self._scheduler.stop(True)
def _create_backup(self):
with open(temp_file, 'w') as f:
f.write(json.dumps(self._config_dict))
print("created backup")
def _sort_dict(self):
tmpdict = dict()
for key in sorted(self.config_dict.keys()):
tmpdict[key] = self.config_dict[key]
self.config_dict = tmpdict
for key in sorted(self._config_dict.keys()):
tmpdict[key] = self._config_dict[key]
self._config_dict = tmpdict
def save_config(self):
"""
@ -72,7 +82,57 @@ class Config:
"""
self._sort_dict()
with open(filename(), 'w') as f:
f.write(json.dumps(self.config_dict))
f.write(json.dumps(self._config_dict))
config = Config()
# noinspection PyPep8Naming
class config:
_instance = None
@staticmethod
def init():
config._instance = Config()
config._instance.initialize()
@staticmethod
def stop():
config._instance.stop()
@staticmethod
def get(key, default=None):
"""
gets a value from configuration,
if it is not found, return the default configuration
:param key: key of the config
:param default: default value to return if key is not found
:return: config value
"""
return default if config._instance[key] is None else config._instance[key]
@staticmethod
def set(key, value, save=True):
"""
saves the configuration is cache (and saves it in file if needed)
:param key: key to save
:param value: value to save
:param save: False if don't want to save right away
"""
config._instance[key] = value
if save:
config.save_config()
@staticmethod
def delete(key):
"""
deletes a key from config
:param key: key to delete
"""
try:
del config._instance[key]
config.save_config()
except KeyError:
pass
@staticmethod
def save_config():
config._instance.save_config()

View File

@ -13,3 +13,4 @@ pynput
pytesseract
keyboard
playsound
event-scheduler