From 31be3b01c6136da0ac5c650f7efd98712d9bee93 Mon Sep 17 00:00:00 2001 From: Underscore Date: Thu, 10 Oct 2024 19:09:54 -0700 Subject: [PATCH] Added comments. --- scripts/start.ps1 | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/scripts/start.ps1 b/scripts/start.ps1 index dcc23865..c12b82b1 100644 --- a/scripts/start.ps1 +++ b/scripts/start.ps1 @@ -39,20 +39,26 @@ $sync.version = "#{replaceme}" $sync.configs = @{} $sync.ProcessRunning = $false +# Store latest script URL in variable. $latestScript = "https://github.com/ChrisTitusTech/winutil/releases/latest/download/winutil.ps1" +# Check if script is running as Administrator if (!([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole]::Administrator)) { Write-Output "Winutil needs to be run as Administrator. Attempting to relaunch." + + # Partial rollback from #2648, changed irm and iex to Invoke-RestMethod and Invoke-Expression. $script = if ($MyInvocation.MyCommand.Path) { "& '" + $MyInvocation.MyCommand.Path + "'" } else { "Invoke-RestMethod '$latestScript' | Invoke-Expression"} $powershellcmd = if (Get-Command pwsh -ErrorAction SilentlyContinue) { "pwsh" } else { "powershell" } $processCmd = if (Get-Command wt.exe -ErrorAction SilentlyContinue) { "wt.exe" } else { $powershellcmd } + # Start new process with elevated privileges Start-Process $processCmd -ArgumentList "$powershellcmd -ExecutionPolicy Bypass -NoProfile -Command $script" -Verb RunAs break } +# Logging $dateTime = Get-Date -Format "yyyy-MM-dd_HH-mm-ss" $logdir = "$env:localappdata\winutil\logs"