fishyboteso/fishy/__main__.py

95 lines
2.3 KiB
Python
Raw Normal View History

import logging
import sys
2021-05-09 07:05:51 +00:00
import fishy
from fishy.gui import GUI, update_dialog, check_eula
from fishy import helper, web
from fishy.engine.common.event_handler import EngineEventHandler
from fishy.gui.log_config import GuiLogger
from fishy.gui.splash import Splash
from fishy.helper import hotkey
2021-05-16 03:04:35 +00:00
from fishy.helper.active_poll import active
2020-10-17 19:06:07 +00:00
from fishy.helper.config import config
2021-05-15 22:40:48 +00:00
from fishy.helper.hotkey.hotkey_process import hotkey
from fishy.helper.migration import Migration
from fishy.osservices.os_services import os_services
# noinspection PyBroadException
def initialize():
Migration.migrate()
if not config.get("shortcut_created", False):
os_services.create_shortcut(False)
config.set("shortcut_created", True)
2020-10-17 19:06:07 +00:00
new_session = web.get_session()
if new_session is None:
logging.error("Couldn't create a session, some features might not work")
logging.debug(f"created session {new_session}")
if os_services.is_admin():
logging.info("Running with admin privileges")
if not config.get("debug", False):
os_services.hide_terminal()
helper.install_thread_excepthook()
sys.excepthook = helper.unhandled_exception_logging
helper.install_required_addons()
def on_gui_load(gui, splash, logger):
splash.finish()
update_dialog.check_update(gui)
logger.connect(gui)
def main():
print("launching please wait...")
if not os_services.init():
print("platform not supported")
return
config.init()
if not check_eula():
return
bot = EngineEventHandler(lambda: gui)
gui = GUI(lambda: bot, lambda: on_gui_load(gui, splash, logger))
logger = GuiLogger()
2021-05-15 22:40:48 +00:00
hotkey.init()
active.init()
2021-05-15 22:40:48 +00:00
try:
config.init()
if not check_eula():
return
logging.info(f"Fishybot v{fishy.__version__}")
splash = Splash().start()
config.start_backup_scheduler()
initialize()
hotkey.start()
gui.start()
active.start()
bot.start_event_handler() # main thread loop
except KeyboardInterrupt:
print("caught KeyboardInterrupt, Stopping main thread")
finally:
gui.stop()
hotkey.stop()
active.stop()
config.stop()
bot.stop()
if __name__ == "__main__":
main()