2-download And Install Usbdk-1.0.22-x64.msi Apr 2026

catch Write-Log "ERROR" "Download failed: $($_.Exception.Message)" return $false

void LogInfo(string message); void LogError(string message); void LogWarning(string message); void LogSuccess(string message);

# USBDKInstaller.ps1 param( [switch]$ForceReinstall, [switch]$Silent ) $ErrorActionPreference = "Stop" Constants $USBDK_URL = "https://github.com/daynix/UsbDk/releases/download/v1.0.22/UsbDk_1.0.22_x64.msi" $InstallerPath = Join-Path $env:TEMP "UsbDk_1.0.22_x64.msi" Logging function function Write-Log param([string]$Level, [string]$Message) $timestamp = Get-Date -Format "HH:mm:ss" $color = @ "INFO" = "Cyan" "ERROR" = "Red" "SUCCESS" = "Green" "WARNING" = "Yellow" [$Level]

if ($success) Write-Log "SUCCESS" "USBDK installation completed successfully" exit 0 2-download and install usbdk-1.0.22-x64.msi

$uninstallKey = "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\*" $usbdkEntry = Get-ItemProperty $uninstallKey function Download-USBDKInstaller Write-Log "INFO" "Downloading USBDK from $USBDK_URL"

private bool InstallMSI() try // Use msiexec for silent installation string arguments = $"/i \"_downloadPath\" /quiet /norestart"; ProcessStartInfo psi = new ProcessStartInfo FileName = "msiexec.exe", Arguments = arguments, UseShellExecute = false, CreateNoWindow = true, Verb = "runas" // Ensures admin elevation ;

else Write-Log "ERROR" "USBDK installation failed" exit 1 catch Write-Log "ERROR" "Download failed: $($_

# Download and install if (Download-USBDKInstaller) $result = Install-USBDK # Cleanup if (Test-Path $InstallerPath) Remove-Item $InstallerPath -Force -ErrorAction SilentlyContinue Write-Log "INFO" "Cleaned up installer file" return $result

private const string USBDK_DOWNLOAD_URL = "https://github.com/daynix/UsbDk/releases/download/v1.0.22/UsbDk_1.0.22_x64.msi"; private const string INSTALLER_FILENAME = "UsbDk_1.0.22_x64.msi"; private readonly string _downloadPath; private readonly ILogger _logger;

function Install-USBDKFeature Write-Log "INFO" "Starting USBDK installation process" void LogError(string message)

private bool IsUSBDKInstalled() try // Check if USBDK driver exists string driverPath = Path.Combine(Environment.SystemDirectory, "drivers", "UsbDk.sys"); if (File.Exists(driverPath)) return true;

_logger.LogInfo($"Downloaded to _downloadPath"); return true; catch (HttpRequestException ex) _logger.LogError($"Download failed: ex.Message"); return false;

private async Task<bool> DownloadInstallerAsync() try using (var httpClient = new HttpClient()) httpClient.Timeout = TimeSpan.FromMinutes(5); using (var response = await httpClient.GetAsync(USBDK_DOWNLOAD_URL, HttpCompletionOption.ResponseHeadersRead)) response.EnsureSuccessStatusCode(); using (var fileStream = new FileStream(_downloadPath, FileMode.Create, FileAccess.Write, FileShare.None)) await response.Content.CopyToAsync(fileStream);

# Check admin privileges if (-not (Test-AdminPrivileges)) Write-Log "ERROR" "Administrator privileges required" # Relaunch as admin if not silent if (-not $Silent) $arguments = "-NoProfile -ExecutionPolicy Bypass -File `"$PSCommandPath`" -Silent" Start-Process powershell.exe -Verb RunAs -ArgumentList $arguments return $false

// Step 3: Download the installer _logger.LogInfo($"Downloading USBDK from USBDK_DOWNLOAD_URL"); if (!await DownloadInstallerAsync()) _logger.LogError("Failed to download USBDK installer"); return false;