RcGcDw/src/migrations/11311.py

48 lines
1.6 KiB
Python
Raw Permalink Normal View History

2021-04-17 14:13:24 +00:00
from src.configloader import settings, load_settings
from src.argparser import command_args
2021-04-17 14:13:24 +00:00
import logging
import shutil
import time
import json
import sys
from src.migrations.utils import return_example_file
logger = logging.getLogger("rcgcdw.migrations.1.13.1.1")
new_settings = settings.copy()
2023-01-10 21:36:20 +00:00
2021-04-17 14:13:24 +00:00
def run():
if "event_appearance" not in settings:
logger.info("Running migration 1.13.1.1")
base_file = return_example_file()
2021-04-17 14:13:24 +00:00
if "event_appearance" not in base_file: # if local base file is outdated, download from repo
base_file = return_example_file(force=True)
try:
struct = settings['appearance']['embed']
new_settings["event_appearance"] = {}
keys = []
for key, value in struct.items():
if key not in ("show_edit_changes", "show_footer", "embed_images"):
new_settings["event_appearance"][key] = value
try:
new_settings["event_appearance"][key]["emoji"] = base_file["event_appearance"][key]["emoji"]
except KeyError:
new_settings["event_appearance"][key]["emoji"] = ""
keys.append(key)
for item in keys:
del new_settings['appearance']['embed'][item]
except KeyError:
logger.exception("Failed to migrate appearance embed.")
sys.exit(1)
2023-01-10 21:36:20 +00:00
shutil.copy(command_args.settings.name, "{}.{}.bak".format(command_args.settings.name, int(time.time())))
with open(command_args.settings.name, "w", encoding="utf-8") as new_write:
2021-04-17 14:13:24 +00:00
new_write.write(json.dumps(new_settings, indent=4))
load_settings()
logger.info("Migration 1.13.1.1 has been successful.")
else:
logger.debug("Ignoring migration 1.13.1.1")
run()