Last active
September 3, 2024 11:39
-
-
Save ishad0w/3b79bf829e9725aa102b2e8446bb5ef8 to your computer and use it in GitHub Desktop.
AveYo (Microsoft Edge Removal)
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
@(set "0=%~f0"^)#) & powershell -nop -c iex([io.file]::ReadAllText($env:0)) & exit /b | |
#:: just copy-paste into powershell - it's a standalone hybrid script | |
sp 'HKCU:\Volatile Environment' 'Edge_Removal' @' | |
$also_remove_webview = 1 | |
## why also remove webview? because it is 2 copies of edge, not a slimmed down CEF, and is driving bloated web apps | |
$also_remove_widgets = 1 | |
## why also remove widgets? because it is a webview glorified ad portal on msn and bing news cathering to stupid people | |
$also_remove_xsocial = 1 | |
## why also remove xsocial? because it starts webview setup every boot - xbox gamebar will still work without the social crap | |
$host.ui.RawUI.WindowTitle = 'Edge Removal - AveYo, 2023.09.14' | |
write-host "Run the script again whenever you need to reinstall and update edge or webview..`n" | |
$remove_appx = @("MicrosoftEdge"); $remove_win32 = @("Microsoft Edge","Microsoft Edge Update"); $skip = @() # @("DevTools") | |
if ($also_remove_webview -eq 1) {$remove_appx += "Win32WebViewHost"; $remove_win32 += "Microsoft EdgeWebView"} | |
if ($also_remove_widgets -eq 1) {$remove_appx += "WebExperience"} | |
if ($also_remove_xsocial -eq 1) {$remove_appx += "GamingServices"} | |
$global:WEBV = $also_remove_webview -eq 1 | |
$global:IS64 = [Environment]::Is64BitOperatingSystem | |
$global:IFEO = 'HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Image File Execution Options' | |
$global:EDGE_UID = '{56EB18F8-B008-4CBD-B6D2-8C97FE7E9062}' | |
$global:WEBV_UID = '{F3017226-FE2A-4295-8BDF-00C3A9A7E4C5}' | |
$global:UPDT_UID = '{F3C4FE00-EFD5-403B-9569-398A20F1BA4A}' | |
$global:PROGRAMS = ($env:ProgramFiles, ${env:ProgramFiles(x86)})[$IS64] | |
$global:SOFTWARE = ('SOFTWARE', 'SOFTWARE\WOW6432Node')[$IS64] | |
$global:ALLHIVES = 'HKCU:\SOFTWARE','HKLM:\SOFTWARE','HKCU:\SOFTWARE\Policies','HKLM:\SOFTWARE\Policies' | |
if ($IS64) { $global:ALLHIVES += "HKCU:\$SOFTWARE","HKLM:\$SOFTWARE","HKCU:\$SOFTWARE\Policies","HKLM:\$SOFTWARE\Policies"} | |
## ------------------------------------------------------------------------------------------------------------------------------- | |
## 1 bonus! enter into powershell console: firefox / edge / webview to install a browser / reinstall edge / webview after removal | |
function global:firefox { $url = 'https://download.mozilla.org/?product=firefox-stub' | |
$setup = "$((new-object -ComObject Shell.Application).NameSpace('shell:Downloads').Self.Path)\Firefox Installer.exe" | |
write-host $url; Invoke-WebRequest $url -OutFile $setup; start $setup | |
} | |
function global:edge { $url = 'https://go.microsoft.com/fwlink/?linkid=2108834&Channel=Stable&language=en' | |
$setup = "$((new-object -ComObject Shell.Application).NameSpace('shell:Downloads').Self.Path)\MicrosoftEdgeSetup.exe" | |
write-host $url; Invoke-WebRequest $url -OutFile $setup; PREPARE_EDGE; start $setup | |
} | |
function global:webview { $url = 'https://go.microsoft.com/fwlink/p/?LinkId=2124703' | |
$setup = "$((new-object -ComObject Shell.Application).NameSpace('shell:Downloads').Self.Path)\MicrosoftEdgeWebview2Setup.exe" | |
write-host $url; Invoke-WebRequest $url -OutFile $setup; PREPARE_WEBVIEW; start $setup | |
} | |
function global:xsocial { $url = 'https://dlassets-ssl.xboxlive.com/public/content/XboxInstaller/XboxInstaller.exe' | |
$setup = "$((new-object -ComObject Shell.Application).NameSpace('shell:Downloads').Self.Path)\XboxInstaller.exe" | |
write-host $url; Invoke-WebRequest $url -OutFile $setup; PREPARE_WEBVIEW; start $setup | |
} | |
## helper for set-itemproperty remove-itemproperty new-item remove-item with auto test-path | |
function global:sp_test_path { if (test-path $args[0]) {Microsoft.PowerShell.Management\Set-ItemProperty @args} else { | |
Microsoft.PowerShell.Management\New-Item $args[0] -force -ea 0 >''; Microsoft.PowerShell.Management\Set-ItemProperty @args} } | |
function global:rp_test_path { if (test-path $args[0]) {Microsoft.PowerShell.Management\Remove-ItemProperty @args} } | |
function global:ni_test_path { if (-not (test-path $args[0])) {Microsoft.PowerShell.Management\New-Item @args} } | |
function global:ri_test_path { if (test-path $args[0]) {Microsoft.PowerShell.Management\Remove-Item @args} } | |
foreach ($f in 'sp','rp','ni','ri') {set-alias -Name $f -Value "${f}_test_path" -Scope Local -Option AllScope -force -ea 0} | |
## helper for edgeupdate reinstall | |
function global:PREPARE_UPDT($cdp='msedgeupdate', $uid=$UPDT_UID) { | |
foreach ($f in 'sp','rp','ni','ri') {set-alias -Name $f -Value "${f}_test_path" -Scope Local -Option AllScope -force -ea 0} | |
foreach ($sw in $ALLHIVES) { | |
rp "$sw\Microsoft\EdgeUpdate" 'DoNotUpdateToEdgeWithChromium' -force -ea 0 | |
rp "$sw\Microsoft\EdgeUpdate" 'UpdaterExperimentationAndConfigurationServiceControl' -force -ea 0 | |
rp "$sw\Microsoft\EdgeUpdate" "InstallDefault" -force -ea 0 | |
rp "$sw\Microsoft\EdgeUpdate" "Install${uid}" -force -ea 0 | |
rp "$sw\Microsoft\EdgeUpdate" "EdgePreview${uid}" -force -ea 0 | |
rp "$sw\Microsoft\EdgeUpdate" "Update${uid}" -force -ea 0 | |
rp "$sw\Microsoft\EdgeUpdate\ClientState\*" 'experiment_control_labels' -force -ea 0 | |
ri "$sw\Microsoft\EdgeUpdate\Clients\${uid}\Commands" -recurse -force -ea 0 | |
rp "$sw\Microsoft\EdgeUpdateDev\CdpNames" "$cdp-*" -force -ea 0 | |
sp "$sw\Microsoft\EdgeUpdateDev" 'CanContinueWithMissingUpdate' 1 -type Dword -force | |
sp "$sw\Microsoft\EdgeUpdateDev" 'AllowUninstall' 1 -type Dword -force | |
} | |
} | |
## helper for edge reinstall - remove bundled OpenWebSearch redirector and edgeupdate policies | |
function global:PREPARE_EDGE { | |
foreach ($f in 'sp','rp','ni','ri') {set-alias -Name $f -Value "${f}_test_path" -Scope Local -Option AllScope -force -ea 0} | |
PREPARE_UPDT 'msedge' $EDGE_UID; PREPARE_UPDT 'msedgeupdate' $UPDT_UID | |
$MSEDGE = "$PROGRAMS\Microsoft\Edge\Application\msedge.exe" | |
ri "$IFEO\msedge.exe" -recurse -force; ri "$IFEO\ie_to_edge_stub.exe" -recurse -force | |
ri 'Registry::HKEY_Users\S-1-5-21*\Software\Classes\microsoft-edge' -recurse -force | |
sp 'HKLM:\SOFTWARE\Classes\microsoft-edge\shell\open\command' '(Default)' "`"$MSEDGE`" --single-argument %%1" -force | |
ri 'Registry::HKEY_Users\S-1-5-21*\Software\Classes\MSEdgeHTM' -recurse -force | |
sp 'HKLM:\SOFTWARE\Classes\MSEdgeHTM\shell\open\command' '(Default)' "`"$MSEDGE`" --single-argument %%1" -force | |
} | |
## helper for webview reinstall - restore webexperience (widgets) if available | |
function global:PREPARE_WEBVIEW { | |
PREPARE_UPDT 'msedgewebview' $WEBV_UID; PREPARE_UPDT 'msedgeupdate' $UPDT_UID | |
$cfg = @{Register=$true; ForceApplicationShutdown=$true; ForceUpdateFromAnyVersion=$true; DisableDevelopmentMode=$true} | |
dir "$env:SystemRoot\SystemApps\Microsoft.Win32WebViewHost*\AppxManifest.xml" -rec -ea 0 | Add-AppxPackage @cfg | |
dir "$env:ProgramFiles\WindowsApps\MicrosoftWindows.Client.WebExperience*\AppxManifest.xml" -rec -ea 0 | Add-AppxPackage @cfg | |
kill -name explorer -ea 0; if ((get-process -name 'explorer' -ea 0) -eq $null) {start explorer} | |
} | |
## ------------------------------------------------------------------------------------------------------------------------------- | |
## 2 enable admin privileges | |
$D1=[uri].module.gettype('System.Diagnostics.Process')."GetM`ethods"(42) |where {$_.Name -eq 'SetPrivilege'} #`:no-ev-warn | |
'SeSecurityPrivilege','SeTakeOwnershipPrivilege','SeBackupPrivilege','SeRestorePrivilege'|foreach {$D1.Invoke($null, @("$_",2))} | |
## ------------------------------------------------------------------------------------------------------------------------------- | |
## 3 shut down edge & webview clone stuff | |
cd $env:systemdrive; taskkill /im explorer.exe /f 2>&1 >'' | |
$shut = 'explorer','Widgets','widgetservice','msedgewebview2','MicrosoftEdge*','chredge','msedge','edge' | |
$shut,'msteams','msfamily','WebViewHost','Clipchamp' |foreach {kill -name $_ -force -ea 0} | |
## clear win32 uninstall block | |
foreach ($name in $remove_win32) { foreach ($sw in $ALLHIVES) { | |
$key = "$sw\Microsoft\Windows\CurrentVersion\Uninstall\$name"; if (-not (test-path $key)) {continue} | |
foreach ($val in 'NoRemove','NoModify','NoRepair') {rp $key $val -force -ea 0} | |
foreach ($val in 'ForceRemove','Delete') {sp $key $val 1 -type Dword -force} | |
}} | |
PREPARE_EDGE | |
## find all Edge setup.exe and gather BHO paths for OpenWebSearch / MSEdgeRedirect usage | |
$edges = @(); $bho = @(); $edgeupdates = @(); 'LocalApplicationData','ProgramFilesX86','ProgramFiles' |foreach { | |
$folder = [Environment]::GetFolderPath($_); $bho += dir "$folder\Microsoft\Edge*\ie_to_edge_stub.exe" -rec -ea 0 | |
if ($WEBV) {$edges += dir "$folder\Microsoft\Edge*\setup.exe" -rec -ea 0 |where {$_ -like '*EdgeWebView*'}} | |
$edges += dir "$folder\Microsoft\Edge*\setup.exe" -rec -ea 0 |where {$_ -notlike '*EdgeWebView*'} | |
$edgeupdates += dir "$folder\Microsoft\EdgeUpdate\*.*.*.*\MicrosoftEdgeUpdate.exe" -rec -ea 0 | |
} | |
## export OpenWebSearch innovative redirector - used by MSEdgeRedirect as well | |
$DIR = "$env:SystemDrive\Scripts"; mkdir $DIR -ea 0 >'' | |
foreach ($b in $bho) { if (test-path $b) { try {copy $b "$DIR\ie_to_edge_stub.exe" -force -ea 0} catch{} } } | |
## ------------------------------------------------------------------------------------------------------------------------------- | |
## 4 remove found *Edge* appx packages with unblock tricks | |
$provisioned = get-appxprovisionedpackage -online; $appxpackage = get-appxpackage -allusers; $eol = @() | |
$store = 'HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Appx\AppxAllUserStore' | |
$users = @('S-1-5-18'); if (test-path $store) {$users += $((dir $store -ea 0 |where {$_ -like '*S-1-5-21*'}).PSChildName)} | |
foreach ($choice in $remove_appx) { if ('' -eq $choice.Trim()) {continue} | |
foreach ($appx in $($provisioned |where {$_.PackageName -like "*$choice*"})) { | |
$next = !1; foreach ($no in $skip) {if ($appx.PackageName -like "*$no*") {$next = !0}} ; if ($next) {continue} | |
$PackageName = $appx.PackageName; $PackageFamilyName = ($appxpackage |where {$_.Name -eq $appx.DisplayName}).PackageFamilyName | |
ni "$store\Deprovisioned\$PackageFamilyName" -force >''; $PackageFamilyName | |
foreach ($sid in $users) {ni "$store\EndOfLife\$sid\$PackageName" -force >''} ; $eol += $PackageName | |
dism /online /set-nonremovableapppolicy /packagefamily:$PackageFamilyName /nonremovable:0 >'' | |
remove-appxprovisionedpackage -packagename $PackageName -online -allusers >'' | |
} | |
foreach ($appx in $($appxpackage |where {$_.PackageFullName -like "*$choice*"})) { | |
$next = !1; foreach ($no in $skip) {if ($appx.PackageFullName -like "*$no*") {$next = !0}} ; if ($next) {continue} | |
$PackageFullName = $appx.PackageFullName; | |
ni "$store\Deprovisioned\$appx.PackageFamilyName" -force >''; $PackageFullName | |
foreach ($sid in $users) {ni "$store\EndOfLife\$sid\$PackageFullName" -force >''} ; $eol += $PackageFullName | |
dism /online /set-nonremovableapppolicy /packagefamily:$PackageFamilyName /nonremovable:0 >'' | |
remove-appxpackage -package $PackageFullName -allusers >'' | |
} | |
} | |
## ------------------------------------------------------------------------------------------------------------------------------- | |
## 5 run found *Edge* setup.exe with uninstall args and wait in-between | |
foreach ($setup in $edges) { if (-not (test-path $setup)) {continue} | |
if ($setup -like '*EdgeWebView*') {$target = "--msedgewebview"} else {$target = "--msedge"} | |
$sulevel = ('--system-level','--user-level')[$setup -like '*\AppData\Local\*'] | |
$removal = "--uninstall $target $sulevel --verbose-logging --force-uninstall" | |
try {write-host $setup $removal; start -wait $setup -args $removal} catch {} | |
do {sleep 3} while ((get-process -name 'setup','MicrosoftEdge*' -ea 0).Path -like '*\Microsoft\Edge*') | |
} | |
## ------------------------------------------------------------------------------------------------------------------------------- | |
## msi installers cleanup | |
gp 'HKLM:\SOFTWARE\Classes\Installer\Products\*' 'ProductName' |where {$_.ProductName -like '*Microsoft Edge*'} |foreach { | |
$prod = ($_.PSChildName -split '(.{8})(.{4})(.{4})(.{4})' -join '-').trim('-') | |
$sort = 7,6,5,4,3,2,1,0,8,12,11,10,9,13,17,16,15,14,18,20,19,22,21,23,25,24,27,26,29,28,31,30,33,32,35,34 | |
$code = '{' + -join ($sort |foreach {$prod[$_]}) + '}'; start -wait msiexec.exe -args "/X$code /qn" 2>'' | |
ri $_.PSPath -recurse -force | |
foreach ($sw in $ALLHIVES) {ri "$sw\Microsoft\Windows\CurrentVersion\Uninstall\$code" -recurse -force} | |
} | |
## 6 edgeupdate graceful cleanup | |
if ($WEBV) { | |
foreach ($sw in $ALLHIVES) {ri "$sw\Microsoft\EdgeUpdate" -recurse -force} | |
foreach ($UPDT in $edgeupdates) { | |
if (test-path $UPDT) {write-host "$UPDT /unregsvc"; start -wait $UPDT -args '/unregsvc'} | |
do {sleep 3} while ((get-process -name 'setup','MicrosoftEdge*' -ea 0).Path -like '*\Microsoft\Edge*') | |
if (test-path $UPDT) {write-host "$UPDT /uninstall"; start -wait $UPDT -args '/uninstall'} | |
do {sleep 3} while ((get-process -name 'setup','MicrosoftEdge*' -ea 0).Path -like '*\Microsoft\Edge*') | |
} | |
Unregister-ScheduledTask -TaskName MicrosoftEdgeUpdate* -Confirm:$false -ea 0; ri "$PROGRAMS\Microsoft\Temp" -recurse -force | |
} | |
$appdata = $([Environment]::GetFolderPath('ApplicationData')) | |
ri "$appdata\Microsoft\Internet Explorer\Quick Launch\User Pinned\TaskBar\Tombstones\Microsoft Edge.lnk" -force | |
ri "$appdata\Microsoft\Internet Explorer\Quick Launch\Microsoft Edge.lnk" -force | |
## undo eol unblock trick to prevent latest cumulative update (LCU) failing | |
foreach ($sid in $users) { foreach ($PackageName in $eol) {ri "$store\EndOfLife\$sid\$PackageName" -force >''} } | |
## .i. "Update policies are configured but will be ignored because this device isn't domain joined" .i. | |
$uids = @($EDGE_UID); $cdps = @('msedge'); if ($WEBV) {$uids += $WEBV_UID; $cdps += 'msedgewebview'} | |
foreach ($sw in $ALLHIVES) { | |
sp "$sw\Microsoft\EdgeUpdate" 'DoNotUpdateToEdgeWithChromium' 1 -type Dword -force | |
sp "$sw\Microsoft\EdgeUpdate" 'UpdaterExperimentationAndConfigurationServiceControl' 0 -type Dword -force | |
sp "$sw\Microsoft\EdgeUpdate" 'InstallDefault' 0 -type Dword -force | |
foreach ($uid in $uids) { | |
sp "$sw\Microsoft\EdgeUpdate" "Install${uid}" 0 -type Dword -force | |
sp "$sw\Microsoft\EdgeUpdate" "EdgePreview${uid}" 0 -type Dword -force | |
sp "$sw\Microsoft\EdgeUpdate" "Update${uid}" 2 -type Dword -force | |
foreach ($trigger in 'on-os-upgrade','on-logon','on-logon-autolaunch','on-logon-startup-boost') { | |
sp "$sw\Microsoft\EdgeUpdate\Clients\${uid}\Commands\$trigger" 'AutoRunOnLogon' 0 -type Dword -force | |
sp "$sw\Microsoft\EdgeUpdate\Clients\${uid}\Commands\$trigger" 'AutoRunOnOSUpgrade' 0 -type Dword -force | |
sp "$sw\Microsoft\EdgeUpdate\Clients\${uid}\Commands\$trigger" 'Enabled' 0 -type Dword -force | |
} | |
} | |
sp "$sw\Microsoft\MicrosoftEdge\Main" 'AllowPrelaunch' 0 -type Dword -force | |
sp "$sw\Microsoft\MicrosoftEdge\TabPreloader" 'AllowTabPreloading' 0 -type Dword -force | |
## microsoft has no shame, so we are gonna insist opting-out of unsolicited reinstalls with windows updates | |
foreach ($cdp in $cdps) { foreach ($arch in 'x64','x86') { foreach ($zdp in '','-zdp') { | |
sp "$sw\Microsoft\EdgeUpdateDev\CdpNames" "$cdp-stable-win-$arch$zdp" "$cdp-stable-win-arm64$zdp" -force | |
}}} | |
} | |
## ------------------------------------------------------------------------------------------------------------------------------- | |
## 7 add bundled OpenWebSearch script to redirect microsoft-edge: anti-competitive links to the default browser | |
$MSEP = ($env:ProgramFiles,${env:ProgramFiles(x86)})[[Environment]::Is64BitOperatingSystem] + '\Microsoft\Edge\Application' | |
$IFEO = 'HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Image File Execution Options' | |
$MIN = ('--headless','--width 1 --height 1')[([environment]::OSVersion.Version.Build) -gt 25179] | |
$CMD = "$env:systemroot\system32\conhost.exe $MIN" # AveYo: minimize prompt - see Terminal issue #13914 | |
ni "HKLM:\SOFTWARE\Classes\microsoft-edge\shell\open\command" -force >'' | |
sp "HKLM:\SOFTWARE\Classes\microsoft-edge" '(Default)' 'URL:microsoft-edge' -force | |
sp "HKLM:\SOFTWARE\Classes\microsoft-edge" 'URL Protocol' '' -force | |
sp "HKLM:\SOFTWARE\Classes\microsoft-edge" 'NoOpenWith' '' -force | |
sp "HKLM:\SOFTWARE\Classes\microsoft-edge\shell\open\command" '(Default)' "`"$DIR\ie_to_edge_stub.exe`" %1" -force | |
ni "HKLM:\SOFTWARE\Classes\MSEdgeHTM\shell\open\command" -force >'' | |
sp "HKLM:\SOFTWARE\Classes\MSEdgeHTM" 'NoOpenWith' '' -force | |
sp "HKLM:\SOFTWARE\Classes\MSEdgeHTM\shell\open\command" '(Default)' "`"$DIR\ie_to_edge_stub.exe`" %1" -force | |
ni "$IFEO\ie_to_edge_stub.exe\0" -force >'' | |
sp "$IFEO\ie_to_edge_stub.exe" 'UseFilter' 1 -type Dword -force | |
sp "$IFEO\ie_to_edge_stub.exe\0" 'FilterFullPath' "$DIR\ie_to_edge_stub.exe" -force | |
sp "$IFEO\ie_to_edge_stub.exe\0" 'Debugger' "$CMD $DIR\OpenWebSearch.cmd" -force | |
ni "$IFEO\msedge.exe\0" -force >'' | |
sp "$IFEO\msedge.exe" 'UseFilter' 1 -type Dword -force | |
sp "$IFEO\msedge.exe\0" 'FilterFullPath' "$MSEP\msedge.exe" -force | |
sp "$IFEO\msedge.exe\0" 'Debugger' "$CMD $DIR\OpenWebSearch.cmd" -force | |
## new: automatically re-create the needed hardlink if edge is reinstalled | |
$ta = New-ScheduledTaskAction -Execute '%Temp%\OpenWebSearchRepair.cmd' | |
$tt = New-ScheduledTaskTrigger -Once -At 00:00; $ts = New-ScheduledTaskSettingsSet -AllowStartIfOnBatteries | |
Register-ScheduledTask -TaskName 'OpenWebSearchRepair' -Action $ta -Trigger $tt -Settings $ts -RunLevel Highest -Force >'' | |
$OpenWebSearch = @$ | |
@title OpenWebSearch Redux & echo off & set ?= open start menu web search, widgets links or help in your chosen browser - by AveYo | |
for /f %%E in ('"prompt $E$S& for %%e in (1) do rem"') do echo;%%E[2t 2>nul & rem AveYo: minimize prompt | |
call :reg_var "HKCU\SOFTWARE\Microsoft\Windows\Shell\Associations\UrlAssociations\https\UserChoice" ProgID ProgID | |
if /i "%ProgID%" equ "MSEdgeHTM" echo;Default browser is set to Edge! Change it or remove OpenWebSearch script. & pause & exit /b | |
call :reg_var "HKCR\%ProgID%\shell\open\command" "" Browser | |
set Choice=& for %%. in (%Browser%) do if not defined Choice set "Choice=%%~." | |
call :reg_var "HKCR\MSEdgeMHT\shell\open\command" "" FallBack | |
set "Edge=" & for %%. in (%FallBack%) do if not defined Edge set "Edge=%%~." | |
set "URI=" & set "URL=" & set "NOOP=" & set "PassTrough=%Edge:msedge=edge%" | |
set "CLI=%CMDCMDLINE:"=``% " | |
if defined CLI set "CLI=%CLI:*ie_to_edge_stub.exe`` =%" | |
if defined CLI set "CLI=%CLI:*ie_to_edge_stub.exe =%" | |
if defined CLI set "CLI=%CLI:*msedge.exe`` =%" | |
if defined CLI set "CLI=%CLI:*msedge.exe =%" | |
set "FIX=%CLI:~-1%" | |
if defined CLI if "%FIX%"==" " set "CLI=%CLI:~0,-1%" | |
if defined CLI set "RED=%CLI:microsoft-edge=%" | |
if defined CLI set "URL=%CLI:http=%" | |
if defined CLI set "ARG=%CLI:``="%" | |
if "%CLI%" equ "%RED%" (set NOOP=1) else if "%CLI%" equ "%URL%" (set NOOP=1) | |
if defined NOOP if not exist "%PassTrough%" echo;@mklink /h "%PassTrough%" "%Edge%" >"%Temp%\OpenWebSearchRepair.cmd" | |
if defined NOOP if not exist "%PassTrough%" schtasks /run /tn OpenWebSearchRepair 2>nul >nul | |
if defined NOOP if not exist "%PassTrough%" timeout /t 3 >nul | |
if defined NOOP if exist "%PassTrough%" start "" "%PassTrough%" %ARG% | |
if defined NOOP exit /b | |
set "URL=%CLI:*microsoft-edge=%" | |
set "URL=http%URL:*http=%" | |
set "FIX=%URL:~-2%" | |
if defined URL if "%FIX%"=="``" set "URL=%URL:~0,-2%" | |
call :dec_url | |
start "" "%Choice%" "%URL%" | |
exit | |
:reg_var [USAGE] call :reg_var "HKCU\Volatile Environment" value-or-"" variable [extra options] | |
set {var}=& set {reg}=reg query "%~1" /v %2 /z /se "," /f /e& if %2=="" set {reg}=reg query "%~1" /ve /z /se "," /f /e | |
for /f "skip=2 tokens=* delims=" %%V in ('%{reg}% %4 %5 %6 %7 %8 %9 2^>nul') do if not defined {var} set "{var}=%%V" | |
if not defined {var} (set {reg}=& set "%~3="& exit /b) else if %2=="" set "{var}=%{var}:*) =%"& rem AveYo: v3 | |
if not defined {var} (set {reg}=& set "%~3="& exit /b) else set {reg}=& set "%~3=%{var}:*) =%"& set {var}=& exit /b | |
:dec_url brute url percent decoding by AveYo | |
set ".=%URL:!=}%"&setlocal enabledelayedexpansion& rem brute url percent decoding | |
set ".=!.:%%={!" &set ".=!.:{3A=:!" &set ".=!.:{2F=/!" &set ".=!.:{3F=?!" &set ".=!.:{23=#!" &set ".=!.:{5B=[!" &set ".=!.:{5D=]!" | |
set ".=!.:{40=@!"&set ".=!.:{21=}!" &set ".=!.:{24=$!" &set ".=!.:{26=&!" &set ".=!.:{27='!" &set ".=!.:{28=(!" &set ".=!.:{29=)!" | |
set ".=!.:{2A=*!"&set ".=!.:{2B=+!" &set ".=!.:{2C=,!" &set ".=!.:{3B=;!" &set ".=!.:{3D==!" &set ".=!.:{25=%%!"&set ".=!.:{20= !" | |
set ".=!.:{=%%!" &rem set ",=!.:%%=!" & if "!,!" neq "!.!" endlocal& set "URL=%.:}=!%" & call :dec_url | |
endlocal& set "URL=%.:}=!%" & exit /b | |
rem done | |
$@ | |
[io.file]::WriteAllText("$DIR\OpenWebSearch.cmd", $OpenWebSearch) | |
## ------------------------------------------------------------------------------------------------------------------------------- | |
## 8 done | |
$done = gp 'Registry::HKEY_Users\S-1-5-21*\Volatile*' Edge_Removal -ea 0; if ($done) {rp $done.PSPath Edge_Removal -force -ea 0} | |
if ((get-process -name 'explorer' -ea 0) -eq $null) {start explorer} | |
## bonus enter into powershell console: firefox / edge / webview to install a browser / reinstall edge or webview after removal | |
${.} = [char]27; $firefox = "${.}[38;2;255;165;0m firefox"; $reinstall = "${.}[96m edge / webview / xsocial${.}[97m " | |
write-host "`n${.}[40;32m EDGE REMOVED! ${.}[97m -GET-ANOTHER-BROWSER? ENTER:$firefox ${.}[97m -REINSTALL? ENTER:$reinstall" | |
## ------------------------------------------------------------------------------------------------------------------------------- | |
## 0 ask to run script as admin | |
'@.replace("$@","'@").replace("@$","@'") -force -ea 0; $code='gp ''Registry::HKEY_Users\S-1-5-21*\Volatile*'' Edge_Removal -ea 0' | |
start powershell -args "-nop -noe -c & {iex(($code)[0].Edge_Removal)}" -verb runas | |
$_Press_Enter | |
#:: |
Gist:
iex ((New-Object System.Net.WebClient).DownloadString('https://gist.githubusercontent.com/ishad0w/3b79bf829e9725aa102b2e8446bb5ef8/raw/aveyo_edge_removal.bat'))
AveYo/Fox repo:
iex ((New-Object System.Net.WebClient).DownloadString('https://raw.githubusercontent.com/AveYo/fox/main/Edge_Removal.bat'))
thank you! now to remove from start menu...
hello, please tell me how to return microsoft edge? reinstalling doesn't help. it still won't start.
thank you! now to remove from start menu...
Hello @garvage. Im done with right click in Edge > "Open file location" and delete it. After, search the Edge in start menu again, right click > Open in new window... Click in remove. That's worked for me!
Why hadnt i thought of that sooner, just deleting it from C:\ProgramData\Microsoft\Windows\Start Menu\Programs works.
Hi guys ! Can i still use this script in LTSC IOT Enterprise 19044.2788?
- Does the Edge still coming back after LCU update?
- What to do next after run the scripts guys? Because the app still exist in start menu. But can't open it.
- Will it break update?
Thanks you !
I don't understand how I'm supposed to use it for reinstalling edge
nvm, i found
Thank you for this.
Thanks a lot!
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
This gist is just a 'mirror'.
Source: (AveYo/fox).