mirror of
https://github.com/MustardChef/WSABuilds.git
synced 2024-11-16 00:25:05 +01:00
146 lines
5.7 KiB
Python
146 lines
5.7 KiB
Python
|
import base64
|
||
|
import os
|
||
|
import html
|
||
|
import json
|
||
|
import re
|
||
|
import requests
|
||
|
import logging
|
||
|
import subprocess
|
||
|
|
||
|
from typing import Any, OrderedDict
|
||
|
from xml.dom import minidom
|
||
|
|
||
|
from requests import Session
|
||
|
from packaging import version
|
||
|
|
||
|
class Prop(OrderedDict):
|
||
|
def __init__(self, props: str = ...) -> None:
|
||
|
super().__init__()
|
||
|
for i, line in enumerate(props.splitlines(False)):
|
||
|
if '=' in line:
|
||
|
k, v = line.split('=', 1)
|
||
|
self[k] = v
|
||
|
else:
|
||
|
self[f".{i}"] = line
|
||
|
|
||
|
def __setattr__(self, __name: str, __value: Any) -> None:
|
||
|
self[__name] = __value
|
||
|
|
||
|
def __repr__(self):
|
||
|
return '\n'.join(f'{item}={self[item]}' for item in self)
|
||
|
|
||
|
logging.captureWarnings(True)
|
||
|
env_file = os.getenv('GITHUB_ENV')
|
||
|
|
||
|
#Category ID
|
||
|
cat_id = '858014f3-3934-4abe-8078-4aa193e74ca8'
|
||
|
|
||
|
release_type = "retail"
|
||
|
|
||
|
new_version_found = False
|
||
|
|
||
|
session = Session()
|
||
|
session.verify = False
|
||
|
|
||
|
git = (
|
||
|
"git checkout -f update || git switch --discard-changes --orphan update"
|
||
|
)
|
||
|
|
||
|
user_code = ""
|
||
|
users = {""}
|
||
|
|
||
|
print("Current working directory:", os.getcwd())
|
||
|
print("Files in '/home/runner/work/test1.0/test1.0/MagiskOnWSALocal1/xml':", os.listdir('/home/runner/work/test1.0/test1.0/MagiskOnWSALocal1/xml'))
|
||
|
|
||
|
currentver = requests.get(f"https://raw.githubusercontent.com/MustardChef/test1.0/update/retail.appversion").text.replace('\n', '')
|
||
|
|
||
|
# Write for pushing later
|
||
|
try:
|
||
|
# Write for pushing later
|
||
|
file = open('retail.appversion', 'w')
|
||
|
file.write(currentver)
|
||
|
file.close()
|
||
|
print("retail.appversion file created successfully.")
|
||
|
except Exception as e:
|
||
|
print(f"Error writing to file: {e}")
|
||
|
|
||
|
if not new_version_found:
|
||
|
# Get information
|
||
|
with open("/home/runner/work/test1.0/test1.0/MagiskOnWSALocal1/xml/GetCookie.xml", "r") as f:
|
||
|
cookie_content = f.read().format(user_code)
|
||
|
try:
|
||
|
out = session.post(
|
||
|
'https://fe3.delivery.mp.microsoft.com/ClientWebService/client.asmx',
|
||
|
data=cookie_content,
|
||
|
headers={'Content-Type': 'application/soap+xml; charset=utf-8'}
|
||
|
)
|
||
|
except:
|
||
|
print("Network Error!")
|
||
|
exit(1)
|
||
|
doc = minidom.parseString(out.text)
|
||
|
cookie = doc.getElementsByTagName('EncryptedData')[0].firstChild.nodeValue
|
||
|
with open("/home/runner/work/test1.0/test1.0/MagiskOnWSALocal1/xml/WUIDRequest.xml", "r") as f:
|
||
|
cat_id_content = f.read().format(user_code, cookie, cat_id, release_type)
|
||
|
try:
|
||
|
out = session.post(
|
||
|
'https://fe3.delivery.mp.microsoft.com/ClientWebService/client.asmx',
|
||
|
data=cat_id_content,
|
||
|
headers={'Content-Type': 'application/soap+xml; charset=utf-8'}
|
||
|
)
|
||
|
except:
|
||
|
print("Network Error!")
|
||
|
exit(1)
|
||
|
doc = minidom.parseString(html.unescape(out.text))
|
||
|
filenames = {}
|
||
|
for node in doc.getElementsByTagName('ExtendedUpdateInfo')[0].getElementsByTagName('Updates')[0].getElementsByTagName('Update'):
|
||
|
node_xml = node.getElementsByTagName('Xml')[0]
|
||
|
node_files = node_xml.getElementsByTagName('Files')
|
||
|
if not node_files:
|
||
|
continue
|
||
|
else:
|
||
|
for node_file in node_files[0].getElementsByTagName('File'):
|
||
|
if node_file.hasAttribute('InstallerSpecificIdentifier') and node_file.hasAttribute('FileName'):
|
||
|
filenames[node.getElementsByTagName('ID')[0].firstChild.nodeValue] = (f"{node_file.attributes['InstallerSpecificIdentifier'].value}_{node_file.attributes['FileName'].value}",
|
||
|
node_xml.getElementsByTagName('ExtendedProperties')[0].attributes['PackageIdentityName'].value)
|
||
|
identities = {}
|
||
|
for node in doc.getElementsByTagName('NewUpdates')[0].getElementsByTagName('UpdateInfo'):
|
||
|
node_xml = node.getElementsByTagName('Xml')[0]
|
||
|
if not node_xml.getElementsByTagName('SecuredFragment'):
|
||
|
continue
|
||
|
else:
|
||
|
id = node.getElementsByTagName('ID')[0].firstChild.nodeValue
|
||
|
update_identity = node_xml.getElementsByTagName('UpdateIdentity')[0]
|
||
|
if id in filenames:
|
||
|
fileinfo = filenames[id]
|
||
|
if fileinfo[0] not in identities:
|
||
|
identities[fileinfo[0]] = ([update_identity.attributes['UpdateID'].value,
|
||
|
update_identity.attributes['RevisionNumber'].value], fileinfo[1])
|
||
|
wsa_build_ver = 0
|
||
|
for filename, value in identities.items():
|
||
|
if re.match(f"MicrosoftCorporationII.WindowsSubsystemForAndroid_.*.msixbundle", filename):
|
||
|
tmp_wsa_build_ver = re.search(r"\d{4}.\d{5}.\d{1,}.\d{1,}", filename).group()
|
||
|
if (wsa_build_ver == 0):
|
||
|
wsa_build_ver = tmp_wsa_build_ver
|
||
|
elif version.parse(wsa_build_ver) < version.parse(tmp_wsa_build_ver):
|
||
|
wsa_build_ver = tmp_wsa_build_ver
|
||
|
|
||
|
if version.parse(currentver) < version.parse(wsa_build_ver):
|
||
|
print(f"New version found: {wsa_build_ver}")
|
||
|
new_version_found = True
|
||
|
subprocess.Popen(git, shell=True, stdout=None, stderr=None, executable='/bin/bash').wait()
|
||
|
try:
|
||
|
with open('retail.appversion', 'w') as file:
|
||
|
file.write(wsa_build_ver)
|
||
|
file.close()
|
||
|
print("retail.appversion file created successfully.")
|
||
|
except Exception as e:
|
||
|
print(f"Error writing to file: {e}")
|
||
|
msg = f'Update WSA Version from `v{currentver}` to `v{wsa_build_ver}`'
|
||
|
with open(env_file, "a") as wr:
|
||
|
wr.write(f"SHOULD_BUILD=yes\n")
|
||
|
wr.write(f"RELEASE_TYPE={release_type}\n")
|
||
|
wr.write(f"LATEST_RETAIL_VER={wsa_build_ver}\n")
|
||
|
wr.write(f"MSG={msg}\n")
|
||
|
wr.write(f"RETAIL_UPDATE=yes\n")
|
||
|
file.close()
|