commit
92f679eb93
|
@ -28,13 +28,14 @@ if ( $psversionTable.PSEdition -eq "core" ) {
|
|||
import-Module -name Appx -UseWIndowsPowershell -WarningAction:SilentlyContinue
|
||||
}
|
||||
|
||||
$Script:WAUConfiguratorVersion = Get-Content ".\Winget-AutoUpdate\Version.txt"
|
||||
$Script:WorkingDir = (Get-Location).Path
|
||||
$Script:WAUConfiguratorVersion = Get-Content "$WorkingDir\Winget-AutoUpdate\Version.txt"
|
||||
|
||||
|
||||
<# FUNCTIONS #>
|
||||
|
||||
. ".\Winget-AutoUpdate\functions\Update-WinGet.ps1"
|
||||
. ".\Winget-AutoUpdate\functions\Get-WingetCmd.ps1"
|
||||
. "$WorkingDir\Winget-AutoUpdate\functions\Update-WinGet.ps1"
|
||||
. "$WorkingDir\Winget-AutoUpdate\functions\Get-WingetCmd.ps1"
|
||||
|
||||
#Function to start or update popup
|
||||
Function Start-PopUp ($Message) {
|
||||
|
@ -183,12 +184,12 @@ function Start-Installations {
|
|||
if ($WAUUseWhiteList) {
|
||||
$WAUParameters += "-UseWhiteList "
|
||||
if ($WAUListPath) {
|
||||
Copy-Item $WAUListPath -Destination ".\included_apps.txt" -Force -ErrorAction SilentlyContinue
|
||||
Copy-Item $WAUListPath -Destination "$WorkingDir\included_apps.txt" -Force -ErrorAction SilentlyContinue
|
||||
}
|
||||
}
|
||||
else {
|
||||
if ($WAUListPath) {
|
||||
Copy-Item $WAUListPath -Destination ".\excluded_apps.txt" -Force -ErrorAction SilentlyContinue
|
||||
Copy-Item $WAUListPath -Destination "$WorkingDir\excluded_apps.txt" -Force -ErrorAction SilentlyContinue
|
||||
}
|
||||
}
|
||||
if ($WAUDesktopShortcut) {
|
||||
|
@ -202,7 +203,7 @@ function Start-Installations {
|
|||
}
|
||||
|
||||
#Install Winget-Autoupdate
|
||||
Start-Process "powershell.exe" -Argument "-NoProfile -ExecutionPolicy Bypass -Command ""& '.\Winget-AutoUpdate-Install.ps1' $WAUParameters""" -Wait -Verb RunAs
|
||||
Start-Process "powershell.exe" -Argument "-NoProfile -ExecutionPolicy Bypass -Command ""& '$WorkingDir\Winget-AutoUpdate-Install.ps1' $WAUParameters""" -Wait -Verb RunAs
|
||||
}
|
||||
|
||||
|
||||
|
@ -275,7 +276,7 @@ function Start-Uninstallations ($AppToUninstall) {
|
|||
|
||||
#Run Winget-Install -Uninstall
|
||||
$AppsToUninstall = "'$($AppToUninstall -join "','")'"
|
||||
Start-Process "powershell.exe" -Argument "-NoProfile -ExecutionPolicy Bypass -Command `".\Winget-AutoUpdate\Winget-Install.ps1 -AppIDs $AppsToUninstall -Uninstall`"" -Wait -Verb RunAs
|
||||
Start-Process "powershell.exe" -Argument "-NoProfile -ExecutionPolicy Bypass -Command `"$WorkingDir\Winget-AutoUpdate\Winget-Install.ps1 -AppIDs $AppsToUninstall -Uninstall`"" -Wait -Verb RunAs
|
||||
|
||||
Close-PopUp
|
||||
}
|
||||
|
|
|
@ -299,9 +299,8 @@ if (Test-Network) {
|
|||
if ($outdated -like "No update found.*") {
|
||||
Write-ToLog "$outdated" "cyan"
|
||||
}
|
||||
|
||||
#Run only if $outdated is populated!
|
||||
if ($outdated) {
|
||||
else {
|
||||
#Log list of app to update
|
||||
foreach ($app in $outdated) {
|
||||
#List available updates
|
||||
|
|
|
@ -13,64 +13,70 @@ function Get-WingetOutdatedApps {
|
|||
|
||||
#Start Conversion of winget format to an array. Check if "-----" exists (Winget Error Handling)
|
||||
if (!($upgradeResult -match "-----")) {
|
||||
return "No update found. Winget upgrade output:`n$upgradeResult"
|
||||
|
||||
return "No update found. 'Winget upgrade' output:`n$upgradeResult"
|
||||
|
||||
}
|
||||
else {
|
||||
|
||||
#Split winget output to lines
|
||||
$lines = $upgradeResult.Split([Environment]::NewLine) | Where-Object { $_ }
|
||||
#Split winget output to lines
|
||||
$lines = $upgradeResult.Split([Environment]::NewLine) | Where-Object { $_ }
|
||||
|
||||
# Find the line that starts with "------"
|
||||
$fl = 0
|
||||
while (-not $lines[$fl].StartsWith("-----")) {
|
||||
$fl++
|
||||
}
|
||||
|
||||
#Get header line
|
||||
$fl = $fl - 1
|
||||
|
||||
#Get header titles [without remove separator]
|
||||
$index = $lines[$fl] -split '(?<=\s)(?!\s)'
|
||||
|
||||
# Line $fl has the header, we can find char where we find ID and Version [and manage non latin characters]
|
||||
$idStart = $($index[0] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
$versionStart = $idStart + $($index[1] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
$availableStart = $versionStart + $($index[2] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
|
||||
# Now cycle in real package and split accordingly
|
||||
$upgradeList = @()
|
||||
For ($i = $fl + 2; $i -lt $lines.Length; $i++) {
|
||||
$line = $lines[$i] -replace "[\u2026]", " " #Fix "..." in long names
|
||||
if ($line.StartsWith("-----")) {
|
||||
#Get header line
|
||||
$fl = $i - 1
|
||||
|
||||
#Get header titles [without remove separator]
|
||||
$index = $lines[$fl] -split '(?<=\s)(?!\s)'
|
||||
|
||||
# Line $fl has the header, we can find char where we find ID and Version [and manage non latin characters]
|
||||
$idStart = $($index[0] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
$versionStart = $idStart + $($index[1] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
$availableStart = $versionStart + $($index[2] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
# Find the line that starts with "------"
|
||||
$fl = 0
|
||||
while (-not $lines[$fl].StartsWith("-----")) {
|
||||
$fl++
|
||||
}
|
||||
#(Alphanumeric | Literal . | Alphanumeric) - the only unique thing in common for lines with applications
|
||||
if ($line -match "\w\.\w") {
|
||||
$software = [Software]::new()
|
||||
#Manage non latin characters
|
||||
$nameDeclination = $($line.Substring(0, $idStart) -replace '[\u4e00-\u9fa5]', '**').Length - $line.Substring(0, $idStart).Length
|
||||
$software.Name = $line.Substring(0, $idStart - $nameDeclination).TrimEnd()
|
||||
$software.Id = $line.Substring($idStart - $nameDeclination, $versionStart - $idStart).TrimEnd()
|
||||
$software.Version = $line.Substring($versionStart - $nameDeclination, $availableStart - $versionStart).TrimEnd()
|
||||
$software.AvailableVersion = $line.Substring($availableStart - $nameDeclination).TrimEnd()
|
||||
#add formatted soft to list
|
||||
$upgradeList += $software
|
||||
|
||||
#Get header line
|
||||
$fl = $fl - 1
|
||||
|
||||
#Get header titles [without remove separator]
|
||||
$index = $lines[$fl] -split '(?<=\s)(?!\s)'
|
||||
|
||||
# Line $fl has the header, we can find char where we find ID and Version [and manage non latin characters]
|
||||
$idStart = $($index[0] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
$versionStart = $idStart + $($index[1] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
$availableStart = $versionStart + $($index[2] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
|
||||
# Now cycle in real package and split accordingly
|
||||
$upgradeList = @()
|
||||
For ($i = $fl + 2; $i -lt $lines.Length; $i++) {
|
||||
$line = $lines[$i] -replace "[\u2026]", " " #Fix "..." in long names
|
||||
if ($line.StartsWith("-----")) {
|
||||
#Get header line
|
||||
$fl = $i - 1
|
||||
|
||||
#Get header titles [without remove separator]
|
||||
$index = $lines[$fl] -split '(?<=\s)(?!\s)'
|
||||
|
||||
# Line $fl has the header, we can find char where we find ID and Version [and manage non latin characters]
|
||||
$idStart = $($index[0] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
$versionStart = $idStart + $($index[1] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
$availableStart = $versionStart + $($index[2] -replace '[\u4e00-\u9fa5]', '**').Length
|
||||
}
|
||||
#(Alphanumeric | Literal . | Alphanumeric) - the only unique thing in common for lines with applications
|
||||
if ($line -match "\w\.\w") {
|
||||
$software = [Software]::new()
|
||||
#Manage non latin characters
|
||||
$nameDeclination = $($line.Substring(0, $idStart) -replace '[\u4e00-\u9fa5]', '**').Length - $line.Substring(0, $idStart).Length
|
||||
$software.Name = $line.Substring(0, $idStart - $nameDeclination).TrimEnd()
|
||||
$software.Id = $line.Substring($idStart - $nameDeclination, $versionStart - $idStart).TrimEnd()
|
||||
$software.Version = $line.Substring($versionStart - $nameDeclination, $availableStart - $versionStart).TrimEnd()
|
||||
$software.AvailableVersion = $line.Substring($availableStart - $nameDeclination).TrimEnd()
|
||||
#add formatted soft to list
|
||||
$upgradeList += $software
|
||||
}
|
||||
}
|
||||
|
||||
#If current user is not system, remove system apps from list
|
||||
if ($IsSystem -eq $false) {
|
||||
$SystemApps = Get-Content -Path "$WorkingDir\config\winget_system_apps.txt" -ErrorAction SilentlyContinue
|
||||
$upgradeList = $upgradeList | Where-Object { $SystemApps -notcontains $_.Id }
|
||||
}
|
||||
|
||||
return $upgradeList | Sort-Object { Get-Random }
|
||||
|
||||
}
|
||||
|
||||
#If current user is not system, remove system apps from list
|
||||
if ($IsSystem -eq $false) {
|
||||
$SystemApps = Get-Content -Path "$WorkingDir\config\winget_system_apps.txt" -ErrorAction SilentlyContinue
|
||||
$upgradeList = $upgradeList | Where-Object { $SystemApps -notcontains $_.Id }
|
||||
}
|
||||
|
||||
return $upgradeList | Sort-Object { Get-Random }
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue