mirror of
https://github.com/dortania/OpenCore-Legacy-Patcher.git
synced 2026-04-14 04:38:20 +10:00
187 lines
6.4 KiB
Python
187 lines
6.4 KiB
Python
import threading
|
|
import time
|
|
import logging
|
|
import sys
|
|
|
|
from resources import defaults, utilities, validation, constants
|
|
from resources.sys_patch import sys_patch, sys_patch_auto
|
|
from resources.build import build
|
|
from data import model_array
|
|
|
|
|
|
# Generic building args
|
|
class arguments:
|
|
|
|
def __init__(self, global_constants: constants.Constants) -> None:
|
|
self.constants: constants.Constants = global_constants
|
|
|
|
self.args = utilities.check_cli_args()
|
|
|
|
self._parse_arguments()
|
|
|
|
|
|
def _parse_arguments(self) -> None:
|
|
"""
|
|
Parses arguments passed to the patcher
|
|
"""
|
|
|
|
if self.args.validate:
|
|
self._validation_handler()
|
|
return
|
|
|
|
if self.args.build:
|
|
self._build_handler()
|
|
return
|
|
|
|
if self.args.patch_sys_vol:
|
|
self._sys_patch_handler()
|
|
return
|
|
|
|
if self.args.unpatch_sys_vol:
|
|
self._sys_unpatch_handler()
|
|
return
|
|
|
|
if self.args.auto_patch:
|
|
self._sys_patch_auto_handler()
|
|
return
|
|
|
|
|
|
def _validation_handler(self) -> None:
|
|
"""
|
|
Enter validation mode
|
|
"""
|
|
|
|
validation.PatcherValidation(self.constants)
|
|
|
|
|
|
def _sys_patch_handler(self) -> None:
|
|
"""
|
|
Start root volume patching
|
|
"""
|
|
|
|
logging.info("- Set System Volume patching")
|
|
if "Library/InstallerSandboxes/" in str(self.constants.payload_path):
|
|
logging.info("- Running from Installer Sandbox")
|
|
thread = threading.Thread(target=sys_patch.PatchSysVolume(self.constants.custom_model or self.constants.computer.real_model, self.constants, None).start_patch)
|
|
thread.start()
|
|
while thread.is_alive():
|
|
utilities.block_os_updaters()
|
|
time.sleep(1)
|
|
else:
|
|
sys_patch.PatchSysVolume(self.constants.custom_model or self.constants.computer.real_model, self.constants, None).start_patch()
|
|
|
|
|
|
def _sys_unpatch_handler(self) -> None:
|
|
"""
|
|
Start root volume unpatching
|
|
"""
|
|
logging.info("- Set System Volume unpatching")
|
|
sys_patch.PatchSysVolume(self.constants.custom_model or self.constants.computer.real_model, self.constants, None).start_unpatch()
|
|
|
|
|
|
def _sys_patch_auto_handler(self) -> None:
|
|
"""
|
|
Start root volume auto patching
|
|
"""
|
|
|
|
logging.info("- Set Auto patching")
|
|
sys_patch_auto.AutomaticSysPatch(self.constants).start_auto_patch()
|
|
|
|
|
|
def _build_handler(self) -> None:
|
|
"""
|
|
Start config building process
|
|
"""
|
|
|
|
if self.args.model:
|
|
if self.args.model:
|
|
logging.info(f"- Using custom model: {self.args.model}")
|
|
self.constants.custom_model = self.args.model
|
|
defaults.GenerateDefaults(self.constants.custom_model, False, self.constants)
|
|
elif self.constants.computer.real_model not in model_array.SupportedSMBIOS and self.constants.allow_oc_everywhere is False:
|
|
logging.info(
|
|
"""Your model is not supported by this patcher for running unsupported OSes!"
|
|
|
|
If you plan to create the USB for another machine, please select the "Change Model" option in the menu."""
|
|
)
|
|
sys.exit(1)
|
|
else:
|
|
logging.info(f"- Using detected model: {self.constants.computer.real_model}")
|
|
defaults.GenerateDefaults(self.constants.custom_model, True, self.constants)
|
|
|
|
if self.args.verbose:
|
|
logging.info("- Set verbose configuration")
|
|
self.constants.verbose_debug = True
|
|
else:
|
|
self.constants.verbose_debug = False # Override Defaults detected
|
|
|
|
if self.args.debug_oc:
|
|
logging.info("- Set OpenCore DEBUG configuration")
|
|
self.constants.opencore_debug = True
|
|
self.constants.opencore_build = "DEBUG"
|
|
|
|
if self.args.debug_kext:
|
|
logging.info("- Set kext DEBUG configuration")
|
|
self.constants.kext_debug = True
|
|
|
|
if self.args.hide_picker:
|
|
logging.info("- Set HidePicker configuration")
|
|
self.constants.showpicker = False
|
|
|
|
if self.args.disable_sip:
|
|
logging.info("- Set Disable SIP configuration")
|
|
self.constants.sip_status = False
|
|
else:
|
|
self.constants.sip_status = True # Override Defaults detected
|
|
|
|
if self.args.disable_smb:
|
|
logging.info("- Set Disable SecureBootModel configuration")
|
|
self.constants.secure_status = False
|
|
else:
|
|
self.constants.secure_status = True # Override Defaults detected
|
|
|
|
if self.args.vault:
|
|
logging.info("- Set Vault configuration")
|
|
self.constants.vault = True
|
|
|
|
if self.args.firewire:
|
|
logging.info("- Set FireWire Boot configuration")
|
|
self.constants.firewire_boot = True
|
|
|
|
if self.args.nvme:
|
|
logging.info("- Set NVMe Boot configuration")
|
|
self.constants.nvme_boot = True
|
|
|
|
if self.args.wlan:
|
|
logging.info("- Set Wake on WLAN configuration")
|
|
self.constants.enable_wake_on_wlan = True
|
|
|
|
if self.args.disable_tb:
|
|
logging.info("- Set Disable Thunderbolt configuration")
|
|
self.constants.disable_tb = True
|
|
|
|
if self.args.force_surplus:
|
|
logging.info("- Forcing SurPlus override configuration")
|
|
self.constants.force_surplus = True
|
|
|
|
if self.args.moderate_smbios:
|
|
logging.info("- Set Moderate SMBIOS Patching configuration")
|
|
self.constants.serial_settings = "Moderate"
|
|
|
|
if self.args.smbios_spoof:
|
|
if self.args.smbios_spoof == "Minimal":
|
|
self.constants.serial_settings = "Minimal"
|
|
elif self.args.smbios_spoof == "Moderate":
|
|
self.constants.serial_settings = "Moderate"
|
|
elif self.args.smbios_spoof == "Advanced":
|
|
self.constants.serial_settings = "Advanced"
|
|
else:
|
|
logging.info(f"- Unknown SMBIOS arg passed: {self.args.smbios_spoof}")
|
|
|
|
if self.args.support_all:
|
|
logging.info("- Building for natively supported model")
|
|
self.constants.allow_oc_everywhere = True
|
|
self.constants.serial_settings = "None"
|
|
|
|
build.BuildOpenCore(self.constants.custom_model or self.constants.computer.real_model, self.constants)
|