wingetautoupdate/Winget-AutoUpdate/winget-upgrade.ps1

139 lines
5.2 KiB
PowerShell
Raw Normal View History

2022-03-14 13:55:02 +00:00
<# LOAD FUNCTIONS #>
2022-03-14 13:55:02 +00:00
#Get Working Dir
$Script:WorkingDir = $PSScriptRoot
#Get Functions
Get-ChildItem "$WorkingDir\functions" | ForEach-Object {. $_.FullName}
2022-03-22 13:39:01 +00:00
<# MAIN #>
2022-03-14 13:55:02 +00:00
#Run log initialisation function
Start-Init
#Get Notif Locale function
2022-03-22 13:39:01 +00:00
Get-NotifLocale
#Check network connectivity
if (Test-Network){
2022-03-26 21:27:11 +00:00
#Get Current Version
Get-WAUCurrentVersion
2022-03-22 13:39:01 +00:00
#Check if WAU update feature is enabled
2022-03-26 15:02:00 +00:00
Get-WAUUpdateStatus
2022-03-22 13:39:01 +00:00
#If yes then check WAU update
2022-03-26 15:02:00 +00:00
if ($true -eq $WAUautoupdate){
2022-03-22 13:39:01 +00:00
#Get Available Version
2022-03-26 21:27:11 +00:00
Get-WAUAvailableVersion
2022-03-22 13:39:01 +00:00
#Compare
2022-03-27 10:20:33 +00:00
if ([version]$WAUAvailableVersion -gt [version]$WAUCurrentVersion){
2022-03-22 13:39:01 +00:00
#If new version is available, update it
2022-03-27 10:20:33 +00:00
Write-Log "WAU Available version: $WAUAvailableVersion" "Yellow"
2022-03-26 21:27:11 +00:00
Update-WAU
2022-03-22 13:39:01 +00:00
}
2022-03-26 21:48:56 +00:00
else{
2022-03-27 10:20:33 +00:00
Write-Log "WAU is up to date." "Green"
2022-03-26 21:48:56 +00:00
}
2022-03-07 01:35:40 +00:00
}
#Get exclude apps list
$toSkip = Get-ExcludedApps
#Get outdated Winget packages
2022-03-27 10:20:33 +00:00
Write-Log "Checking application updates on Winget Repository..." "yellow"
2022-03-22 13:39:01 +00:00
$outdated = Get-WingetOutdatedApps
#Log list of app to update
foreach ($app in $outdated){
#List available updates
$Log = "Available update : $($app.Name). Current version : $($app.Version). Available version : $($app.AvailableVersion)."
$Log | Write-host
$Log | out-file -filepath $LogFile -Append
}
2022-03-22 13:39:01 +00:00
#Count good update installations
$InstallOK = 0
#For each app, notify and update
foreach ($app in $outdated){
2022-02-21 11:46:53 +00:00
if (-not ($toSkip -contains $app.Id) -and $($app.Version) -ne "Unknown"){
#Send available update notification
Write-Log "Updating $($app.Name) from $($app.Version) to $($app.AvailableVersion)..." "Cyan"
$Title = $NotifLocale.local.outputs.output[2].title -f $($app.Name)
$Message = $NotifLocale.local.outputs.output[2].message -f $($app.Version), $($app.AvailableVersion)
$MessageType = "info"
$Balise = $($app.Name)
Start-NotifTask $Title $Message $MessageType $Balise
#Winget upgrade
2022-02-23 09:44:40 +00:00
Write-Log "########## WINGET UPGRADE PROCESS STARTS FOR APPLICATION ID '$($App.Id)' ##########" "Gray"
2022-02-22 17:29:48 +00:00
#Run Winget Upgrade command
& $UpgradeCmd upgrade --id $($app.Id) --all --accept-package-agreements --accept-source-agreements -h | Tee-Object -file $LogFile -Append
#Check if application updated properly
2022-03-22 13:39:01 +00:00
$CheckOutdated = Get-WingetOutdatedApps
2022-02-22 17:29:48 +00:00
$FailedToUpgrade = $false
foreach ($CheckApp in $CheckOutdated){
if ($($CheckApp.Id) -eq $($app.Id)) {
#If app failed to upgrade, run Install command
& $upgradecmd install --id $($app.Id) --accept-package-agreements --accept-source-agreements -h | Tee-Object -file $LogFile -Append
#Check if application installed properly
2022-03-22 13:39:01 +00:00
$CheckOutdated2 = Get-WingetOutdatedApps
2022-02-22 17:29:48 +00:00
foreach ($CheckApp2 in $CheckOutdated2){
if ($($CheckApp2.Id) -eq $($app.Id)) {
$FailedToUpgrade = $true
}
}
}
}
2022-02-23 09:44:40 +00:00
Write-Log "########## WINGET UPGRADE PROCESS FINISHED FOR APPLICATION ID '$($App.Id)' ##########" "Gray"
#Notify installation
if ($FailedToUpgrade -eq $false){
#Send success updated app notification
Write-Log "$($app.Name) updated to $($app.AvailableVersion) !" "Green"
#Send Notif
$Title = $NotifLocale.local.outputs.output[3].title -f $($app.Name)
$Message = $NotifLocale.local.outputs.output[3].message -f $($app.AvailableVersion)
$MessageType = "success"
$Balise = $($app.Name)
Start-NotifTask $Title $Message $MessageType $Balise
$InstallOK += 1
}
else {
#Send failed updated app notification
Write-Log "$($app.Name) update failed." "Red"
#Send Notif
$Title = $NotifLocale.local.outputs.output[4].title -f $($app.Name)
$Message = $NotifLocale.local.outputs.output[4].message
$MessageType = "error"
$Balise = $($app.Name)
Start-NotifTask $Title $Message $MessageType $Balise
}
2022-02-21 11:46:53 +00:00
}
#if current app version is unknown
elseif($($app.Version) -eq "Unknown"){
Write-Log "$($app.Name) : Skipped upgrade because current version is 'Unknown'" "Gray"
2022-02-21 13:26:30 +00:00
}
2022-02-21 11:46:53 +00:00
#if app is in "excluded list"
else{
Write-Log "$($app.Name) : Skipped upgrade because it is in the excluded app list" "Gray"
}
}
if ($InstallOK -gt 0){
Write-Log "$InstallOK apps updated ! No more update." "Green"
}
if ($InstallOK -eq 0){
Write-Log "No new update." "Green"
}
}
#End
Write-Log "End of process!" "Cyan"
2022-02-21 11:46:53 +00:00
Start-Sleep 3