Compare commits
No commits in common. "3c74aa025e0f6493fb59ccfd2b4b1295f6037269" and "9bd96ad876fcf3c2ef8624b7e5da3824a3a8c1bd" have entirely different histories.
3c74aa025e
...
9bd96ad876
|
@ -16,4 +16,3 @@ file.png
|
|||
*.ts
|
||||
LICENSE
|
||||
README.md
|
||||
venv
|
||||
|
|
87
V6.py
87
V6.py
|
@ -1,17 +1,16 @@
|
|||
#!/usr/bin/python3
|
||||
import random
|
||||
import subprocess
|
||||
|
||||
from modules.Classes.Config import Config
|
||||
from modules.Classes.DiscordLogger import DiscordLogger
|
||||
from modules.Classes.UserCredentials import UserCredentials
|
||||
from modules.Tools.logger import critical, warning
|
||||
from modules.Tools.logger import warning, critical
|
||||
from modules.cards import *
|
||||
from modules.config import *
|
||||
from modules.db import add_to_database
|
||||
from modules.driver_tools import *
|
||||
from modules.error import *
|
||||
|
||||
import random
|
||||
|
||||
|
||||
# create a webdriver
|
||||
def create_driver(mobile=False):
|
||||
|
@ -211,7 +210,7 @@ def all_cards():
|
|||
welcome_tour = driver.find_element(By.ID, "welcome-tour")
|
||||
interest_button_box = welcome_tour.find_element(By.CLASS_NAME, "interest-buttons")
|
||||
interests = interest_button_box.find_elements(By.CLASS_NAME, "ng-binding")
|
||||
debug("Got the following interests: " + str(interests))
|
||||
debug("Got the following interests: "+str(interests))
|
||||
random.choice(interests).click() # Choose interest
|
||||
custom_sleep(1.5)
|
||||
|
||||
|
@ -266,12 +265,6 @@ def all_cards():
|
|||
if not checked:
|
||||
continue
|
||||
|
||||
try:
|
||||
activity = findall("data-bi-id=\"([^\"]+)\"", card_list[i].get_attribute("innerHTML"))[0]
|
||||
except Exception as e:
|
||||
warning("Can't find activity." + str(e))
|
||||
activity = ""
|
||||
|
||||
custom_sleep(1.5)
|
||||
check_welcome_tour()
|
||||
driver.execute_script("arguments[0].scrollIntoView();", card_list[i])
|
||||
|
@ -280,7 +273,7 @@ def all_cards():
|
|||
|
||||
if len(driver.window_handles) > 1:
|
||||
driver.switch_to.window(driver.window_handles[1])
|
||||
try_play(driver.title, activity)
|
||||
try_play(driver.title)
|
||||
close_tab(driver.window_handles[1])
|
||||
|
||||
try:
|
||||
|
@ -347,35 +340,8 @@ def promo():
|
|||
custom_sleep(3)
|
||||
|
||||
|
||||
def explore_on_bing(activity: str, config: Config):
|
||||
driver = config.WebDriver.driver
|
||||
|
||||
def search_bing(txt):
|
||||
search_elm = driver.find_element(By.ID, "sb_form_q")
|
||||
send_keys_wait(search_elm, txt)
|
||||
send_keys_wait(search_elm, Keys.ENTER)
|
||||
|
||||
if "lyrics" in activity:
|
||||
search_bing(
|
||||
f"paroles de {['Gata', 'Pyramide', 'Dolce Camara', 'Position', 'Mami Wata'][randint(0, 4)]}") # merci bing copilot pour les titres
|
||||
elif "flight" in activity:
|
||||
search_bing(
|
||||
f"vol {['Paris - New York', 'Londres Amsterdam', 'Bora-Bora Miami', 'Los Angeles Toulouse', 'Rome Dubai'][randint(0, 4)]}")
|
||||
elif "shopping" in activity:
|
||||
search_bing(f"idée cadeau {['Noel', 'Anniversaire'][randint(0, 1)]}")
|
||||
elif "movie" in activity:
|
||||
search_bing(
|
||||
f"Distribution {['Code 8 part 2', 'The Hunger Games: The ballad of Songbirds & Snakes', 'Rebel Moon: Part Two', 'Dune II', 'Wonka'][randint(0, 4)]}")
|
||||
elif "translator" in activity:
|
||||
search_bing(f"traduction {config.wordlist.get_word()} en anglais")
|
||||
elif "map" in activity:
|
||||
search_bing(f"{['Paris', 'Nice', 'Marseille', 'Bordeaux', 'Lyon'][randint(0, 4)]} carte")
|
||||
else:
|
||||
log_error(f"Explore on bing: {activity} not found.")
|
||||
|
||||
|
||||
# Find out which type of action to do
|
||||
def try_play(nom="unknown", activity=""):
|
||||
def try_play(nom="unknown"):
|
||||
driver = config.WebDriver.driver
|
||||
rgpd_popup(config)
|
||||
|
||||
|
@ -421,7 +387,7 @@ def try_play(nom="unknown", activity=""):
|
|||
info("On fidelity page.")
|
||||
fidelity()
|
||||
|
||||
elif wait_until_visible(By.ID, "rqStartQuiz", 5, driver, raise_error=False):
|
||||
elif wait_until_visible(By.ID, "rqStartQuiz", 5, driver):
|
||||
custom_sleep(3)
|
||||
driver.find_element(By.ID, "rqStartQuiz").click() # start the quiz
|
||||
answer_number = driver.page_source.count("rqAnswerOption")
|
||||
|
@ -431,12 +397,9 @@ def try_play(nom="unknown", activity=""):
|
|||
number = driver.page_source.count("rqAnswerOption")
|
||||
warning(f"recovery detected. quiz : {number}")
|
||||
play(number - 1)
|
||||
elif "exploreonbing" in activity:
|
||||
info(f"Explore on bing: {activity}")
|
||||
explore_on_bing(activity, config)
|
||||
custom_sleep(uniform(3, 5))
|
||||
|
||||
else:
|
||||
info(f"Nothing obvious to do on page `{nom}`.")
|
||||
info(f"Nothing to do on page `{nom}`")
|
||||
custom_sleep(uniform(3, 5))
|
||||
|
||||
|
||||
|
@ -513,12 +476,10 @@ def login():
|
|||
def logged_in():
|
||||
driver.get("https://login.live.com")
|
||||
custom_sleep(10)
|
||||
debug(get_domain(driver))
|
||||
if get_domain(driver) == "account.microsoft.com":
|
||||
return True
|
||||
return False
|
||||
|
||||
info("Logging in...")
|
||||
driver = config.WebDriver.driver
|
||||
try:
|
||||
if not logged_in():
|
||||
|
@ -647,23 +608,19 @@ def fidelity():
|
|||
pause = driver.find_element(By.CSS_SELECTOR, f'[class="c-action-toggle c-glyph f-toggle glyph-pause"]')
|
||||
pause.click()
|
||||
except Exception as e:
|
||||
debug("No pause button.")
|
||||
|
||||
error(f"Error while clicking pause. Probably no cards. {e}")
|
||||
return "no cards"
|
||||
cartes = driver.find_elements(By.CSS_SELECTOR, f'[ng-repeat="item in $ctrl.transcludedItems"]')
|
||||
nb_cartes = len(cartes)
|
||||
if nb_cartes == 0:
|
||||
warning("No fidelity cards detected")
|
||||
return "No cards."
|
||||
checked_list_all = driver.find_elements(By.CSS_SELECTOR, f'[ng-if="$ctrl.complete"]')
|
||||
for i in range(nb_cartes):
|
||||
cartes[i].click()
|
||||
checked_txt = checked_list_all[i].get_attribute("innerHTML")
|
||||
ok = checked_txt.count("StatusCircleOuter checkmark")
|
||||
total = checked_txt.count("StatusCircleOuter")
|
||||
if ok != total:
|
||||
if (ok != total):
|
||||
elm = driver.find_elements(By.CLASS_NAME, 'clickable-link')[i]
|
||||
# legacy code. Should be removed
|
||||
if "moviesandtv" not in elm.get_attribute("innerHTML"): # not the film card
|
||||
if not "moviesandtv" in elm.get_attribute("innerHTML"): # not the film card
|
||||
elm.click()
|
||||
driver.switch_to.window(driver.window_handles[len(driver.window_handles) - 1])
|
||||
sub_fidelity()
|
||||
|
@ -781,8 +738,9 @@ def json_start(json_entry, cred: UserCredentials):
|
|||
config.WebDriver.set_pc_driver(create_driver())
|
||||
config.WebDriver.switch_to_driver("PC")
|
||||
driver = config.WebDriver.driver
|
||||
try:
|
||||
if "unban" in json_entry and str(account_id) in json_entry["unban"]:
|
||||
login()
|
||||
login_part_1()
|
||||
info("\nGO TO example.com TO PROCEED or wait 1200 secs.")
|
||||
for _ in range(1200):
|
||||
sleep(1)
|
||||
|
@ -791,10 +749,13 @@ def json_start(json_entry, cred: UserCredentials):
|
|||
break
|
||||
else:
|
||||
login()
|
||||
except KeyError:
|
||||
login()
|
||||
try:
|
||||
if str(account_id) in json_entry["tout"]:
|
||||
daily_routine(cred, True)
|
||||
|
||||
except KeyError:
|
||||
pass
|
||||
else:
|
||||
try:
|
||||
if str(account_id) in json_entry["daily"]:
|
||||
|
@ -820,14 +781,10 @@ def json_start(json_entry, cred: UserCredentials):
|
|||
log_error(e)
|
||||
except KeyError:
|
||||
pass
|
||||
|
||||
except KeyError:
|
||||
pass
|
||||
try:
|
||||
log_points()
|
||||
except Exception as e:
|
||||
error(f"CustomStart {e}")
|
||||
|
||||
driver.close()
|
||||
cred.next_account()
|
||||
account_id += 1
|
||||
|
@ -844,16 +801,13 @@ def default_start():
|
|||
while config.UserCredentials.is_valid():
|
||||
custom_sleep(1)
|
||||
info("Starting and configuring driver.")
|
||||
try:
|
||||
config.WebDriver.set_pc_driver(create_driver())
|
||||
except:
|
||||
subprocess.Popen(["python3", "/app/MsRewards-Reborn/modules/Tools/update_chrome.py"])
|
||||
config.WebDriver.set_pc_driver(create_driver())
|
||||
config.WebDriver.switch_to_driver("PC")
|
||||
info("Driver started.")
|
||||
config.WebDriver.pc_driver.implicitly_wait(3)
|
||||
try:
|
||||
wait_time = uniform(1200, 3600)
|
||||
wait_time = 10 # the display closes when I ctrl + c
|
||||
info(f"Waiting for {round(wait_time / 60)}min before starting")
|
||||
custom_sleep(wait_time)
|
||||
daily_routine(config.UserCredentials)
|
||||
|
@ -881,6 +835,7 @@ def log_error(msg):
|
|||
|
||||
|
||||
def check_updated():
|
||||
debug(f"updated: {config.has_been_updated()}")
|
||||
if config.has_been_updated():
|
||||
config.discord.wh.send(f"Updated to {config.version}", username="update",
|
||||
avatar_url="https://cdn-icons-png.flaticon.com/512/1688/1688988.png")
|
||||
|
|
|
@ -1,12 +0,0 @@
|
|||
file=version
|
||||
|
||||
if [ "$(git diff HEAD version | wc -w)" -eq 0 ]
|
||||
then
|
||||
echo 'updating minor version'
|
||||
new_path=$(cat $file | awk -F . '{print $1"."$2"."$3+1 }')
|
||||
echo $new_path > $file
|
||||
git add version
|
||||
else
|
||||
echo 'Version have been updated manually'
|
||||
fi
|
||||
echo Version: $(cat $file)
|
|
@ -1 +0,0 @@
|
|||
sh hooks/bump.sh
|
|
@ -22,8 +22,7 @@ class Config:
|
|||
proxy = json.load(inFile)
|
||||
with open("/app/MsRewards-Reborn/user_data/configs.json", "r") as inFile:
|
||||
config = json.load(inFile)
|
||||
with open("/app/MsRewards-Reborn/user_data/version", "r") as inFile:
|
||||
version = inFile.readline()
|
||||
|
||||
"""
|
||||
setup standalone stuff
|
||||
"""
|
||||
|
@ -32,9 +31,10 @@ class Config:
|
|||
self.json_entry = args.json.replace("'", "\"")
|
||||
self.wordlist = WordList("/usr/share/dict/french")
|
||||
self.vnc = args.vnc
|
||||
self.version = args.update_version
|
||||
self.WebDriver = Driver()
|
||||
self.display = None
|
||||
self.version = version
|
||||
|
||||
"""
|
||||
setup UserCredential
|
||||
"""
|
||||
|
@ -81,11 +81,4 @@ class Config:
|
|||
self.display = display
|
||||
|
||||
def has_been_updated(self):
|
||||
with open('/app/MsRewards-Reborn/version', "r") as inFile:
|
||||
in_file_content = inFile.readlines()
|
||||
if self.version != in_file_content[0]:
|
||||
self.version = in_file_content[0]
|
||||
with open('/app/MsRewards-Reborn/user_data/version', "w") as outFile:
|
||||
outFile.write(self.version)
|
||||
return True
|
||||
return False
|
||||
return self.version != "None"
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
import json
|
||||
import os
|
||||
import json
|
||||
from random import uniform
|
||||
|
||||
from selenium.common import TimeoutException
|
||||
from selenium.webdriver import Keys
|
||||
from selenium.webdriver import ActionChains, Keys
|
||||
from selenium.webdriver.common.by import By
|
||||
from selenium.webdriver.support import expected_conditions
|
||||
from selenium.webdriver.support.wait import WebDriverWait
|
||||
|
@ -14,9 +14,9 @@ from modules.Tools.tools import *
|
|||
|
||||
def init_profile(mail, mobile=False):
|
||||
if not mobile:
|
||||
chrome_profile_dir = "/app/MsRewards-Reborn/user_data/profile/" + mail
|
||||
chrome_profile_dir = "/app/MsRewards-Reborn/user_data/profile/"+mail
|
||||
else:
|
||||
chrome_profile_dir = "/app/MsRewards-Reborn/user_data/profile/mobile-" + mail
|
||||
chrome_profile_dir = "/app/MsRewards-Reborn/user_data/profile/mobile-"+mail
|
||||
|
||||
os.makedirs(chrome_profile_dir, exist_ok=True)
|
||||
|
||||
|
@ -69,7 +69,6 @@ def send_keys_wait(element, keys: str) -> None:
|
|||
element.send_keys(i)
|
||||
sleep(uniform(0.1, 0.3))
|
||||
|
||||
|
||||
def send_wait_and_confirm(element, keys: str) -> None:
|
||||
send_keys_wait(element, keys)
|
||||
element.send_keys(Keys.ENTER)
|
||||
|
@ -82,6 +81,6 @@ def wait_until_visible(search_by: str, identifier: str, timeout: int = 20, brows
|
|||
expected_conditions.visibility_of_element_located((search_by, identifier)), "element not found")
|
||||
return True
|
||||
except TimeoutException as e:
|
||||
f = error if raise_error else debug
|
||||
f(f"element {identifier} not found after {timeout}s")
|
||||
if raise_error:
|
||||
error(f"element {identifier} not found after {timeout}s")
|
||||
return False
|
||||
|
|
|
@ -1 +0,0 @@
|
|||
0.0.0
|
Loading…
Reference in New Issue