fishyboteso/fishy/__main__.py

99 lines
2.7 KiB
Python
Raw Normal View History

import ctypes
import logging
import os
import sys
import traceback
import win32con
import win32gui
import fishy
from fishy import web, helper, gui
from fishy.engine.common.event_handler import EngineEventHandler
2021-02-14 18:07:49 +00:00
from fishy.gui import GUI, splash, update_dialog
2020-10-17 19:06:07 +00:00
from fishy.helper import hotkey
from fishy.helper.config import config
2021-03-24 16:58:35 +00:00
from fishy.constants import chalutier, lam2
def check_window_name(title):
titles = ["Command Prompt", "PowerShell", "Fishy"]
for t in titles:
if t in title:
return True
return False
# noinspection PyBroadException
2020-10-17 19:06:07 +00:00
def initialize(window_to_hide):
helper.create_shortcut_first()
helper.initialize_uid()
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")
print(f"created session {new_session}")
try:
is_admin = os.getuid() == 0
except AttributeError:
is_admin = ctypes.windll.shell32.IsUserAnAdmin() != 0
if is_admin:
logging.info("Running with admin privileges")
try:
2021-02-14 18:07:49 +00:00
if helper.upgrade_avail() and not config.get("dont_ask_update", False):
cv,hv = helper.versions()
update_now, dont_ask_update = update_dialog.start(cv,hv)
if dont_ask_update:
config.set("dont_ask_update", dont_ask_update)
else:
config.delete("dont_ask_update")
if update_now:
helper.auto_upgrade()
except Exception:
logging.error(traceback.format_exc())
2020-10-17 19:06:07 +00:00
if not config.get("debug", False) and check_window_name(win32gui.GetWindowText(window_to_hide)):
win32gui.ShowWindow(window_to_hide, win32con.SW_HIDE)
helper.install_thread_excepthook()
sys.excepthook = helper.unhandled_exception_logging
2021-03-26 09:34:01 +00:00
if not config.get("addoninstalled", 0) or helper.get_addonversion(chalutier[0]) < chalutier[2]:
2021-03-24 16:58:35 +00:00
helper.install_addon(*chalutier)
helper.install_addon(*lam2)
2021-03-26 09:34:01 +00:00
helper.remove_addon("ProvisionsChalutier") #TODO delete with fishy 0.4.6
2021-03-28 19:36:55 +00:00
helper.remove_addon("FooAddon") #TODO delete with fishy 0.4.6
2021-03-26 09:34:01 +00:00
config.set("addoninstalled", helper.get_addonversion(chalutier[0]))
def main():
config.init()
splash.start()
print("launching please wait...")
pil_logger = logging.getLogger('PIL')
pil_logger.setLevel(logging.INFO)
window_to_hide = win32gui.GetForegroundWindow()
2020-10-17 19:06:07 +00:00
if not gui.check_eula():
return
2020-10-17 19:06:07 +00:00
bot = EngineEventHandler(lambda: gui_window)
gui_window = GUI(lambda: bot)
hotkey.initalize()
logging.info(f"Fishybot v{fishy.__version__}")
2020-10-17 19:06:07 +00:00
initialize(window_to_hide)
2021-02-14 18:07:12 +00:00
gui_window.start()
bot.start_event_handler()
config.stop()
if __name__ == "__main__":
main()