euh ué
This commit is contained in:
parent
fbb2feae31
commit
2dc8cda167
|
@ -19,6 +19,7 @@ RUN set -x \
|
||||||
nano \
|
nano \
|
||||||
tigervnc-standalone-server \
|
tigervnc-standalone-server \
|
||||||
&& git clone https://github.com/piair338/MsRewards \
|
&& git clone https://github.com/piair338/MsRewards \
|
||||||
|
&& ln -fs /usr/share/zoneinfo/Europe/Paris /etc/localtime \
|
||||||
&& pip install -r MsRewards/requirements.txt \
|
&& pip install -r MsRewards/requirements.txt \
|
||||||
&& curl -sSLO https://download-installer.cdn.mozilla.net/pub/firefox/releases/91.9.1esr/linux-x86_64/en-US/firefox-91.9.1esr.tar.bz2 \
|
&& curl -sSLO https://download-installer.cdn.mozilla.net/pub/firefox/releases/91.9.1esr/linux-x86_64/en-US/firefox-91.9.1esr.tar.bz2 \
|
||||||
&& tar -jxf firefox-* \
|
&& tar -jxf firefox-* \
|
||||||
|
|
63
V5.py
63
V5.py
|
@ -1,7 +1,7 @@
|
||||||
#!/usr/bin/python3.10
|
#!/usr/bin/python3.10
|
||||||
from modules.imports import *
|
from modules.imports import *
|
||||||
from modules.db import add_to_database
|
|
||||||
from modules.config import *
|
from modules.config import *
|
||||||
|
from modules.db import add_to_database
|
||||||
from modules.tools import *
|
from modules.tools import *
|
||||||
from modules.error import *
|
from modules.error import *
|
||||||
from modules.driver_tools import *
|
from modules.driver_tools import *
|
||||||
|
@ -29,12 +29,8 @@ def firefox_driver(mobile=False, headless=False):
|
||||||
)
|
)
|
||||||
options = Options()
|
options = Options()
|
||||||
options.set_preference('intl.accept_languages', 'fr-FR, fr')
|
options.set_preference('intl.accept_languages', 'fr-FR, fr')
|
||||||
if proxy_enabled :
|
|
||||||
setup_proxy(proxy_address,proxy_port, options)
|
|
||||||
options.set_preference("browser.link.open_newwindow", 3)
|
options.set_preference("browser.link.open_newwindow", 3)
|
||||||
options.set_preference("dom.confirm_repost.testing.always_accept", True)
|
options.set_preference("dom.confirm_repost.testing.always_accept", True)
|
||||||
if FAST :
|
|
||||||
options.set_preference("permissions.default.image", 2) #disable image loading. You shouldn't use it except if really nessecary
|
|
||||||
if headless:
|
if headless:
|
||||||
options.add_argument("-headless")
|
options.add_argument("-headless")
|
||||||
if mobile :
|
if mobile :
|
||||||
|
@ -48,14 +44,14 @@ def firefox_driver(mobile=False, headless=False):
|
||||||
return(driver)
|
return(driver)
|
||||||
|
|
||||||
|
|
||||||
def log_error(error, ldriver=driver, log=FULL_LOG):
|
def log_error(error, ldriver=driver, log=g.full_log):
|
||||||
global driver
|
global driver
|
||||||
if ldriver is None:
|
if ldriver is None:
|
||||||
ldriver = driver
|
ldriver = driver
|
||||||
if type(error) != str :
|
if type(error) != str :
|
||||||
error = format_error(error)
|
error = format_error(error)
|
||||||
printf(f"\n\n\033[93m Erreur : {str(error)} \033[0m\n\n")
|
printf(f"\n\n\033[93m Erreur : {str(error)} \033[0m\n\n")
|
||||||
if DISCORD_ENABLED_ERROR:
|
if g.discord_enabled_error:
|
||||||
with open("page.html", "w") as f:
|
with open("page.html", "w") as f:
|
||||||
try :
|
try :
|
||||||
f.write(ldriver.page_source)
|
f.write(ldriver.page_source)
|
||||||
|
@ -81,8 +77,8 @@ def log_error(error, ldriver=driver, log=FULL_LOG):
|
||||||
file = File("screenshot.png")
|
file = File("screenshot.png")
|
||||||
embed.set_image(url="attachment://screenshot.png")
|
embed.set_image(url="attachment://screenshot.png")
|
||||||
embed.set_footer(text=g._mail)
|
embed.set_footer(text=g._mail)
|
||||||
webhookFailure.send(embed=embed, username="error", file=file, avatar_url = AVATAR_URL)
|
webhookFailure.send(embed=embed, username="error", file=file, avatar_url = g.avatar_url)
|
||||||
webhookFailure.send(username="error", file=File("page.html"), avatar_url = AVATAR_URL)
|
webhookFailure.send(username="error", file=File("page.html"), avatar_url = g.avatar_url)
|
||||||
|
|
||||||
|
|
||||||
# close the tab currently on and go back to the one first, or the one specified
|
# close the tab currently on and go back to the one first, or the one specified
|
||||||
|
@ -125,6 +121,7 @@ def play_quiz2(override=10) -> None:
|
||||||
log_error(e)
|
log_error(e)
|
||||||
break
|
break
|
||||||
printf("play_quiz2 done")
|
printf("play_quiz2 done")
|
||||||
|
custom_sleep(3)
|
||||||
|
|
||||||
|
|
||||||
def play_quiz8():
|
def play_quiz8():
|
||||||
|
@ -164,6 +161,7 @@ def play_quiz8():
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
log_error(f"{format_error(e)} \n Good answers : {' '.join(correct_answers)}")
|
log_error(f"{format_error(e)} \n Good answers : {' '.join(correct_answers)}")
|
||||||
printf("play_quiz8 : fin ")
|
printf("play_quiz8 : fin ")
|
||||||
|
custom_sleep(3)
|
||||||
|
|
||||||
|
|
||||||
def play_quiz4(override=None):
|
def play_quiz4(override=None):
|
||||||
|
@ -192,6 +190,7 @@ def play_quiz4(override=None):
|
||||||
log_error(e)
|
log_error(e)
|
||||||
raise ValueError(e)
|
raise ValueError(e)
|
||||||
printf("play_quiz4 : end")
|
printf("play_quiz4 : end")
|
||||||
|
custom_sleep(3)
|
||||||
|
|
||||||
|
|
||||||
# do_poll() answer a random thing to poll, on of daily activities
|
# do_poll() answer a random thing to poll, on of daily activities
|
||||||
|
@ -208,6 +207,7 @@ def do_poll():
|
||||||
log_error(error)
|
log_error(error)
|
||||||
raise ValueError(error)
|
raise ValueError(error)
|
||||||
printf("do_poll : end")
|
printf("do_poll : end")
|
||||||
|
custom_sleep(3)
|
||||||
|
|
||||||
|
|
||||||
def all_cards():
|
def all_cards():
|
||||||
|
@ -552,8 +552,8 @@ def log_points(account="unknown"):
|
||||||
custom_sleep(uniform(3, 20))
|
custom_sleep(uniform(3, 20))
|
||||||
account_name = account.split("@")[0]
|
account_name = account.split("@")[0]
|
||||||
|
|
||||||
if DISCORD_ENABLED_SUCCESS:
|
if g.discord_enabled_success:
|
||||||
if DISCORD_EMBED:
|
if g.discord_embed:
|
||||||
embed = Embed(
|
embed = Embed(
|
||||||
title=f"{account_name} actuellement à {str(points)} points", colour=Colour.green()
|
title=f"{account_name} actuellement à {str(points)} points", colour=Colour.green()
|
||||||
)
|
)
|
||||||
|
@ -562,8 +562,8 @@ def log_points(account="unknown"):
|
||||||
else:
|
else:
|
||||||
webhookSuccess.send(f"{account_name} actuellement à {str(points)} points")
|
webhookSuccess.send(f"{account_name} actuellement à {str(points)} points")
|
||||||
|
|
||||||
if sql_enabled :
|
if g.sql_enabled :
|
||||||
add_to_database(account_name, points, sql_host, sql_usr, sql_pwd, sql_database)
|
add_to_database(account_name, points, g.sql_host, g.sql_usr, g.sql_pwd, g.sql_database)
|
||||||
|
|
||||||
|
|
||||||
def fidelity():
|
def fidelity():
|
||||||
|
@ -707,20 +707,19 @@ def daily_routine(custom = False):
|
||||||
|
|
||||||
|
|
||||||
def dev():
|
def dev():
|
||||||
input("paused")
|
input("dev pause")
|
||||||
|
|
||||||
|
|
||||||
def CustomStart(Credentials):
|
def CustomStart():
|
||||||
global START_TIME
|
if not g.islinux :
|
||||||
if not LINUX_HOST :
|
|
||||||
raise NameError('You need to be on linux to do that, due to the utilisation of a module named enquieries, sorry.')
|
raise NameError('You need to be on linux to do that, due to the utilisation of a module named enquieries, sorry.')
|
||||||
global driver, p
|
global driver
|
||||||
|
|
||||||
system("clear") # clear from previous command to allow a clean choice
|
system("clear") # clear from previous command to allow a clean choice
|
||||||
actions = ["tout", "daily", "pc", "mobile", "log_points","fidelity", "dev"]
|
actions = ["tout", "daily", "pc", "mobile", "log_points","fidelity", "dev"]
|
||||||
Actions = enquiries.choose("quels Actions ?", actions, multi=True)
|
Actions = enquiries.choose("quels Actions ?", actions, multi=True)
|
||||||
liste = select_accounts()
|
liste = select_accounts()
|
||||||
START_TIME = time() # Reset timer to the start of the actions
|
g.start_time = time() # Reset timer to the start of the actions
|
||||||
|
|
||||||
for cred in liste:
|
for cred in liste:
|
||||||
g._mail = cred[0]
|
g._mail = cred[0]
|
||||||
|
@ -730,7 +729,6 @@ def CustomStart(Credentials):
|
||||||
|
|
||||||
driver = firefox_driver()
|
driver = firefox_driver()
|
||||||
driver.implicitly_wait(3)
|
driver.implicitly_wait(3)
|
||||||
|
|
||||||
if login(driver) != "STOP":
|
if login(driver) != "STOP":
|
||||||
if "tout" in Actions:
|
if "tout" in Actions:
|
||||||
daily_routine(True)
|
daily_routine(True)
|
||||||
|
@ -765,34 +763,33 @@ def CustomStart(Credentials):
|
||||||
log_points(g._mail)
|
log_points(g._mail)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
printf(f"CustomStart {e}")
|
printf(f"CustomStart {e}")
|
||||||
driver.close()
|
driver.quit()
|
||||||
|
|
||||||
|
|
||||||
if VNC_ENABLED :
|
if g.vnc_enabled :
|
||||||
display = SmartDisplay(backend="xvnc", size=(2160, 2160), rfbport=VNC_PORT, color_depth=24)
|
display = SmartDisplay(backend="xvnc", size=(2160, 2160), rfbport=g.vnc_port, color_depth=24)
|
||||||
else :
|
else :
|
||||||
display = SmartDisplay(size=(2160, 2160))
|
display = SmartDisplay(size=(2160, 2160))
|
||||||
display.start()
|
display.start()
|
||||||
|
|
||||||
|
|
||||||
if CUSTOM_START:
|
if g.custom_start:
|
||||||
CustomStart(Credentials)
|
CustomStart()
|
||||||
elif UNBAN:
|
elif g.unban:
|
||||||
g._mail, g._password = select_accounts(False)[0]
|
g._mail, g._password = select_accounts(False)[0]
|
||||||
driver = firefox_driver()
|
driver = firefox_driver()
|
||||||
try :
|
try :
|
||||||
login(driver)
|
login(driver)
|
||||||
except Banned:
|
except Banned:
|
||||||
unban()
|
unban()
|
||||||
|
|
||||||
driver.quit()
|
driver.quit()
|
||||||
elif POINTS_FILE != "":
|
elif g.points_file != "":
|
||||||
save_points_from_file(POINTS_FILE)
|
save_points_from_file(g.points_file)
|
||||||
else:
|
else:
|
||||||
if UPDATE_VERSION != "None":
|
if g.update_version != "None":
|
||||||
if DISCORD_ENABLED_ERROR:
|
if g.discord_enabled_error:
|
||||||
webhookFailure.send(f"Updated to {UPDATE_VERSION}", username="UPDATE", avatar_url="https://cdn-icons-png.flaticon.com/512/1688/1688988.png")
|
webhookFailure.send(f"Updated to {g.update_version}", username="UPDATE", avatar_url="https://cdn-icons-png.flaticon.com/512/1688/1688988.png")
|
||||||
for cred in Credentials:
|
for cred in g._cred:
|
||||||
g._mail = cred[0]
|
g._mail = cred[0]
|
||||||
g._password = cred[1]
|
g._password = cred[1]
|
||||||
if len(cred) == 3:
|
if len(cred) == 3:
|
||||||
|
|
|
@ -1,18 +1,7 @@
|
||||||
#!/usr/bin/python3.10
|
#!/usr/bin/python3.10
|
||||||
import configparser
|
from modules.driver_tools import *
|
||||||
from csv import reader
|
from modules.imports import *
|
||||||
from os import sys, system, path
|
import modules.globals as g
|
||||||
from sys import platform
|
|
||||||
import argparse
|
|
||||||
from discord import ( # Importing discord.Webhook and discord.RequestsWebhookAdapter
|
|
||||||
RequestsWebhookAdapter,
|
|
||||||
Webhook,
|
|
||||||
Colour,
|
|
||||||
)
|
|
||||||
|
|
||||||
from time import time
|
|
||||||
from random import shuffle
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Setup for option, like --override or --fulllog
|
Setup for option, like --override or --fulllog
|
||||||
"""
|
"""
|
||||||
|
@ -50,13 +39,6 @@ parser.add_argument(
|
||||||
help="enable full logging in discord",
|
help="enable full logging in discord",
|
||||||
action="store_true",
|
action="store_true",
|
||||||
)
|
)
|
||||||
parser.add_argument(
|
|
||||||
"-r",
|
|
||||||
"--risky",
|
|
||||||
help="make the program faster, probably better risk of ban",
|
|
||||||
dest="fast",
|
|
||||||
action="store_true"
|
|
||||||
)
|
|
||||||
|
|
||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
"-c",
|
"-c",
|
||||||
|
@ -89,26 +71,21 @@ parser.add_argument(
|
||||||
)
|
)
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
CUSTOM_START = args.override
|
g.custom_start = args.override
|
||||||
UNBAN = args.unban
|
g.unban = args.unban
|
||||||
LOG = args.log
|
g.log = args.log
|
||||||
FULL_LOG = args.fulllog
|
g.full_log = args.fulllog
|
||||||
FAST = args.fast
|
|
||||||
if CUSTOM_START :
|
if g.custom_start :
|
||||||
LOG = True
|
g.log = True
|
||||||
VNC_ENABLED = args.vnc != "None"
|
|
||||||
VNC_PORT = args.vnc
|
g.vnc_enabled = args.vnc != "None"
|
||||||
POINTS_FILE = args.points_file
|
g.vnc_port = args.vnc
|
||||||
UPDATE_VERSION = args.update_version
|
g.points_file = args.points_file
|
||||||
|
g.update_version = args.update_version
|
||||||
# global variables used later in the code
|
# global variables used later in the code
|
||||||
LINUX_HOST = platform == "linux" # if the computer running this program is Linux, it allow more things
|
g.islinux = platform == "linux" # if the computer running this program is Linux, it allow more things
|
||||||
START_TIME = time()
|
g.start_time = time()
|
||||||
|
|
||||||
|
|
||||||
if LINUX_HOST:
|
|
||||||
import enquiries
|
|
||||||
else:
|
|
||||||
system("") # enable colors in windows cmd
|
|
||||||
|
|
||||||
#reading configuration
|
#reading configuration
|
||||||
|
|
||||||
|
@ -122,56 +99,57 @@ config = configparser.ConfigParser()
|
||||||
config.read(config_path)
|
config.read(config_path)
|
||||||
|
|
||||||
# path configurations
|
# path configurations
|
||||||
MotPath = config["PATH"]["motpath"]
|
g.mot_path = config["PATH"]["motpath"]
|
||||||
CREDENTIALS_PATH = config["PATH"]["logpath"]
|
g.credential_path = config["PATH"]["logpath"]
|
||||||
|
|
||||||
|
|
||||||
# discord configuration
|
# discord configuration
|
||||||
DISCORD_SUCCESS_LINK = config["DISCORD"]["successlink"]
|
g.discord_success_link = config["DISCORD"]["successlink"]
|
||||||
DISCORD_ERROR_LINK = config["DISCORD"]["errorlink"]
|
g.discord_error_link = config["DISCORD"]["errorlink"]
|
||||||
DISCORD_ENABLED_ERROR = config["DISCORD"]["DiscordErrorEnabled"] == "True"
|
g.discord_enabled_error = config["DISCORD"]["DiscordErrorEnabled"] == "True"
|
||||||
DISCORD_ENABLED_SUCCESS = config["DISCORD"]["DiscordSuccessEnabled"]== "True"
|
g.discord_enabled_success = config["DISCORD"]["DiscordSuccessEnabled"]== "True"
|
||||||
try :
|
try :
|
||||||
AVATAR_URL = config["OTHER"]["avatar"]== "True"
|
g.avatar_url = config["OTHER"]["avatar"]
|
||||||
except :
|
except :
|
||||||
AVATAR_URL = "https://cdn.discordapp.com/icons/793934298977009674/d8055bccef6eca4855c349e808d0d788.webp"
|
g.avatar_url = "https://cdn.discordapp.com/icons/793934298977009674/d8055bccef6eca4855c349e808d0d788.webp"
|
||||||
|
|
||||||
if DISCORD_ENABLED_ERROR:
|
if g.discord_enabled_error:
|
||||||
webhookFailure = Webhook.from_url(DISCORD_ERROR_LINK, adapter=RequestsWebhookAdapter())
|
webhookFailure = Webhook.from_url(g.discord_error_link, adapter=RequestsWebhookAdapter())
|
||||||
if DISCORD_ENABLED_SUCCESS:
|
if g.discord_enabled_success:
|
||||||
webhookSuccess = Webhook.from_url(DISCORD_SUCCESS_LINK, adapter=RequestsWebhookAdapter())
|
webhookSuccess = Webhook.from_url(g.discord_success_link, adapter=RequestsWebhookAdapter())
|
||||||
|
|
||||||
# base settings
|
# base settings
|
||||||
FidelityLink = config["SETTINGS"]["FidelityLink"]
|
g.fidelity_link = config["SETTINGS"]["FidelityLink"]
|
||||||
DISCORD_EMBED = config["SETTINGS"]["embeds"] == "True" #print new point value in an embed
|
g.discord_embed = config["SETTINGS"]["embeds"] == "True" #print new point value in an embed
|
||||||
Headless = config["SETTINGS"]["headless"] == "True"
|
g.headless = config["SETTINGS"]["headless"] == "True"
|
||||||
|
|
||||||
# proxy settings
|
# proxy settings
|
||||||
proxy_enabled = config["PROXY"]["proxy_enabled"] == "True"
|
g.proxy_enabled = config["PROXY"]["proxy_enabled"] == "True"
|
||||||
proxy_address = config["PROXY"]["url"]
|
g.proxy_address = config["PROXY"]["url"]
|
||||||
proxy_port = config["PROXY"]["port"]
|
g.proxy_port = config["PROXY"]["port"]
|
||||||
|
|
||||||
# MySQL settings
|
# MySQL settings
|
||||||
sql_enabled = config["SQL"]["sql_enabled"] == "True"
|
g.sql_enabled = config["SQL"]["sql_enabled"] == "True"
|
||||||
sql_usr = config["SQL"]["usr"]
|
g.sql_usr = config["SQL"]["usr"]
|
||||||
sql_pwd = config["SQL"]["pwd"]
|
g.sql_pwd = config["SQL"]["pwd"]
|
||||||
sql_host = config["SQL"]["host"]
|
g.sql_host = config["SQL"]["host"]
|
||||||
sql_database = config["SQL"]["database"]
|
g.sql_database = config["SQL"]["database"]
|
||||||
|
|
||||||
# Other settings
|
|
||||||
IPV6_CHECKED = config["OTHER"]["ipv6"]
|
|
||||||
|
|
||||||
|
|
||||||
g = open(MotPath, "r", encoding="utf-8")
|
h = open(g.mot_path, "r", encoding="utf-8")
|
||||||
lines = g.readlines()
|
lines = h.readlines()
|
||||||
if len(lines) < 3 :
|
if len(lines) < 3 :
|
||||||
Liste_de_mot = list(lines[0].split(","))
|
Liste_de_mot = list(lines[0].split(","))
|
||||||
else :
|
else :
|
||||||
Liste_de_mot = [x.replace('\n', "") for x in lines]
|
Liste_de_mot = [x.replace('\n', "") for x in lines]
|
||||||
g.close()
|
h.close()
|
||||||
|
|
||||||
|
|
||||||
with open(CREDENTIALS_PATH) as f:
|
with open(g.credential_path) as f:
|
||||||
reader = reader(f)
|
reader = reader(f)
|
||||||
Credentials = list(reader)
|
Credentials = list(reader)
|
||||||
shuffle(Credentials)
|
shuffle(Credentials)
|
||||||
|
g._cred = Credentials
|
||||||
|
|
||||||
|
if g.proxy_enabled :
|
||||||
|
setup_proxy(g.proxy_address,g.proxy_port)
|
||||||
|
|
|
@ -3,19 +3,13 @@ from modules.config import *
|
||||||
from modules.tools import *
|
from modules.tools import *
|
||||||
import modules.globals as g
|
import modules.globals as g
|
||||||
|
|
||||||
def setup_proxy(ip, port, options, socks=False) :
|
def setup_proxy(ip, port) :
|
||||||
PROXY = f"{ip}:{port}"
|
PROXY = f"{ip}:{port}"
|
||||||
if socks :
|
webdriver.DesiredCapabilities.FIREFOX['proxy'] = {
|
||||||
options.set_preference('network.proxy.type', 1)
|
"httpProxy": PROXY,
|
||||||
options.set_preference('network.proxy.socks', ip)
|
"sslProxy": PROXY,
|
||||||
options.set_preference('network.proxy.socks_port', int(port))
|
"proxyType": "MANUAL",
|
||||||
options.set_preference("browser.link.open_newwindow", 3)
|
}
|
||||||
else :
|
|
||||||
webdriver.DesiredCapabilities.FIREFOX['proxy'] = {
|
|
||||||
"httpProxy": PROXY,
|
|
||||||
"sslProxy": PROXY,
|
|
||||||
"proxyType": "MANUAL",
|
|
||||||
}
|
|
||||||
|
|
||||||
#Deal with rgpd popup as well as some random popup like 'are you satisfied' one
|
#Deal with rgpd popup as well as some random popup like 'are you satisfied' one
|
||||||
def rgpd_popup(driver) -> None:
|
def rgpd_popup(driver) -> None:
|
||||||
|
@ -42,10 +36,7 @@ keys can be an string, but also selenium keys
|
||||||
def send_keys_wait(element, keys):
|
def send_keys_wait(element, keys):
|
||||||
for i in keys:
|
for i in keys:
|
||||||
element.send_keys(i)
|
element.send_keys(i)
|
||||||
if FAST :
|
sleep(uniform(0.1, 0.3))
|
||||||
pass
|
|
||||||
else :
|
|
||||||
sleep(uniform(0.1, 0.3))
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -3,3 +3,32 @@ _mail = '_mail temp'
|
||||||
_password = '_password temp'
|
_password = '_password temp'
|
||||||
_otp = '_otp temp'
|
_otp = '_otp temp'
|
||||||
display = None
|
display = None
|
||||||
|
_cred = []
|
||||||
|
custom_start = False
|
||||||
|
unban = False
|
||||||
|
log = False
|
||||||
|
full_log = False
|
||||||
|
vnc_enabled = False
|
||||||
|
vnc_port = 0
|
||||||
|
points_file = "/"
|
||||||
|
update_version = False
|
||||||
|
islinux = True
|
||||||
|
start_time = 0
|
||||||
|
mot_path = "/"
|
||||||
|
credential_path = "/"
|
||||||
|
discord_success_link = "https://example.com"
|
||||||
|
discord_error_link = "https://example.com"
|
||||||
|
discord_enabled_error = False
|
||||||
|
discord_enabled_success = False
|
||||||
|
avatar_url = ""
|
||||||
|
fidelity_link = "https://example.com"
|
||||||
|
discord_embed = False
|
||||||
|
headless = False
|
||||||
|
proxy_enabled = False
|
||||||
|
proxy_address = "0.0.0.0"
|
||||||
|
proxy_port = "0"
|
||||||
|
sql_enabled = False
|
||||||
|
sql_usr = "None"
|
||||||
|
sql_pwd = "azerty"
|
||||||
|
sql_host = "https://example.com"
|
||||||
|
sql_database = "MsRewards"
|
|
@ -1,24 +1,32 @@
|
||||||
|
import argparse
|
||||||
import asyncio
|
import asyncio
|
||||||
import csv
|
import configparser
|
||||||
from os import sys, system, path
|
import pickle
|
||||||
|
from csv import reader
|
||||||
|
from datetime import datetime, timedelta
|
||||||
|
from os import path, sys, system
|
||||||
from random import choice, randint, shuffle, uniform
|
from random import choice, randint, shuffle, uniform
|
||||||
from re import findall, search
|
from re import findall, search
|
||||||
from sys import platform
|
from sys import platform
|
||||||
from time import sleep
|
from time import sleep, time
|
||||||
from requests import get
|
|
||||||
from selenium import webdriver
|
|
||||||
from selenium.common import exceptions
|
|
||||||
from selenium.webdriver.common.by import By
|
|
||||||
from selenium.webdriver.common.keys import Keys
|
|
||||||
from selenium.webdriver.firefox.options import Options
|
|
||||||
from selenium.webdriver.support.ui import WebDriverWait
|
|
||||||
from selenium.webdriver.support import expected_conditions as EC
|
|
||||||
from selenium.webdriver.support.ui import Select
|
|
||||||
from selenium.common.exceptions import WebDriverException, TimeoutException, NoSuchElementException, ElementClickInterceptedException, StaleElementReferenceException
|
|
||||||
|
|
||||||
|
from discord import Colour, Embed, File, RequestsWebhookAdapter, Webhook
|
||||||
from pyotp import TOTP
|
from pyotp import TOTP
|
||||||
from pyvirtualdisplay import Display
|
from pyvirtualdisplay import Display
|
||||||
from pyvirtualdisplay.smartdisplay import SmartDisplay
|
from pyvirtualdisplay.smartdisplay import SmartDisplay
|
||||||
import pickle
|
from requests import get
|
||||||
from datetime import timedelta, datetime
|
from selenium import webdriver
|
||||||
from discord import Embed, Colour, File
|
from selenium.common import exceptions
|
||||||
|
from selenium.common.exceptions import (ElementClickInterceptedException,
|
||||||
|
NoSuchElementException,
|
||||||
|
StaleElementReferenceException,
|
||||||
|
TimeoutException, WebDriverException)
|
||||||
|
from selenium.webdriver.common.by import By
|
||||||
|
from selenium.webdriver.common.keys import Keys
|
||||||
|
from selenium.webdriver.firefox.options import Options
|
||||||
|
from selenium.webdriver.support import expected_conditions as EC
|
||||||
|
from selenium.webdriver.support.ui import Select, WebDriverWait
|
||||||
|
try:
|
||||||
|
import enquiries
|
||||||
|
except:
|
||||||
|
system("") # enable colors in windows cmd
|
|
@ -1,10 +1,9 @@
|
||||||
from modules.imports import *
|
from modules.imports import *
|
||||||
from modules.config import *
|
from modules.config import *
|
||||||
import modules.globals as g
|
import modules.globals as g
|
||||||
|
|
||||||
# add the time arround the text given in [text]&
|
# add the time arround the text given in [text]&
|
||||||
def Timer(text: str) -> str:
|
def Timer(text: str) -> str:
|
||||||
return(f"[{g._mail.split('@')[0]} - {datetime.today().strftime('%d/%m')} - {timedelta(seconds = round(float(time() - START_TIME)))}] " + str(text))
|
return(f"[{g._mail.split('@')[0]} - {datetime.today().strftime('%d/%m')} - {timedelta(seconds = round(float(time() - g.start_time)))}] " + str(text))
|
||||||
|
|
||||||
|
|
||||||
# replace the function print, with more options
|
# replace the function print, with more options
|
||||||
|
@ -32,9 +31,7 @@ def check_ipv4(driver):
|
||||||
|
|
||||||
def custom_sleep(temps):
|
def custom_sleep(temps):
|
||||||
try :
|
try :
|
||||||
if FAST and temps > 50:
|
if g.log : #only print sleep when user see it
|
||||||
sleep(temps/10)
|
|
||||||
elif LOG: #only print sleep when user see it
|
|
||||||
points = ["⢿", "⣻", "⣽", "⣾", "⣷", "⣯", "⣟", "⡿"]
|
points = ["⢿", "⣻", "⣽", "⣾", "⣷", "⣯", "⣟", "⡿"]
|
||||||
passe = 0
|
passe = 0
|
||||||
for i in range(int(temps)):
|
for i in range(int(temps)):
|
||||||
|
@ -80,7 +77,7 @@ def save_points_from_file(file):
|
||||||
|
|
||||||
def select_accounts(multiple = True):
|
def select_accounts(multiple = True):
|
||||||
system("clear") # clear from previous command to allow a clean choice
|
system("clear") # clear from previous command to allow a clean choice
|
||||||
emails = [x[0] for x in Credentials] # list of all email adresses
|
emails = [x[0] for x in g._cred] # list of all email adresses
|
||||||
emails_selected = enquiries.choose(f"quel{'s' if multiple else ''} compte{'s' if multiple else ''} ?", emails, multi=multiple)
|
emails_selected = enquiries.choose(f"quel{'s' if multiple else ''} compte{'s' if multiple else ''} ?", emails, multi=multiple)
|
||||||
return([x for x in Credentials if x[0] in emails_selected])
|
return([x for x in g._cred if x[0] in emails_selected])
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue