cleaned up under the hood (better error logic)

This commit is contained in:
piair 2023-03-14 19:54:12 +01:00
parent d0c78d7db1
commit dff47887bc
2 changed files with 48 additions and 49 deletions

76
V5.py
View File

@ -142,7 +142,7 @@ def play_quiz2(override=10) -> None:
except exceptions.ElementNotInteractableException as e: except exceptions.ElementNotInteractableException as e:
driver.execute_script("arguments[0].click();", answer_elem) driver.execute_script("arguments[0].click();", answer_elem)
except Exception as e: except Exception as e:
LogError(f"play_quiz2 {e}", driver, _mail) log_error(e, driver, _mail)
break break
printf("play_quiz2 done") printf("play_quiz2 done")
@ -184,7 +184,7 @@ def play_quiz8(task = None):
correct_answers.append(answer_id) correct_answers.append(answer_id)
except Exception as e: except Exception as e:
LogError(f"play_quiz8 - 4 - {e} \n Good answers : {' '.join(correct_answers)}", driver, _mail) log_error(f"{format_error(e)} \n Good answers : {' '.join(correct_answers)}", driver, _mail)
printf("play_quiz8 : fin ") printf("play_quiz8 : fin ")
@ -211,7 +211,7 @@ def play_quiz4(override=None):
driver.execute_script("arguments[0].click();", answer_element) driver.execute_script("arguments[0].click();", answer_element)
except Exception as e: except Exception as e:
LogError(f"play_quiz4 {str(e)}", driver, _mail) log_error(e, driver, _mail)
raise ValueError(e) raise ValueError(e)
printf("play_quiz4 : end") printf("play_quiz4 : end")
@ -227,7 +227,7 @@ def do_poll():
driver.execute_script("arguments[0].click();", answer_elem) driver.execute_script("arguments[0].click();", answer_elem)
custom_sleep(uniform(2, 2.5)) custom_sleep(uniform(2, 2.5))
except Exception as error: except Exception as error:
LogError(f"do_poll {error}" , driver, _mail) log_error(error , driver, _mail)
raise ValueError(error) raise ValueError(error)
printf("do_poll : end") printf("do_poll : end")
@ -270,7 +270,7 @@ def all_cards():
except Exception as e: except Exception as e:
printf(f"all_cards card {titre} error ({e})") printf(f"all_cards card {titre} error ({e})")
except Exception as e: except Exception as e:
LogError(f"daily_cards {e}", driver, _mail) log_error(e, driver, _mail)
def weekly_cards(): def weekly_cards():
@ -318,17 +318,17 @@ def all_cards():
try : try :
top_cards() top_cards()
except Exception as e: except Exception as e:
LogError(f"top_cards {e}", driver, _mail) log_error(e, driver, _mail)
try: try:
daily_cards() daily_cards()
except Exception as e: except Exception as e:
printf(f"error in daily_cards {e}") log_error(e, driver, _mail)
try : try :
weekly_cards() weekly_cards()
except Exception as e: except Exception as e:
LogError(f"weekly_cards {e}", driver, _mail) log_error(e, driver, _mail)
# Find out which type of action to do # Find out which type of action to do
@ -363,7 +363,7 @@ def try_play(nom="inconnu", task = None):
except Exception as e: except Exception as e:
printf(f"fail of PlayQuiz 2. Aborted {e}") printf(f"fail of PlayQuiz 2. Aborted {e}")
else: else:
LogError("There is an error. rqAnswerOption present in page but no action to do. skipping.", driver, _mail) log_error("There is an error. rqAnswerOption present in page but no action to do. skipping.", driver, _mail)
try: try:
driver.find_element(By.ID, "rqStartQuiz").click() # start the quiz driver.find_element(By.ID, "rqStartQuiz").click() # start the quiz
@ -417,7 +417,7 @@ def login():
custom_sleep(5) custom_sleep(5)
if ('Abuse' in driver.current_url) : if ('Abuse' in driver.current_url) :
LogError("account suspended", driver, _mail) log_error("account suspended", driver, _mail)
raise Banned() raise Banned()
for id in ["KmsiCheckboxField","iLooksGood", "idSIButton9", "iCancel"]: for id in ["KmsiCheckboxField","iLooksGood", "idSIButton9", "iCancel"]:
@ -453,7 +453,7 @@ def login():
except Banned: except Banned:
raise Banned() raise Banned()
except Exception as e: except Exception as e:
LogError(f"login - 3 - {e}", driver, _mail) log_error(e, driver, _mail)
driver.quit() driver.quit()
custom_sleep(1200) custom_sleep(1200)
driver = firefox_driver() driver = firefox_driver()
@ -495,14 +495,13 @@ def bing_pc_search(override=randint(35, 40)):
driver.get('https://www.bing.com/search?q=plans') driver.get('https://www.bing.com/search?q=plans')
driver.find_element(By.ID, "sb_form_q").clear() driver.find_element(By.ID, "sb_form_q").clear()
except Exception as e: except Exception as e:
LogError(f"bing_pc_search - clear la barre de recherche - {e}", driver, _mail) log_error(f"clear la barre de recherche - {format_error(e)}", driver, _mail)
AdvanceTask(task["PC"], 100 ) AdvanceTask(task["PC"], 100 )
ChangeColor(task["PC"], "green") ChangeColor(task["PC"], "green")
# Unban an account, called with -u parameter. You will need a phone number # Unban an account, called with -u parameter. You will need a phone number
def unban() -> None: def unban() -> None:
LogError("test", driver, _mail)
driver.find_element(By.ID, "StartAction").click() driver.find_element(By.ID, "StartAction").click()
custom_sleep(2) custom_sleep(2)
txt = driver.page_source txt = driver.page_source
@ -521,7 +520,6 @@ def unban() -> None:
send_sms_elem = driver.find_element(By.ID, "wlspispHipSendCode" + uuid2) send_sms_elem = driver.find_element(By.ID, "wlspispHipSendCode" + uuid2)
send_sms_elem.click() send_sms_elem.click()
wait_until_visible(By.ID, "wlspispSolutionElement" + uuid3, browser=driver) wait_until_visible(By.ID, "wlspispSolutionElement" + uuid3, browser=driver)
LogError("test", driver,"phone test")
sms_code_elem = driver.find_element(By.ID, "wlspispSolutionElement" + uuid3) sms_code_elem = driver.find_element(By.ID, "wlspispSolutionElement" + uuid3)
sms_code_input = input("entrez le contenu du msg : ") sms_code_input = input("entrez le contenu du msg : ")
sms_code_elem.send_keys(sms_code_input) sms_code_elem.send_keys(sms_code_input)
@ -556,11 +554,11 @@ def log_points(account="unknown"):
break break
except Exception as e: except Exception as e:
custom_sleep(300) custom_sleep(300)
LogError(f"log_points : {e}", driver, _mail) log_error(e, driver, _mail)
points = None points = None
if not points : if not points :
LogError(f"impossible d'avoir les points :", driver, _mail) log_error(f"impossible d'avoir les points", driver, _mail)
custom_sleep(uniform(3, 20)) custom_sleep(uniform(3, 20))
account_name = account.split("@")[0] account_name = account.split("@")[0]
@ -622,7 +620,7 @@ def fidelity():
recover_elem = driver.find_element(By.XPATH,'/html/body/div[1]/div[2]/main/div[2]/div[2]/div[7]/div[3]/div[1]/a') recover_elem = driver.find_element(By.XPATH,'/html/body/div[1]/div[2]/main/div[2]/div[2]/div[7]/div[3]/div[1]/a')
recover_elem.click() recover_elem.click()
except Exception as e2 : except Exception as e2 :
LogError(f"fidélité - double erreur - e1 : {e1} - e2 {e2}", driver, _mail) log_error(f"fidélité - double erreur - e1 : {format_error(e1)} - e2 {format_error(e2)}", driver, _mail)
break break
custom_sleep(uniform(3, 5)) custom_sleep(uniform(3, 5))
driver.switch_to.window(driver.window_handles[1]) driver.switch_to.window(driver.window_handles[1])
@ -637,7 +635,7 @@ def fidelity():
else : else :
printf("invalid fidelity link.") printf("invalid fidelity link.")
except Exception as e: except Exception as e:
LogError(f"Fidélité {e}", driver, _mail) log_error(e, driver, _mail)
def mobile_login(error): def mobile_login(error):
@ -672,7 +670,7 @@ def mobile_login(error):
custom_sleep(uniform(5, 10)) custom_sleep(uniform(5, 10))
mobile_login(error) mobile_login(error)
else: else:
LogError( log_error(
f"login impossible 3 fois de suite. {e}", mobile_driver, _mail f"login impossible 3 fois de suite. {e}", mobile_driver, _mail
) )
mobile_driver.quit() mobile_driver.quit()
@ -694,21 +692,13 @@ def mobile_alert_popup():
except exceptions.NoAlertPresentException as e: except exceptions.NoAlertPresentException as e:
pass pass
except Exception as e: except Exception as e:
LogError(f"mobile_alert_popup : {e}", mobile_driver, _mail) log_error(e, mobile_driver, _mail)
def bing_mobile_search(override=randint(22, 25)): def bing_mobile_search(override=randint(22, 25)):
global mobile_driver global mobile_driver
mobile_driver = "unable to start"
try:
try:
mobile_driver = firefox_driver(mobile=True) mobile_driver = firefox_driver(mobile=True)
mobile_driver.implicitly_wait(15) try:
except Exception as e:
LogError("bing_mobile_search - 1 - failure of mobile driver creation", mobile_driver, _mail)
ChangeColor(task["Mobile"], "red")
error = 0
if not mobile_login(error): if not mobile_login(error):
StartTask(task["Mobile"]) StartTask(task["Mobile"])
custom_sleep(uniform(1, 2)) custom_sleep(uniform(1, 2))
@ -732,43 +722,43 @@ def bing_mobile_search(override=randint(22, 25)):
ChangeColor(task["Mobile"], "green") ChangeColor(task["Mobile"], "green")
except Exception as e: except Exception as e:
LogError(f"bing_mobile_search - 4 - {e}", mobile_driver, _mail) log_error(e, mobile_driver, _mail)
mobile_driver.quit() mobile_driver.quit()
def DailyRoutine(custom = False): def daily_routine(custom = False):
ShowDefaultTask() ShowDefaultTask()
try : try :
if not custom: # custom already login if not custom: # custom already login
login() login()
except Banned : except Banned :
LogError("THIS ACCOUNT IS BANNED. FIX THIS ISSUE WITH -U", driver, _mail) log_error("THIS ACCOUNT IS BANNED. FIX THIS ISSUE WITH -U", driver, _mail)
return() return()
try: try:
all_cards() all_cards()
except Exception as e: except Exception as e:
LogError(f"DailyRoutine - all_cards - \n{e}", driver, _mail) log_error(e, driver, _mail)
try: try:
bing_pc_search() bing_pc_search()
except Exception as e: except Exception as e:
LogError(f"DailyRoutine - bing_pc_search - \n{e}", driver, _mail) log_error(e, driver, _mail)
try: try:
bing_mobile_search() bing_mobile_search()
except Exception as e: except Exception as e:
LogError(f"DailyRoutine - bing_mobile_search - \n{e}", driver, _mail) log_error(e, driver, _mail)
try: try:
fidelity() fidelity()
except Exception as e: except Exception as e:
LogError(f"DailyRoutine - fidelity - \n{e}", driver, _mail) log_error(e, driver, _mail)
try: try:
log_points(_mail) log_points(_mail)
except Exception as e: except Exception as e:
LogError(f"DailyRoutine - log_points - \n{e}", driver, _mail) log_error(e, driver, _mail)
def dev(): def dev():
@ -801,33 +791,33 @@ def CustomStart(Credentials):
if login() != "STOP": if login() != "STOP":
if "tout" in Actions: if "tout" in Actions:
DailyRoutine(True) daily_routine(True)
if "daily" in Actions: if "daily" in Actions:
try: try:
all_cards() all_cards()
except Exception as e: except Exception as e:
LogError(f"all_cards - {e} -- override", driver, _mail) log_error(e, driver, _mail)
if "pc" in Actions: if "pc" in Actions:
try: try:
ShowTask(task["PC"]) ShowTask(task["PC"])
bing_pc_search() bing_pc_search()
except Exception as e: except Exception as e:
LogError(f"il y a eu une erreur dans bing_pc_search, {e} -- override", driver, _mail) log_error(e, driver, _mail)
if "mobile" in Actions: if "mobile" in Actions:
try: try:
ShowTask(task["Mobile"]) ShowTask(task["Mobile"])
bing_mobile_search() bing_mobile_search()
except Exception as e: except Exception as e:
LogError(f"bing_mobile_search - {e} -- override", driver, _mail) log_error(e, driver, _mail)
if "fidelity" in Actions: if "fidelity" in Actions:
try : try :
fidelity() fidelity()
except Exception as e : except Exception as e :
LogError(f"fidelity - {e} -- override", driver, _mail) log_error(e, driver, _mail)
if "dev" in Actions: if "dev" in Actions:
try: try:
@ -932,7 +922,7 @@ else:
driver.implicitly_wait(3) driver.implicitly_wait(3)
try: try:
DailyRoutine() daily_routine()
driver.quit() driver.quit()
attente = uniform(1200, 3600) attente = uniform(1200, 3600)
printf(f"finis. attente de {round(attente/60)}min") printf(f"finis. attente de {round(attente/60)}min")

View File

@ -23,8 +23,10 @@ def send_keys_wait(element, keys):
sleep(uniform(0.1, 0.3)) sleep(uniform(0.1, 0.3))
def LogError(message, driver, mail, log=FULL_LOG): def log_error(error, driver, mail, log=FULL_LOG):
print(f"\n\n\033[93m Erreur : {str(message)} \033[0m\n\n") if type(error) != str :
error = format_error(error)
print(f"\n\n\033[93m Erreur : {str(error)} \033[0m\n\n")
if DISCORD_ENABLED_ERROR: if DISCORD_ENABLED_ERROR:
with open("page.html", "w") as f: with open("page.html", "w") as f:
f.write(driver.page_source) f.write(driver.page_source)
@ -33,13 +35,13 @@ def LogError(message, driver, mail, log=FULL_LOG):
if not log: if not log:
embed = discord.Embed( embed = discord.Embed(
title="An Error has occured", title="An Error has occured",
description=str(message), description=str(error),
colour=Colour.red(), colour=Colour.red(),
) )
else: else:
embed = discord.Embed( embed = discord.Embed(
title="Full log is enabled", title="Full log is enabled",
description=str(message), description=str(error),
colour=Colour.blue(), colour=Colour.blue(),
) )
@ -66,7 +68,7 @@ def printf2(txt, mail, LOG = LOG):
# check if the user is using IPV4 using ipify.org # check if the user is using IPV4 using ipify.org
# [driver] : selenium webdriver # [driver] : selenium webdriver
# never used here
def check_ipv4(driver): def check_ipv4(driver):
driver.get("https://api64.ipify.org") driver.get("https://api64.ipify.org")
elm = driver.find_element(By.TAG_NAME, "body") elm = driver.find_element(By.TAG_NAME, "body")
@ -96,7 +98,14 @@ def CustomSleep(temps):
print("attente annulée") print("attente annulée")
def format_error(e):
tb = e.__traceback__
txt = ""
while tb != None :
txt = txt + f" -> {tb.tb_frame.f_code.co_name} ({tb.tb_lineno})"
tb = tb.tb_next
#type(ex).__name__ # Type of the error. Useless here.
return(txt[4::] + "\n" + str(e))
def progressBar(current, total=30, barLength=20, name="Progress"): def progressBar(current, total=30, barLength=20, name="Progress"):