mirror of
https://github.com/MustardChef/WSABuilds.git
synced 2025-01-15 04:39:09 +01:00
97 lines
3.5 KiB
Python
97 lines
3.5 KiB
Python
|
#!/usr/bin/python3
|
||
|
#
|
||
|
# This file is part of MagiskOnWSALocal.
|
||
|
#
|
||
|
# MagiskOnWSALocal is free software: you can redistribute it and/or modify
|
||
|
# it under the terms of the GNU Affero General Public License as
|
||
|
# published by the Free Software Foundation, either version 3 of the
|
||
|
# License, or (at your option) any later version.
|
||
|
#
|
||
|
# MagiskOnWSALocal is distributed in the hope that it will be useful,
|
||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
# GNU Affero General Public License for more details.
|
||
|
#
|
||
|
# You should have received a copy of the GNU Affero General Public License
|
||
|
# along with MagiskOnWSALocal. If not, see <https://www.gnu.org/licenses/>.
|
||
|
#
|
||
|
# Copyright (C) 2023 LSPosed Contributors
|
||
|
#
|
||
|
|
||
|
from __future__ import annotations
|
||
|
from io import TextIOWrapper
|
||
|
from typing import OrderedDict
|
||
|
from pathlib import Path
|
||
|
import sys
|
||
|
class Prop(OrderedDict):
|
||
|
def __init__(self, file: TextIOWrapper) -> None:
|
||
|
super().__init__()
|
||
|
for i, line in enumerate(file.read().splitlines(False)):
|
||
|
if '=' in line:
|
||
|
k, v = line.split('=', 1)
|
||
|
self[k] = v
|
||
|
else:
|
||
|
self[f".{i}"] = line
|
||
|
|
||
|
def __str__(self) -> str:
|
||
|
return '\n'.join([v if k.startswith('.') else f"{k}={v}" for k, v in self.items()])
|
||
|
|
||
|
def __iadd__(self, other: str) -> Prop:
|
||
|
self[f".{len(self)}"] = other
|
||
|
return self
|
||
|
|
||
|
new_props = {
|
||
|
("product", "brand"): "google",
|
||
|
("system", "brand"): "google",
|
||
|
("product", "manufacturer"): "Google",
|
||
|
("system", "manufacturer"): "Google",
|
||
|
("build", "product"): sys.argv[2],
|
||
|
("product", "name"): sys.argv[2],
|
||
|
("system", "name"): sys.argv[2],
|
||
|
("product", "device"): sys.argv[2],
|
||
|
("system", "device"): sys.argv[2],
|
||
|
("product", "model"): sys.argv[3],
|
||
|
("system", "model"): sys.argv[3],
|
||
|
("build", "flavor"): sys.argv[2] + "-user"
|
||
|
}
|
||
|
|
||
|
def description(sec: str, p: Prop) -> str:
|
||
|
return f"{p[f'ro.{sec}.build.flavor']} {p[f'ro.{sec}.build.version.release_or_codename']} {p[f'ro.{sec}.build.id']} {p[f'ro.{sec}.build.version.incremental']} {p[f'ro.{sec}.build.tags']}"
|
||
|
|
||
|
|
||
|
def fingerprint(sec: str, p: Prop) -> str:
|
||
|
return f"""{p[f"ro.product.{sec}.brand"]}/{p[f"ro.product.{sec}.name"]}/{p[f"ro.product.{sec}.device"]}:{p[f"ro.{sec}.build.version.release"]}/{p[f"ro.{sec}.build.id"]}/{p[f"ro.{sec}.build.version.incremental"]}:{p[f"ro.{sec}.build.type"]}/{p[f"ro.{sec}.build.tags"]}"""
|
||
|
|
||
|
|
||
|
def fix_prop(sec, prop):
|
||
|
if not Path(prop).is_file():
|
||
|
return
|
||
|
|
||
|
print(f"fixing {prop}", flush=True)
|
||
|
with open(prop, 'r') as f:
|
||
|
p = Prop(f)
|
||
|
|
||
|
p += "# extra props added by MagiskOnWSA"
|
||
|
|
||
|
for k, v in new_props.items():
|
||
|
p[f"ro.{k[0]}.{k[1]}"] = v
|
||
|
|
||
|
if k[0] == "build":
|
||
|
p[f"ro.{sec}.{k[0]}.{k[1]}"] = v
|
||
|
elif k[0] == "product":
|
||
|
p[f"ro.{k[0]}.{sec}.{k[1]}"] = v
|
||
|
|
||
|
p["ro.build.description"] = description(sec, p)
|
||
|
p[f"ro.build.fingerprint"] = fingerprint(sec, p)
|
||
|
p[f"ro.{sec}.build.description"] = description(sec, p)
|
||
|
p[f"ro.{sec}.build.fingerprint"] = fingerprint(sec, p)
|
||
|
p[f"ro.bootimage.build.fingerprint"] = fingerprint(sec, p)
|
||
|
|
||
|
with open(prop, 'w') as f:
|
||
|
f.write(str(p))
|
||
|
|
||
|
|
||
|
sys_path = sys.argv[1]
|
||
|
for sec, prop in {"system": sys_path+"/system/build.prop", "vendor": sys_path+"/vendor/build.prop", "odm": sys_path+"/vendor/odm/etc/build.prop", "vendor_dlkm": sys_path+"/vendor/vendor_dlkm/etc/build.prop"}.items():
|
||
|
fix_prop(sec, prop)
|