def compute_sha256(file_path): """Compute SHA256 hash of a file.""" sha256 = hashlib.sha256() with open(file_path, "rb") as f: for chunk in iter(lambda: f.read(4096), b""): sha256.update(chunk) return sha256.hexdigest()
I'll help you create a solid, well-structured feature for an installer tool. Since "UMTv2-UMTPro-UltimateUnisoc-v0.1-installer" appears to be a flashing/service tool for Unisoc (formerly Spreadtrum) chipsets (likely for GSM/CDMA phone servicing, firmware flashing, IMEI repair, etc.), I'll assume it's a professional tool installer with robust features.
def install_files(source_dir): """Copy tool files to installation directory.""" install_path = DEFAULT_INSTALL_PATH install_path.mkdir(parents=True, exist_ok=True) for item in source_dir.iterdir(): dest = install_path / item.name if item.is_file(): shutil.copy2(item, dest) elif item.is_dir(): shutil.copytree(item, dest, dirs_exist_ok=True) log.info(f"Files installed to {install_path}") umtv2-umtpro-ultimateunisoc-v0.1-installer
# Step 1: Backup old version backup_old_version(DEFAULT_INSTALL_PATH)
# Step 7: Create uninstaller create_uninstaller(DEFAULT_INSTALL_PATH) (Y/n): ")
def add_to_path(install_path): """Add tool directory to system PATH (optional).""" try: import winreg key = winreg.OpenKey(winreg.HKEY_LOCAL_MACHINE, r"SYSTEM\CurrentControlSet\Control\Session Manager\Environment", 0, winreg.KEY_SET_VALUE) current_path, _ = winreg.QueryValueEx(key, "Path") if str(install_path) not in current_path: new_path = current_path + ";" + str(install_path) winreg.SetValueEx(key, "Path", 0, winreg.REG_EXPAND_SZ, new_path) winreg.CloseKey(key) log.info("Added to system PATH") # Notify system about change subprocess.run(["refreshenv.exe"], shell=True, capture_output=True) except Exception as e: log.error(f"Failed to update PATH: {e}")
if not args.silent: print(f"\n=== {TOOL_NAME} Installer v{INSTALLER_VERSION} ===\n") print(f"Installation target: {DEFAULT_INSTALL_PATH}") response = input("Proceed with installation? (Y/n): ").strip().lower() if response == 'n': print("Installation cancelled.") sys.exit(0) dest) elif item.is_dir(): shutil.copytree(item
# Elevate privileges if not admin if not is_admin(): log.warning("Installer requires admin privileges.") run_as_admin()
# Step 5: Driver installation if not args.no_drivers: install_drivers()
def log_system_info(): """Log environment details for troubleshooting.""" log.info(f"OS: {platform.system()} {platform.release()}") log.info(f"Architecture: {platform.machine()}") log.info(f"Python version: {sys.version}") log.info(f"Installer path: {os.path.abspath(sys.argv[0])}") def main(): parser = argparse.ArgumentParser(description=f"{TOOL_NAME} Installer v{INSTALLER_VERSION}") parser.add_argument("--silent", action="store_true", help="Silent install (no prompts)") parser.add_argument("--no-path", action="store_true", help="Don't add to system PATH") parser.add_argument("--no-drivers", action="store_true", help="Skip driver installation") parser.add_argument("--source", type=str, help="Path to ZIP package with tool files") args = parser.parse_args()