oh boy i probably just broke everything

This commit is contained in:
piair338 2022-10-24 18:08:33 +00:00
parent f8e9daaedd
commit 3155b545dc
3 changed files with 344 additions and 367 deletions

511
V4.py
View File

@ -1,20 +1,13 @@
#!/usr/bin/python3.10
import asyncio
import configparser
from csv import reader
from os import sys, system, path
from random import choice, randint, shuffle, uniform
from re import findall, search
from sys import platform
from time import sleep, time
from time import sleep
from requests import get
from datetime import timedelta
import discord
from discord import ( # Importing discord.Webhook and discord.RequestsWebhookAdapter
Colour,
RequestsWebhookAdapter,
Webhook,
)
from selenium import webdriver
from selenium.common import exceptions
from selenium.webdriver.common.by import By
@ -23,120 +16,12 @@ 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.common.exceptions import TimeoutException, NoSuchElementException
import argparse
from modules.db import add_to_database
"""
Setup for option, like --override or --fulllog
"""
parser = argparse.ArgumentParser()
parser.add_argument(
"-o", "--override", help="override", dest="override", action="store_true"
)
parser.add_argument(
"-l", "--log", dest="log", help="enable logging in terminal", action="store_true"
)
parser.add_argument(
"-fl",
"--fulllog",
dest="fulllog",
help="enable full logging in discord",
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(
"-c", "--config", help="Choose a specific config file", type=argparse.FileType('r')
)
args = parser.parse_args()
CUSTOM_START = args.override
LOG = args.log
FULL_LOG = args.fulllog
FAST = args.fast
if CUSTOM_START :
LOG = True
#SOON (maybe) (no)
#logpath = ("/".join(__file__.split("/")[:-1])+"/LogFile.out")
#logfile = open(logpath, "w")
# gloabal variables used later in the code
LINUX_HOST = platform == "linux" # if the computer running this programm is linux, it allow more things
START_TIME = time()
from modules.config import *
from modules.tools import *
global driver
driver = None
if LINUX_HOST:
import enquiries
else:
system("") # enable colors in windows cmd
#reading configuration
config_path = f"{path.abspath( path.dirname( __file__ ) )}/user_data/config.cfg"
if args.config :
config_path = path.abspath(args.config.name)
config = configparser.ConfigParser()
config.read(config_path)
# path configurations
MotPath = config["PATH"]["motpath"]
CREDENTIALS_PATH = config["PATH"]["logpath"]
# discord configuration
DISCORD_SUCCESS_LINK = config["DISCORD"]["successlink"]
DISCORD_ERROR_LINK = config["DISCORD"]["errorlink"]
DISCORD_ENABLED_ERROR = config["DISCORD"]["DiscordErrorEnabled"] == "True"
DISCORD_ENABLED_SUCCESS = config["DISCORD"]["DiscordSuccessEnabled"]== "True"
if DISCORD_ENABLED_ERROR:
webhookFailure = Webhook.from_url(DISCORD_ERROR_LINK, adapter=RequestsWebhookAdapter())
if DISCORD_ENABLED_SUCCESS:
webhookSuccess = Webhook.from_url(DISCORD_SUCCESS_LINK, adapter=RequestsWebhookAdapter())
# base settings
FidelityLink = config["SETTINGS"]["FidelityLink"]
DISCORD_EMBED = config["SETTINGS"]["embeds"] == "True" #print new point value in an embed
Headless = config["SETTINGS"]["headless"] == "True"
# proxy settings
proxy_enabled = config["PROXY"]["proxy_enabled"] == "True"
proxy_address = config["PROXY"]["url"]
proxy_port = config["PROXY"]["port"]
# MySQL settings
sql_enabled = config["SQL"]["sql_enabled"] == "True"
sql_usr = config["SQL"]["usr"]
sql_pwd = config["SQL"]["pwd"]
sql_host = config["SQL"]["host"]
sql_database = config["SQL"]["database"]
# Other seetings
IPV6_CHECKED = config["OTHER"]["ipv6"]
CLAIM_AMAZON = config["OTHER"]["claim_amazon"]
g = open(MotPath, "r", encoding="utf-8")
lines = g.readlines()
if len(lines) < 3 :
Liste_de_mot = list(lines[0].split(","))
else :
Liste_de_mot = [x.replace('\n', "") for x in lines]
g.close()
def WaitUntilVisible(by, id, to = 20, browser = driver):
@ -146,17 +31,6 @@ def WaitUntilVisible(by, id, to = 20, browser = driver):
print(f"element not found after {to}s")
def Timer(text="undefined"):
return(f"[{_mail} - {timedelta(seconds = round(float(time() - START_TIME)))}] " + str(text))
def check_ipv4():
driver.get("https://api64.ipify.org")
elm = driver.find_element(By.TAG_NAME, "body")
if len(elm.text.split('.')) == 4 :
return True
return False
def claim_amazon():
try :
@ -196,14 +70,14 @@ def claim_amazon():
webhookFailure.send(_mail +" - "+ fcode)
return(1)
else :
LogError("impossible de localiser le code ")
LogError("impossible de localiser le code ", driver)
return(1)
else :
LogError("la recuperation ne peux pas être automatique")
LogError("la recuperation ne peux pas être automatique", driver)
return(0)
except Exception as e :
LogError(f'problème dans la recuperation : {str(e)}')
LogError(f'problème dans la recuperation : {str(e)}', driver)
def setup_proxy(ip, port) :
@ -242,22 +116,12 @@ def FirefoxDriver(mobile=False, Headless=Headless):
return driver
def printf(txt, end="", Mobdriver=driver):
if LOG:
print(Timer(txt))
if FULL_LOG:
try :
LogError(Timer(txt), Mobdriver=Mobdriver)
except Exception as e:
print("\n" + Timer(e) + "\n" + Timer(txt) + "\n" )
def CustomSleep(temps):
try :
if FAST and temps > 50:
sleep(temps/10)
return()
if LOG or not LINUX_HOST: #only print sleep when user see it
if not LOG or not LINUX_HOST: #only print sleep when user see it
points = ["", "", "", "", "", "", "", ""]
passe = 0
for i in range(int(temps)):
@ -273,37 +137,6 @@ def CustomSleep(temps):
printf("attente annulée")
def LogError(message, log=FULL_LOG, Mobdriver=None):
print(f"\n\n\033[93m Erreur : {str(message)} \033[0m\n\n")
if Mobdriver:
gdriver = Mobdriver
else:
gdriver = driver
if LINUX_HOST and DISCORD_ENABLED_ERROR:
with open("page.html", "w") as f:
f.write(gdriver.page_source)
gdriver.save_screenshot("screenshot.png")
if not log:
embed = discord.Embed(
title="An Error has occured",
description=str(message),
colour=Colour.red(),
)
else:
embed = discord.Embed(
title="Full log is enabled",
description=str(message),
colour=Colour.blue(),
)
file = discord.File("screenshot.png")
embed.set_image(url="attachment://screenshot.png")
embed.set_footer(text=_mail)
webhookFailure.send(embed=embed, file=file)
webhookFailure.send(file=discord.File("page.html"))
def progressBar(current, total=30, barLength=20, name="Progress"):
percent = float(current + 1) * 100 / total
@ -368,7 +201,7 @@ def PlayQuiz2(override=10):
driver.execute_script("arguments[0].click();", elem)
except Exception as e:
LogError("PlayQuiz2" + str(e))
LogError("PlayQuiz2" + str(e), driver)
break
printf("PlayQuiz2 finis")
@ -387,7 +220,7 @@ def PlayQuiz8(override=3):
if 'iscorrectoption="True" ' in Card.get_attribute("outerHTML"):
ListeOfGood.append(f"rqAnswerOption{i-1}") # premier div = 3 ?
except Exception as e:
LogError(f"playquiz8 - 1 - {e}")
LogError(f"playquiz8 - 1 - {e}", driver)
shuffle(ListeOfGood)
for i in ListeOfGood:
@ -401,7 +234,7 @@ def PlayQuiz8(override=3):
try:
driver.execute_script("arguments[0].click();", elem)
except Exception as e:
LogError(f"playquizz8 - 2 - {e}")
LogError(f"playquizz8 - 2 - {e}", driver)
except exceptions.NoSuchElementException as e :
try :
driver.refresh()
@ -409,15 +242,15 @@ def PlayQuiz8(override=3):
elem = driver.find_element(By.ID, i)
elem.click()
except Exception as e :
LogError(f"playquizz8 - 5 - {e}")
LogError(f"playquizz8 - 5 - {e}", driver)
except Exception as e:
if CUSTOM_START:
printf(f"playquiz8 - 3 - {e}") # may append during
else:
LogError(f"playquizz8 - 3 - {e}")
LogError(f"playquizz8 - 3 - {e}", driver)
except Exception as e:
LogError(f"PlayQuiz8 - 4 - {e} \n ListOfGood : {str(ListeOfGood)}")
LogError(f"PlayQuiz8 - 4 - {e} \n ListOfGood : {str(ListeOfGood)}", driver)
printf("PlayQuiz8 : fin ")
@ -438,8 +271,8 @@ def PlayQuiz4(override=None):
RGPD()
reponse = search('correctAnswer":"([^"]+)', txt)[1] # je suis pas sur qu'il y ait un espace
reponse = reponse.replace("\\u0027", "'") # il faut cancel l'unicode avec un double \ (on replacer les caracteres en unicode en caracteres utf-8)
printf(f"validation de la reponse ",end="\r",)
printf(f"validation de la reponse {i+1}/{override} {reponse}", end="\r")
printf(f"validation de la reponse ")
printf(f"validation de la reponse {i+1}/{override} {reponse}")
try:
elem = driver.find_element(
By.CSS_SELECTOR, f'[data-option="{reponse}"]'
@ -449,7 +282,7 @@ def PlayQuiz4(override=None):
driver.execute_script("arguments[0].click();", elem)
except Exception as e:
LogError(f"PlayQuiz4 {str(e)}")
LogError(f"PlayQuiz4 {str(e)}", driver)
raise ValueError(e)
printf("PlayQuiz4 : end")
@ -467,7 +300,7 @@ def PlayPoll():
driver.execute_script("arguments[0].click();", elem)
CustomSleep(uniform(2, 2.5))
except Exception as e:
LogError("PlayPoll" + str(e))
LogError("PlayPoll" + str(e), driver)
raise ValueError(e)
printf("PlayPoll : end")
@ -506,7 +339,7 @@ def AllCard(): # fonction qui clique sur les cartes
except Exception as e:
printf(f"Allcard card {titre} error ({e})")
except Exception as e:
LogError(f"Dailycards {e}")
LogError(f"Dailycards {e}", driver)
try:
dailyCards()
@ -552,7 +385,7 @@ def AllCard(): # fonction qui clique sur les cartes
weekly_cards()
break
except Exception as e:
LogError(f"weekly_cards, try n°{i+1} \n {e}")
LogError(f"weekly_cards, try n°{i+1} \n {e}", driver)
if i == 0 :
driver.refresh()
else :
@ -560,18 +393,6 @@ def AllCard(): # fonction qui clique sur les cartes
driver.refresh()
"""
send_keys_wait([selenium element:element, str:keys]) send the different keys to the field element, with a random time between each press to simulate human action.
keys can be an string, but alos selenium keys
"""
def send_keys_wait(element, keys):
for i in keys:
element.send_keys(i)
if FAST :
pass
else :
sleep(uniform(0.1, 0.3))
"""
login() tries to login to your micrososft account.
@ -599,29 +420,11 @@ def login():
send_keys_wait(pwd, _password)
pwd.send_keys(Keys.ENTER)
CustomSleep(5)
for i in ["KmsiCheckboxField","iLooksGood", "idSIButton9", "iCancel"]:
try:
driver.find_element(By.ID, "KmsiCheckboxField").click()
driver.find_element(By.ID, i).click()
except Exception as e:
pass
#printf(f"login - 2.1 - erreur validation bouton KmsiCheckboxField. pas forcement grave {e}")
try:
driver.find_element(By.ID, "iLooksGood").click()
except Exception as e:
pass
#printf(f"login - 2.2 - erreur validation bouton iLooksGood. pas forcement grave {e}")
try:
driver.find_element(By.ID, "idSIButton9").click()
except Exception as e:
pass
#printf(f"login - 2.3 - erreur validation bouton idSIButton9. pas forcement grave {e}")
try:
driver.find_element(By.ID, "iCancel").click()
except Exception as e:
pass
#printf(f"login - 2.4 - erreur validation bouton iCancel. pas forcement grave {e}")
try :
elm = driver.find_element(By.TAG_NAME, "body")
elm.send_keys(Keys.ENTER)
@ -638,7 +441,7 @@ def login():
sub_login()
return (driver.current_window_handle)
except Exception as e:
LogError("login - 3 - " + str(e))
LogError("login - 3 - " + str(e), driver)
driver.close()
CustomSleep(1200)
driver = FirefoxDriver()
@ -683,137 +486,11 @@ def BingPcSearch(override=randint(35, 40)):
driver.get('https://www.bing.com/search?q=pls')
driver.find_element(By.ID, "sb_form_q").clear()
except Exception as e:
LogError(f"BingPcSearch - clear la barre de recherche - {e}")
LogError(f"BingPcSearch - clear la barre de recherche - {e}", driver)
print("\n\n")
def BingMobileSearch(override=randint(22, 25)):
MobileDriver = "unable to start"
try:
try:
MobileDriver = FirefoxDriver(mobile=True)
MobileDriver.implicitly_wait(15)
except Exception as e:
sleep(30)
LogError("BingMobileSearch - 1 - echec de la creation du driver mobile")
MobileDriver = FirefoxDriver(mobile=True)
MobileDriver.implicitly_wait(15)
echec = 0
def Mlogin(echec):
try:
MobileDriver.get(
"https://www.bing.com/search?q=test+speed"
)
MRGPD()
CustomSleep(uniform(3, 5))
printf("début du login", Mobdriver=MobileDriver)
MobileDriver.find_element(By.ID, "mHamburger").click()
CustomSleep(uniform(1, 2))
printf("Mlogin - 1", Mobdriver=MobileDriver)
MobileDriver.find_element(By.ID, "hb_s").click()
CustomSleep(uniform(1, 2))
printf("Mlogin - 2", Mobdriver=MobileDriver)
mail = MobileDriver.find_element(By.ID, "i0116")
send_keys_wait(mail, _mail)
printf("Mlogin - 3", Mobdriver=MobileDriver)
mail.send_keys(Keys.ENTER)
CustomSleep(uniform(7, 9))
printf("Mlogin - 4", Mobdriver=MobileDriver)
pwd = MobileDriver.find_element(By.ID, "i0118")
printf("Mlogin - 5", Mobdriver=MobileDriver)
send_keys_wait(pwd, _password)
printf("Mlogin - 6", Mobdriver=MobileDriver)
pwd.send_keys(Keys.ENTER)
CustomSleep(uniform(1, 2))
try:
MobileDriver.find_element(By.ID, "KmsiCheckboxField").click()
except Exception as e:
printf(f"Mlogin - 2.1 - erreur validation bouton KmsiCheckboxField. pas forcement grave {e}")
try:
MobileDriver.find_element(By.ID, "iLooksGood").click()
except Exception as e:
printf(f"Mlogin - 2.2 - erreur validation bouton iLooksGood. pas forcement grave {e}")
try:
MobileDriver.find_element(By.ID, "idSIButton9").click()
except Exception as e:
printf(f"Mlogin - 2.3 - erreur validation bouton idSIButton9. pas forcement grave {e}")
printf("fin du Mlogin", Mobdriver=MobileDriver)
except Exception as e:
echec += 1
if echec <= 3:
printf(
f"echec du login sur la version mobile. on reesaye ({echec}/3), {e}"
)
CustomSleep(uniform(5, 10))
Mlogin(echec)
else:
LogError(
f"login impossible 3 fois de suite. {e}", Mobdriver=MobileDriver
)
MobileDriver.quit()
return True
def MRGPD():
try:
MobileDriver.find_element(By.ID, "bnp_btn_accept").click()
except Exception as e:
pass
printf(e)
try:
MobileDriver.find_element(By.ID, "bnp_hfly_cta2").click()
except Exception as e:
pass
printf(f"MRGPD : e")
def Alerte():
try:
alert = MobileDriver.switch_to.alert
alert.dismiss()
except exceptions.NoAlertPresentException as e:
pass
except Exception as e:
LogError(
f"error sur une alerte dans le driver mobile. {e}",
Mobdriver=MobileDriver,
)
if not Mlogin(echec):
CustomSleep(uniform(1, 2))
MRGPD()
CustomSleep(uniform(1, 1.5))
for i in range(override): # 20
try :
mot = choice(Liste_de_mot)
send_keys_wait(MobileDriver.find_element(By.ID, "sb_form_q"), mot)
MobileDriver.find_element(By.ID, "sb_form_q").send_keys(Keys.ENTER)
progressBar(i, override, name="Mobile")
printf(MobileDriver.current_url, Mobdriver=MobileDriver)
CustomSleep(uniform(5, 20))
Alerte() # verifie si il y a des alertes (demande de positions ....)
MobileDriver.find_element(By.ID, "sb_form_q").clear()
except :
driver.refresh()
CustomSleep(30)
i -= 1
MobileDriver.quit()
except Exception as e:
LogError("BingMobileSearch - 4 - " + str(e), Mobdriver=MobileDriver)
try:
MobileDriver.quit()
except Exception as e:
LogError(f"can't close mobile driveer . {e}")
def TryPlay(nom="inconnu"):
@ -845,9 +522,7 @@ def TryPlay(nom="inconnu"):
except Exception as e:
printf(f"echec de PlayQuiz 2. Aborted {e}")
else:
LogError(
"probleme dans la carte : il y a un bouton play et aucun quiz detecté"
)
LogError("probleme dans la carte : il y a un bouton play et aucun quiz detecté", driver)
try:
driver.find_element(By.ID, "rqStartQuiz").click() # start the quiz
@ -922,7 +597,7 @@ def LogPoint(account="unknown"): # log des points sur discord
points = None
if not points :
LogError(f"impossible d'avoir les points : {e}")
LogError(f"impossible d'avoir les points : {e}", driver)
CustomSleep(uniform(3, 20))
account = account.split("@")[0]
@ -989,7 +664,7 @@ def Fidelite():
t = driver.find_element(By.XPATH,'/html/body/div[1]/div[2]/main/div[2]/div[2]/div[7]/div[3]/div[1]')
t.click()
except Exception as e2 :
LogError(f"fidélité - double erreur - e1 : {e1} - e2 {e2}")
LogError(f"fidélité - double erreur - e1 : {e1} - e2 {e2}", driver)
break
CustomSleep(uniform(3, 5))
driver.switch_to.window(driver.window_handles[1])
@ -1004,7 +679,115 @@ def Fidelite():
else :
printf("lien invalide")
except Exception as e:
LogError("Fidélité" + str(e))
LogError("Fidélité" + str(e), driver)
def Mlogin(echec):
try:
MobileDriver.get("https://www.bing.com/search?q=test+speed")
MRGPD()
printf("début du login", Mobdriver=MobileDriver)
MobileDriver.find_element(By.ID, "mHamburger").click()
CustomSleep(uniform(1, 2))
MobileDriver.find_element(By.ID, "hb_s").click()
CustomSleep(uniform(1, 2))
mail = MobileDriver.find_element(By.ID, "i0116")
send_keys_wait(mail, _mail)
mail.send_keys(Keys.ENTER)
CustomSleep(uniform(7, 9))
pwd = MobileDriver.find_element(By.ID, "i0118")
send_keys_wait(pwd, _password)
pwd.send_keys(Keys.ENTER)
CustomSleep(uniform(1, 2))
try:
MobileDriver.find_element(By.ID, "KmsiCheckboxField").click()
except Exception as e:
pass
try:
MobileDriver.find_element(By.ID, "iLooksGood").click()
except Exception as e:
pass
try:
MobileDriver.find_element(By.ID, "idSIButton9").click()
except Exception as e:
pass
printf("fin du Mlogin")
except Exception as e:
echec += 1
if echec <= 3:
printf(
f"echec du login sur la version mobile. on reesaye ({echec}/3), {e}"
)
CustomSleep(uniform(5, 10))
Mlogin(echec)
else:
LogError(
f"login impossible 3 fois de suite. {e}", MobileDriver
)
MobileDriver.quit()
return True
def MRGPD():
try:
MobileDriver.find_element(By.ID, "bnp_btn_accept").click()
except Exception as e:
pass
try:
MobileDriver.find_element(By.ID, "bnp_hfly_cta2").click()
except Exception as e:
pass
def Alerte():
try:
alert = MobileDriver.switch_to.alert
alert.dismiss()
except exceptions.NoAlertPresentException as e:
pass
except Exception as e:
LogError(
f"mobile.py -> Alerte : {e}",
driver=MobileDriver,
)
def BingMobileSearch(override=randint(22, 25)):
MobileDriver = "unable to start"
try:
try:
MobileDriver = FirefoxDriver(mobile=True)
MobileDriver.implicitly_wait(15)
except Exception as e:
LogError("BingMobileSearch - 1 - echec de la creation du driver mobile", MobileDriver)
echec = 0
if not Mlogin(echec):
CustomSleep(uniform(1, 2))
MRGPD()
CustomSleep(uniform(1, 1.5))
for i in range(override): # 20
try :
mot = choice(Liste_de_mot)
send_keys_wait(MobileDriver.find_element(By.ID, "sb_form_q"), mot)
MobileDriver.find_element(By.ID, "sb_form_q").send_keys(Keys.ENTER)
progressBar(i, override, name="Mobile")
printf(MobileDriver.current_url)
CustomSleep(uniform(5, 20))
Alerte() # verifie si il y a des alertes (demande de positions ....)
MobileDriver.find_element(By.ID, "sb_form_q").clear()
except :
driver.refresh()
CustomSleep(30)
i -= 1
MobileDriver.quit()
except Exception as e:
LogError("BingMobileSearch - 4 - " + str(e), MobileDriver)
MobileDriver.quit()
def DailyRoutine(custom = False):
@ -1017,31 +800,31 @@ def DailyRoutine(custom = False):
try:
AllCard()
except Exception as e:
LogError(f"DailyRoutine - AllCard - \n{e}")
LogError(f"DailyRoutine - AllCard - \n{e}", driver)
try:
BingPcSearch()
except Exception as e:
LogError(f"DailyRoutine - BingPcSearch - \n{e}")
LogError(f"DailyRoutine - BingPcSearch - \n{e}", driver)
CustomSleep(uniform(3, 20))
try:
Fidelite()
except Exception as e:
LogError(f"DailyRoutine - Fidelité - \n{e}")
LogError(f"DailyRoutine - Fidelité - \n{e}", driver)
try:
BingMobileSearch()
except Exception as e:
LogError(f"DailyRoutine - BingMobileSearch - \n{e}")
LogError(f"DailyRoutine - BingMobileSearch - \n{e}", driver)
CustomSleep(uniform(3, 20))
try:
LogPoint(_mail)
except Exception as e:
LogError(f"DailyRoutine - LogPoint - \n{e}")
LogError(f"DailyRoutine - LogPoint - \n{e}", driver)
else :
LogError(f"probleme de login sur le comte {_mail}")
LogError(f"probleme de login sur le comte {_mail}", driver)
def close():
@ -1050,7 +833,7 @@ def close():
def dev():
print(check_ipv4())
pass
def CustomStart(Credentials):
@ -1082,25 +865,25 @@ def CustomStart(Credentials):
try:
AllCard()
except Exception as e:
LogError(f"AllCards - {e} -- override")
LogError(f"AllCards - {e} -- override", driver)
if "pc" in Actions:
try:
BingPcSearch()
except Exception as e:
LogError(f"il y a eu une erreur dans BingPcSearch, {e} -- override")
LogError(f"il y a eu une erreur dans BingPcSearch, {e} -- override", driver)
if "mobile" in Actions:
try:
BingMobileSearch()
except Exception as e:
LogError(f"BingMobileSearch - {e} -- override")
LogError(f"BingMobileSearch - {e} -- override", driver)
if "Fidelite" in Actions:
try :
Fidelite()
except Exception as e :
LogError(f"Fidelite - {e} -- override")
LogError(f"Fidelite - {e} -- override", driver)
if "dev" in Actions:
try:

117
modules/config.py Normal file
View File

@ -0,0 +1,117 @@
#!/usr/bin/python3.10
import configparser
from csv import reader
from os import sys, system, path
from sys import platform
import argparse
from discord import ( # Importing discord.Webhook and discord.RequestsWebhookAdapter
RequestsWebhookAdapter,
Webhook,
)
from time import time
"""
Setup for option, like --override or --fulllog
"""
parser = argparse.ArgumentParser()
parser.add_argument(
"-o", "--override", help="override", dest="override", action="store_true"
)
parser.add_argument(
"-l", "--log", dest="log", help="enable logging in terminal", action="store_true"
)
parser.add_argument(
"-fl",
"--fulllog",
dest="fulllog",
help="enable full logging in discord",
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(
"-c", "--config", help="Choose a specific config file", type=argparse.FileType('r')
)
args = parser.parse_args()
CUSTOM_START = args.override
LOG = args.log
FULL_LOG = args.fulllog
FAST = args.fast
if CUSTOM_START :
LOG = True
# gloabal variables used later in the code
LINUX_HOST = platform == "linux" # if the computer running this programm is linux, it allow more things
START_TIME = time()
driver = None
if LINUX_HOST:
import enquiries
else:
system("") # enable colors in windows cmd
#reading configuration
config_path = f"{path.abspath( path.dirname( __file__ ) )}/user_data/config.cfg"
if args.config :
config_path = path.abspath(args.config.name)
config = configparser.ConfigParser()
config.read(config_path)
# path configurations
MotPath = config["PATH"]["motpath"]
CREDENTIALS_PATH = config["PATH"]["logpath"]
# discord configuration
DISCORD_SUCCESS_LINK = config["DISCORD"]["successlink"]
DISCORD_ERROR_LINK = config["DISCORD"]["errorlink"]
DISCORD_ENABLED_ERROR = config["DISCORD"]["DiscordErrorEnabled"] == "True"
DISCORD_ENABLED_SUCCESS = config["DISCORD"]["DiscordSuccessEnabled"]== "True"
if DISCORD_ENABLED_ERROR:
webhookFailure = Webhook.from_url(DISCORD_ERROR_LINK, adapter=RequestsWebhookAdapter())
if DISCORD_ENABLED_SUCCESS:
webhookSuccess = Webhook.from_url(DISCORD_SUCCESS_LINK, adapter=RequestsWebhookAdapter())
# base settings
FidelityLink = config["SETTINGS"]["FidelityLink"]
DISCORD_EMBED = config["SETTINGS"]["embeds"] == "True" #print new point value in an embed
Headless = config["SETTINGS"]["headless"] == "True"
# proxy settings
proxy_enabled = config["PROXY"]["proxy_enabled"] == "True"
proxy_address = config["PROXY"]["url"]
proxy_port = config["PROXY"]["port"]
# MySQL settings
sql_enabled = config["SQL"]["sql_enabled"] == "True"
sql_usr = config["SQL"]["usr"]
sql_pwd = config["SQL"]["pwd"]
sql_host = config["SQL"]["host"]
sql_database = config["SQL"]["database"]
# Other seetings
IPV6_CHECKED = config["OTHER"]["ipv6"]
CLAIM_AMAZON = config["OTHER"]["claim_amazon"]
g = open(MotPath, "r", encoding="utf-8")
lines = g.readlines()
if len(lines) < 3 :
Liste_de_mot = list(lines[0].split(","))
else :
Liste_de_mot = [x.replace('\n', "") for x in lines]
g.close()

77
modules/tools.py Normal file
View File

@ -0,0 +1,77 @@
from time import sleep
from random import uniform
import discord
from discord import ( # Importing discord.Webhook and discord.RequestsWebhookAdapter
Colour,
Webhook,
)
from modules.config import *
"""
send_keys_wait([selenium element:element, str:keys]) send the different keys to the field element, with a random time between each press to simulate human action.
keys can be an string, but alos selenium keys
"""
def send_keys_wait(element, keys):
for i in keys:
element.send_keys(i)
if FAST :
pass
else :
sleep(uniform(0.1, 0.3))
def LogError(message, driver, log=FULL_LOG):
print(f"\n\n\033[93m Erreur : {str(message)} \033[0m\n\n")
if DISCORD_ENABLED_ERROR:
with open("page.html", "w") as f:
f.write(gdriver.page_source)
gdriver.save_screenshot("screenshot.png")
if not log:
embed = discord.Embed(
title="An Error has occured",
description=str(message),
colour=Colour.red(),
)
else:
embed = discord.Embed(
title="Full log is enabled",
description=str(message),
colour=Colour.blue(),
)
file = discord.File("screenshot.png")
embed.set_image(url="attachment://screenshot.png")
embed.set_footer(text=_mail)
webhookFailure.send(embed=embed, file=file)
webhookFailure.send(file=discord.File("page.html"))
# add the time arround the text given in [text]
# [text] : string
def Timer(text="undefined"):
return(f"[{_mail} - {timedelta(seconds = round(float(time() - START_TIME)))}] " + str(text))
# replace the function print, with more options
# [txt] : string, [driver] : selenium wbdriver
def printf(txt, LOG = False):
if LOG:
print(Timer(txt))
# check if the user is using IPV4 using ipify.org
# [driver] : selenium webdriver
def check_ipv4(driver):
driver.get("https://api64.ipify.org")
elm = driver.find_element(By.TAG_NAME, "body")
if len(elm.text.split('.')) == 4 :
return True
return False