Merge branch 'main' into Update-Winget
commit
61f08e423b
|
@ -82,11 +82,14 @@ jobs:
|
||||||
|
|
||||||
- name: Build project
|
- name: Build project
|
||||||
run: |
|
run: |
|
||||||
zip -r WAU Winget-AutoUpdate/*
|
zip -r WAU.zip Winget-AutoUpdate
|
||||||
zip -r WAU Winget-AutoUpdate-Install.ps1
|
zip WAU.zip Winget-AutoUpdate-Install.ps1
|
||||||
zip -r WAU excluded_apps.txt
|
zip WAU.zip excluded_apps.txt
|
||||||
zip -r WAU install.bat
|
zip WAU.zip install.bat
|
||||||
zip -r WAU uninstall.bat
|
zip WAU.zip uninstall.bat
|
||||||
|
cd Policies
|
||||||
|
zip -r ../WAU_ADMX.zip *
|
||||||
|
cd ..
|
||||||
|
|
||||||
- name: Create release
|
- name: Create release
|
||||||
uses: "ncipollo/release-action@v1"
|
uses: "ncipollo/release-action@v1"
|
||||||
|
@ -96,7 +99,7 @@ jobs:
|
||||||
prerelease: true
|
prerelease: true
|
||||||
generateReleaseNotes: true
|
generateReleaseNotes: true
|
||||||
name: "v${{ steps.versioning.outputs.version }} [Nightly Build]"
|
name: "v${{ steps.versioning.outputs.version }} [Nightly Build]"
|
||||||
artifacts: "WAU.zip"
|
artifacts: "WAU.zip,WAU_ADMX.zip"
|
||||||
|
|
||||||
- name: URL to release
|
- name: URL to release
|
||||||
run: echo "Release -> ${{ steps.release.outputs.html_url }}"
|
run: echo "Release -> ${{ steps.release.outputs.html_url }}"
|
||||||
|
|
|
@ -55,11 +55,14 @@ jobs:
|
||||||
|
|
||||||
- name: Build project
|
- name: Build project
|
||||||
run: |
|
run: |
|
||||||
zip -r WAU Winget-AutoUpdate/*
|
zip -r WAU.zip Winget-AutoUpdate
|
||||||
zip -r WAU Winget-AutoUpdate-Install.ps1
|
zip WAU.zip Winget-AutoUpdate-Install.ps1
|
||||||
zip -r WAU excluded_apps.txt
|
zip WAU.zip excluded_apps.txt
|
||||||
zip -r WAU install.bat
|
zip WAU.zip install.bat
|
||||||
zip -r WAU uninstall.bat
|
zip WAU.zip uninstall.bat
|
||||||
|
cd Policies
|
||||||
|
zip -r ../WAU_ADMX.zip *
|
||||||
|
cd ..
|
||||||
|
|
||||||
- name: Create release
|
- name: Create release
|
||||||
uses: "ncipollo/release-action@v1"
|
uses: "ncipollo/release-action@v1"
|
||||||
|
@ -68,4 +71,4 @@ jobs:
|
||||||
prerelease: ${{ github.event.inputs.pre-release }}
|
prerelease: ${{ github.event.inputs.pre-release }}
|
||||||
generateReleaseNotes: true
|
generateReleaseNotes: true
|
||||||
name: "v${{ steps.versioning.outputs.version }}"
|
name: "v${{ steps.versioning.outputs.version }}"
|
||||||
artifacts: "WAU.zip"
|
artifacts: "WAU.zip,WAU_ADMX.zip"
|
||||||
|
|
|
@ -172,8 +172,8 @@ Remove scheduled tasks and scripts.
|
||||||
See https://github.com/Romanitho/Winget-AutoUpdate/discussions/88
|
See https://github.com/Romanitho/Winget-AutoUpdate/discussions/88
|
||||||
|
|
||||||
## Custom script (Mods for WAU)
|
## Custom script (Mods for WAU)
|
||||||
**Mods for WAU** allows you to craft a script to do whatever you like via `_WAU-mods.ps1` in the **mods** folder.
|
**Mods for WAU** allows you to craft a script to do whatever you like via `_WAU-mods.ps1` in the **mods** folder.<br>
|
||||||
This script executes **if the network is active/any version of Winget is installed/WAU is running as SYSTEM**.
|
This script executes **if the network is active/any version of Winget is installed/WAU is running as SYSTEM**.<br>
|
||||||
If **ExitCode** is **1** from `_WAU-mods.ps1` then **Re-run WAU**.
|
If **ExitCode** is **1** from `_WAU-mods.ps1` then **Re-run WAU**.
|
||||||
## Custom scripts (Mods feature for Apps)
|
## Custom scripts (Mods feature for Apps)
|
||||||
From version 1.8.0, the Mods feature allows you to run additional scripts when upgrading or installing an app.
|
From version 1.8.0, the Mods feature allows you to run additional scripts when upgrading or installing an app.
|
||||||
|
@ -206,7 +206,7 @@ This will use the **content** of the text file as a native **winget --override**
|
||||||
In an enterprise environment it's crucial that different groups can have different settings in applications etc. or to implement other mandatory settings, i.e for security/management reasons.<br>
|
In an enterprise environment it's crucial that different groups can have different settings in applications etc. or to implement other mandatory settings, i.e for security/management reasons.<br>
|
||||||
**WAU** doesn't have any setting that can be changed except for when installing (or editing the registry/the task `Winget-AutoUpdate` as **Admin**).<br>
|
**WAU** doesn't have any setting that can be changed except for when installing (or editing the registry/the task `Winget-AutoUpdate` as **Admin**).<br>
|
||||||
With the use of **ADML/ADMX** files you can manage every **WAU** setting from within **GPO**.<br>
|
With the use of **ADML/ADMX** files you can manage every **WAU** setting from within **GPO**.<br>
|
||||||
They will be detected/evaluated during the next run of **WAU** (taking effect before any actions).<br>
|
They will be detected/evaluated on a daily basis.<br>
|
||||||
The **GPO ADMX/ADML** validated with: [Windows 10 - Validate ADMX for Ingestion](https://developer.vmware.com/samples/7115/windows-10---validate-admx-for-ingestion)<br>
|
The **GPO ADMX/ADML** validated with: [Windows 10 - Validate ADMX for Ingestion](https://developer.vmware.com/samples/7115/windows-10---validate-admx-for-ingestion)<br>
|
||||||
Read more in the `README.md` under the directory **Policies**.
|
Read more in the `README.md` under the directory **Policies**.
|
||||||
|
|
||||||
|
|
|
@ -374,6 +374,15 @@ function Install-WingetAutoUpdate {
|
||||||
$task = New-ScheduledTask -Action $taskAction -Principal $taskUserPrincipal -Settings $taskSettings
|
$task = New-ScheduledTask -Action $taskAction -Principal $taskUserPrincipal -Settings $taskSettings
|
||||||
Register-ScheduledTask -TaskName 'Winget-AutoUpdate-Notify' -TaskPath 'WAU' -InputObject $task -Force | Out-Null
|
Register-ScheduledTask -TaskName 'Winget-AutoUpdate-Notify' -TaskPath 'WAU' -InputObject $task -Force | Out-Null
|
||||||
|
|
||||||
|
# Settings for the GPO scheduled task
|
||||||
|
$taskAction = New-ScheduledTaskAction -Execute "powershell.exe" -Argument "-NoProfile -ExecutionPolicy Bypass -File `"$($WingetUpdatePath)\WAU-Policies.ps1`""
|
||||||
|
$tasktrigger = New-ScheduledTaskTrigger -Daily -At 6am
|
||||||
|
$taskUserPrincipal = New-ScheduledTaskPrincipal -UserId S-1-5-18 -RunLevel Highest
|
||||||
|
$taskSettings = New-ScheduledTaskSettingsSet -Compatibility Win8 -StartWhenAvailable -AllowStartIfOnBatteries -DontStopIfGoingOnBatteries -ExecutionTimeLimit 00:05:00
|
||||||
|
# Set up the task, and register it
|
||||||
|
$task = New-ScheduledTask -Action $taskAction -Principal $taskUserPrincipal -Settings $taskSettings -Trigger $taskTrigger
|
||||||
|
Register-ScheduledTask -TaskName 'Winget-AutoUpdate-Policies' -TaskPath 'WAU' -InputObject $task -Force | Out-Null
|
||||||
|
|
||||||
#Set task readable/runnable for all users
|
#Set task readable/runnable for all users
|
||||||
$scheduler = New-Object -ComObject "Schedule.Service"
|
$scheduler = New-Object -ComObject "Schedule.Service"
|
||||||
$scheduler.Connect()
|
$scheduler.Connect()
|
||||||
|
@ -406,6 +415,7 @@ function Install-WingetAutoUpdate {
|
||||||
New-ItemProperty $regPath -Name WAU_MaxLogFiles -Value $MaxLogFiles -PropertyType DWord -Force | Out-Null
|
New-ItemProperty $regPath -Name WAU_MaxLogFiles -Value $MaxLogFiles -PropertyType DWord -Force | Out-Null
|
||||||
New-ItemProperty $regPath -Name WAU_MaxLogSize -Value $MaxLogSize -PropertyType DWord -Force | Out-Null
|
New-ItemProperty $regPath -Name WAU_MaxLogSize -Value $MaxLogSize -PropertyType DWord -Force | Out-Null
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatesAtTime -Value $UpdatesAtTime -Force | Out-Null
|
New-ItemProperty $regPath -Name WAU_UpdatesAtTime -Value $UpdatesAtTime -Force | Out-Null
|
||||||
|
New-ItemProperty $regPath -Name WAU_UpdatesInterval -Value $UpdatesInterval -Force | Out-Null
|
||||||
if ($UpdatesAtLogon) {
|
if ($UpdatesAtLogon) {
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatesAtLogon -Value 1 -PropertyType DWord -Force | Out-Null
|
New-ItemProperty $regPath -Name WAU_UpdatesAtLogon -Value 1 -PropertyType DWord -Force | Out-Null
|
||||||
}
|
}
|
||||||
|
@ -511,6 +521,7 @@ function Uninstall-WingetAutoUpdate {
|
||||||
Get-ScheduledTask -TaskName "Winget-AutoUpdate" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
Get-ScheduledTask -TaskName "Winget-AutoUpdate" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
||||||
Get-ScheduledTask -TaskName "Winget-AutoUpdate-Notify" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
Get-ScheduledTask -TaskName "Winget-AutoUpdate-Notify" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
||||||
Get-ScheduledTask -TaskName "Winget-AutoUpdate-UserContext" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
Get-ScheduledTask -TaskName "Winget-AutoUpdate-UserContext" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
||||||
|
Get-ScheduledTask -TaskName "Winget-AutoUpdate-Policies" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
||||||
& reg delete "HKCR\AppUserModelId\Windows.SystemToast.Winget.Notification" /f | Out-Null
|
& reg delete "HKCR\AppUserModelId\Windows.SystemToast.Winget.Notification" /f | Out-Null
|
||||||
& reg delete "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate" /f | Out-Null
|
& reg delete "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate" /f | Out-Null
|
||||||
|
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
1.17.9-0
|
1.17.9-1
|
|
@ -0,0 +1,101 @@
|
||||||
|
<#
|
||||||
|
.SYNOPSIS
|
||||||
|
Handle GPO/Polices
|
||||||
|
|
||||||
|
.DESCRIPTION
|
||||||
|
Daily update settings from policies
|
||||||
|
#>
|
||||||
|
|
||||||
|
#Import functions
|
||||||
|
. "$PSScriptRoot\functions\Get-WAUConfig.ps1"
|
||||||
|
. "$PSScriptRoot\functions\Add-Shortcut.ps1"
|
||||||
|
|
||||||
|
#Check if GPO Management is enabled
|
||||||
|
$ActivateGPOManagement = Get-ItemPropertyValue "HKLM:\SOFTWARE\Policies\Romanitho\Winget-AutoUpdate" -Name "WAU_ActivateGPOManagement" -ErrorAction SilentlyContinue
|
||||||
|
if ($ActivateGPOManagement -eq 1) {
|
||||||
|
#Add (or update) tag to activate WAU-Policies Management
|
||||||
|
New-ItemProperty "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate" -Name WAU_RunGPOManagement -Value 1 -Force | Out-Null
|
||||||
|
}
|
||||||
|
|
||||||
|
#Get WAU settings
|
||||||
|
$WAUConfig = Get-WAUConfig
|
||||||
|
|
||||||
|
#Check if GPO got applied from Get-WAUConfig (tag)
|
||||||
|
if ($WAUConfig.WAU_RunGPOManagement -eq 1) {
|
||||||
|
|
||||||
|
#Log init
|
||||||
|
$GPOLogFile = "$($WAUConfig.InstallLocation)\logs\LatestAppliedSettings.txt"
|
||||||
|
Set-Content -Path $GPOLogFile -Value "### POLICY CYCLE - $(Get-Date) ###`n"
|
||||||
|
|
||||||
|
#Reset WAU_RunGPOManagement if not GPO managed anymore (This is used to run this job one last time and reset initial settings)
|
||||||
|
if ($($WAUConfig.WAU_ActivateGPOManagement -eq 1)) {
|
||||||
|
Add-Content -Path $GPOLogFile -Value "GPO Management Enabled. Policies updated."
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
New-ItemProperty "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate" -Name WAU_RunGPOManagement -Value 0 -Force | Out-Null
|
||||||
|
$WAUConfig.WAU_RunGPOManagement = 0
|
||||||
|
Add-Content -Path $GPOLogFile -Value "GPO Management Disabled. Policies removed."
|
||||||
|
}
|
||||||
|
|
||||||
|
#Get Winget-AutoUpdate scheduled task
|
||||||
|
$WAUTask = Get-ScheduledTask -TaskName 'Winget-AutoUpdate' -ErrorAction SilentlyContinue
|
||||||
|
|
||||||
|
#Update 'Winget-AutoUpdate' scheduled task settings
|
||||||
|
$taskTriggers = @()
|
||||||
|
if ($WAUConfig.WAU_UpdatesAtLogon -eq 1) {
|
||||||
|
$tasktriggers += New-ScheduledTaskTrigger -AtLogOn
|
||||||
|
}
|
||||||
|
if ($WAUConfig.WAU_UpdatesInterval -eq "Daily") {
|
||||||
|
$tasktriggers += New-ScheduledTaskTrigger -Daily -At $WAUConfig.WAU_UpdatesAtTime
|
||||||
|
}
|
||||||
|
elseif ($WAUConfig.WAU_UpdatesInterval -eq "BiDaily") {
|
||||||
|
$tasktriggers += New-ScheduledTaskTrigger -Daily -At $WAUConfig.WAU_UpdatesAtTime -DaysInterval 2
|
||||||
|
}
|
||||||
|
elseif ($WAUConfig.WAU_UpdatesInterval -eq "Weekly") {
|
||||||
|
$tasktriggers += New-ScheduledTaskTrigger -Weekly -At $WAUConfig.WAU_UpdatesAtTime -DaysOfWeek 2
|
||||||
|
}
|
||||||
|
elseif ($WAUConfig.WAU_UpdatesInterval -eq "BiWeekly") {
|
||||||
|
$tasktriggers += New-ScheduledTaskTrigger -Weekly -At $WAUConfig.WAU_UpdatesAtTime -DaysOfWeek 2 -WeeksInterval 2
|
||||||
|
}
|
||||||
|
elseif ($WAUConfig.WAU_UpdatesInterval -eq "Monthly") {
|
||||||
|
$tasktriggers += New-ScheduledTaskTrigger -Weekly -At $WAUConfig.WAU_UpdatesAtTime -DaysOfWeek 2 -WeeksInterval 4
|
||||||
|
}
|
||||||
|
#If trigger(s) set
|
||||||
|
if ($taskTriggers) {
|
||||||
|
#Edit scheduled task
|
||||||
|
Set-ScheduledTask -TaskPath $WAUTask.TaskPath -TaskName $WAUTask.TaskName -Trigger $taskTriggers | Out-Null
|
||||||
|
}
|
||||||
|
#If not, remove trigger(s)
|
||||||
|
else {
|
||||||
|
#Remove by setting past due date
|
||||||
|
$tasktriggers = New-ScheduledTaskTrigger -Once -At "01/01/1970"
|
||||||
|
Set-ScheduledTask -TaskPath $WAUTask.TaskPath -TaskName $WAUTask.TaskName -Trigger $taskTriggers | Out-Null
|
||||||
|
}
|
||||||
|
|
||||||
|
#Update Desktop shortcut
|
||||||
|
$DesktopShortcut = "${env:Public}\Desktop\WAU - Check for updated Apps.lnk"
|
||||||
|
if (($WAUConfig.WAU_DesktopShortcut -eq 1) -and !(Test-Path $DesktopShortcut)) {
|
||||||
|
Add-Shortcut "wscript.exe" $DesktopShortcut "`"$($WAUConfig.InstallLocation)\Invisible.vbs`" `"powershell.exe -NoProfile -ExecutionPolicy Bypass -File `"`"`"$($WAUConfig.InstallLocation)\user-run.ps1`"`"" "${env:SystemRoot}\System32\shell32.dll,-16739" "Manual start of Winget-AutoUpdate (WAU)..."
|
||||||
|
}
|
||||||
|
elseif ($WAUConfig.WAU_DesktopShortcut -ne 1) {
|
||||||
|
Remove-Item -Path $DesktopShortcut -Force -ErrorAction SilentlyContinue | Out-Null
|
||||||
|
}
|
||||||
|
|
||||||
|
#Update Start Menu shortcuts
|
||||||
|
$StartMenuShortcut = "${env:ProgramData}\Microsoft\Windows\Start Menu\Programs\Winget-AutoUpdate (WAU)"
|
||||||
|
if (($WAUConfig.WAU_StartMenuShortcut -eq 1) -and !(Test-Path $StartMenuShortcut)) {
|
||||||
|
New-Item -ItemType Directory -Force -Path $StartMenuShortcut | Out-Null
|
||||||
|
Add-Shortcut "wscript.exe" "$StartMenuShortcut\WAU - Check for updated Apps.lnk" "`"$($WAUConfig.InstallLocation)\Invisible.vbs`" `"powershell.exe -NoProfile -ExecutionPolicy Bypass -File `"`"`"$($WAUConfig.InstallLocation)\user-run.ps1`"`"" "${env:SystemRoot}\System32\shell32.dll,-16739" "Manual start of Winget-AutoUpdate (WAU)..."
|
||||||
|
Add-Shortcut "wscript.exe" "$StartMenuShortcut\WAU - Open logs.lnk" "`"$($WAUConfig.InstallLocation)\Invisible.vbs`" `"powershell.exe -NoProfile -ExecutionPolicy Bypass -File `"`"`"$($WAUConfig.InstallLocation)\user-run.ps1`" -Logs`"" "${env:SystemRoot}\System32\shell32.dll,-16763" "Open existing WAU logs..."
|
||||||
|
Add-Shortcut "wscript.exe" "$StartMenuShortcut\WAU - Web Help.lnk" "`"$($WAUConfig.InstallLocation)\Invisible.vbs`" `"powershell.exe -NoProfile -ExecutionPolicy Bypass -File `"`"`"$($WAUConfig.InstallLocation)\user-run.ps1`" -Help`"" "${env:SystemRoot}\System32\shell32.dll,-24" "Help for WAU..."
|
||||||
|
}
|
||||||
|
elseif ($WAUConfig.WAU_StartMenuShortcut -ne 1) {
|
||||||
|
Remove-Item -Path $StartMenuShortcut -Recurse -Force -ErrorAction SilentlyContinue | Out-Null
|
||||||
|
}
|
||||||
|
|
||||||
|
#Log latest applied config
|
||||||
|
Add-Content -Path $GPOLogFile -Value "`nLatest applied settings:"
|
||||||
|
$WAUConfig.PSObject.Properties | Where-Object { $_.Name -like "WAU_*" } | Select-Object Name, Value | Out-File -Encoding default -FilePath $GPOLogFile -Append
|
||||||
|
}
|
||||||
|
|
||||||
|
Exit 0
|
|
@ -50,6 +50,7 @@ try {
|
||||||
Get-ScheduledTask -TaskName "Winget-AutoUpdate" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
Get-ScheduledTask -TaskName "Winget-AutoUpdate" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
||||||
Get-ScheduledTask -TaskName "Winget-AutoUpdate-Notify" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
Get-ScheduledTask -TaskName "Winget-AutoUpdate-Notify" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
||||||
Get-ScheduledTask -TaskName "Winget-AutoUpdate-UserContext" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
Get-ScheduledTask -TaskName "Winget-AutoUpdate-UserContext" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
||||||
|
Get-ScheduledTask -TaskName "Winget-AutoUpdate-Policies" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
||||||
& reg delete "HKCR\AppUserModelId\Windows.SystemToast.Winget.Notification" /f | Out-Null
|
& reg delete "HKCR\AppUserModelId\Windows.SystemToast.Winget.Notification" /f | Out-Null
|
||||||
& reg delete "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate" /f | Out-Null
|
& reg delete "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate" /f | Out-Null
|
||||||
if (Test-Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate") {
|
if (Test-Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate") {
|
||||||
|
|
|
@ -14,25 +14,16 @@ $Script:IsSystem = [System.Security.Principal.WindowsIdentity]::GetCurrent().IsS
|
||||||
#Run log initialisation function
|
#Run log initialisation function
|
||||||
Start-Init
|
Start-Init
|
||||||
|
|
||||||
#Get WAU Configurations
|
#Get settings and Domain/Local Policies (GPO) if activated.
|
||||||
$Script:WAUConfig = Get-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate"
|
$WAUConfig = Get-WAUConfig
|
||||||
|
if ($($WAUPolicies.WAU_ActivateGPOManagement -eq 1)) {
|
||||||
|
Write-ToLog "WAU Policies management Enabled."
|
||||||
|
}
|
||||||
|
|
||||||
#Log running context and more...
|
#Log running context and more...
|
||||||
if ($IsSystem) {
|
if ($IsSystem) {
|
||||||
Write-ToLog "Running in System context"
|
Write-ToLog "Running in System context"
|
||||||
|
|
||||||
#Get and set Domain/Local Policies (GPO)
|
|
||||||
$ActivateGPOManagement, $ChangedSettings = Get-Policies
|
|
||||||
if ($ActivateGPOManagement) {
|
|
||||||
Write-ToLog "Activated WAU GPO Management detected, comparing..."
|
|
||||||
if ($null -ne $ChangedSettings -and $ChangedSettings -ne 0) {
|
|
||||||
Write-ToLog "Changed settings detected and applied" "Yellow"
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
Write-ToLog "No Changed settings detected" "Yellow"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
# Maximum number of log files to keep. Default is 3. Setting MaxLogFiles to 0 will keep all log files.
|
# Maximum number of log files to keep. Default is 3. Setting MaxLogFiles to 0 will keep all log files.
|
||||||
$MaxLogFiles = $WAUConfig.WAU_MaxLogFiles
|
$MaxLogFiles = $WAUConfig.WAU_MaxLogFiles
|
||||||
if ($null -eq $MaxLogFiles) {
|
if ($null -eq $MaxLogFiles) {
|
||||||
|
@ -315,7 +306,7 @@ if (Test-Network) {
|
||||||
$UserContextTask = Get-ScheduledTask -TaskName 'Winget-AutoUpdate-UserContext' -ErrorAction SilentlyContinue
|
$UserContextTask = Get-ScheduledTask -TaskName 'Winget-AutoUpdate-UserContext' -ErrorAction SilentlyContinue
|
||||||
if (!$UserContextTask) {
|
if (!$UserContextTask) {
|
||||||
#Create the scheduled task in User context
|
#Create the scheduled task in User context
|
||||||
$taskAction = New-ScheduledTaskAction -Execute "wscript.exe" -Argument "`"$($WingetUpdatePath)\Invisible.vbs`" `"powershell.exe -NoProfile -ExecutionPolicy Bypass -File `"`"`"$($WingetUpdatePath)\winget-upgrade.ps1`"`""
|
$taskAction = New-ScheduledTaskAction -Execute "wscript.exe" -Argument "`"$($WAUConfig.InstallLocation)\Invisible.vbs`" `"powershell.exe -NoProfile -ExecutionPolicy Bypass -File `"`"`"$($WAUConfig.InstallLocation)\winget-upgrade.ps1`"`""
|
||||||
$taskUserPrincipal = New-ScheduledTaskPrincipal -GroupId S-1-5-11
|
$taskUserPrincipal = New-ScheduledTaskPrincipal -GroupId S-1-5-11
|
||||||
$taskSettings = New-ScheduledTaskSettingsSet -Compatibility Win8 -AllowStartIfOnBatteries -DontStopIfGoingOnBatteries -ExecutionTimeLimit 03:00:00
|
$taskSettings = New-ScheduledTaskSettingsSet -Compatibility Win8 -AllowStartIfOnBatteries -DontStopIfGoingOnBatteries -ExecutionTimeLimit 03:00:00
|
||||||
$task = New-ScheduledTask -Action $taskAction -Principal $taskUserPrincipal -Settings $taskSettings
|
$task = New-ScheduledTask -Action $taskAction -Principal $taskUserPrincipal -Settings $taskSettings
|
||||||
|
|
|
@ -1,364 +0,0 @@
|
||||||
#Function to get the Domain/Local Policies (GPO)
|
|
||||||
|
|
||||||
Function Get-Policies {
|
|
||||||
#Get WAU Policies and set the Configurations Registry Accordingly
|
|
||||||
$WAUPolicies = Get-ItemProperty -Path "HKLM:\SOFTWARE\Policies\Romanitho\Winget-AutoUpdate" -ErrorAction SilentlyContinue
|
|
||||||
if ($WAUPolicies) {
|
|
||||||
if ($($WAUPolicies.WAU_ActivateGPOManagement -eq 1)) {
|
|
||||||
$ChangedSettings = 0
|
|
||||||
$regPath = "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate"
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_BypassListForUsers) -and ($($WAUPolicies.WAU_BypassListForUsers) -ne $($WAUConfig.WAU_BypassListForUsers))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_BypassListForUsers -Value $($WAUPolicies.WAU_BypassListForUsers) -PropertyType DWord -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_BypassListForUsers) -and ($($WAUConfig.WAU_BypassListForUsers) -or $($WAUConfig.WAU_BypassListForUsers) -eq 0)) {
|
|
||||||
Remove-ItemProperty $regPath -Name WAU_BypassListForUsers -Force -ErrorAction SilentlyContinue | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_DisableAutoUpdate) -and ($($WAUPolicies.WAU_DisableAutoUpdate) -ne $($WAUConfig.WAU_DisableAutoUpdate))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_DisableAutoUpdate -Value $($WAUPolicies.WAU_DisableAutoUpdate) -PropertyType DWord -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_DisableAutoUpdate) -and ($($WAUConfig.WAU_DisableAutoUpdate) -or $($WAUConfig.WAU_DisableAutoUpdate) -eq 0)) {
|
|
||||||
Remove-ItemProperty $regPath -Name WAU_DisableAutoUpdate -Force -ErrorAction SilentlyContinue | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_DoNotRunOnMetered) -and ($($WAUPolicies.WAU_DoNotRunOnMetered) -ne $($WAUConfig.WAU_DoNotRunOnMetered))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_DoNotRunOnMetered -Value $($WAUPolicies.WAU_DoNotRunOnMetered) -PropertyType DWord -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_DoNotRunOnMetered) -and !$($WAUConfig.WAU_DoNotRunOnMetered)) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_DoNotRunOnMetered -Value 1 -PropertyType DWord -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_UpdatePrerelease) -and ($($WAUPolicies.WAU_UpdatePrerelease) -ne $($WAUConfig.WAU_UpdatePrerelease))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatePrerelease -Value $($WAUPolicies.WAU_UpdatePrerelease) -PropertyType DWord -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_UpdatePrerelease) -and $($WAUConfig.WAU_UpdatePrerelease)) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatePrerelease -Value 0 -PropertyType DWord -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_UseWhiteList) -and ($($WAUPolicies.WAU_UseWhiteList) -ne $($WAUConfig.WAU_UseWhiteList))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UseWhiteList -Value $($WAUPolicies.WAU_UseWhiteList) -PropertyType DWord -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_UseWhiteList) -and ($($WAUConfig.WAU_UseWhiteList) -or $($WAUConfig.WAU_UseWhiteList) -eq 0)) {
|
|
||||||
Remove-ItemProperty $regPath -Name WAU_UseWhiteList -Force -ErrorAction SilentlyContinue | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_ListPath) -and ($($WAUPolicies.WAU_ListPath) -ne $($WAUConfig.WAU_ListPath))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_ListPath -Value $($WAUPolicies.WAU_ListPath.TrimEnd(" ", "\", "/")) -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_ListPath) -and $($WAUConfig.WAU_ListPath)) {
|
|
||||||
Remove-ItemProperty $regPath -Name WAU_ListPath -Force -ErrorAction SilentlyContinue | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_ModsPath) -and ($($WAUPolicies.WAU_ModsPath) -ne $($WAUConfig.WAU_ModsPath))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_ModsPath -Value $($WAUPolicies.WAU_ModsPath.TrimEnd(" ", "\", "/")) -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_ModsPath) -and $($WAUConfig.WAU_ModsPath)) {
|
|
||||||
Remove-ItemProperty $regPath -Name WAU_ModsPath -Force -ErrorAction SilentlyContinue | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_AzureBlobSASURL) -and ($($WAUPolicies.WAU_AzureBlobSASURL) -ne $($WAUConfig.WAU_AzureBlobSASURL))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_AzureBlobSASURL -Value $($WAUPolicies.WAU_AzureBlobSASURL.TrimEnd(" ", "\", "/")) -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_AzureBlobSASURL) -and $($WAUConfig.WAU_AzureBlobSASURL)) {
|
|
||||||
Remove-ItemProperty $regPath -Name WAU_AzureBlobSASURL -Force -ErrorAction SilentlyContinue | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_NotificationLevel) -and ($($WAUPolicies.WAU_NotificationLevel) -ne $($WAUConfig.WAU_NotificationLevel))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_NotificationLevel -Value $($WAUPolicies.WAU_NotificationLevel) -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_NotificationLevel) -and $($WAUConfig.WAU_NotificationLevel) -ne "Full") {
|
|
||||||
New-ItemProperty $regPath -Name WAU_NotificationLevel -Value "Full" -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_UpdatesAtTime) -and ($($WAUPolicies.WAU_UpdatesAtTime) -ne $($WAUConfig.WAU_UpdatesAtTime))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatesAtTime -Value $($WAUPolicies.WAU_UpdatesAtTime) -Force | Out-Null
|
|
||||||
$Script:WAUConfig = Get-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate"
|
|
||||||
$service = New-Object -ComObject Schedule.Service
|
|
||||||
$service.Connect($env:COMPUTERNAME)
|
|
||||||
$folder = $service.GetFolder('\')
|
|
||||||
$task = $folder.GetTask("Winget-AutoUpdate")
|
|
||||||
$definition = $task.Definition
|
|
||||||
for ($triggerId = 1; $triggerId -le $definition.Triggers.Count; $triggerId++) {
|
|
||||||
if (($definition.Triggers.Item($triggerId).Type -eq "2") -or ($definition.Triggers.Item($triggerId).Type -eq "3")) {
|
|
||||||
$PreStartBoundary = ($definition.Triggers.Item($triggerId).StartBoundary).Substring(0, 11)
|
|
||||||
$PostStartBoundary = ($definition.Triggers.Item($triggerId).StartBoundary).Substring(19, 6)
|
|
||||||
$Boundary = $PreStartBoundary + $($WAUPolicies.WAU_UpdatesAtTime) + $PostStartBoundary
|
|
||||||
$definition.Triggers.Item($triggerId).StartBoundary = $Boundary
|
|
||||||
break
|
|
||||||
$triggerId -= 1
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$folder.RegisterTaskDefinition($task.Name, $definition, 4, $null, $null, $null) | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_UpdatesAtTime) -and $($WAUConfig.WAU_UpdatesAtTime) -ne "06:00:00") {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatesAtTime -Value "06:00:00" -Force | Out-Null
|
|
||||||
$Script:WAUConfig = Get-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate"
|
|
||||||
$service = New-Object -ComObject Schedule.Service
|
|
||||||
$service.Connect($env:COMPUTERNAME)
|
|
||||||
$folder = $service.GetFolder('\')
|
|
||||||
$task = $folder.GetTask("Winget-AutoUpdate")
|
|
||||||
$definition = $task.Definition
|
|
||||||
for ($triggerId = 1; $triggerId -le $definition.Triggers.Count; $triggerId++) {
|
|
||||||
if (($definition.Triggers.Item($triggerId).Type -eq "2") -or ($definition.Triggers.Item($triggerId).Type -eq "3")) {
|
|
||||||
$PreStartBoundary = ($definition.Triggers.Item($triggerId).StartBoundary).Substring(0, 11)
|
|
||||||
$PostStartBoundary = ($definition.Triggers.Item($triggerId).StartBoundary).Substring(19, 6)
|
|
||||||
$Boundary = $PreStartBoundary + "06:00:00" + $PostStartBoundary
|
|
||||||
$definition.Triggers.Item($triggerId).StartBoundary = $Boundary
|
|
||||||
break
|
|
||||||
$triggerId -= 1
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$folder.RegisterTaskDefinition($task.Name, $definition, 4, $null, $null, $null) | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_UpdatesInterval) -and ($($WAUPolicies.WAU_UpdatesInterval) -ne $($WAUConfig.WAU_UpdatesInterval))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatesInterval -Value $($WAUPolicies.WAU_UpdatesInterval) -Force | Out-Null
|
|
||||||
$service = New-Object -ComObject Schedule.Service
|
|
||||||
$service.Connect($env:COMPUTERNAME)
|
|
||||||
$folder = $service.GetFolder('\')
|
|
||||||
$task = $folder.GetTask("Winget-AutoUpdate")
|
|
||||||
$definition = $task.Definition
|
|
||||||
for ($triggerId = 1; $triggerId -le $definition.Triggers.Count; $triggerId++) {
|
|
||||||
if (($definition.Triggers.Item($triggerId).Type -eq "2") -or ($definition.Triggers.Item($triggerId).Type -eq "3")) {
|
|
||||||
$UpdatesAtTime = ($definition.Triggers.Item($triggerId).StartBoundary).Substring(11, 8)
|
|
||||||
$definition.Triggers.Remove($triggerId)
|
|
||||||
$triggerId -= 1
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$folder.RegisterTaskDefinition($task.Name, $definition, 4, $null, $null, $null) | Out-Null
|
|
||||||
|
|
||||||
if (!$($WAUConfig.WAU_UpdatesAtTime)) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatesAtTime -Value $UpdatesAtTime -Force | Out-Null
|
|
||||||
$Script:WAUConfig = Get-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate"
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($($WAUPolicies.WAU_UpdatesInterval) -ne "Never") {
|
|
||||||
#Count Triggers (correctly)
|
|
||||||
$service = New-Object -ComObject Schedule.Service
|
|
||||||
$service.Connect($env:COMPUTERNAME)
|
|
||||||
$folder = $service.GetFolder('\')
|
|
||||||
$task = $folder.GetTask("Winget-AutoUpdate")
|
|
||||||
$definition = $task.Definition
|
|
||||||
$definition.Triggers.Count | Out-Null
|
|
||||||
switch ($($WAUPolicies.WAU_UpdatesInterval)) {
|
|
||||||
"Daily" { $tasktrigger = New-ScheduledTaskTrigger -Daily -At $($WAUConfig.WAU_UpdatesAtTime); break }
|
|
||||||
"BiDaily" { $tasktrigger = New-ScheduledTaskTrigger -Daily -At $($WAUConfig.WAU_UpdatesAtTime) -DaysInterval 2; break }
|
|
||||||
"Weekly" { $tasktrigger = New-ScheduledTaskTrigger -Weekly -At $($WAUConfig.WAU_UpdatesAtTime) -DaysOfWeek 2; break }
|
|
||||||
"BiWeekly" { $tasktrigger = New-ScheduledTaskTrigger -Weekly -At $($WAUConfig.WAU_UpdatesAtTime) -DaysOfWeek 2 -WeeksInterval 2; break }
|
|
||||||
"Monthly" { $tasktrigger = New-ScheduledTaskTrigger -Weekly -At $($WAUConfig.WAU_UpdatesAtTime) -DaysOfWeek 2 -WeeksInterval 4; break }
|
|
||||||
}
|
|
||||||
if ($definition.Triggers.Count -gt 0) {
|
|
||||||
$triggers = @()
|
|
||||||
$triggers += (Get-ScheduledTask "Winget-AutoUpdate").Triggers
|
|
||||||
$triggers += $tasktrigger
|
|
||||||
Set-ScheduledTask -TaskName "Winget-AutoUpdate" -Trigger $triggers
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
Set-ScheduledTask -TaskName "Winget-AutoUpdate" -Trigger $tasktrigger
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_UpdatesInterval) -and $($WAUConfig.WAU_UpdatesInterval) -ne "Daily") {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatesInterval -Value "Daily" -Force | Out-Null
|
|
||||||
$service = New-Object -ComObject Schedule.Service
|
|
||||||
$service.Connect($env:COMPUTERNAME)
|
|
||||||
$folder = $service.GetFolder('\')
|
|
||||||
$task = $folder.GetTask("Winget-AutoUpdate")
|
|
||||||
$definition = $task.Definition
|
|
||||||
for ($triggerId = 1; $triggerId -le $definition.Triggers.Count; $triggerId++) {
|
|
||||||
if (($definition.Triggers.Item($triggerId).Type -eq "2") -or ($definition.Triggers.Item($triggerId).Type -eq "3")) {
|
|
||||||
$UpdatesAtTime = ($definition.Triggers.Item($triggerId).StartBoundary).Substring(11, 8)
|
|
||||||
$definition.Triggers.Remove($triggerId)
|
|
||||||
$triggerId -= 1
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$folder.RegisterTaskDefinition($task.Name, $definition, 4, $null, $null, $null) | Out-Null
|
|
||||||
|
|
||||||
if (!$($WAUConfig.WAU_UpdatesAtTime)) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatesAtTime -Value $UpdatesAtTime -Force | Out-Null
|
|
||||||
$Script:WAUConfig = Get-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate"
|
|
||||||
}
|
|
||||||
|
|
||||||
$tasktrigger = New-ScheduledTaskTrigger -Daily -At $($WAUConfig.WAU_UpdatesAtTime)
|
|
||||||
|
|
||||||
#Count Triggers (correctly)
|
|
||||||
$service = New-Object -ComObject Schedule.Service
|
|
||||||
$service.Connect($env:COMPUTERNAME)
|
|
||||||
$folder = $service.GetFolder('\')
|
|
||||||
$task = $folder.GetTask("Winget-AutoUpdate")
|
|
||||||
$definition = $task.Definition
|
|
||||||
$definition.Triggers.Count | Out-Null
|
|
||||||
if ($definition.Triggers.Count -gt 0) {
|
|
||||||
$triggers = @()
|
|
||||||
$triggers += (Get-ScheduledTask "Winget-AutoUpdate").Triggers
|
|
||||||
$triggers += $tasktrigger
|
|
||||||
Set-ScheduledTask -TaskName "Winget-AutoUpdate" -Trigger $triggers
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
Set-ScheduledTask -TaskName "Winget-AutoUpdate" -Trigger $tasktrigger
|
|
||||||
}
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_UpdatesAtLogon) -and ($($WAUPolicies.WAU_UpdatesAtLogon) -ne $($WAUConfig.WAU_UpdatesAtLogon))) {
|
|
||||||
if ($WAUPolicies.WAU_UpdatesAtLogon -eq 1) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatesAtLogon -Value $($WAUPolicies.WAU_UpdatesAtLogon) -PropertyType DWord -Force | Out-Null
|
|
||||||
$triggers = @()
|
|
||||||
$triggers += (Get-ScheduledTask "Winget-AutoUpdate").Triggers
|
|
||||||
#Count Triggers (correctly)
|
|
||||||
$service = New-Object -ComObject Schedule.Service
|
|
||||||
$service.Connect($env:COMPUTERNAME)
|
|
||||||
$folder = $service.GetFolder('\')
|
|
||||||
$task = $folder.GetTask("Winget-AutoUpdate")
|
|
||||||
$definition = $task.Definition
|
|
||||||
$triggerLogon = $false
|
|
||||||
foreach ($trigger in $definition.Triggers) {
|
|
||||||
if ($trigger.Type -eq "9") {
|
|
||||||
$triggerLogon = $true
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!$triggerLogon) {
|
|
||||||
$triggers += New-ScheduledTaskTrigger -AtLogon
|
|
||||||
Set-ScheduledTask -TaskName "Winget-AutoUpdate" -Trigger $triggers
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UpdatesAtLogon -Value $($WAUPolicies.WAU_UpdatesAtLogon) -PropertyType DWord -Force | Out-Null
|
|
||||||
$service = New-Object -ComObject Schedule.Service
|
|
||||||
$service.Connect($env:COMPUTERNAME)
|
|
||||||
$folder = $service.GetFolder('\')
|
|
||||||
$task = $folder.GetTask("Winget-AutoUpdate")
|
|
||||||
$definition = $task.Definition
|
|
||||||
$definition.Triggers.Count | Out-Null
|
|
||||||
for ($triggerId = 1; $triggerId -le $definition.Triggers.Count; $triggerId++) {
|
|
||||||
if ($definition.Triggers.Item($triggerId).Type -eq "9") {
|
|
||||||
$definition.Triggers.Remove($triggerId)
|
|
||||||
$triggerId -= 1
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$folder.RegisterTaskDefinition($task.Name, $definition, 4, $null, $null, $null) | Out-Null
|
|
||||||
}
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_UpdatesAtLogon) -and ($($WAUConfig.WAU_UpdatesAtLogon) -or $($WAUConfig.WAU_UpdatesAtLogon) -eq 0)) {
|
|
||||||
Remove-ItemProperty $regPath -Name WAU_UpdatesAtLogon -Force -ErrorAction SilentlyContinue | Out-Null
|
|
||||||
$service = New-Object -ComObject Schedule.Service
|
|
||||||
$service.Connect($env:COMPUTERNAME)
|
|
||||||
$folder = $service.GetFolder('\')
|
|
||||||
$task = $folder.GetTask("Winget-AutoUpdate")
|
|
||||||
$definition = $task.Definition
|
|
||||||
for ($triggerId = 1; $triggerId -le $definition.Triggers.Count; $triggerId++) {
|
|
||||||
if ($definition.Triggers.Item($triggerId).Type -eq "9") {
|
|
||||||
$definition.Triggers.Remove($triggerId)
|
|
||||||
$triggerId -= 1
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$folder.RegisterTaskDefinition($task.Name, $definition, 4, $null, $null, $null) | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_UserContext) -and ($($WAUPolicies.WAU_UserContext) -ne $($WAUConfig.WAU_UserContext))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_UserContext -Value $($WAUPolicies.WAU_UserContext) -PropertyType DWord -Force | Out-Null
|
|
||||||
if ($WAUPolicies.WAU_UserContext -eq 1) {
|
|
||||||
# Settings for the scheduled task in User context
|
|
||||||
$taskAction = New-ScheduledTaskAction -Execute "wscript.exe" -Argument "`"$($WAUConfig.InstallLocation)\Invisible.vbs`" `"powershell.exe -NoProfile -ExecutionPolicy Bypass -File `"`"`"$($WAUConfig.InstallLocation)\winget-upgrade.ps1`"`""
|
|
||||||
$taskUserPrincipal = New-ScheduledTaskPrincipal -GroupId S-1-5-11
|
|
||||||
$taskSettings = New-ScheduledTaskSettingsSet -Compatibility Win8 -AllowStartIfOnBatteries -DontStopIfGoingOnBatteries -ExecutionTimeLimit 03:00:00
|
|
||||||
|
|
||||||
# Set up the task for user apps
|
|
||||||
$task = New-ScheduledTask -Action $taskAction -Principal $taskUserPrincipal -Settings $taskSettings
|
|
||||||
Register-ScheduledTask -TaskName 'Winget-AutoUpdate-UserContext' -InputObject $task -Force
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
Get-ScheduledTask -TaskName "Winget-AutoUpdate-UserContext" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
|
||||||
}
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_UserContext) -and ($($WAUConfig.WAU_UserContext) -or $($WAUConfig.WAU_UserContext) -eq 0)) {
|
|
||||||
Remove-ItemProperty $regPath -Name WAU_UserContext -Force -ErrorAction SilentlyContinue | Out-Null
|
|
||||||
Get-ScheduledTask -TaskName "Winget-AutoUpdate-UserContext" -ErrorAction SilentlyContinue | Unregister-ScheduledTask -Confirm:$False
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_DesktopShortcut) -and ($($WAUPolicies.WAU_DesktopShortcut) -ne $($WAUConfig.WAU_DesktopShortcut))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_DesktopShortcut -Value $($WAUPolicies.WAU_DesktopShortcut) -PropertyType DWord -Force | Out-Null
|
|
||||||
if ($WAUPolicies.WAU_DesktopShortcut -eq 1) {
|
|
||||||
Add-Shortcut "wscript.exe" "${env:Public}\Desktop\WAU - Check for updated Apps.lnk" "`"$($WAUConfig.InstallLocation)\Invisible.vbs`" `"powershell.exe -NoProfile -ExecutionPolicy Bypass -File `"`"`"$($WAUConfig.InstallLocation)\user-run.ps1`"`"" "${env:SystemRoot}\System32\shell32.dll,-16739" "Manual start of Winget-AutoUpdate (WAU)..."
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
Remove-Item -Path "${env:Public}\Desktop\WAU - Check for updated Apps.lnk" -Force | Out-Null
|
|
||||||
}
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_DesktopShortcut) -and ($($WAUConfig.WAU_DesktopShortcut) -or $($WAUConfig.WAU_DesktopShortcut) -eq 0)) {
|
|
||||||
Remove-ItemProperty $regPath -Name WAU_DesktopShortcut -Force -ErrorAction SilentlyContinue | Out-Null
|
|
||||||
Remove-Item -Path "${env:Public}\Desktop\WAU - Check for updated Apps.lnk" -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_StartMenuShortcut) -and ($($WAUPolicies.WAU_StartMenuShortcut) -ne $($WAUConfig.WAU_StartMenuShortcut))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_StartMenuShortcut -Value $($WAUPolicies.WAU_StartMenuShortcut) -PropertyType DWord -Force | Out-Null
|
|
||||||
if ($WAUPolicies.WAU_StartMenuShortcut -eq 1) {
|
|
||||||
if (!(Test-Path "${env:ProgramData}\Microsoft\Windows\Start Menu\Programs\Winget-AutoUpdate (WAU)")) {
|
|
||||||
New-Item -ItemType Directory -Force -Path "${env:ProgramData}\Microsoft\Windows\Start Menu\Programs\Winget-AutoUpdate (WAU)" | Out-Null
|
|
||||||
}
|
|
||||||
Add-Shortcut "wscript.exe" "${env:ProgramData}\Microsoft\Windows\Start Menu\Programs\Winget-AutoUpdate (WAU)\WAU - Check for updated Apps.lnk" "`"$($WAUConfig.InstallLocation)\Invisible.vbs`" `"powershell.exe -NoProfile -ExecutionPolicy Bypass -File `"`"`"$($WAUConfig.InstallLocation)\user-run.ps1`"`"" "${env:SystemRoot}\System32\shell32.dll,-16739" "Manual start of Winget-AutoUpdate (WAU)..."
|
|
||||||
Add-Shortcut "wscript.exe" "${env:ProgramData}\Microsoft\Windows\Start Menu\Programs\Winget-AutoUpdate (WAU)\WAU - Open logs.lnk" "`"$($WAUConfig.InstallLocation)\Invisible.vbs`" `"powershell.exe -NoProfile -ExecutionPolicy Bypass -File `"`"`"$($WAUConfig.InstallLocation)\user-run.ps1`" -Logs`"" "${env:SystemRoot}\System32\shell32.dll,-16763" "Open existing WAU logs..."
|
|
||||||
Add-Shortcut "wscript.exe" "${env:ProgramData}\Microsoft\Windows\Start Menu\Programs\Winget-AutoUpdate (WAU)\WAU - Web Help.lnk" "`"$($WAUConfig.InstallLocation)\Invisible.vbs`" `"powershell.exe -NoProfile -ExecutionPolicy Bypass -File `"`"`"$($WAUConfig.InstallLocation)\user-run.ps1`" -Help`"" "${env:SystemRoot}\System32\shell32.dll,-24" "Help for WAU..."
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
Remove-Item -Path "${env:ProgramData}\Microsoft\Windows\Start Menu\Programs\Winget-AutoUpdate (WAU)" -Recurse -Force | Out-Null
|
|
||||||
}
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_StartMenuShortcut) -and ($($WAUConfig.WAU_StartMenuShortcut) -or $($WAUConfig.WAU_StartMenuShortcut) -eq 0)) {
|
|
||||||
Remove-ItemProperty $regPath -Name WAU_StartMenuShortcut -Force -ErrorAction SilentlyContinue | Out-Null
|
|
||||||
Remove-Item -Path "${env:ProgramData}\Microsoft\Windows\Start Menu\Programs\Winget-AutoUpdate (WAU)" -Recurse -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_MaxLogFiles) -and ($($WAUPolicies.WAU_MaxLogFiles) -ne $($WAUConfig.WAU_MaxLogFiles))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_MaxLogFiles -Value $($WAUPolicies.WAU_MaxLogFiles.TrimEnd(" ", "\", "/")) -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_MaxLogFiles) -and $($WAUConfig.WAU_MaxLogFiles) -ne 3) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_MaxLogFiles -Value 3 -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($null -ne $($WAUPolicies.WAU_MaxLogSize) -and ($($WAUPolicies.WAU_MaxLogSize) -ne $($WAUConfig.WAU_MaxLogSize))) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_MaxLogSize -Value $($WAUPolicies.WAU_MaxLogSize.TrimEnd(" ", "\", "/")) -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
elseif ($null -eq $($WAUPolicies.WAU_MaxLogSize) -and $($WAUConfig.WAU_MaxLogSize) -ne 1048576) {
|
|
||||||
New-ItemProperty $regPath -Name WAU_MaxLogSize -Value 1048576 -Force | Out-Null
|
|
||||||
$ChangedSettings++
|
|
||||||
}
|
|
||||||
|
|
||||||
#Get WAU Configurations after Policies change
|
|
||||||
$Script:WAUConfig = Get-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Return $($WAUPolicies.WAU_ActivateGPOManagement), $ChangedSettings
|
|
||||||
}
|
|
|
@ -0,0 +1,26 @@
|
||||||
|
#Function to get the WAU settings, including Domain/Local Policies (GPO)
|
||||||
|
|
||||||
|
Function Get-WAUConfig {
|
||||||
|
|
||||||
|
#Get WAU Configurations from install config
|
||||||
|
$WAUConfig = Get-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Winget-AutoUpdate" -ErrorAction SilentlyContinue
|
||||||
|
|
||||||
|
#Check if GPO Management is enabled
|
||||||
|
$ActivateGPOManagement = Get-ItemPropertyValue "HKLM:\SOFTWARE\Policies\Romanitho\Winget-AutoUpdate" -Name "WAU_ActivateGPOManagement" -ErrorAction SilentlyContinue
|
||||||
|
|
||||||
|
#If GPO Management is enabled, replace settings
|
||||||
|
if ($ActivateGPOManagement -eq 1) {
|
||||||
|
|
||||||
|
#Get all WAU Policies
|
||||||
|
$WAUPolicies = Get-ItemProperty -Path "HKLM:\SOFTWARE\Policies\Romanitho\Winget-AutoUpdate" -ErrorAction SilentlyContinue
|
||||||
|
|
||||||
|
#Replace loaded configurations by ones from Policies
|
||||||
|
$WAUPolicies.PSObject.Properties | ForEach-Object {
|
||||||
|
$WAUConfig.PSObject.Properties.add($_)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#Return config
|
||||||
|
return $WAUConfig
|
||||||
|
}
|
|
@ -146,7 +146,7 @@ function Invoke-PostUpdateActions {
|
||||||
|
|
||||||
#Remove old functions / files
|
#Remove old functions / files
|
||||||
$FileNames = @(
|
$FileNames = @(
|
||||||
"$WorkingDir\functions\Get-WAUConfig.ps1",
|
"$WorkingDir\functions\Get-Policies.ps1",
|
||||||
"$WorkingDir\functions\Get-WAUCurrentVersion.ps1",
|
"$WorkingDir\functions\Get-WAUCurrentVersion.ps1",
|
||||||
"$WorkingDir\functions\Get-WAUUpdateStatus.ps1",
|
"$WorkingDir\functions\Get-WAUUpdateStatus.ps1",
|
||||||
"$WorkingDir\functions\Write-Log.ps1",
|
"$WorkingDir\functions\Write-Log.ps1",
|
||||||
|
@ -176,7 +176,7 @@ function Invoke-PostUpdateActions {
|
||||||
$UserContextTask = Get-ScheduledTask -TaskName 'Winget-AutoUpdate-UserContext' -TaskPath '\' -ErrorAction SilentlyContinue
|
$UserContextTask = Get-ScheduledTask -TaskName 'Winget-AutoUpdate-UserContext' -TaskPath '\' -ErrorAction SilentlyContinue
|
||||||
if ($UserContextTask) {
|
if ($UserContextTask) {
|
||||||
#Remove Winget-AutoUpdate-UserContext at root.
|
#Remove Winget-AutoUpdate-UserContext at root.
|
||||||
Unregister-ScheduledTask $UserContextTask -Confirm:$False
|
$null = $UserContextTask | Unregister-ScheduledTask -Confirm:$False
|
||||||
|
|
||||||
#Set it in registry as activated.
|
#Set it in registry as activated.
|
||||||
New-ItemProperty $regPath -Name WAU_UserContext -Value 1 -PropertyType DWord -Force | Out-Null
|
New-ItemProperty $regPath -Name WAU_UserContext -Value 1 -PropertyType DWord -Force | Out-Null
|
||||||
|
|
Loading…
Reference in New Issue