Compare commits
No commits in common. "5fe05712bd0d1445abf467675b88a9e9e4e718ad" and "5ca91a7075a4032798129c67591306bb61ec3657" have entirely different histories.
5fe05712bd
...
5ca91a7075
103
V6.py
103
V6.py
|
@ -12,21 +12,21 @@ from modules.error import *
|
||||||
|
|
||||||
# create a webdriver
|
# create a webdriver
|
||||||
def create_driver(mobile=False):
|
def create_driver(mobile=False):
|
||||||
pc_user_agent = (
|
PC_USER_AGENT = (
|
||||||
"Mozilla/5.0 (X11; Linux x86_64)"
|
"Mozilla/5.0 (X11; Linux x86_64)"
|
||||||
"AppleWebKit/537.36 (KHTML, like Gecko)"
|
"AppleWebKit/537.36 (KHTML, like Gecko)"
|
||||||
"Chrome/122.0.0.0 Safari/537.36 Edg/122.0.2088.46"
|
"Chrome/122.0.0.0 Safari/537.36 Edg/122.0.2088.46"
|
||||||
)
|
)
|
||||||
mobile_user_agent = (
|
MOBILE_USER_AGENT = (
|
||||||
"Mozilla/5.0 (Linux; Android 7.0; Nexus 5 Build/MRA58N)"
|
"Mozilla/5.0 (Linux; Android 7.0; Nexus 5 Build/MRA58N)"
|
||||||
"AppleWebKit/537.36 (KHTML, like Gecko)"
|
"AppleWebKit/537.36 (KHTML, like Gecko)"
|
||||||
"Chrome/22 Mobile Safari/537.36"
|
"Chrome/22 Mobile Safari/537.36"
|
||||||
)
|
)
|
||||||
chrome_options = webdriver.ChromeOptions()
|
chrome_options = webdriver.ChromeOptions()
|
||||||
if mobile:
|
if mobile:
|
||||||
chrome_options.add_argument(f"--user-agent={mobile_user_agent}")
|
chrome_options.add_argument(f"--user-agent={MOBILE_USER_AGENT}")
|
||||||
else:
|
else:
|
||||||
chrome_options.add_argument(f"--user-agent={pc_user_agent}")
|
chrome_options.add_argument(f"--user-agent={PC_USER_AGENT}")
|
||||||
# disabled as it may cause detection
|
# disabled as it may cause detection
|
||||||
if config.proxy.is_enabled():
|
if config.proxy.is_enabled():
|
||||||
chrome_options.add_argument(f'--proxy-server={config.proxy.ip}:{config.proxy.port}')
|
chrome_options.add_argument(f'--proxy-server={config.proxy.ip}:{config.proxy.port}')
|
||||||
|
@ -91,13 +91,13 @@ def play_quiz8():
|
||||||
for _ in range(override):
|
for _ in range(override):
|
||||||
sleep(uniform(3, 5))
|
sleep(uniform(3, 5))
|
||||||
correct_answers = []
|
correct_answers = []
|
||||||
for i in range(8):
|
for i in range(1, 9): # todo: remove this odd 1-offset
|
||||||
try:
|
try:
|
||||||
element = driver.find_element(By.ID, f"rqAnswerOption{i}")
|
element = driver.find_element(By.ID, f"rqAnswerOption{i - 1}")
|
||||||
if 'iscorrectoption="True"' in element.get_attribute("outerHTML"):
|
if 'iscorrectoption="True"' in element.get_attribute("outerHTML"):
|
||||||
correct_answers.append(f'rqAnswerOption{i}')
|
correct_answers.append(f'rqAnswerOption{i - 1}')
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
warning(f"can't find rqAnswerOption{i}. Probably already clicked" + str(e))
|
warning(f"can't find rqAnswerOption{i - 1}. Probably already clicked" + str(e))
|
||||||
shuffle(correct_answers)
|
shuffle(correct_answers)
|
||||||
for answer_id in correct_answers:
|
for answer_id in correct_answers:
|
||||||
wait_until_visible(By.ID, answer_id, timeout=20, browser=driver)
|
wait_until_visible(By.ID, answer_id, timeout=20, browser=driver)
|
||||||
|
@ -171,83 +171,92 @@ def do_poll():
|
||||||
|
|
||||||
|
|
||||||
# Find each playable card and tries to click on it to earn points
|
# Find each playable card and tries to click on it to earn points
|
||||||
|
# todo : refactor
|
||||||
def all_cards():
|
def all_cards():
|
||||||
driver = config.WebDriver.driver
|
driver = config.WebDriver.driver
|
||||||
driver.get("https://rewards.bing.com")
|
driver.get("https://rewards.bing.com")
|
||||||
wait_until_visible(By.CLASS_NAME, "c-card-content", 10, driver)
|
wait_until_visible(By.CLASS_NAME, "c-card-content", 10, driver)
|
||||||
|
liste = driver.find_elements(By.CLASS_NAME, "c-card-content")
|
||||||
card_list = driver.find_elements(By.CLASS_NAME, "c-card-content")
|
|
||||||
custom_sleep(2)
|
custom_sleep(2)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
promo()
|
promo()
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
debug(e)
|
|
||||||
info("no promo card")
|
info("no promo card")
|
||||||
|
if (len(liste) < 10): # most likely an error during loading
|
||||||
if len(card_list) < 10: # most likely an error during loading
|
|
||||||
if "suspendu" in driver.page_source:
|
if "suspendu" in driver.page_source:
|
||||||
raise Banned()
|
raise Banned()
|
||||||
driver.refresh()
|
driver.refresh()
|
||||||
card_list = driver.find_elements(By.CLASS_NAME, "c-card-content")
|
liste = driver.find_elements(By.CLASS_NAME, "c-card-content")
|
||||||
if len(card_list) < 10:
|
if (len(liste) < 10):
|
||||||
log_error("Less than 10 cards. Most likely an error with login.")
|
log_error("Less than 10 cards. Most likely an error with login.")
|
||||||
return "Not enough cards"
|
return ("PAS ASSEZ DE CARTES")
|
||||||
|
if (len(liste) < 20): # most likely not in france
|
||||||
for i in range(len(card_list)):
|
error("moins de 20 cartes. Probablement pas en France.")
|
||||||
|
for i in range(len(liste)):
|
||||||
debug(f"carte {i}")
|
debug(f"carte {i}")
|
||||||
checked = False
|
|
||||||
try:
|
try:
|
||||||
checked = "mee-icon-AddMedium" in card_list[i].get_attribute("innerHTML")
|
checked = ("mee-icon-AddMedium" in liste[i].get_attribute("innerHTML"))
|
||||||
|
|
||||||
except StaleElementReferenceException:
|
except StaleElementReferenceException:
|
||||||
driver.refresh()
|
driver.refresh()
|
||||||
card_list = driver.find_elements(By.CLASS_NAME, "c-card-content")
|
liste = driver.find_elements(By.CLASS_NAME, "c-card-content")
|
||||||
warning(f"staled, {len(card_list)}")
|
warning(f"staled, {len(liste)}")
|
||||||
checked = "mee-icon-AddMedium" in card_list[i].get_attribute("innerHTML")
|
checked = ("mee-icon-AddMedium" in liste[i].get_attribute("innerHTML"))
|
||||||
|
|
||||||
except IndexError:
|
except IndexError:
|
||||||
driver.get("https://rewards.bing.com")
|
driver.get("https://rewards.bing.com")
|
||||||
custom_sleep(10)
|
custom_sleep(10)
|
||||||
card_list = driver.find_elements(By.CLASS_NAME, "c-card-content")
|
liste = driver.find_elements(By.CLASS_NAME, "c-card-content")
|
||||||
try:
|
try:
|
||||||
checked = "mee-icon-AddMedium" in card_list[i].get_attribute("innerHTML")
|
checked = ("mee-icon-AddMedium" in liste[i].get_attribute("innerHTML"))
|
||||||
except IndexError:
|
except IndexError:
|
||||||
if i == len(card_list) and i > 15:
|
if i == len(liste) & i > 15:
|
||||||
checked = False
|
checked = False
|
||||||
|
|
||||||
if checked:
|
if checked:
|
||||||
custom_sleep(1.5)
|
custom_sleep(1.5)
|
||||||
driver.execute_script("arguments[0].scrollIntoView();", card_list[i])
|
driver.execute_script("arguments[0].scrollIntoView();", liste[i])
|
||||||
custom_sleep(1.5)
|
custom_sleep(1.5)
|
||||||
card_list[i].click()
|
liste[i].click()
|
||||||
|
|
||||||
if len(driver.window_handles) > 1:
|
if len(driver.window_handles) > 1:
|
||||||
driver.switch_to.window(driver.window_handles[1])
|
driver.switch_to.window(driver.window_handles[1])
|
||||||
try_play(driver.title)
|
try_play(driver.title)
|
||||||
close_tab(driver.window_handles[1])
|
close_tab(driver.window_handles[1])
|
||||||
|
|
||||||
try:
|
try:
|
||||||
driver.refresh()
|
driver.refresh()
|
||||||
card_list = driver.find_elements(By.CLASS_NAME, "c-card-content")
|
liste = driver.find_elements(By.CLASS_NAME, "c-card-content")
|
||||||
|
if ("mee-icon-AddMedium" in liste[i].get_attribute("innerHTML")):
|
||||||
if "mee-icon-AddMedium" in card_list[i].get_attribute("innerHTML"):
|
warning(f"carte {i} not okay. Retrying.")
|
||||||
driver.execute_script("arguments[0].scrollIntoView();", card_list[i])
|
try:
|
||||||
card_list[i].click()
|
liste[i].click()
|
||||||
|
except:
|
||||||
|
log_error("problème inconnu ? sauf si c'est un element obscure...")
|
||||||
|
driver.get("https://rewards.bing.com")
|
||||||
|
checked = ("mee-icon-AddMedium" in liste[i].get_attribute("innerHTML"))
|
||||||
driver.switch_to.window(driver.window_handles[1])
|
driver.switch_to.window(driver.window_handles[1])
|
||||||
custom_sleep(10)
|
try_play(driver.title)
|
||||||
|
close_tab(driver.window_handles[1])
|
||||||
|
if ("mee-icon-AddMedium" in liste[i].get_attribute("innerHTML")):
|
||||||
|
driver.execute_script("arguments[0].scrollIntoView();", liste[i])
|
||||||
log_error(f"Card {i} Can't be completed. Why MS ?")
|
log_error(f"Card {i} Can't be completed. Why MS ?")
|
||||||
|
liste[i].click()
|
||||||
|
driver.switch_to.window(driver.window_handles[1])
|
||||||
|
log_error(f"Cart completion - log - 2")
|
||||||
|
custom_sleep(10)
|
||||||
|
log_error(f"Cart completion - log - 3 - after 10 sec")
|
||||||
try:
|
try:
|
||||||
try_play(driver.title) # go back to the main page
|
try_play(driver.title) # go back to the main page
|
||||||
try:
|
try:
|
||||||
close_tab(driver.window_handles[1])
|
close_tab(driver.window_handles[1])
|
||||||
except Exception as e:
|
except:
|
||||||
debug(e)
|
pass
|
||||||
except Exception as e:
|
except:
|
||||||
debug(e)
|
driver.get("https://rewards.bing.com")
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
try:
|
||||||
|
welcome_tour(liste[i], driver)
|
||||||
|
except Exception as e:
|
||||||
|
error("no new windows" + format_error(e))
|
||||||
driver.get("https://rewards.bing.com")
|
driver.get("https://rewards.bing.com")
|
||||||
except Exception as err:
|
|
||||||
log_error(err)
|
|
||||||
custom_sleep(3)
|
custom_sleep(3)
|
||||||
|
|
||||||
|
|
||||||
|
@ -753,7 +762,7 @@ def default_start():
|
||||||
|
|
||||||
|
|
||||||
def log_error(msg):
|
def log_error(msg):
|
||||||
DiscordLogger(config).send(msg)
|
DiscordLogger(config)
|
||||||
|
|
||||||
|
|
||||||
def check_updated():
|
def check_updated():
|
||||||
|
|
|
@ -29,7 +29,7 @@ class ColoredFormatter(logging.Formatter):
|
||||||
|
|
||||||
|
|
||||||
# Set up the root logger
|
# Set up the root logger
|
||||||
root_logger = logging.getLogger(__name__)
|
root_logger = logging.getLogger()
|
||||||
root_logger.setLevel(logging.DEBUG)
|
root_logger.setLevel(logging.DEBUG)
|
||||||
|
|
||||||
# Create a console handler and set the formatter
|
# Create a console handler and set the formatter
|
||||||
|
|
Loading…
Reference in New Issue