mirror of
https://github.com/ChrisTitusTech/winutil.git
synced 2025-01-15 09:20:36 -06:00
Merge branch 'main' into config-schema
This commit is contained in:
commit
14efc4f4f6
@ -9,7 +9,7 @@ jobs:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v2
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Check if PR was merged
|
||||
if: github.event.pull_request.merged == true
|
22
.github/workflows/compile-check.yaml
vendored
Normal file
22
.github/workflows/compile-check.yaml
vendored
Normal file
@ -0,0 +1,22 @@
|
||||
name: Compile & Check
|
||||
|
||||
on:
|
||||
push:
|
||||
branches: ["main"]
|
||||
pull_request:
|
||||
branches: ["main"]
|
||||
workflow_dispatch: # Manual trigger added
|
||||
workflow_call: # Allow other Actions to call this workflow
|
||||
|
||||
jobs:
|
||||
Compile-and-Check:
|
||||
runs-on: windows-latest
|
||||
steps:
|
||||
- name: Checkout Sources
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Compile and Syntaxcheck winutil.ps1
|
||||
shell: pwsh
|
||||
run: |
|
||||
Set-ExecutionPolicy Bypass -Scope Process -Force; ./Compile.ps1
|
||||
continue-on-error: false # Directly fail the job on error, removing the need for a separate check
|
48
.github/workflows/compile.yaml
vendored
48
.github/workflows/compile.yaml
vendored
@ -1,48 +0,0 @@
|
||||
name: Compile
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
- test*
|
||||
workflow_dispatch: # Manual trigger added
|
||||
|
||||
jobs:
|
||||
build-runspace:
|
||||
runs-on: windows-latest
|
||||
env:
|
||||
CERTIFICATE_BASE64: ${{ secrets.CERTIFICATE_BASE64 }}
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
with:
|
||||
ref: ${{ github.head_ref }}
|
||||
- name: Compile project
|
||||
shell: pwsh
|
||||
run: |
|
||||
Set-ExecutionPolicy Bypass -Scope Process -Force; ./Compile.ps1
|
||||
continue-on-error: false # Directly fail the job on error, removing the need for a separate check
|
||||
- name: Create and import code signing certificate
|
||||
shell: pwsh
|
||||
run: |
|
||||
[System.IO.File]::WriteAllBytes("$env:USERPROFILE\code-signing-cert.pfx", [System.Convert]::FromBase64String("$env:CERTIFICATE_BASE64"))
|
||||
Import-PfxCertificate -FilePath "$env:USERPROFILE\code-signing-cert.pfx" -CertStoreLocation Cert:\CurrentUser\My
|
||||
- name: Code sign winutil.ps1
|
||||
shell: pwsh
|
||||
run: |
|
||||
$cert = Get-ChildItem -Path Cert:\CurrentUser\My -CodeSigningCert | Select-Object -First 1
|
||||
if ($null -eq $cert) { throw "Code signing certificate not found" }
|
||||
Set-AuthenticodeSignature -FilePath ./winutil.ps1 -Certificate $cert
|
||||
- name: Verify code signature
|
||||
shell: pwsh
|
||||
run: |
|
||||
$signature = Get-AuthenticodeSignature -FilePath ./winutil.ps1
|
||||
if ($signature.Status -ne 'Valid') { throw "Code signing failed" }
|
||||
- name: Upload winutil.ps1 as artifact
|
||||
uses: actions/upload-artifact@v2
|
||||
with:
|
||||
name: winutil
|
||||
path: ./winutil.ps1
|
||||
- uses: stefanzweifel/git-auto-commit-action@v5
|
||||
with:
|
||||
commit_message: Compile Winutil
|
||||
if: success()
|
33
.github/workflows/pre-release.yaml
vendored
33
.github/workflows/pre-release.yaml
vendored
@ -10,10 +10,18 @@ on:
|
||||
jobs:
|
||||
build-runspace:
|
||||
runs-on: windows-latest
|
||||
env:
|
||||
CERTIFICATE_BASE64: ${{ secrets.CERTIFICATE_BASE64 }}
|
||||
steps:
|
||||
- name: Checkout Repository
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Compile project
|
||||
shell: pwsh
|
||||
run: |
|
||||
Set-ExecutionPolicy Bypass -Scope Process -Force; ./Compile.ps1
|
||||
continue-on-error: false # Directly fail the job on error, removing the need for a separate check
|
||||
|
||||
- name: Set Version to Todays Date
|
||||
id: extract_version
|
||||
run: |
|
||||
@ -41,6 +49,31 @@ jobs:
|
||||
}
|
||||
shell: pwsh
|
||||
|
||||
- name: Create and import code signing certificate
|
||||
shell: pwsh
|
||||
run: |
|
||||
[System.IO.File]::WriteAllBytes("$env:USERPROFILE\code-signing-cert.pfx", [System.Convert]::FromBase64String("$env:CERTIFICATE_BASE64"))
|
||||
Import-PfxCertificate -FilePath "$env:USERPROFILE\code-signing-cert.pfx" -CertStoreLocation Cert:\CurrentUser\My
|
||||
|
||||
- name: Code sign winutil.ps1
|
||||
shell: pwsh
|
||||
run: |
|
||||
$cert = Get-ChildItem -Path Cert:\CurrentUser\My -CodeSigningCert | Select-Object -First 1
|
||||
if ($null -eq $cert) { throw "Code signing certificate not found" }
|
||||
Set-AuthenticodeSignature -FilePath ./winutil.ps1 -Certificate $cert
|
||||
|
||||
- name: Verify code signature
|
||||
shell: pwsh
|
||||
run: |
|
||||
$signature = Get-AuthenticodeSignature -FilePath ./winutil.ps1
|
||||
if ($signature.Status -ne 'Valid') { throw "Code signing failed" }
|
||||
|
||||
- name: Upload winutil.ps1 as artifact
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: winutil
|
||||
path: ./winutil.ps1
|
||||
|
||||
- name: Create and Upload Release
|
||||
id: create_release
|
||||
uses: softprops/action-gh-release@v2
|
||||
|
44
.github/workflows/release.yaml
vendored
44
.github/workflows/release.yaml
vendored
@ -1,44 +0,0 @@
|
||||
name: Release WinUtil
|
||||
|
||||
on:
|
||||
workflow_dispatch: # Manual trigger added
|
||||
|
||||
jobs:
|
||||
build-runspace:
|
||||
runs-on: windows-latest
|
||||
outputs:
|
||||
version: ${{ steps.extract_version.outputs.version }}
|
||||
steps:
|
||||
- name: Checkout Repository
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Extract Version from winutil.ps1
|
||||
id: extract_version
|
||||
run: |
|
||||
$version = ''
|
||||
Get-Content ./winutil.ps1 -TotalCount 30 | ForEach-Object {
|
||||
if ($_ -match 'Version\s*:\s*(\d{2}\.\d{2}\.\d{2})') {
|
||||
$version = $matches[1]
|
||||
echo "version=$version" >> $GITHUB_OUTPUT
|
||||
break
|
||||
}
|
||||
}
|
||||
if (-not $version) {
|
||||
Write-Error "Version not found in winutil.ps1"
|
||||
exit 1
|
||||
}
|
||||
shell: pwsh
|
||||
|
||||
- name: Create and Upload Release
|
||||
id: create_release
|
||||
uses: softprops/action-gh-release@v2
|
||||
with:
|
||||
tag_name: ${{ steps.extract_version.outputs.version }}
|
||||
name: Release ${{ steps.extract_version.outputs.version }}
|
||||
body: "![GitHub Downloads (specific asset, specific tag)](https://img.shields.io/github/downloads/ChrisTitusTech/winutil/${{ steps.extract_version.outputs.version }}/winutil.ps1)"
|
||||
append_body: true
|
||||
files: ./winutil.ps1
|
||||
prerelease: false
|
||||
make_latest: "true"
|
||||
env:
|
||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
34
.github/workflows/remove-winutil.yaml
vendored
Normal file
34
.github/workflows/remove-winutil.yaml
vendored
Normal file
@ -0,0 +1,34 @@
|
||||
name: Remove winutil.ps1 if included in a Push
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- '**'
|
||||
|
||||
jobs:
|
||||
check-and-delete-file:
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Check if winutil.ps1 exists
|
||||
id: check_existence
|
||||
run: |
|
||||
if [ -f "winutil.ps1" ]; then
|
||||
echo "winutil_exists=true" >> $GITHUB_OUTPUT
|
||||
else
|
||||
echo "winutil_exists=false" >> $GITHUB_OUTPUT
|
||||
fi
|
||||
|
||||
- name: Delete winutil.ps1 if it exists
|
||||
if: steps.check_existence.outputs.winutil_exists == 'true'
|
||||
run: |
|
||||
git config --global user.email "winutil-action@noreply.github.com"
|
||||
git config --global user.name "winutil-action"
|
||||
git rm winutil.ps1
|
||||
git commit -m "Delete winutil.ps1 as it is not allowed"
|
||||
git push origin HEAD:${{ github.ref }}
|
||||
env:
|
||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
12
Compile.ps1
12
Compile.ps1
@ -43,7 +43,7 @@ if (-NOT $SkipPreprocessing) {
|
||||
$preprocessingFilePath = ".\tools\Invoke-Preprocessing.ps1"
|
||||
. "$(($workingdir -replace ('\\$', '')) + '\' + ($preprocessingFilePath -replace ('\.\\', '')))"
|
||||
|
||||
$excludedFiles = @('.\.git\', '.\.gitignore', '.\.gitattributes', '.\.github\CODEOWNERS', '.\LICENSE', '.\winutil.ps1', "$preprocessingFilePath", '*.png', '*.exe')
|
||||
$excludedFiles = @('.\.git\', '.\.gitignore', '.\.gitattributes', '.\.github\CODEOWNERS', '.\LICENSE', "$preprocessingFilePath", '*.png', '*.exe')
|
||||
$msg = "Pre-req: Code Formatting"
|
||||
Invoke-Preprocessing -WorkingDir "$workingdir" -ExcludedFiles $excludedFiles -ProgressStatusMessage $msg
|
||||
}
|
||||
@ -152,6 +152,16 @@ if ($Debug) {
|
||||
Set-Content -Path "$workingdir\$scriptname" -Value ($script_content -join "`r`n") -Encoding ascii
|
||||
Write-Progress -Activity "Compiling" -Completed
|
||||
|
||||
Update-Progress -Activity "Validating" -StatusMessage "Checking winutil.ps1 Syntax" -Percent 0
|
||||
try {
|
||||
$null = Get-Command -Syntax .\winutil.ps1
|
||||
}
|
||||
catch {
|
||||
Write-Warning "Syntax Validation for 'winutil.ps1' has failed"
|
||||
Write-Host "$($Error[0])" -ForegroundColor Red
|
||||
}
|
||||
Write-Progress -Activity "Validating" -Completed
|
||||
|
||||
if ($run) {
|
||||
try {
|
||||
Start-Process -FilePath "pwsh" -ArgumentList "$workingdir\$scriptname"
|
||||
|
@ -1 +0,0 @@
|
||||
"enabled": ["AT", "BE", "BG", "CH", "CY", "CZ", "DE", "DK", "EE", "ES", "FI", "FR", "GF", "GP", "GR", "HR", "HU", "IE", "IS", "IT", "LI", "LT", "LU", "LV", "MT", "MQ", "NL", "NO", "PL", "PT", "RE", "RO", "SE", "SI", "SK", "YT"]
|
@ -2557,14 +2557,14 @@
|
||||
},
|
||||
"WPFTweaksRemoveEdge": {
|
||||
"Content": "Remove Microsoft Edge",
|
||||
"Description": "Removes MS Edge when it gets reinstalled by updates. Credit: Techie Jack",
|
||||
"Description": "Removes MS Edge when it gets reinstalled by updates. Credit: Psyirius",
|
||||
"category": "z__Advanced Tweaks - CAUTION",
|
||||
"panel": "1",
|
||||
"Order": "a029_",
|
||||
"InvokeScript": [
|
||||
"
|
||||
Uninstall-WinUtilEdgeBrowser
|
||||
"
|
||||
Uninstall-WinUtilEdgeBrowser
|
||||
"
|
||||
],
|
||||
"UndoScript": [
|
||||
"
|
||||
|
138
edgeremoval.ps1
138
edgeremoval.ps1
@ -1,138 +0,0 @@
|
||||
$msedgeProcess = Get-Process -Name "msedge" -ErrorAction SilentlyContinue
|
||||
$widgetsProcess = Get-Process -Name "widgets" -ErrorAction SilentlyContinue
|
||||
# Checking if Microsoft Edge is running
|
||||
if ($msedgeProcess) {
|
||||
Stop-Process -Name "msedge" -Force
|
||||
} else {
|
||||
Write-Output "msedge process is not running."
|
||||
}
|
||||
# Checking if Widgets is running
|
||||
if ($widgetsProcess) {
|
||||
Stop-Process -Name "widgets" -Force
|
||||
} else {
|
||||
Write-Output "widgets process is not running."
|
||||
}
|
||||
|
||||
function Uninstall-Process {
|
||||
param (
|
||||
[Parameter(Mandatory = $true)]
|
||||
[string]$Key
|
||||
)
|
||||
|
||||
$originalNation = [microsoft.win32.registry]::GetValue('HKEY_USERS\.DEFAULT\Control Panel\International\Geo', 'Nation', [Microsoft.Win32.RegistryValueKind]::String)
|
||||
|
||||
# Set Nation to 84 (France) temporarily
|
||||
[microsoft.win32.registry]::SetValue('HKEY_USERS\.DEFAULT\Control Panel\International\Geo', 'Nation', 68, [Microsoft.Win32.RegistryValueKind]::String) | Out-Null
|
||||
|
||||
# credits to he3als for the Acl commands
|
||||
$fileName = "IntegratedServicesRegionPolicySet.json"
|
||||
$pathISRPS = [Environment]::SystemDirectory + "\" + $fileName
|
||||
$aclISRPS = Get-Acl -Path $pathISRPS
|
||||
$aclISRPSBackup = [System.Security.AccessControl.FileSecurity]::new()
|
||||
$aclISRPSBackup.SetSecurityDescriptorSddlForm($acl.Sddl)
|
||||
if (Test-Path -Path $pathISRPS) {
|
||||
try {
|
||||
$admin = [System.Security.Principal.NTAccount]$(New-Object System.Security.Principal.SecurityIdentifier('S-1-5-32-544')).Translate([System.Security.Principal.NTAccount]).Value
|
||||
|
||||
$aclISRPS.SetOwner($admin)
|
||||
$rule = New-Object System.Security.AccessControl.FileSystemAccessRule($admin, 'FullControl', 'Allow')
|
||||
$aclISRPS.AddAccessRule($rule)
|
||||
Set-Acl -Path $pathISRPS -AclObject $aclISRPS
|
||||
|
||||
Rename-Item -Path $pathISRPS -NewName ($fileName + '.bak') -Force
|
||||
}
|
||||
catch {
|
||||
Write-Error "[$Mode] Failed to set owner for $pathISRPS"
|
||||
}
|
||||
}
|
||||
|
||||
$baseKey = 'HKLM:\SOFTWARE\WOW6432Node\Microsoft\EdgeUpdate'
|
||||
$registryPath = $baseKey + '\ClientState\' + $Key
|
||||
|
||||
if (!(Test-Path -Path $registryPath)) {
|
||||
Write-Host "[$Mode] Registry key not found: $registryPath"
|
||||
return
|
||||
}
|
||||
|
||||
Remove-ItemProperty -Path $registryPath -Name "experiment_control_labels" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
$uninstallString = (Get-ItemProperty -Path $registryPath).UninstallString
|
||||
$uninstallArguments = (Get-ItemProperty -Path $registryPath).UninstallArguments
|
||||
|
||||
if ([string]::IsNullOrEmpty($uninstallString) -or [string]::IsNullOrEmpty($uninstallArguments)) {
|
||||
Write-Host "[$Mode] Cannot find uninstall methods for $Mode"
|
||||
return
|
||||
}
|
||||
|
||||
$uninstallArguments += " --force-uninstall --delete-profile"
|
||||
|
||||
# $uninstallCommand = "`"$uninstallString`"" + $uninstallArguments
|
||||
if (!(Test-Path -Path $uninstallString)) {
|
||||
Write-Host "[$Mode] setup.exe not found at: $uninstallString"
|
||||
return
|
||||
}
|
||||
Start-Process -FilePath $uninstallString -ArgumentList $uninstallArguments -Wait -NoNewWindow -Verbose
|
||||
|
||||
# Restore Acl
|
||||
if (Test-Path -Path ($pathISRPS + '.bak')) {
|
||||
Rename-Item -Path ($pathISRPS + '.bak') -NewName $fileName -Force
|
||||
Set-Acl -Path $pathISRPS -AclObject $aclISRPSBackup
|
||||
}
|
||||
|
||||
# Restore Nation
|
||||
[microsoft.win32.registry]::SetValue('HKEY_USERS\.DEFAULT\Control Panel\International\Geo', 'Nation', $originalNation, [Microsoft.Win32.RegistryValueKind]::String) | Out-Null
|
||||
|
||||
if ((Get-ItemProperty -Path $baseKey).IsEdgeStableUninstalled -eq 1) {
|
||||
Write-Host "[$Mode] Edge Stable has been successfully uninstalled"
|
||||
}
|
||||
}
|
||||
|
||||
function Uninstall-Edge {
|
||||
Remove-ItemProperty -Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\Microsoft Edge" -Name "NoRemove" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
[microsoft.win32.registry]::SetValue("HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\Microsoft\EdgeUpdateDev", "AllowUninstall", 1, [Microsoft.Win32.RegistryValueKind]::DWord) | Out-Null
|
||||
|
||||
Uninstall-Process -Key '{56EB18F8-B008-4CBD-B6D2-8C97FE7E9062}'
|
||||
|
||||
@( "$env:ProgramData\Microsoft\Windows\Start Menu\Programs",
|
||||
"$env:PUBLIC\Desktop",
|
||||
"$env:USERPROFILE\Desktop" ) | ForEach-Object {
|
||||
$shortcutPath = Join-Path -Path $_ -ChildPath "Microsoft Edge.lnk"
|
||||
if (Test-Path -Path $shortcutPath) {
|
||||
Remove-Item -Path $shortcutPath -Force
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
function Uninstall-WebView {
|
||||
Remove-ItemProperty -Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\Microsoft EdgeWebView" -Name "NoRemove" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
# Force to use system-wide WebView2
|
||||
# [microsoft.win32.registry]::SetValue("HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Edge\WebView2\BrowserExecutableFolder", "*", "%%SystemRoot%%\System32\Microsoft-Edge-WebView")
|
||||
|
||||
Uninstall-Process -Key '{F3017226-FE2A-4295-8BDF-00C3A9A7E4C5}'
|
||||
}
|
||||
|
||||
function Uninstall-EdgeUpdate {
|
||||
Remove-ItemProperty -Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\Microsoft Edge Update" -Name "NoRemove" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
$registryPath = 'HKLM:\SOFTWARE\WOW6432Node\Microsoft\EdgeUpdate'
|
||||
if (!(Test-Path -Path $registryPath)) {
|
||||
Write-Host "Registry key not found: $registryPath"
|
||||
return
|
||||
}
|
||||
$uninstallCmdLine = (Get-ItemProperty -Path $registryPath).UninstallCmdLine
|
||||
|
||||
if ([string]::IsNullOrEmpty($uninstallCmdLine)) {
|
||||
Write-Host "Cannot find uninstall methods for $Mode"
|
||||
return
|
||||
}
|
||||
|
||||
Write-Output "Uninstalling: $uninstallCmdLine"
|
||||
Start-Process cmd.exe "/c $uninstallCmdLine" -WindowStyle Hidden -Wait
|
||||
}
|
||||
|
||||
Uninstall-Edge
|
||||
# "WebView" { Uninstall-WebView }
|
||||
# "EdgeUpdate" { Uninstall-EdgeUpdate }
|
@ -51,7 +51,7 @@ function ConvertTo-Icon {
|
||||
# Handle the thrown exception here...
|
||||
}
|
||||
|
||||
This Example make use of '-overrideIconFile' Optional Parameter, the default for this paramter is $true.
|
||||
This Example make use of '-overrideIconFile' Optional Parameter, the default for this parameter is $true.
|
||||
By doing '-overrideIconFile $false', the 'ConvertTo-Icon' function will raise an exception that needs to be catched throw a 'catch' Code Block,
|
||||
otherwise it'll crash the running PowerShell instance/process.
|
||||
|
||||
|
@ -1,152 +1,101 @@
|
||||
Function Uninstall-WinUtilEdgeBrowser {
|
||||
|
||||
<#
|
||||
|
||||
.SYNOPSIS
|
||||
This will uninstall edge by changing the region to Ireland and uninstalling edge the changing it back
|
||||
|
||||
Uninstall the Edge Browser (Chromium) from the system in an elegant way.
|
||||
.DESCRIPTION
|
||||
This will switch up the region to one of the EEA countries temporarily and uninstall the Edge Browser (Chromium).
|
||||
#>
|
||||
|
||||
$msedgeProcess = Get-Process -Name "msedge" -ErrorAction SilentlyContinue
|
||||
$widgetsProcess = Get-Process -Name "widgets" -ErrorAction SilentlyContinue
|
||||
# Checking if Microsoft Edge is running
|
||||
if ($msedgeProcess) {
|
||||
Stop-Process -Name "msedge" -Force
|
||||
} else {
|
||||
Write-Output "msedge process is not running."
|
||||
}
|
||||
# Checking if Widgets is running
|
||||
if ($widgetsProcess) {
|
||||
Stop-Process -Name "widgets" -Force
|
||||
} else {
|
||||
Write-Output "widgets process is not running."
|
||||
}
|
||||
function Uninstall-EdgeClient {
|
||||
param (
|
||||
[Parameter(Mandatory = $true)]
|
||||
[string]$Key
|
||||
)
|
||||
|
||||
function Uninstall-Process {
|
||||
param (
|
||||
[Parameter(Mandatory = $true)]
|
||||
[string]$Key
|
||||
)
|
||||
$originalNation = [microsoft.win32.registry]::GetValue('HKEY_USERS\.DEFAULT\Control Panel\International\Geo', 'Nation', [Microsoft.Win32.RegistryValueKind]::String)
|
||||
|
||||
$originalNation = [microsoft.win32.registry]::GetValue('HKEY_USERS\.DEFAULT\Control Panel\International\Geo', 'Nation', [Microsoft.Win32.RegistryValueKind]::String)
|
||||
# Set Nation to any of the EEA regions temporarily
|
||||
# Refer: https://learn.microsoft.com/en-us/windows/win32/intl/table-of-geographical-locations
|
||||
$tmpNation = 68 # Ireland
|
||||
[microsoft.win32.registry]::SetValue('HKEY_USERS\.DEFAULT\Control Panel\International\Geo', 'Nation', $tmpNation, [Microsoft.Win32.RegistryValueKind]::String) | Out-Null
|
||||
|
||||
# Set Nation to 84 (France) temporarily
|
||||
[microsoft.win32.registry]::SetValue('HKEY_USERS\.DEFAULT\Control Panel\International\Geo', 'Nation', 68, [Microsoft.Win32.RegistryValueKind]::String) | Out-Null
|
||||
$baseKey = 'HKLM:\SOFTWARE\WOW6432Node\Microsoft\EdgeUpdate'
|
||||
$registryPath = $baseKey + '\ClientState\' + $Key
|
||||
|
||||
# credits to he3als for the Acl commands
|
||||
$fileName = "IntegratedServicesRegionPolicySet.json"
|
||||
$pathISRPS = [Environment]::SystemDirectory + "\" + $fileName
|
||||
$aclISRPS = Get-Acl -Path $pathISRPS
|
||||
$aclISRPSBackup = [System.Security.AccessControl.FileSecurity]::new()
|
||||
$aclISRPSBackup.SetSecurityDescriptorSddlForm($acl.Sddl)
|
||||
if (Test-Path -Path $pathISRPS) {
|
||||
try {
|
||||
$admin = [System.Security.Principal.NTAccount]$(New-Object System.Security.Principal.SecurityIdentifier('S-1-5-32-544')).Translate([System.Security.Principal.NTAccount]).Value
|
||||
|
||||
$aclISRPS.SetOwner($admin)
|
||||
$rule = New-Object System.Security.AccessControl.FileSystemAccessRule($admin, 'FullControl', 'Allow')
|
||||
$aclISRPS.AddAccessRule($rule)
|
||||
Set-Acl -Path $pathISRPS -AclObject $aclISRPS
|
||||
|
||||
Rename-Item -Path $pathISRPS -NewName ($fileName + '.bak') -Force
|
||||
if (!(Test-Path -Path $registryPath)) {
|
||||
Write-Host "[$Mode] Registry key not found: $registryPath"
|
||||
return
|
||||
}
|
||||
catch {
|
||||
Write-Error "[$Mode] Failed to set owner for $pathISRPS"
|
||||
|
||||
# Remove the status flag
|
||||
Remove-ItemProperty -Path $baseKey -Name "IsEdgeStableUninstalled" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
Remove-ItemProperty -Path $registryPath -Name "experiment_control_labels" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
$uninstallString = (Get-ItemProperty -Path $registryPath).UninstallString
|
||||
$uninstallArguments = (Get-ItemProperty -Path $registryPath).UninstallArguments
|
||||
|
||||
if ([string]::IsNullOrEmpty($uninstallString) -or [string]::IsNullOrEmpty($uninstallArguments)) {
|
||||
Write-Host "[$Mode] Cannot find uninstall methods for $Mode"
|
||||
return
|
||||
}
|
||||
|
||||
# Extra arguments to nuke it
|
||||
$uninstallArguments += " --force-uninstall --delete-profile"
|
||||
|
||||
# $uninstallCommand = "`"$uninstallString`"" + $uninstallArguments
|
||||
if (!(Test-Path -Path $uninstallString)) {
|
||||
Write-Host "[$Mode] setup.exe not found at: $uninstallString"
|
||||
return
|
||||
}
|
||||
Start-Process -FilePath $uninstallString -ArgumentList $uninstallArguments -Wait -NoNewWindow -Verbose
|
||||
|
||||
# Restore Nation back to the original
|
||||
[microsoft.win32.registry]::SetValue('HKEY_USERS\.DEFAULT\Control Panel\International\Geo', 'Nation', $originalNation, [Microsoft.Win32.RegistryValueKind]::String) | Out-Null
|
||||
|
||||
# might not exist in some cases
|
||||
if ((Get-ItemProperty -Path $baseKey).IsEdgeStableUninstalled -eq 1) {
|
||||
Write-Host "[$Mode] Edge Stable has been successfully uninstalled"
|
||||
}
|
||||
}
|
||||
|
||||
$baseKey = 'HKLM:\SOFTWARE\WOW6432Node\Microsoft\EdgeUpdate'
|
||||
$registryPath = $baseKey + '\ClientState\' + $Key
|
||||
function Uninstall-Edge {
|
||||
Remove-ItemProperty -Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\Microsoft Edge" -Name "NoRemove" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
if (!(Test-Path -Path $registryPath)) {
|
||||
Write-Host "[$Mode] Registry key not found: $registryPath"
|
||||
return
|
||||
[microsoft.win32.registry]::SetValue("HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\Microsoft\EdgeUpdateDev", "AllowUninstall", 1, [Microsoft.Win32.RegistryValueKind]::DWord) | Out-Null
|
||||
|
||||
Uninstall-EdgeClient -Key '{56EB18F8-B008-4CBD-B6D2-8C97FE7E9062}'
|
||||
}
|
||||
|
||||
Remove-ItemProperty -Path $registryPath -Name "experiment_control_labels" -ErrorAction SilentlyContinue | Out-Null
|
||||
function Uninstall-WebView {
|
||||
# FIXME: might not work on some systems
|
||||
|
||||
$uninstallString = (Get-ItemProperty -Path $registryPath).UninstallString
|
||||
$uninstallArguments = (Get-ItemProperty -Path $registryPath).UninstallArguments
|
||||
Remove-ItemProperty -Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\Microsoft EdgeWebView" -Name "NoRemove" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
if ([string]::IsNullOrEmpty($uninstallString) -or [string]::IsNullOrEmpty($uninstallArguments)) {
|
||||
Write-Host "[$Mode] Cannot find uninstall methods for $Mode"
|
||||
return
|
||||
Uninstall-EdgeClient -Key '{F3017226-FE2A-4295-8BDF-00C3A9A7E4C5}'
|
||||
}
|
||||
|
||||
$uninstallArguments += " --force-uninstall --delete-profile"
|
||||
function Uninstall-EdgeUpdate {
|
||||
# FIXME: might not work on some systems
|
||||
|
||||
# $uninstallCommand = "`"$uninstallString`"" + $uninstallArguments
|
||||
if (!(Test-Path -Path $uninstallString)) {
|
||||
Write-Host "[$Mode] setup.exe not found at: $uninstallString"
|
||||
return
|
||||
}
|
||||
Start-Process -FilePath $uninstallString -ArgumentList $uninstallArguments -Wait -NoNewWindow -Verbose
|
||||
Remove-ItemProperty -Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\Microsoft Edge Update" -Name "NoRemove" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
# Restore Acl
|
||||
if (Test-Path -Path ($pathISRPS + '.bak')) {
|
||||
Rename-Item -Path ($pathISRPS + '.bak') -NewName $fileName -Force
|
||||
Set-Acl -Path $pathISRPS -AclObject $aclISRPSBackup
|
||||
}
|
||||
|
||||
# Restore Nation
|
||||
[microsoft.win32.registry]::SetValue('HKEY_USERS\.DEFAULT\Control Panel\International\Geo', 'Nation', $originalNation, [Microsoft.Win32.RegistryValueKind]::String) | Out-Null
|
||||
|
||||
if ((Get-ItemProperty -Path $baseKey).IsEdgeStableUninstalled -eq 1) {
|
||||
Write-Host "[$Mode] Edge Stable has been successfully uninstalled"
|
||||
}
|
||||
}
|
||||
|
||||
function Uninstall-Edge {
|
||||
Remove-ItemProperty -Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\Microsoft Edge" -Name "NoRemove" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
[microsoft.win32.registry]::SetValue("HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\Microsoft\EdgeUpdateDev", "AllowUninstall", 1, [Microsoft.Win32.RegistryValueKind]::DWord) | Out-Null
|
||||
|
||||
Uninstall-Process -Key '{56EB18F8-B008-4CBD-B6D2-8C97FE7E9062}'
|
||||
|
||||
@( "$env:ProgramData\Microsoft\Windows\Start Menu\Programs",
|
||||
"$env:PUBLIC\Desktop",
|
||||
"$env:USERPROFILE\Desktop" ) | ForEach-Object {
|
||||
$shortcutPath = Join-Path -Path $_ -ChildPath "Microsoft Edge.lnk"
|
||||
if (Test-Path -Path $shortcutPath) {
|
||||
Remove-Item -Path $shortcutPath -Force
|
||||
$registryPath = 'HKLM:\SOFTWARE\WOW6432Node\Microsoft\EdgeUpdate'
|
||||
if (!(Test-Path -Path $registryPath)) {
|
||||
Write-Host "Registry key not found: $registryPath"
|
||||
return
|
||||
}
|
||||
$uninstallCmdLine = (Get-ItemProperty -Path $registryPath).UninstallCmdLine
|
||||
|
||||
if ([string]::IsNullOrEmpty($uninstallCmdLine)) {
|
||||
Write-Host "Cannot find uninstall methods for $Mode"
|
||||
return
|
||||
}
|
||||
|
||||
Start-Process cmd.exe "/c $uninstallCmdLine" -WindowStyle Hidden -Wait
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
function Uninstall-WebView {
|
||||
Remove-ItemProperty -Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\Microsoft EdgeWebView" -Name "NoRemove" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
# Force to use system-wide WebView2
|
||||
# [microsoft.win32.registry]::SetValue("HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Edge\WebView2\BrowserExecutableFolder", "*", "%%SystemRoot%%\System32\Microsoft-Edge-WebView")
|
||||
|
||||
Uninstall-Process -Key '{F3017226-FE2A-4295-8BDF-00C3A9A7E4C5}'
|
||||
}
|
||||
|
||||
function Uninstall-EdgeUpdate {
|
||||
Remove-ItemProperty -Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall\Microsoft Edge Update" -Name "NoRemove" -ErrorAction SilentlyContinue | Out-Null
|
||||
|
||||
$registryPath = 'HKLM:\SOFTWARE\WOW6432Node\Microsoft\EdgeUpdate'
|
||||
if (!(Test-Path -Path $registryPath)) {
|
||||
Write-Host "Registry key not found: $registryPath"
|
||||
return
|
||||
}
|
||||
$uninstallCmdLine = (Get-ItemProperty -Path $registryPath).UninstallCmdLine
|
||||
|
||||
if ([string]::IsNullOrEmpty($uninstallCmdLine)) {
|
||||
Write-Host "Cannot find uninstall methods for $Mode"
|
||||
return
|
||||
}
|
||||
|
||||
Write-Output "Uninstalling: $uninstallCmdLine"
|
||||
Start-Process cmd.exe "/c $uninstallCmdLine" -WindowStyle Hidden -Wait
|
||||
}
|
||||
|
||||
Uninstall-Edge
|
||||
# "WebView" { Uninstall-WebView }
|
||||
# "EdgeUpdate" { Uninstall-EdgeUpdate }
|
||||
|
||||
|
||||
|
||||
|
||||
Uninstall-Edge
|
||||
# Uninstall-WebView - WebView is needed for Visual Studio and some MS Store Games like Forza
|
||||
Uninstall-EdgeUpdate
|
||||
}
|
||||
|
16256
winutil.ps1
16256
winutil.ps1
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user