From 0c957de5e5d9de27bdc25cdbb8bdfb1776be3bc7 Mon Sep 17 00:00:00 2001 From: phylax2020 Date: Thu, 5 Jan 2023 10:01:57 +0100 Subject: [PATCH] Copy dashboard files from config folder to config/dashboard when upgrading to version 4.0.7. Detect missing or empty dashboard file in config/dashboard. --- cbpi/configFolder.py | 20 +++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/cbpi/configFolder.py b/cbpi/configFolder.py index be01fc04..043ed2e5 100644 --- a/cbpi/configFolder.py +++ b/cbpi/configFolder.py @@ -8,7 +8,7 @@ import zipfile from pathlib import Path import glob - +import json class ConfigFolder: def __init__(self, configFolderPath, logsFolderPath): @@ -121,9 +121,23 @@ def check_for_setup(self): # if cbpi_dashboard_1.json doesnt exist at the new location (configFolderPath/dashboard) # we move every cbpi_dashboard_n.json file from the old location (configFolderPath) there. # this could be a config zip file restore from version 4.0.7.a4 or prior. - if not (os.path.isfile(os.path.join(self.configFolderPath, 'dashboard', 'cbpi_dashboard_1.json'))): + dashboard_1_path = os.path.join(self.configFolderPath, 'dashboard', 'cbpi_dashboard_1.json') + if (not (os.path.isfile(dashboard_1_path))) or self.check_for_empty_dashboard_1(dashboard_1_path): for file in glob.glob(os.path.join(self.configFolderPath, 'cbpi_dashboard_*.json')): - shutil.move(file, os.path.join(self.configFolderPath, 'dashboard', os.path.basename(file))) + dashboardFile = os.path.basename(file) + print(f"Copy dashboard json file {dashboardFile} from config to config/dashboard folder") + shutil.move(file, os.path.join(self.configFolderPath, 'dashboard', dashboardFile)) + + def check_for_empty_dashboard_1(self, dashboard_1_path): + try: + with open(dashboard_1_path, 'r') as f: + data = json.load(f) + if (len(data['elements']) == 0): # there may exist some pathes but pathes without elements in dashboard is not very likely + return True + else: + return False + except: # file missing or bad json format + return True def inform_missing_content(self, whatsmissing : str): if whatsmissing == "":