mirror of
https://gitea.augustin64.fr/piair/MsRewards-Reborn.git
synced 2025-06-29 11:53:56 +02:00
Compare commits
12 Commits
fix4
...
45ea72a354
Author | SHA1 | Date | |
---|---|---|---|
45ea72a354 | |||
18b35f6f68 | |||
c53125479e | |||
df256f2405 | |||
31b4d5d7da | |||
574fa45813 | |||
3bb49d1618 | |||
e25334f1bd | |||
41312b53b9 | |||
1ac98f14c4 | |||
f9a21f5b98 | |||
82161973a9 |
51
V6.py
51
V6.py
@ -200,6 +200,10 @@ def do_poll():
|
|||||||
def all_cards():
|
def all_cards():
|
||||||
driver = config.WebDriver.driver
|
driver = config.WebDriver.driver
|
||||||
|
|
||||||
|
def check_popups() -> bool:
|
||||||
|
"""
|
||||||
|
Check various annoying popups
|
||||||
|
"""
|
||||||
def check_welcome_tour() -> bool:
|
def check_welcome_tour() -> bool:
|
||||||
if "rewards.bing.com/welcometour" not in driver.current_url:
|
if "rewards.bing.com/welcometour" not in driver.current_url:
|
||||||
return False
|
return False
|
||||||
@ -236,6 +240,27 @@ def all_cards():
|
|||||||
# les éléments sont présents dans le DOM même quand la popup n'est pas visible apparemment
|
# les éléments sont présents dans le DOM même quand la popup n'est pas visible apparemment
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
def check_streak_protection_expired() -> bool:
|
||||||
|
"""
|
||||||
|
Non, vous avez utilisé tous vos jours de protection contre les séries !
|
||||||
|
"""
|
||||||
|
try:
|
||||||
|
streak_protection_close = driver.find_element(By.ID, "streak-protection-popup-close-cross")
|
||||||
|
ok_sad_button = driver.find_elements(By.CLASS_NAME, "dashboardPopUpPopUpSelectButton")
|
||||||
|
ok_sad_button[0].click()
|
||||||
|
info("Popup 'Streak Protection fully used' reçue")
|
||||||
|
custom_sleep(1.5)
|
||||||
|
|
||||||
|
return True
|
||||||
|
except (exceptions.NoSuchElementException, exceptions.ElementNotInteractableException, IndexError):
|
||||||
|
return False
|
||||||
|
|
||||||
|
return (
|
||||||
|
check_welcome_tour()
|
||||||
|
or check_streak_protection()
|
||||||
|
or check_streak_protection_expired()
|
||||||
|
)
|
||||||
|
|
||||||
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)
|
||||||
|
|
||||||
@ -289,8 +314,7 @@ def all_cards():
|
|||||||
activity = ""
|
activity = ""
|
||||||
|
|
||||||
custom_sleep(1.5)
|
custom_sleep(1.5)
|
||||||
check_welcome_tour()
|
check_popups()
|
||||||
check_streak_protection()
|
|
||||||
driver.execute_script("arguments[0].scrollIntoView();", card_list[i])
|
driver.execute_script("arguments[0].scrollIntoView();", card_list[i])
|
||||||
custom_sleep(1.5)
|
custom_sleep(1.5)
|
||||||
card_list[i].click()
|
card_list[i].click()
|
||||||
@ -307,8 +331,7 @@ def all_cards():
|
|||||||
if "mee-icon-AddMedium" not in card_list[i].get_attribute("innerHTML"):
|
if "mee-icon-AddMedium" not in card_list[i].get_attribute("innerHTML"):
|
||||||
continue
|
continue
|
||||||
|
|
||||||
check_welcome_tour()
|
check_popups()
|
||||||
check_streak_protection()
|
|
||||||
driver.execute_script("arguments[0].scrollIntoView();", card_list[i])
|
driver.execute_script("arguments[0].scrollIntoView();", card_list[i])
|
||||||
card_list[i].click()
|
card_list[i].click()
|
||||||
|
|
||||||
@ -424,7 +447,21 @@ def explore_on_bing(activity: str, config: Config):
|
|||||||
search_bing(f"météo {['Paris', 'Nice', 'Marseille', 'Bordeaux', 'Lyon'][randint(0, 4)]}")
|
search_bing(f"météo {['Paris', 'Nice', 'Marseille', 'Bordeaux', 'Lyon'][randint(0, 4)]}")
|
||||||
elif "packagetracking" in activity:
|
elif "packagetracking" in activity:
|
||||||
driver.get("https://www.bing.com/?setmkt=en-US&setlang=en-US")
|
driver.get("https://www.bing.com/?setmkt=en-US&setlang=en-US")
|
||||||
search_bing(f"{['fedex', 'UPS', '']} package tracking")
|
search_bing(f"{['fedex', 'UPS'][randint(0, 1)]} package tracking")
|
||||||
|
elif "hotel" in activity:
|
||||||
|
search_bing(f" {['Paris', 'Nice', 'Marseille', 'Bordeaux', 'Lyon'][randint(0, 4)]}")
|
||||||
|
elif "health" in activity:
|
||||||
|
search_bing(f"{['toux', 'douleur dos', 'nez qui coule', 'mal au genoux', 'otite'][randint(0, 4)]}")
|
||||||
|
elif "news" in activity:
|
||||||
|
search_bing(["actualités", "news"][randint(0, 1)])
|
||||||
|
elif "jobs" in activity:
|
||||||
|
search_bing("jobs")
|
||||||
|
elif "realestate" in activity:
|
||||||
|
search_bing(f"appartement à louer {['Paris', 'Nice', 'Marseille', 'Bordeaux', 'Lyon'][randint(0, 4)]}")
|
||||||
|
elif "financemarket" in activity:
|
||||||
|
search_bing(
|
||||||
|
f"cours action {['AIR LIQUIDE', 'Airbus', 'BNP Paribas', 'Michelin', 'Stellantis', 'Vinci'][randint(0, 5)]}")
|
||||||
|
|
||||||
else:
|
else:
|
||||||
log_error(f"Explore on bing: {activity} not found.")
|
log_error(f"Explore on bing: {activity} not found.")
|
||||||
|
|
||||||
@ -501,11 +538,15 @@ def login_part_1():
|
|||||||
info("Starting part 1 of login")
|
info("Starting part 1 of login")
|
||||||
driver = config.WebDriver.driver
|
driver = config.WebDriver.driver
|
||||||
driver.get("https://login.live.com")
|
driver.get("https://login.live.com")
|
||||||
|
try:
|
||||||
wait_until_visible(By.ID, "i0116", browser=driver)
|
wait_until_visible(By.ID, "i0116", browser=driver)
|
||||||
send_wait_and_confirm(
|
send_wait_and_confirm(
|
||||||
driver.find_element(By.ID, "i0116"),
|
driver.find_element(By.ID, "i0116"),
|
||||||
config.UserCredentials.get_mail()
|
config.UserCredentials.get_mail()
|
||||||
)
|
)
|
||||||
|
except exceptions.NoSuchElementException:
|
||||||
|
info("Unable to find mail input for login, might be semi-logged-in")
|
||||||
|
|
||||||
wait_until_visible(By.ID, "i0118", browser=driver)
|
wait_until_visible(By.ID, "i0118", browser=driver)
|
||||||
send_wait_and_confirm(
|
send_wait_and_confirm(
|
||||||
driver.find_element(By.ID, "i0118"),
|
driver.find_element(By.ID, "i0118"),
|
||||||
|
@ -5,7 +5,7 @@ import subprocess
|
|||||||
|
|
||||||
from logger import critical, info, error
|
from logger import critical, info, error
|
||||||
|
|
||||||
errorMessage = subprocess.run(['python3', 'generate_error.py'], check=False, stdout=subprocess.PIPE,
|
errorMessage = subprocess.run(['python3', '/app/MsRewards-Reborn/modules/Tools/generate_error.py'], check=False, stdout=subprocess.PIPE,
|
||||||
stderr=subprocess.PIPE).stderr.decode("utf-8")
|
stderr=subprocess.PIPE).stderr.decode("utf-8")
|
||||||
|
|
||||||
versionPattern = "This version of ChromeDriver only supports Chrome version ([0-9]+)"
|
versionPattern = "This version of ChromeDriver only supports Chrome version ([0-9]+)"
|
||||||
|
Reference in New Issue
Block a user