mirror of
https://github.com/ChrisTitusTech/winutil.git
synced 2025-01-16 01:40:35 -06:00
Compare commits
4 Commits
a3ab1409e5
...
7f482d5e4b
Author | SHA1 | Date | |
---|---|---|---|
|
7f482d5e4b | ||
|
579030eeb9 | ||
|
d111244347 | ||
|
44c6ecc334 |
@ -14,10 +14,10 @@ function Install-WinUtilProgramChoco {
|
|||||||
#>
|
#>
|
||||||
|
|
||||||
param(
|
param(
|
||||||
[Parameter(Mandatory, Position=0)]
|
[Parameter(Mandatory, Position = 0)]
|
||||||
[PsCustomObject]$ProgramsToInstall,
|
[PsCustomObject]$ProgramsToInstall,
|
||||||
|
|
||||||
[Parameter(Position=1)]
|
[Parameter(Position = 1)]
|
||||||
[String]$manage = "Installing"
|
[String]$manage = "Installing"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -25,7 +25,7 @@ function Install-WinUtilProgramChoco {
|
|||||||
$count = $ProgramsToInstall.Count
|
$count = $ProgramsToInstall.Count
|
||||||
|
|
||||||
# This check isn't really necessary, as there's a couple of checks before this Private Function gets called, but just to make sure ;)
|
# This check isn't really necessary, as there's a couple of checks before this Private Function gets called, but just to make sure ;)
|
||||||
if($count -le 0) {
|
if ($count -le 0) {
|
||||||
throw "Private Function 'Install-WinUtilProgramChoco' expected Parameter 'ProgramsToInstall' to be of size 1 or greater, instead got $count,`nPlease double check your code and re-compile WinUtil."
|
throw "Private Function 'Install-WinUtilProgramChoco' expected Parameter 'ProgramsToInstall' to be of size 1 or greater, instead got $count,`nPlease double check your code and re-compile WinUtil."
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -35,70 +35,78 @@ function Install-WinUtilProgramChoco {
|
|||||||
Write-Host "==========================================="
|
Write-Host "==========================================="
|
||||||
Foreach ($Program in $ProgramsToInstall) {
|
Foreach ($Program in $ProgramsToInstall) {
|
||||||
|
|
||||||
if($manage -eq "Installing") {
|
if ($manage -eq "Installing") {
|
||||||
write-host "Starting install of $($Program.choco) with Chocolatey."
|
write-host "Starting install of $($Program.choco) with Chocolatey."
|
||||||
try {
|
try {
|
||||||
$tryUpgrade = $false
|
$tryUpgrade = $false
|
||||||
$installOutputFilePath = "$env:TEMP\Install-WinUtilProgramChoco.install-command.output.txt"
|
$installOutputFilePath = "$env:TEMP\Install-WinUtilProgramChoco.install-command.output.txt"
|
||||||
New-Item -ItemType File -Path $installOutputFilePath
|
New-Item -ItemType File -Path $installOutputFilePath
|
||||||
$chocoInstallStatus = $(Start-Process -FilePath "choco" -ArgumentList "install $($Program.choco) -y" -Wait -PassThru -RedirectStandardOutput $installOutputFilePath -NoNewWindow).ExitCode
|
$chocoInstallStatus = $(Start-Process -FilePath "choco" -ArgumentList "install $($Program.choco) -y --log-file $($installOutputFilePath)" -Wait -PassThru).ExitCode
|
||||||
if(($chocoInstallStatus -eq 0) -AND (Test-Path -Path $installOutputFilePath)) {
|
if (($chocoInstallStatus -eq 0) -AND (Test-Path -Path $installOutputFilePath)) {
|
||||||
$keywordsFound = Get-Content -Path $installOutputFilePath | Where-Object {$_ -match "reinstall" -OR $_ -match "already installed"}
|
$keywordsFound = Get-Content -Path $installOutputFilePath | Where-Object { $_ -match "reinstall" -OR $_ -match "already installed" }
|
||||||
if ($keywordsFound) {
|
if ($keywordsFound) {
|
||||||
$tryUpgrade = $true
|
$tryUpgrade = $true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
# TODO: Implement the Upgrade part using 'choco upgrade' command, this will make choco consistent with WinGet, as WinGet tries to Upgrade when you use the install command.
|
|
||||||
if ($tryUpgrade) {
|
if ($tryUpgrade) {
|
||||||
$chocoUpdateStatus = $(Start-Process -FilePath "choco" -ArgumentList "upgrade $($Program.choco) -y" -Wait -PassThru -RedirectStandardOutput $installOutputFilePath -NoNewWindow).ExitCode
|
$chocoUpdateStatus = $(Start-Process -FilePath "choco" -ArgumentList "upgrade $($Program.choco) -y" -Wait -PassThru).ExitCode
|
||||||
if ($chocoUpdateStatus -eq 0) {
|
if ($chocoUpdateStatus -eq 0) {
|
||||||
Write-Host "$($Program.choco) was updated successfully using Chocolatey."
|
Write-Host "$($Program.choco) was updated successfully using Chocolatey."
|
||||||
}
|
}
|
||||||
|
else{
|
||||||
|
Write-Host "Failed upgdate of $($Program.choco) using Chocolatey."
|
||||||
}
|
}
|
||||||
if(($chocoInstallStatus -eq 0) -AND ($tryUpgrade -eq $false)) {
|
}
|
||||||
|
if (($chocoInstallStatus -eq 0) -AND ($tryUpgrade -eq $false)) {
|
||||||
Write-Host "$($Program.choco) installed successfully using Chocolatey."
|
Write-Host "$($Program.choco) installed successfully using Chocolatey."
|
||||||
$X++
|
$X++
|
||||||
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Normal" -value ($x/$count) })
|
$sync.form.Dispatcher.Invoke([action] { Set-WinUtilTaskbaritem -state "Normal" -value ($x / $count) })
|
||||||
continue
|
continue
|
||||||
} else {
|
|
||||||
Write-Host "Failed to install $($Program.choco) using Chocolatey, Chocolatey output:`n`n$(Get-Content -Path $installOutputFilePath)."
|
|
||||||
$X++
|
|
||||||
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Error" -value ($x/$count) })
|
|
||||||
}
|
}
|
||||||
} catch {
|
elseif (($chocoInstallStatus -ne 0) -AND ($tryUpgrade -eq $false)) {
|
||||||
|
Write-Host "Failed to install $($Program.choco) using Chocolatey"
|
||||||
|
$X++
|
||||||
|
$sync.form.Dispatcher.Invoke([action] { Set-WinUtilTaskbaritem -state "Error" -value ($x / $count) })
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch {
|
||||||
Write-Host "Failed to install $($Program.choco) due to an error: $_"
|
Write-Host "Failed to install $($Program.choco) due to an error: $_"
|
||||||
$X++
|
$X++
|
||||||
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Error" -value ($x/$count) })
|
$sync.form.Dispatcher.Invoke([action] { Set-WinUtilTaskbaritem -state "Error" -value ($x / $count) })
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if($manage -eq "Uninstalling") {
|
if ($manage -eq "Uninstalling") {
|
||||||
write-host "Starting uninstall of $($Program.choco) with Chocolatey."
|
Write-Host "Searching for Metapackages of of $($Program.choco) (.install or .portable)"
|
||||||
|
$chocoPackages = ((choco list | Select-String -Pattern "$($Program.choco)(\.install|\.portable) {0,1}").Matches.Value) -join " "
|
||||||
|
Write-Host "Starting uninstall of $chocoPackages with Chocolatey."
|
||||||
try {
|
try {
|
||||||
$uninstallOutputFilePath = "$env:TEMP\Install-WinUtilProgramChoco.uninstall-command.output.txt"
|
$uninstallOutputFilePath = "$env:TEMP\Install-WinUtilProgramChoco.uninstall-command.output.txt"
|
||||||
New-Item -ItemType File -Path $uninstallOutputFilePath
|
New-Item -ItemType File -Path $uninstallOutputFilePath
|
||||||
$chocoUninstallStatus = $(Start-Process -FilePath "choco" -ArgumentList "uninstall $($Program.choco) -y" -Wait -PassThru -NoNewWindow).ExitCode
|
$chocoUninstallStatus = $(Start-Process -FilePath "choco" -ArgumentList "uninstall $chocoPackages -y" -Wait -PassThru).ExitCode
|
||||||
if($chocoUninstallStatus -eq 0) {
|
if ($chocoUninstallStatus -eq 0) {
|
||||||
Write-Host "$($Program.choco) uninstalled successfully using Chocolatey."
|
Write-Host "$($Program.choco) uninstalled successfully using Chocolatey."
|
||||||
$x++
|
$x++
|
||||||
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Normal" -value ($x/$count) })
|
$sync.form.Dispatcher.Invoke([action] { Set-WinUtilTaskbaritem -state "Normal" -value ($x / $count) })
|
||||||
continue
|
continue
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
Write-Host "Failed to uninstall $($Program.choco) using Chocolatey, Chocolatey output:`n`n$(Get-Content -Path $uninstallOutputFilePath)."
|
Write-Host "Failed to uninstall $($Program.choco) using Chocolatey, Chocolatey output:`n`n$(Get-Content -Path $uninstallOutputFilePath)."
|
||||||
$x++
|
$x++
|
||||||
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Error" -value ($x/$count) })
|
$sync.form.Dispatcher.Invoke([action] { Set-WinUtilTaskbaritem -state "Error" -value ($x / $count) })
|
||||||
}
|
}
|
||||||
} catch {
|
}
|
||||||
|
catch {
|
||||||
Write-Host "Failed to uninstall $($Program.choco) due to an error: $_"
|
Write-Host "Failed to uninstall $($Program.choco) due to an error: $_"
|
||||||
$x++
|
$x++
|
||||||
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Error" -value ($x/$count) })
|
$sync.form.Dispatcher.Invoke([action] { Set-WinUtilTaskbaritem -state "Error" -value ($x / $count) })
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# Cleanup leftovers files
|
# Cleanup leftovers files
|
||||||
if(Test-Path -Path $installOutputFilePath) { Remove-Item -Path $installOutputFilePath }
|
if (Test-Path -Path $installOutputFilePath) { Remove-Item -Path $installOutputFilePath }
|
||||||
if(Test-Path -Path $uninstallOutputFilePath) { Remove-Item -Path $uninstallOutputFilePath }
|
if (Test-Path -Path $uninstallOutputFilePath) { Remove-Item -Path $uninstallOutputFilePath }
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -13,6 +13,16 @@ Function Invoke-WinUtilCurrentSystem {
|
|||||||
param(
|
param(
|
||||||
$CheckBox
|
$CheckBox
|
||||||
)
|
)
|
||||||
|
if ($CheckBox -eq "choco") {
|
||||||
|
$apps = (choco list | Select-String -Pattern "^\S+").Matches.Value
|
||||||
|
$filter = Get-WinUtilVariables -Type Checkbox | Where-Object {$psitem -like "WPFInstall*"}
|
||||||
|
$sync.GetEnumerator() | Where-Object {$psitem.Key -in $filter} | ForEach-Object {
|
||||||
|
$dependencies = @($sync.configs.applications.$($psitem.Key).choco -split ";")
|
||||||
|
if ($dependencies -in $apps) {
|
||||||
|
Write-Output $psitem.name
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ($checkbox -eq "winget") {
|
if ($checkbox -eq "winget") {
|
||||||
|
|
||||||
|
@ -16,14 +16,12 @@ function Invoke-WPFGetInstalled {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if(((Test-WinUtilPackageManager -winget) -eq "not-installed") -and $checkbox -eq "winget") {
|
if(($sync.WPFpreferChocolatey.IsChecked -eq $false) -and ((Test-WinUtilPackageManager -winget) -eq "not-installed") -and $checkbox -eq "winget") {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if ($sync.WPFpreferChocolatey.IsChecked) {
|
$preferChoco = $sync.WPFpreferChocolatey.IsChecked
|
||||||
Write-Host "The Function `"Get Installed`" is only supported for Winget at the moment" -ForegroundColor Red
|
Invoke-WPFRunspace -ArgumentList $checkbox, $preferChoco -DebugPreference $DebugPreference -ScriptBlock {
|
||||||
}
|
param($checkbox, $preferChoco, $DebugPreference)
|
||||||
Invoke-WPFRunspace -ArgumentList $checkbox -DebugPreference $DebugPreference -ScriptBlock {
|
|
||||||
param($checkbox, $DebugPreference)
|
|
||||||
|
|
||||||
$sync.ProcessRunning = $true
|
$sync.ProcessRunning = $true
|
||||||
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Indeterminate" })
|
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Indeterminate" })
|
||||||
@ -34,8 +32,12 @@ function Invoke-WPFGetInstalled {
|
|||||||
if($checkbox -eq "tweaks") {
|
if($checkbox -eq "tweaks") {
|
||||||
Write-Host "Getting Installed Tweaks..."
|
Write-Host "Getting Installed Tweaks..."
|
||||||
}
|
}
|
||||||
|
if ($preferChoco -and $checkbox -eq "winget") {
|
||||||
|
$Checkboxes = Invoke-WinUtilCurrentSystem -CheckBox "choco"
|
||||||
|
}
|
||||||
|
else{
|
||||||
$Checkboxes = Invoke-WinUtilCurrentSystem -CheckBox $checkbox
|
$Checkboxes = Invoke-WinUtilCurrentSystem -CheckBox $checkbox
|
||||||
|
}
|
||||||
|
|
||||||
$sync.form.Dispatcher.invoke({
|
$sync.form.Dispatcher.invoke({
|
||||||
foreach($checkbox in $Checkboxes) {
|
foreach($checkbox in $Checkboxes) {
|
||||||
|
@ -87,6 +87,14 @@ try {
|
|||||||
|
|
||||||
$xaml.SelectNodes("//*[@Name]") | ForEach-Object {$sync["$("$($psitem.Name)")"] = $sync["Form"].FindName($psitem.Name)}
|
$xaml.SelectNodes("//*[@Name]") | ForEach-Object {$sync["$("$($psitem.Name)")"] = $sync["Form"].FindName($psitem.Name)}
|
||||||
|
|
||||||
|
#Persist the Chocolatey preference across winutil restarts
|
||||||
|
$ChocoPreferencePath = "$env:LOCALAPPDATA\winutil\preferChocolatey.ini"
|
||||||
|
$sync.WPFpreferChocolatey.Add_Checked({New-Item -Path $ChocoPreferencePath -Force })
|
||||||
|
$sync.WPFpreferChocolatey.Add_Unchecked({Remove-Item $ChocoPreferencePath -Force})
|
||||||
|
if (Test-Path $ChocoPreferencePath) {
|
||||||
|
$sync.WPFpreferChocolatey.IsChecked = $true
|
||||||
|
}
|
||||||
|
|
||||||
$sync.keys | ForEach-Object {
|
$sync.keys | ForEach-Object {
|
||||||
if($sync.$psitem) {
|
if($sync.$psitem) {
|
||||||
if($($sync["$psitem"].GetType() | Select-Object -ExpandProperty Name) -eq "CheckBox" `
|
if($($sync["$psitem"].GetType() | Select-Object -ExpandProperty Name) -eq "CheckBox" `
|
||||||
|
Loading…
Reference in New Issue
Block a user