$is_elevated = [bool]([Security.Principal.WindowsPrincipal] [Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole] "Administrator") $choices = '&Yes', '&No' if (-Not $is_elevated) { # Not running with elevated permissions Write-Host "Not running as Administrator. Performing unprivileged actions..." Install Scoop $scoop_installer = "$env:USERPROFILE/Downloads/ScoopInstaller.ps1" Invoke-WebRequest -Uri https://get.scoop.sh -OutFile $scoop_installer &$scoop_installer -ScoopDir "$env:LocalAppData/Scoop" -ScoopGlobalDir "$env:ProgramData/Scoop" # The command you want to run with elevated privileges $Command = "Set-ExecutionPolicy Bypass -Scope Process -Force; " + "[System.Net.ServicePointManager]::SecurityProtocol = " + "[System.Net.ServicePointManager]::SecurityProtocol -bor 3072; " + "iex ((New-Object System.Net.WebClient).DownloadString('https://git.infektor.net/config/bootstrap/raw/update/bootstrap-Windows.ps1'))" # Create a temporary batch file $batchFile = [System.IO.Path]::GetTempFileName() + ".bat" $batchContent = "@echo off`r`n" + ` "powershell.exe -NoProfile -ExecutionPolicy Bypass -Command `"$Command`"`r`n" + ` "pause" # Write the batch content to the file Set-Content -Path $batchFile -Value $batchContent # Start the batch file with elevated privileges $StartInfo = New-Object System.Diagnostics.ProcessStartInfo $StartInfo.FileName = $batchFile $StartInfo.Verb = "runas" $StartInfo.UseShellExecute = $true [System.Diagnostics.Process]::Start($StartInfo) | Out-Null # Exit the current (non-admin) process # exit } # Code to execute after elevation Write-Host "Running as Administrator. Performing privileged actions..." # Install 1Password $decision = $Host.UI.PromptForChoice('Install 1Password', 'Proceed?', $choices, 0) if ($decision -eq 0) { $1password_installer = "$env:USERPROFILE/Downloads/1PasswordSetup-latest.exe" Invoke-WebRequest -Uri "https://downloads.1password.com/win/1PasswordSetup-latest.exe" -OutFile "$1password_installer" &$1password_installer Remove-Item $1password_installer } else { echo 'Skipping 1Password' } # # Enable Hyper-V # $decision = $Host.UI.PromptForChoice('Enable Hyper-V', 'Proceed?', $choices, 0) # if ($decision -eq 0) { # Enable-WindowsOptionalFeature -Online -FeatureName Microsoft-Hyper-V -All # } else { # echo 'Skipping Hyper-V' # } # # Enable Containters # $decision = $Host.UI.PromptForChoice('Enable Containers', 'Proceed?', $choices, 0) # if ($decision -eq 0) { # Enable-WindowsOptionalFeature -Online -FeatureName Containers -All # } else { # echo 'Skipping Containers' # } # # Get the shell application object # $shellApp = New-Object -ComObject "Shell.Application" # # Run the command without elevation # $shellApp.ShellExecute("powershell.exe", "-NoProfile -Command `"& { $nonElevatedCommand }`"", "", "open", 0) # # Start-Process -NoNewWindow -Credential "$env:UserDomain\$env:UserName" -FilePath "powershell.exe" -ArgumentList "-NoProfile -Command & { & $($command) }" # # Start-Process -FilePath "powershell.exe" -ArgumentList "-NoProfile -Command & { & $($command) }" -Credential $user -WindowStyle Hidden # # Install Chocolatey # iex ((New-Object System.Net.WebClient).DownloadString('https://community.chocolatey.org/install.ps1')) # # Install SSH Server # $decision = $Host.UI.PromptForChoice('Install SSH Server', 'Proceed?', $choices, 0) # if ($decision -eq 0) { # choco install --yes "--package-parameters=/SSHServerFeature" openssh # Start-Service sshd # Set-Service -Name sshd -StartupType 'Automatic' # } else { # echo 'Skipping SSH Server' # }