From 962c2eab86e9dc543c90c95a153eed43cce77ead Mon Sep 17 00:00:00 2001 From: piair Date: Tue, 27 Feb 2024 00:33:08 +0100 Subject: [PATCH] created user management class --- modules/Classes/UserCredentials.py | 45 ++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 modules/Classes/UserCredentials.py diff --git a/modules/Classes/UserCredentials.py b/modules/Classes/UserCredentials.py new file mode 100644 index 0000000..5986bfa --- /dev/null +++ b/modules/Classes/UserCredentials.py @@ -0,0 +1,45 @@ +import json +from modules.Tools.logger import debug, warning + + +class UserCredentials: + def __init__(self, config_id: int): + self.data = {} + self.current = 0 + self.total = 0 + with open("/app/MsRewards-Reborn/user_data/configs.json", "r") as inFile: + configs = json.load(inFile) + for i in configs[str(config_id)]["accounts"]: + d = configs[str(config_id)]["accounts"][i] + self.add(d["mail"], d["pwd"], d["2fa"]) + debug(f"Initiated UserCredentials.") + + def add(self, username: str, password: str, tfa: str = None): + debug(f"adding account with data : Username: {username}, Password: {password}, 2FA: {'None' if tfa == '' else tfa}") + self.data[self.total] = { + "username": username, + "password": password, + "2fa": None if tfa == '' else tfa + } + self.total += 1 + + def tfa_enable(self): + return self.data[self.current]["2fa"] is not None + + def get_mail(self): + return self.data[self.current]["username"] + + def get_password(self): + return self.data[self.current]["password"] + + def get_tfa(self): + if not self.tfa_enable(): + warning("Warning: TFA is not enabled. Calling get_tfa is an expected behaviour.") + return self.data[self.current]["tfa"] + + def next_account(self): + self.current += 1 + debug(f"New credentials: {self.data[self.current]}") + + def is_valid(self): + return self.current < self.total