mirror of
				https://gitea.augustin64.fr/piair/MsRewards-Reborn.git
				synced 2025-10-26 12:53:34 +01:00 
			
		
		
		
	Compare commits
	
		
			13 Commits
		
	
	
		
			dev
			...
			9af0f4aadb
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 9af0f4aadb | ||
|  | 1d16294c04 | ||
|  | fae2033061 | ||
|  | 50c4036c73 | ||
|  | c683472895 | ||
|  | 178f2d472a | ||
|  | d3137f858a | ||
|  | d2ad467d4e | ||
|  | b45e9e549f | ||
|  | 200b0d8a86 | ||
|  | 4a5af6455d | ||
|  | 49b691d736 | ||
|  | 9549a6dea3 | 
							
								
								
									
										44
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								Dockerfile
									
									
									
									
									
								
							| @@ -1,21 +1,37 @@ | |||||||
| FROM python:3.10 | FROM python:3.10 | ||||||
| ENV DEBIAN_FRONTEND noninteractive | ENV DEBIAN_FRONTEND noninteractive | ||||||
| WORKDIR /app/ | WORKDIR /app/ | ||||||
| RUN apt update \ |  | ||||||
|     && wget http://security.ubuntu.com/ubuntu/pool/main/o/openssl/libssl1.1_1.1.0g-2ubuntu4_amd64.deb \ | # Initial apt install | ||||||
|     && dpkg -i libssl1.1_1.1.0g-2ubuntu4_amd64.deb \ | RUN apt update | ||||||
|     && apt install redis libgtk-4-1 libvulkan1 libxdamage1 -y \ | RUN apt install -y libgtk-4-1 libvulkan1 libxdamage1 \ | ||||||
|     && curl -sSLO https://nc.piair.xyz/s/BKLsBWoZkTdYjfq/download/chrome.deb \ |                 novnc websockify xvfb nginx nano tzdata \ | ||||||
|     && ln -fs /usr/share/zoneinfo/Europe/Paris /etc/localtime \ |                 sqlite3 apt-transport-https software-properties-common \ | ||||||
|     && git clone https://gitea.augustin64.fr/piair/MsRewards-Reborn \ |                 wget wfrench tigervnc-standalone-server libasound2 \ | ||||||
|     && python3 -m pip install -r MsRewards-Reborn/requirements.txt \ |                 libatk-bridge2.0-0 libnss3 libnspr4 xvfb libgbm1 libatk1.0-0 \ | ||||||
|     && wget -q -O /usr/share/keyrings/grafana.key https://apt.grafana.com/gpg.key \ |                 libu2f-udev libatspi2.0-0 libcups2 libxkbcommon0 libxrandr2 \ | ||||||
|     && curl -fsSL https://packages.redis.io/gpg | gpg --dearmor -o /usr/share/keyrings/redis-archive-keyring.gpg \ |                 libdbus-1-3 xdg-utils fonts-liberation libdrm2 | ||||||
|     && echo "deb [signed-by=/usr/share/keyrings/grafana.key] https://apt.grafana.com stable main" | tee -a /etc/apt/sources.list.d/grafana.list \ |  | ||||||
|     && apt update \ | # Additional repos and packages | ||||||
|     && apt install novnc websockify grafana xvfb nginx nano tzdata sqlite3 apt-transport-https software-properties-common wget wfrench tigervnc-standalone-server libasound2 libatk-bridge2.0-0 libnss3 libnspr4 xvfb libgbm1 libatk1.0-0 libu2f-udev libatspi2.0-0 libcups2 libxkbcommon0 libxrandr2 libdbus-1-3 xdg-utils fonts-liberation libdrm2 -y \ | RUN wget http://security.ubuntu.com/ubuntu/pool/main/o/openssl/libssl1.1_1.1.0g-2ubuntu4_amd64.deb \ | ||||||
|     && bash MsRewards-Reborn/config/config.sh \ |     && dpkg -i libssl1.1_1.1.0g-2ubuntu4_amd64.deb | ||||||
|  | RUN curl -sSLO https://nc.piair.xyz/s/BKLsBWoZkTdYjfq/download/chrome.deb \ | ||||||
|     && dpkg -i chrome.deb |     && dpkg -i chrome.deb | ||||||
|  | RUN ln -fs /usr/share/zoneinfo/Europe/Paris /etc/localtime | ||||||
|  | RUN wget -q -O /usr/share/keyrings/grafana.key https://apt.grafana.com/gpg.key \ | ||||||
|  |     && echo "deb [signed-by=/usr/share/keyrings/grafana.key] https://apt.grafana.com stable main" | tee -a /etc/apt/sources.list.d/grafana.list | ||||||
|  | RUN curl -fsSL https://packages.redis.io/gpg | gpg --dearmor -o /usr/share/keyrings/redis-archive-keyring.gpg | ||||||
|  | # Install from new repo | ||||||
|  | RUN apt update \ | ||||||
|  |     && apt install -y redis grafana | ||||||
|  |  | ||||||
|  | # Setup app | ||||||
|  | RUN git clone https://gitea.augustin64.fr/piair/MsRewards-Reborn | ||||||
|  | # Use this instead when developping locally: | ||||||
|  | # COPY . /app/MsRewards-Reborn | ||||||
|  |  | ||||||
|  | RUN python3 -m pip install -r MsRewards-Reborn/requirements.txt | ||||||
|  | RUN bash MsRewards-Reborn/config/config.sh | ||||||
|  |  | ||||||
| ENV TZ="Europe/Paris" | ENV TZ="Europe/Paris" | ||||||
| WORKDIR /app/MsRewards-Reborn/Flask/ | WORKDIR /app/MsRewards-Reborn/Flask/ | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								Flask/app.py
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								Flask/app.py
									
									
									
									
									
								
							| @@ -373,8 +373,18 @@ def config_post(): | |||||||
| def logs(): | def logs(): | ||||||
|     with open("/app/MsRewards-Reborn/user_data/configs.json", "r") as inFile: |     with open("/app/MsRewards-Reborn/user_data/configs.json", "r") as inFile: | ||||||
|         configs = json.load(inFile) |         configs = json.load(inFile) | ||||||
|     print(configs) |      | ||||||
|     return(render_template("logs.html", data=configs)) |     files = [(configs[i]["name"], i) for i in configs] | ||||||
|  |     config_files = [i[1] for i in files] | ||||||
|  |     for f in os.listdir("/app/MsRewards-Reborn/Flask/static/logs"): | ||||||
|  |         fid = ".".join(f.split(".")[:-1]) # filename without .txt | ||||||
|  |         if f != ".gitignore" and fid not in config_files: | ||||||
|  |             files.append((f, fid)) | ||||||
|  |  | ||||||
|  |     return render_template( | ||||||
|  |         "logs.html", | ||||||
|  |         files=files | ||||||
|  |     ) | ||||||
|  |  | ||||||
|  |  | ||||||
| @app.route("/stats/", methods=["GET", "POST"]) | @app.route("/stats/", methods=["GET", "POST"]) | ||||||
|   | |||||||
| @@ -8,14 +8,37 @@ | |||||||
|  |  | ||||||
| <select name="select" onchange="change_logs(this.value)"> | <select name="select" onchange="change_logs(this.value)"> | ||||||
|     <option id="null" value="0">Choisir une config</option> |     <option id="null" value="0">Choisir une config</option> | ||||||
|     {% for i in data %} |     {% for file in files %} | ||||||
|     <option id="{{data[i]['name']}}" value="{{i}}">{{data[i]['name']}}</option> |     <option id="{{ file[0] }}" value="{{ file[1] }}">{{ file[0] }}</option> | ||||||
|     {% endfor %} |     {% endfor %} | ||||||
| </select> | </select> | ||||||
| <br><br> | <br><br> | ||||||
| <iframe type="text/html" src="{{url_for('static', filename='logs/1.txt')}}"  width="100%" height="85%" id="embed"> | <iframe type="text/html" src="{{url_for('static', filename='logs/1.txt')}}"  width="100%" height="85%" id="embed"></iframe> | ||||||
|  |  | ||||||
|  | <script defer> | ||||||
|  |     const iframe = document.getElementsByTagName("iframe")[0]; | ||||||
|  |     var script = document.createElement('script'); | ||||||
|  |  | ||||||
|  |     // Wait until ansi_up load | ||||||
|  |     script.onload = function () { | ||||||
|  |         // Wait until iframe load | ||||||
|  |         iframe.onload = function() { | ||||||
|  |             const subdoc = iframe.contentWindow.document; | ||||||
|  |             const subBody = subdoc.getElementsByTagName("body")[0] | ||||||
|  |             let ansiOutput = subBody; | ||||||
|  |             // Depending on the content encoding (and maybe on the browser) | ||||||
|  |             // a <pre> is added around the content of the file | ||||||
|  |             if (subBody.getElementsByTagName("pre").length > 0) { | ||||||
|  |                 ansiOutput = subBody.getElementsByTagName("pre")[0]; | ||||||
|  |             } | ||||||
|  |             const ansi_up = new AnsiUp(); | ||||||
|  |             ansiOutput.innerHTML = ansi_up.ansi_to_html(ansiOutput.innerText); | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  |      | ||||||
|  |     script.src = "https://cdn.jsdelivr.net/npm/ansi_up@4.0.4/ansi_up.js"; | ||||||
|  |     document.head.appendChild(script); | ||||||
|  | </script> | ||||||
|  |  | ||||||
| {% endif %} | {% endif %} | ||||||
| {% endblock %} | {% endblock %} | ||||||
							
								
								
									
										16
									
								
								V6.py
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								V6.py
									
									
									
									
									
								
							| @@ -152,7 +152,7 @@ def play_quiz4(override: int = None): | |||||||
|     except Exception as e: |     except Exception as e: | ||||||
|         log_error(e) |         log_error(e) | ||||||
|         raise ValueError(e) |         raise ValueError(e) | ||||||
|     info("Quiz 8 done.") |     info("Quiz 4 done.") | ||||||
|     custom_sleep(3) |     custom_sleep(3) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -165,6 +165,8 @@ def do_poll(): | |||||||
|         try: |         try: | ||||||
|             answer_elem.click() |             answer_elem.click() | ||||||
|         except exceptions.ElementNotInteractableException: |         except exceptions.ElementNotInteractableException: | ||||||
|  |             warning("element not clickable. Waiting a bit and retrying.") | ||||||
|  |             custom_sleep(uniform(2, 2.5)) | ||||||
|             driver.execute_script("arguments[0].click();", answer_elem) |             driver.execute_script("arguments[0].click();", answer_elem) | ||||||
|         custom_sleep(uniform(2, 2.5)) |         custom_sleep(uniform(2, 2.5)) | ||||||
|     except Exception as err: |     except Exception as err: | ||||||
| @@ -610,9 +612,11 @@ def daily_routine(cred: UserCredentials, custom=False): | |||||||
|     try: |     try: | ||||||
|         if not custom:  # custom already is logged in |         if not custom:  # custom already is logged in | ||||||
|             login() |             login() | ||||||
|  |  | ||||||
|     except Banned: |     except Banned: | ||||||
|         log_error("This account is locked.") |         log_error("This account is locked.") | ||||||
|         return |         raise Banned() | ||||||
|  |  | ||||||
|     except Identity: |     except Identity: | ||||||
|         log_error("This account has an issue.") |         log_error("This account has an issue.") | ||||||
|         return |         return | ||||||
| @@ -680,7 +684,7 @@ def json_start(json_entry, cred: UserCredentials): | |||||||
|                 login() |                 login() | ||||||
|             try: |             try: | ||||||
|                 if str(account_id) in json_entry["tout"]: |                 if str(account_id) in json_entry["tout"]: | ||||||
|                     daily_routine(cred) |                     daily_routine(cred, True) | ||||||
|             except KeyError: |             except KeyError: | ||||||
|                 pass |                 pass | ||||||
|             else: |             else: | ||||||
| @@ -744,12 +748,16 @@ def default_start(): | |||||||
|             config.WebDriver.pc_driver.quit() |             config.WebDriver.pc_driver.quit() | ||||||
|             config.display.stop() |             config.display.stop() | ||||||
|             break |             break | ||||||
|  |         except Banned: | ||||||
|  |             warning("this account is banned. Switching to next account") | ||||||
|         except Exception as e: |         except Exception as e: | ||||||
|             log_error(f"Error not caught. Skipping this account. " + format_error(e)) |             log_error(f"Error not caught. Skipping this account. " + format_error(e)) | ||||||
|             critical(f"Error not caught. Skipping this account. {e}") |             critical(f"Error not caught. Skipping this account. {e}") | ||||||
|             config.WebDriver.pc_driver.quit() |             config.WebDriver.pc_driver.quit() | ||||||
|  |  | ||||||
|         config.UserCredentials.next_account() |         finally: | ||||||
|  |             config.UserCredentials.next_account() | ||||||
|  |  | ||||||
|     config.display.stop() |     config.display.stop() | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								build.sh
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								build.sh
									
									
									
									
									
								
							| @@ -1 +1,12 @@ | |||||||
| sudo docker build --no-cache --network host -t msrewards . && sudo docker run -d --restart unless-stopped -p 1234:1234 -p 2345:2345 -ti --shm-size=2gb --name MsRewards msrewards  | #!/bin/bash | ||||||
|  |  | ||||||
|  | docker-do () { # Check if sudo needs to be used | ||||||
|  |     if id -nG "$(whoami)" | grep -qw "docker"; then | ||||||
|  |         docker $@ | ||||||
|  |     else | ||||||
|  |         sudo docker $@ | ||||||
|  |     fi | ||||||
|  | } | ||||||
|  |  | ||||||
|  | docker-do build --network host -t msrewards . | ||||||
|  | docker-do run -d --restart unless-stopped -p 1234:1234 -p 2345:2345 -ti --shm-size=2gb --name MsRewards msrewards  | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ class DiscordLogger: | |||||||
|         ) |         ) | ||||||
|         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=self.config.UserCredentials.creds.get_mail()) |         embed.set_footer(text=self.config.UserCredentials.get_mail() + " - " + self.config.WebDriver.current_driver()) | ||||||
|  |  | ||||||
|         self.config.discord.wh.send(embed=embed, username="error", file=file, avatar_url=self.config.discord.avatar_url) |         self.config.discord.wh.send(embed=embed, username="error", file=file, avatar_url=self.config.discord.avatar_url) | ||||||
|         self.config.discord.wh.send(username="error", file=File("page.html"), avatar_url=self.config.discord.avatar_url) |         self.config.discord.wh.send(username="error", file=File("page.html"), avatar_url=self.config.discord.avatar_url) | ||||||
|   | |||||||
| @@ -20,3 +20,6 @@ class Driver: | |||||||
|  |  | ||||||
|             case _: |             case _: | ||||||
|                 raise ValueError("The driver must be either pc or mobile") |                 raise ValueError("The driver must be either pc or mobile") | ||||||
|  |  | ||||||
|  |     def current_driver(self): | ||||||
|  |         return "PC" if self.pc_driver == self.driver else "Mobile" | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ class UserCredentials: | |||||||
|     def get_tfa(self): |     def get_tfa(self): | ||||||
|         if not self.tfa_enable(): |         if not self.tfa_enable(): | ||||||
|             warning("Warning: TFA is not enabled. Calling get_tfa is an expected behaviour.") |             warning("Warning: TFA is not enabled. Calling get_tfa is an expected behaviour.") | ||||||
|         return TOTP(self.data[self.current]["tfa"]) |         return TOTP(self.data[self.current]["2fa"]) | ||||||
|  |  | ||||||
|     def next_account(self): |     def next_account(self): | ||||||
|         self.current += 1 |         self.current += 1 | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								modules/Tools/generate_error.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								modules/Tools/generate_error.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | import undetected_chromedriver as uc | ||||||
|  | from pyvirtualdisplay.smartdisplay import SmartDisplay | ||||||
|  |  | ||||||
|  | display = SmartDisplay(size=(1920, 1080)) | ||||||
|  | display.start() | ||||||
|  | driver = uc.Chrome() | ||||||
|  | driver.close() | ||||||
|  | driver.close() | ||||||
| @@ -30,7 +30,7 @@ class ColoredFormatter(logging.Formatter): | |||||||
|  |  | ||||||
| # Set up the root logger | # Set up the root logger | ||||||
| root_logger = logging.getLogger(__name__) | root_logger = logging.getLogger(__name__) | ||||||
| root_logger.setLevel(logging.DEBUG) | root_logger.setLevel(logging.INFO) | ||||||
|  |  | ||||||
| # Create a console handler and set the formatter | # Create a console handler and set the formatter | ||||||
| ch = logging.StreamHandler() | ch = logging.StreamHandler() | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ def get_domain(driver): | |||||||
|  |  | ||||||
| def custom_sleep(temps): | def custom_sleep(temps): | ||||||
|     try: |     try: | ||||||
|         if True:  # todo: change this awful condition |         if False:  # todo: change this awful condition | ||||||
|             points = ["⢿", "⣻", "⣽", "⣾", "⣷", "⣯", "⣟", "⡿"] |             points = ["⢿", "⣻", "⣽", "⣾", "⣷", "⣯", "⣟", "⡿"] | ||||||
|             passe = 0 |             passe = 0 | ||||||
|             for _ in range(int(temps)): |             for _ in range(int(temps)): | ||||||
|   | |||||||
							
								
								
									
										48
									
								
								modules/Tools/update_chrome.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								modules/Tools/update_chrome.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | |||||||
|  | import requests | ||||||
|  | import re | ||||||
|  | from packaging import version | ||||||
|  | import subprocess | ||||||
|  |  | ||||||
|  | from logger import critical, info, error | ||||||
|  |  | ||||||
|  | errorMessage = subprocess.run(['python3', 'generate_error.py'], check=False, stdout=subprocess.PIPE, | ||||||
|  |                               stderr=subprocess.PIPE).stderr.decode("utf-8") | ||||||
|  |  | ||||||
|  | versionPattern = "This version of ChromeDriver only supports Chrome version ([0-9]+)" | ||||||
|  |  | ||||||
|  | try: | ||||||
|  |     versionN = re.search(versionPattern, errorMessage)[1] | ||||||
|  | except Exception as e: | ||||||
|  |     critical("Can't get version number from error") | ||||||
|  |     error(e) | ||||||
|  |     exit(0) | ||||||
|  |  | ||||||
|  | info(f"Needed version : '{versionN}'") | ||||||
|  |  | ||||||
|  | downloadUrl = "http://mirror.cs.uchicago.edu/google-chrome/pool/main/g/google-chrome-stable/" | ||||||
|  | r = requests.get(downloadUrl) | ||||||
|  |  | ||||||
|  | content = r.text | ||||||
|  |  | ||||||
|  | exactVersionList = re.findall(f"(google-chrome-stable_({versionN}.[0-9.]+)[^<^>^\"]+)", content) | ||||||
|  |  | ||||||
|  | try: | ||||||
|  |     best = exactVersionList[0] | ||||||
|  | except Exception as e: | ||||||
|  |     critical("No version matches required version") | ||||||
|  |     error(e) | ||||||
|  |     exit(0) | ||||||
|  |  | ||||||
|  | for i in exactVersionList: | ||||||
|  |     if version.parse(i[1]) > version.parse(best[1]): | ||||||
|  |         best = i | ||||||
|  |  | ||||||
|  | chromeDebURL = f"http://mirror.cs.uchicago.edu/google-chrome/pool/main/g/google-chrome-stable/{best[0]}" | ||||||
|  | info(f"chrome deb URL : {chromeDebURL}") | ||||||
|  | info("downloading chrome") | ||||||
|  |  | ||||||
|  | subprocess.call(['wget', "-O", "/tmp/chrome.deb", chromeDebURL]) | ||||||
|  | info("Chrome deb downloaded. Installing chrome") | ||||||
|  |  | ||||||
|  | subprocess.call(["dpkg", "-i", "/tmp/chrome.deb"]) | ||||||
|  | info("Chrome installed") | ||||||
		Reference in New Issue
	
	Block a user