From 6fe99d33009aad17dc46dd13a7e3d4d9de5a63f2 Mon Sep 17 00:00:00 2001 From: Adam Saudagar Date: Sun, 7 Mar 2021 14:10:45 +0530 Subject: [PATCH] update uid on discord login, and fetch uid from config (never cache it) --- fishy/engine/semifisher/fishing_event.py | 3 +- fishy/gui/config_top.py | 6 ++-- fishy/gui/discord_login.py | 4 +-- fishy/gui/main_gui.py | 2 +- fishy/web/web.py | 39 +++++++++++++----------- 5 files changed, 29 insertions(+), 25 deletions(-) diff --git a/fishy/engine/semifisher/fishing_event.py b/fishy/engine/semifisher/fishing_event.py index 7c458ce..4af6c50 100644 --- a/fishy/engine/semifisher/fishing_event.py +++ b/fishy/engine/semifisher/fishing_event.py @@ -33,7 +33,6 @@ class FishEvent: # initialize these action_key = 'e' collect_allow_auto = False - uid = None sound = False @@ -117,7 +116,7 @@ def on_look(): def on_idle(): if FishEvent.fishCaught > 0: - web.send_hole_deplete(FishEvent.uid, FishEvent.fishCaught, time.time() - FishEvent.hole_start_time, + web.send_hole_deplete(FishEvent.fishCaught, time.time() - FishEvent.hole_start_time, FishEvent.fish_times) FishEvent.fishCaught = 0 diff --git a/fishy/gui/config_top.py b/fishy/gui/config_top.py index 52df1cb..51ede8b 100644 --- a/fishy/gui/config_top.py +++ b/fishy/gui/config_top.py @@ -59,10 +59,10 @@ def start_semifisher_config(gui: 'GUI'): def toggle_sub(): if web.is_subbed(config.get("uid"))[0]: - if web.unsub(config.get("uid")): + if web.unsub(): gui._notify.set(0) else: - if web.sub(config.get("uid")): + if web.sub(): gui._notify.set(1) def toggle_collect(): @@ -83,7 +83,7 @@ def start_semifisher_config(gui: 'GUI'): gui._notify_check = Checkbutton(controls_frame, command=toggle_sub, variable=gui._notify) gui._notify_check.grid(row=0, column=1) gui._notify_check['state'] = DISABLED - is_subbed = web.is_subbed(config.get('uid')) + is_subbed = web.is_subbed() if is_subbed[1]: gui._notify_check['state'] = NORMAL gui._notify.set(is_subbed[0]) diff --git a/fishy/gui/discord_login.py b/fishy/gui/discord_login.py index cdbfee5..8de3914 100644 --- a/fishy/gui/discord_login.py +++ b/fishy/gui/discord_login.py @@ -18,8 +18,8 @@ if typing.TYPE_CHECKING: # noinspection PyProtectedMember def discord_login(gui: 'GUI'): - if web.is_logged_in(config.get("uid")): - if web.logout(config.get("uid")): + if web.is_logged_in(): + if web.logout(): gui.login.set(0) return diff --git a/fishy/gui/main_gui.py b/fishy/gui/main_gui.py index 4a6184f..903e3f2 100644 --- a/fishy/gui/main_gui.py +++ b/fishy/gui/main_gui.py @@ -39,7 +39,7 @@ def _create(gui: 'GUI'): filemenu = Menu(menubar, tearoff=0) - login = web.is_logged_in(config.get('uid')) + login = web.is_logged_in() gui.login = IntVar() gui.login.set(1 if login > 0 else 0) state = DISABLED if login == -1 else ACTIVE diff --git a/fishy/web/web.py b/fishy/web/web.py index a59f62d..233aea5 100644 --- a/fishy/web/web.py +++ b/fishy/web/web.py @@ -11,11 +11,11 @@ _session_id = None @fallback(-1) -def is_logged_in(uid): - if uid is None: +def is_logged_in(): + if config.get("uid") is None: return -1 - body = {"uid": uid} + body = {"uid": config.get("uid")} response = requests.get(urls.discord, params=body) logged_in = response.json()["discord_login"] return 1 if logged_in else 0 @@ -29,13 +29,17 @@ def login(uid, login_code): } reponse = requests.post(urls.discord, json=body) result = reponse.json() + + if "new_id" in result: + config.set("uid", result["new_id"]) + return result["success"] @fallback(False) -def logout(uid): +def logout(): body = { - "uid": uid, + "uid": config.get("uid"), } reponse = requests.delete(urls.discord, json=body) result = reponse.json() @@ -43,15 +47,16 @@ def logout(uid): @fallback(False) -def register_user(uid): +def register_user(new_uid): ip = get_ip(GoogleDnsProvider) - body = {"uid": uid, "ip": ip} + body = {"uid": new_uid, "ip": ip} response = requests.post(urls.user, json=body) return response.ok and response.json()["success"] @fallback(None) def send_notification(uid, message): + # todo clean dead code if not is_subbed(uid): return False @@ -61,38 +66,38 @@ def send_notification(uid, message): @uses_session @fallback(None) -def send_hole_deplete(uid, fish_caught, hole_time, fish_times): +def send_hole_deplete(fish_caught, hole_time, fish_times): hole_data = { "fish_caught": fish_caught, "hole_time": hole_time, "fish_times": fish_times, - "session": get_session(uid) + "session": get_session() } - body = {"uid": uid, "hole_data": hole_data} + body = {"uid": config.get("uid"), "hole_data": hole_data} requests.post(urls.hole_depleted, json=body) @fallback(False) -def sub(uid): - body = {"uid": uid} +def sub(): + body = {"uid": config.get("uid")} response = requests.post(urls.subscription, json=body) result = response.json() return result["success"] @fallback((False, False)) -def is_subbed(uid): +def is_subbed(): """ :param uid: :param lazy: :return: Tuple[is_subbed, success] """ - if uid is None: + if config.get("uid") is None: return False, False - body = {"uid": uid} + body = {"uid": config.get("uid")} response = requests.get(urls.subscription, params=body) if response.status_code != 200: @@ -103,8 +108,8 @@ def is_subbed(uid): @fallback(None) -def unsub(uid): - body = {"uid": uid} +def unsub(): + body = {"uid": config.get("uid")} response = requests.delete(urls.subscription, json=body) result = response.json() return result["success"]