# Reserved Windows 10 system paths RESERVED_PATHS = [ "Windows", "System32", "System", "ProgramData", "Boot", "Recovery", "Users", "$Recycle.Bin" ]
def get_recommended_path(self, app_name: str, is_portable: bool = False) -> str: """ Get recommended installation path based on app type """ if is_portable: base_path = self.default_install_paths[InstallLocation.LOCAL_APPDATA] return str(Path(base_path) / app_name) else: base_path = self.default_install_paths[InstallLocation.PROGRAM_FILES] return str(Path(base_path) / app_name)
Overview A feature that helps applications handle installation directories on Windows 10, including validation, permission checking, and path management. Key Components # installation_manager.py import os import winreg import ctypes from pathlib import Path from typing import Tuple, Optional from enum import Enum class InstallLocation(Enum): PROGRAM_FILES = "PROGRAMFILES" PROGRAM_FILES_X86 = "PROGRAMFILES(X86)" LOCAL_APPDATA = "LOCALAPPDATA" CUSTOM = "CUSTOM" installation directory windows 10
def validate_install_directory(self, path: str, create_if_missing: bool = False) -> Tuple[bool, Optional[str]]: """ Validate if a directory is suitable for installation on Windows 10 Returns: (is_valid, error_message) """ try: path_obj = Path(path).resolve() # Check 1: Path length if len(str(path_obj)) > self.MAX_PATH_LENGTH: return False, f"Path exceeds Windows 10 self.MAX_PATH_LENGTH character limit" # Check 2: Reserved system paths for reserved in self.RESERVED_PATHS: if path_obj.absolute().as_posix().lower().find(reserved.lower()) != -1: return False, f"Cannot install in Windows system directory: reserved" # Check 3: Root directory if path_obj.anchor == str(path_obj): return False, "Cannot install directly to drive root" # Check 4: Contains invalid characters for Windows 10 invalid_chars = ['<', '>', ':', '"', '|', '?', '*', '\x00'] for char in invalid_chars: if char in str(path_obj.name): return False, f"Path contains invalid character: char" # Check 5: Reserved names (Windows 10) reserved_names = ['CON', 'PRN', 'AUX', 'NUL', 'COM1', 'COM2', 'COM3', 'COM4', 'COM5', 'COM6', 'COM7', 'COM8', 'COM9', 'LPT1', 'LPT2', 'LPT3', 'LPT4', 'LPT5', 'LPT6', 'LPT7', 'LPT8', 'LPT9'] if path_obj.name.upper() in reserved_names: return False, f"Reserved Windows device name: path_obj.name" # Check 6: Permissions if not self._has_write_permission(path_obj.parent if not path_obj.exists() else path_obj): return False, "Insufficient write permissions in target directory" # Create directory if needed if create_if_missing and not path_obj.exists(): try: path_obj.mkdir(parents=True, exist_ok=True) except PermissionError: return False, "Permission denied when creating directory" except OSError as e: return False, f"Failed to create directory: str(e)" return True, None except Exception as e: return False, f"Validation error: str(e)"
# Proceed with installation return True
def _is_admin(self) -> bool: """Check if running with administrator privileges""" try: return ctypes.windll.shell32.IsUserAnAdmin() != 0 except: return False
def require_admin_elevation(self, path: str) -> bool: """Check if admin elevation is needed for installation""" protected_dirs = [ "C:\\Program Files", "C:\\Program Files (x86)", "C:\\Windows", "C:\\System32" ] path_lower = path.lower() for protected in protected_dirs: if path_lower.startswith(protected.lower()): return not self._is_admin() return False # Reserved Windows 10 system paths RESERVED_PATHS =
if not is_valid: print(f"Installation failed: error") return False