Files
docker-py-revanced/src/parser.py
T
2022-10-05 19:18:02 +05:30

86 lines
2.9 KiB
Python

from subprocess import PIPE, Popen
from time import perf_counter
from typing import Any, List
from loguru import logger
class Parser(object):
def __init__(self, patcher, env, temp_folder):
self._PATCHES = []
self._EXCLUDED = []
self.patcher = patcher
self.keystore_name = env.str("KEYSTORE_FILE_NAME", "revanced.keystore")
self.build_extended = env.bool("BUILD_EXTENDED", False)
self.extended_apps = ["youtube", "youtube_music"]
self.keystore_name = env.str("KEYSTORE_FILE_NAME", "revanced.keystore")
self.normal_cli_jar = "revanced-cli.jar"
self.normal_patches_jar = "revanced-patches.jar"
self.normal_integrations_apk = "revanced-integrations.apk"
self.cli_jar = (
f"inotia00-{self.normal_cli_jar}"
if self.build_extended
else self.normal_cli_jar
)
self.patches_jar = (
f"inotia00-{self.normal_patches_jar}"
if self.build_extended
else self.normal_patches_jar
)
self.integrations_apk = (
f"inotia00-{self.normal_integrations_apk}"
if self.build_extended
else self.normal_integrations_apk
)
self.temp_folder = temp_folder
def include(self, name: str) -> None:
self._PATCHES.extend(["-i", name])
def exclude(self, name: str) -> None:
self._PATCHES.extend(["-e", name])
self._EXCLUDED.append(name)
def get_excluded_patches(self) -> List[Any]:
return self._EXCLUDED
def patch_app(self, app: str, version: str, is_experimental: bool = False) -> None:
logger.debug(f"Sending request to revanced cli for building {app} revanced")
cli = self.normal_cli_jar
patches = self.normal_patches_jar
integrations = self.normal_integrations_apk
if self.build_extended and app in self.extended_apps:
cli = self.cli_jar
patches = self.patches_jar
integrations = self.integrations_apk
args = [
"-jar",
cli,
"-a",
app + ".apk",
"-b",
patches,
"-m",
integrations,
"-o",
f"Re-{app}-{version}-output.apk",
"--keystore",
self.keystore_name,
]
if is_experimental:
logger.debug("Using experimental features")
args.append("--experimental")
args[1::2] = map(lambda i: self.temp_folder.joinpath(i), args[1::2])
if self._PATCHES:
args.extend(self._PATCHES)
start = perf_counter()
process = Popen(["java", *args], stdout=PIPE)
for line in process.stdout:
logger.debug(line.decode(), flush=True, end="")
process.wait()
logger.info(
f"Patching completed for app {app} in {perf_counter() - start:.2f} seconds."
)