89 lines
3.3 KiB
PowerShell
89 lines
3.3 KiB
PowerShell
$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
|
|
|
|
# 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"
|
|
|
|
# Get the current script's path
|
|
$ScriptPath = $MyInvocation.MyCommand.Definition
|
|
|
|
# Create a new process to run the script as administrator
|
|
$StartInfo = New-Object System.Diagnostics.ProcessStartInfo
|
|
$StartInfo.FileName = "powershell.exe"
|
|
|
|
# Add parameters to the command-line arguments
|
|
$StartInfo.Arguments = "-NoProfile -ExecutionPolicy Bypass -File `"$ScriptPath`""
|
|
|
|
# Elevate privileges
|
|
$StartInfo.Verb = "runas"
|
|
|
|
# Ensure output is visible to the user
|
|
$StartInfo.UseShellExecute = $true
|
|
$StartInfo.RedirectStandardOutput = $false
|
|
$StartInfo.RedirectStandardError = $false
|
|
$StartInfo.CreateNoWindow = $false
|
|
|
|
# Start the elevated process
|
|
[System.Diagnostics.Process]::Start($StartInfo) | Out-Null
|
|
|
|
# Exit the current (non-admin) process
|
|
exit
|
|
}
|
|
|
|
# Running with elevated permissions
|
|
Write-Host "Press Enter to exit..."
|
|
[System.Console]::ReadLine() | Out-Null
|
|
# # 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'
|
|
# }
|