import re import time import random import lxml.html from cloudscraper import CloudScraper from aterrors import AternosCredentialsError class AternosConnect: REQGET = 0 REQPOST = 1 REQUA = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:68.0) Gecko/20100101 Goanna/4.8 Firefox/68.0 PaleMoon/29.4.0.2' def __init__(self): pass def get_token(self, response=None): if response == None: loginpage = self.request_cloudflare( f'https://aternos.org/go/', self.REQGET ).content pagetree = lxml.html.fromstring(loginpage) else: pagetree = lxml.html.fromstring(response) try: pagehead = pagetree.head self.token = re.search( r'const\s+AJAX_TOKEN\s*=\s*["\'](\w+)["\']', pagehead.text_content() )[1] except (IndexError, TypeError): raise AternosCredentialsError( 'Unable to parse TOKEN from the page' ) return self.token def generate_sec(self): randkey = self.generate_aternos_rand() randval = self.generate_aternos_rand() self.sec = f'{randkey}:{randval}' self.session.cookies.set( f'ATERNOS_SEC_{randkey}', randval, domain='aternos.org' ) return self.sec def generate_aternos_rand(self, randlen=16): rand_arr = [] for i in range(randlen+1): rand_arr.append('') rand_alphanum = \ self.convert_num(random.random(),36) + \ '00000000000000000' return (rand_alphanum[2:18].join(rand_arr)[:randlen]) def convert_num(self, num, base): result = '' while num > 0: result = str(num % base) + result num //= base return result def request_cloudflare( self, url, method, retries=10, params=None, data=None, headers=None, reqcookies=None, sendtoken=False): cftitle = '