Autoclaim_LuckyPot/honeygaingift.py

182 lines
8.2 KiB
Python

import os, sys
import json
import time
import logging
import requests
import platform
import subprocess
from selenium import webdriver
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions as EC
from selenium.common.exceptions import TimeoutException
from selenium.webdriver.common.action_chains import ActionChains
# Hier wird das logging erstmal auf Critical gestellt
logging.basicConfig(level=logging.CRITICAL)
# Speichere den absoluten Pfad zum Skript.
script_dir = os.path.dirname(os.path.realpath(sys.argv[0]))
# Erstelle logdatei & defeniert das format
log_file = os.path.join(script_dir, 'claim.log')
logging.basicConfig(filename=log_file,
format='%(asctime)s %(message)s',
datefmt='%d.%m.%Y %H:%M:%S',
filemode='w')
# Erstelle ein Aufrufbares Objekt.
logger = logging.getLogger()
# Stelle das Log Level ein
logger.setLevel(logging.INFO)
# Lade die Logindaten aus der honeygainlogin.json datei.
with open('honeygainlogin.json', 'r') as file:
login_data = json.load(file)
username = login_data['username']
password = login_data['password']
# Nutze den vorinstallierten Chrome Browser
if platform.system() == 'Windows':
chrome_binary = r'C:\Program Files\Google\Chrome\Application\chrome.exe' # Chrome EXE die genutzt werden soll in Windows
elif platform.system() == 'Linux':
chrome_binary = '/usr/bin/google-chrome' # Chrome executable die genutzt werden soll in Linux
# Erstelle Chrome Argumente Variable
chrome_options = webdriver.ChromeOptions()
# Verhindert das der Chromedriver log angezeigt wird.
chrome_options.add_experimental_option('excludeSwitches', ['enable-logging'])
chrome_options.binary_location = chrome_binary
chrome_options.add_argument('--no-first-run')
chrome_options.add_argument('--no-sandbox')
# Öffnet den Chrome im Headless modus (Ohne Fenster)
chrome_options.add_argument('--headless')
# Erstelle eine Session mit Chrome und den vorher definierten Einstellungen
driver = webdriver.Chrome(options=chrome_options)
"""
Öffne Chrome mit einer Auflösung von 2560x1440
Dies ist wichtig, da sonst die info mit dem Jumpcoin über der Login-Mail eingabe hängt und daher nicht klickbar ist.
"""
driver.set_window_size(2560, 1440)
# Öffne die Loginseite
driver.get('https://dashboard.honeygain.com/login')
try:
# Warte bis der Login Button verfügbar ist.
WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.XPATH, "//button[contains(., 'Login with email')]")))
except TimeoutException:
print("Timeout: Failed to load page within 10 seconds")
driver.quit()
# Suche die Nutzernamen & Passwort felder und fülle diese aus.
username_field = driver.find_element(By.ID, 'email')
username_field.send_keys(username)
password_field = driver.find_element(By.ID, 'password')
password_field.send_keys(password)
# Zur Sicherheit ein 3 Sekunden Timer. Damit es nicht zu "bottig" wirkt.
time.sleep(3)
# Drücke den Login Button, scrolle gegebenfalls etwas in dessen Richtung, um sicherzustellen, dass dieser drückbar ist.
submit_button = driver.find_element(By.XPATH, "//button[contains(., 'Login with email')]")
driver.execute_script("arguments[0].scrollIntoView(true);", submit_button)
submit_button.click()
actions = ActionChains(driver)
actions.move_to_element(submit_button).click().perform()
try:
# Warte max 10 Sekunden bis der Text "Total earnings" erscheint.
WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.XPATH, "//div[contains(text(), 'Total earnings')]")))
except TimeoutException:
print("Timeout: Failed to load page within 10 seconds")
driver.quit()
# Lasse den Cookie Banner verschwinden.
cookie_button = driver.find_element(By.XPATH, "//button[contains(., 'Accept selected')]")
cookie_button.click()
# Zunächst überprüfen wir, ob wir schon genug Traffic zum claimen erzeugt haben
while True:
try:
time.sleep(5)
traffic = driver.find_element(By.ID, "__lottie_element_2")
traffic_element = driver.find_element(By.XPATH, "//span[contains(text(), 'MB')]")
traffic_text = traffic_element.text
print(f"Es wurde noch nicht genug traffic erzeugt ({traffic_text}) von 15 MB")
print('Warte 60 Minuten und versuche es erneut')
time.sleep(3600)
driver.get(driver.current_url)
except:
# Element not found, do something else
break
# Versuche einen Timer ausfindig zu machen
try:
# Warte 10 Sekunden ob ein Timer auftaucht mit dem text "hours" "min" and "sec"
timer = WebDriverWait(driver, 10).until(EC.presence_of_element_located((
By.XPATH, "//p[contains(., 'hours') and contains(., 'min') and contains(., 'sec')]")))
# Wenn der Timer aufgetaucht ist, finde die CSS Class und speicher diese als string.
current_time = driver.find_element(By.CSS_SELECTOR, 'p.sc-jOiSOi.jgbyVL').text
# Zeige eine Nachricht mit der noch zu wartenden Zeit
print('Nächster Pot Verfügbar in:', current_time)
# Versuche den JWT Token zu extrahieren:
WebDriverWait(driver, 10).until(
lambda driver: driver.execute_script('return localStorage.getItem("JWT");') is not None)
# Definiere eine variable mit dem JWT Token inhalt.
jwt_token = driver.execute_script('return localStorage.getItem("JWT");')
# Nutze den JWT Token um sich für den API call anzumelden
url = 'https://dashboard.honeygain.com/api/v1/contest_winnings'
headers = {'Authorization': f'Bearer {jwt_token}'}
response = requests.get(url, headers=headers)
# Überprüfe den zurückgegebenen Status Code des API Calls
if response.status_code == 200:
# Extrahiere die daten aus der json und nenne die variable "winning_credits"
winnings = response.json()['data']['winning_credits']
# Konvertiere die Credits in $
winnings_in_dollars = winnings / 1000
# Nun konvertieren wir die Credits in integer und dann zurück in einen String, dadurch streichen wir nachkommastellen (5 Credits werden als 5.0 angegeben, aber es gibt keine 0.5 Credits)
winnings_int = int(winnings)
winnings_str = str(winnings_int)
# Zeige eine Nachricht mit den Credits die heute gewonnen wurden.
print('Du hast heute', winnings_str ,'Credits (', winnings_in_dollars, '$) gewonnen.')
else:
print('Error:', response.status_code, response.text)
except TimeoutException:
# Falls der Timer nicht vorhanden ist, schaue ob der Lucky Port geclaimed werden kann
try:
# Warte max 10 Sekunden bis der text "Open Lucky Pot" auf der Seite erscheint.
WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.XPATH, "//span[contains(text(), 'Open Lucky Pot')]")))
# Klicke den Lucky Pot button:
lucky_pot_button = driver.find_element(By.XPATH, "//span[contains(text(), 'Open Lucky Pot')]/ancestor::button")
lucky_pot_button.click()
# Definiere eine variable mit dem JWT Token inhalt.
jwt_token = driver.execute_script('return localStorage.getItem("JWT");')
# Nutze den JWT Token um sich für den API call anzumelden
url = 'https://dashboard.honeygain.com/api/v1/contest_winnings'
headers = {'Authorization': f'Bearer {jwt_token}'}
response = requests.get(url, headers=headers)
# Überprüfe den zurückgegebenen Status Code des API Calls
if response.status_code == 200:
# Extrahiere die daten aus der json und nenne die variable "winning_credits"
winnings = response.json()['data']['winning_credits']
# Konvertiere die Credits in $
winnings_in_dollars = winnings / 1000
# Nun konvertieren wir die Credits in integer und dann zurück in einen String, dadurch streichen wir nachkommastellen (5 Credits werden als 5.0 angegeben, aber es gibt keine 0.5 Credits)
winnings_int = int(winnings)
winnings_str = str(winnings_int)
# Zeige eine Nachricht mit den Credits die heute gewonnen wurden.
print('Der LuckyPot wurde erfolgreich geclaimed! Du hast', winnings_str ,'Credits (', winnings_in_dollars, '$) gewonnen.')
except TimeoutException:
print("The 'Open Lucky Pot' button was not found within 10 seconds. Exiting...")
driver.quit()