mirror of
https://github.com/ChrisTitusTech/winutil.git
synced 2025-01-21 20:27:43 -06:00
Test 2023 11 15 (#1209)
* Compile Winutil * fix enable toggle visual shape (#1179) * Compile Winutil * Update README.md (#1142) * Update README.md * Update README.md Update the README.md to be more precise & clear. Fix up grammatical mistakes, allow users to figure out their issues easier. Fix crediting of IRM execution script. * Update README.md * Compile Winutil * replacing the hard-coded paths for windows dir (#1126) * Changed version of python for winget to 3.12 (#1137) * Compile Winutil * Added Programs to the Install List (#1143) * Added the checkboxes of what I want to add * Added duplicati * Added KDE Connect * Added OpenVPN Connect * Added Oracle Virtual Box * Added Paint.net * Fixed an error spotted in the KDE Connect package names * Added the checkboxes into inputXML.xaml * Added the package details to config\applications.json * Reverted changes from winutil --------- Co-authored-by: Chris Titus <contact@christitus.com> * Compile Winutil * New Section: Customize Preferences (inside tweaks section) (#1163) * convert numlock on startup checkboxs into toggle button * convert verboselogon checkbox into toggle button * gui changes : added new section, new style for toggle buttons * convert showfileextentions checkbox into toggle button * convert mouse acceleration checkboxs into togglebutton * manor changes : cleanup, adding tooltips * fix style of toggle tweaks added new style 'labelfortweaks' that fix sytle and give mouse hover effect like previous tweaks that are using checkbox style but here for toggle tweaks we are using label and to make other tweaks style 'labelfortweaks' sytle is used. it mimic the style of checkbox style --------- Co-authored-by: Chris Titus <contact@christitus.com> * Compile Winutil * add Thunderbird (#1165) * Compile Winutil * Update the screenshot in README w/ dark mode (#1173) * took a pr on main and pulling it to test (#1175) * Add Session messenger to the applications list. (#1166) * Update applications.json * Update inputXML.xaml * Compile Winutil --------- Co-authored-by: charlescgs <135472912+charlescgs@users.noreply.github.com> Co-authored-by: ChrisTitusTech <ChrisTitusTech@users.noreply.github.com> * Compile Winutil * fix enable toggle visual shape --------- Co-authored-by: ChrisTitusTech <ChrisTitusTech@users.noreply.github.com> Co-authored-by: aim <aimansadiqrahman@gmail.com> Co-authored-by: edelvarden <42596339+edelvarden@users.noreply.github.com> Co-authored-by: dass2608 <139251779+dass2608@users.noreply.github.com> Co-authored-by: Inventhrice <45127310+Inventhrice@users.noreply.github.com> Co-authored-by: Chris Titus <contact@christitus.com> Co-authored-by: Antun Nitraj <antnitraj@gmail.com> Co-authored-by: Meen Beese <meenbeese@tutanota.com> Co-authored-by: charlescgs <135472912+charlescgs@users.noreply.github.com> Co-authored-by: padsalatushal <padsalatushal@users.noreply.github.com> * Add 2 Applications (#1180) This adds KDE Dolphin File Manager and Sublime Merge. * Compile Winutil * Microwin and fixes (#1184) * Microwin and fixes * comment out product key --------- Co-authored-by: KonTy <KonTy@github.com> Co-authored-by: Chris Titus <contact@christitus.com> * Compile Winutil * Microwin Fixes * Set owner fix for issue (#1184) (#1185) * Microwin and fixes * Fix for #1184, takeown doesn't work on non English Windows --------- Co-authored-by: KonTy <KonTy@github.com> * Compile Winutil * Microwin Fix on Bare Metal Fixes the "The computer restarted unexpectedly" error on a fresh install * Compile Winutil * MicroWin: fixing German and Spanish bugs (#1194) * Fixing German and other languages local issue, also doing some house keeping * Fixed several Microwin bugs * Fixing local bug and adding copy to USB feature * Adding driver injection capabilities and fixing bugs in Microwin --------- Co-authored-by: KonTy <KonTy@github.com> * Compile Winutil * error check before removing mountDir * MicroWin Finalized - fix typo - changed oscdimg from using & to Start-Process * Compile Winutil * winget reinstall addition * Adding Floorp Browser (#1204) * Update applications.json * Khalylexe patch 1 (#2) * Update inputXML.xaml * Update applications.json (#1) * Update applications.json * Update applications.json * Update inputXML.xaml * Compile Winutil * Mercury Browser from Alex313031 (#1206) * Compile Winutil * Add Git Extensions git client (#1201) * Compile Winutil * Add PDFsam Basic (#1198) * Compile Winutil * Add new applications (#1197) * Compile Winutil * fixed typo in a few places. (#1192) * Compile Winutil * Added new tools! (#1190) * Update applications.json Added: - Anki - Clipgrab - clink - copyq - Devtoys - ohmyposh - masscode - portmaster - starship * Update inputXML.xaml added the software to the form --------- Co-authored-by: Chris Titus <contact@christitus.com> * Compile Winutil * Update applications.json (#1187) Added to choco : nilesoft-shell prismlauncher bluestacks flameshot * Compile Winutil * fix unit test * Update functions.Tests.ps1 FIXED * fix trailing comma * Compile Winutil * Update winutil.ps1 --------- Co-authored-by: ChrisTitusTech <ChrisTitusTech@users.noreply.github.com> Co-authored-by: Padsala Tushal <57517785+padsalatushal@users.noreply.github.com> Co-authored-by: aim <aimansadiqrahman@gmail.com> Co-authored-by: edelvarden <42596339+edelvarden@users.noreply.github.com> Co-authored-by: dass2608 <139251779+dass2608@users.noreply.github.com> Co-authored-by: Inventhrice <45127310+Inventhrice@users.noreply.github.com> Co-authored-by: Antun Nitraj <antnitraj@gmail.com> Co-authored-by: Meen Beese <meenbeese@tutanota.com> Co-authored-by: charlescgs <135472912+charlescgs@users.noreply.github.com> Co-authored-by: padsalatushal <padsalatushal@users.noreply.github.com> Co-authored-by: AshlynOrSomethin <31773733+AshlynOrSomethin@users.noreply.github.com> Co-authored-by: KonTy <9524513+KonTy@users.noreply.github.com> Co-authored-by: KonTy <KonTy@github.com> Co-authored-by: Khalyl <119526243+Khalylexe@users.noreply.github.com> Co-authored-by: Rodhri Erebo <109485128+erebus05@users.noreply.github.com> Co-authored-by: Julius Vitkauskas <jvitkauskas@users.noreply.github.com> Co-authored-by: Finn Krestel <83225836+FinnKrestel@users.noreply.github.com> Co-authored-by: BladeWDR <ssbarning@gmail.com> Co-authored-by: Albert <87888006+MustCodeAl@users.noreply.github.com> Co-authored-by: Straight <107145976+DaEpicR@users.noreply.github.com>
This commit is contained in:
parent
b1664158f4
commit
4be4805e7c
1
.gitignore
vendored
1
.gitignore
vendored
@ -36,3 +36,4 @@ Microsoft.PowerShell.ConsoleHost.dll
|
|||||||
|
|
||||||
# General
|
# General
|
||||||
.DS_Store
|
.DS_Store
|
||||||
|
microwin.log
|
||||||
|
@ -15,10 +15,18 @@
|
|||||||
"Winget": "Alacritty.Alacritty",
|
"Winget": "Alacritty.Alacritty",
|
||||||
"choco": "alacritty"
|
"choco": "alacritty"
|
||||||
},
|
},
|
||||||
|
"WPFInstallangryipscanner": {
|
||||||
|
"Winget": "angryziber.AngryIPScanner",
|
||||||
|
"choco": "angryip"
|
||||||
|
},
|
||||||
"WPFInstallanydesk": {
|
"WPFInstallanydesk": {
|
||||||
"winget": "AnyDeskSoftwareGmbH.AnyDesk",
|
"winget": "AnyDeskSoftwareGmbH.AnyDesk",
|
||||||
"choco": "anydesk"
|
"choco": "anydesk"
|
||||||
},
|
},
|
||||||
|
"WPFInstallanki": {
|
||||||
|
"winget": "Anki.Anki",
|
||||||
|
"choco": "anki"
|
||||||
|
},
|
||||||
"WPFInstallaimp": {
|
"WPFInstallaimp": {
|
||||||
"winget": "AIMP.AIMP",
|
"winget": "AIMP.AIMP",
|
||||||
"choco": "aimp"
|
"choco": "aimp"
|
||||||
@ -41,7 +49,7 @@
|
|||||||
},
|
},
|
||||||
"WPFInstallbluestacks": {
|
"WPFInstallbluestacks": {
|
||||||
"winget": "BlueStack.BlueStacks",
|
"winget": "BlueStack.BlueStacks",
|
||||||
"choco": "na"
|
"choco": "bluestacks"
|
||||||
},
|
},
|
||||||
"WPFInstallbrave": {
|
"WPFInstallbrave": {
|
||||||
"winget": "Brave.Brave",
|
"winget": "Brave.Brave",
|
||||||
@ -51,10 +59,18 @@
|
|||||||
"winget": "Klocman.BulkCrapUninstaller",
|
"winget": "Klocman.BulkCrapUninstaller",
|
||||||
"choco": "bulk-crap-uninstaller"
|
"choco": "bulk-crap-uninstaller"
|
||||||
},
|
},
|
||||||
|
"WPFInstallcalibre": {
|
||||||
|
"winget": "calibre.calibre",
|
||||||
|
"choco": "calibre"
|
||||||
|
},
|
||||||
"WPFInstallchrome": {
|
"WPFInstallchrome": {
|
||||||
"winget": "Google.Chrome",
|
"winget": "Google.Chrome",
|
||||||
"choco": "googlechrome"
|
"choco": "googlechrome"
|
||||||
},
|
},
|
||||||
|
"WPFInstallcopyq": {
|
||||||
|
"winget": "copyq",
|
||||||
|
"choco": "copyq"
|
||||||
|
},
|
||||||
"WPFInstallchromium": {
|
"WPFInstallchromium": {
|
||||||
"winget": "eloston.ungoogled-chromium",
|
"winget": "eloston.ungoogled-chromium",
|
||||||
"choco": "chromium"
|
"choco": "chromium"
|
||||||
@ -63,6 +79,14 @@
|
|||||||
"winget": "CiderCollective.Cider",
|
"winget": "CiderCollective.Cider",
|
||||||
"choco": "cider"
|
"choco": "cider"
|
||||||
},
|
},
|
||||||
|
"WPFInstallclink": {
|
||||||
|
"winget": "chrisant996.Clink",
|
||||||
|
"choco": "clink"
|
||||||
|
},
|
||||||
|
"WPFInstallclipgrab": {
|
||||||
|
"winget": "na",
|
||||||
|
"choco": "clipgrab"
|
||||||
|
},
|
||||||
"WPFInstallcpuz": {
|
"WPFInstallcpuz": {
|
||||||
"winget": "CPUID.CPU-Z",
|
"winget": "CPUID.CPU-Z",
|
||||||
"choco": "cpu-z"
|
"choco": "cpu-z"
|
||||||
@ -75,6 +99,10 @@
|
|||||||
"winget": "DelugeTeam.Deluge",
|
"winget": "DelugeTeam.Deluge",
|
||||||
"choco": "deluge"
|
"choco": "deluge"
|
||||||
},
|
},
|
||||||
|
"WPFInstalldevtoys": {
|
||||||
|
"winget": "devtoys",
|
||||||
|
"choco": "devToys"
|
||||||
|
},
|
||||||
"WPFInstalldiscord": {
|
"WPFInstalldiscord": {
|
||||||
"winget": "Discord.Discord",
|
"winget": "Discord.Discord",
|
||||||
"choco": "discord"
|
"choco": "discord"
|
||||||
@ -99,6 +127,10 @@
|
|||||||
"winget": "Microsoft.DotNet.DesktopRuntime.7",
|
"winget": "Microsoft.DotNet.DesktopRuntime.7",
|
||||||
"choco": "dotnet-7.0-runtime"
|
"choco": "dotnet-7.0-runtime"
|
||||||
},
|
},
|
||||||
|
"WPFInstalldolphin": {
|
||||||
|
"winget": "KDE.Dolphin",
|
||||||
|
"choco": "na"
|
||||||
|
},
|
||||||
"WPFInstallduplicati": {
|
"WPFInstallduplicati": {
|
||||||
"winget": "Duplicati.Duplicati",
|
"winget": "Duplicati.Duplicati",
|
||||||
"choco": "duplicati"
|
"choco": "duplicati"
|
||||||
@ -131,9 +163,13 @@
|
|||||||
"winget": "Mozilla.Firefox",
|
"winget": "Mozilla.Firefox",
|
||||||
"choco": "firefox"
|
"choco": "firefox"
|
||||||
},
|
},
|
||||||
|
"WPFInstallfloorp": {
|
||||||
|
"winget": "Ablaze.Floorp",
|
||||||
|
"choco": "na"
|
||||||
|
},
|
||||||
"WPFInstallflameshot": {
|
"WPFInstallflameshot": {
|
||||||
"winget": "Flameshot.Flameshot",
|
"winget": "Flameshot.Flameshot",
|
||||||
"choco": "na"
|
"choco": "flameshot"
|
||||||
},
|
},
|
||||||
"WPFInstallflux": {
|
"WPFInstallflux": {
|
||||||
"winget": "flux.flux",
|
"winget": "flux.flux",
|
||||||
@ -167,6 +203,10 @@
|
|||||||
"winget": "Git.Git;GitHub.GitHubDesktop",
|
"winget": "Git.Git;GitHub.GitHubDesktop",
|
||||||
"choco": "git;github-desktop"
|
"choco": "git;github-desktop"
|
||||||
},
|
},
|
||||||
|
"WPFInstallgitextensions": {
|
||||||
|
"winget": "Git.Git;GitExtensionsTeam.GitExtensions",
|
||||||
|
"choco": "git;gitextensions"
|
||||||
|
},
|
||||||
"WPFInstallglaryutilities": {
|
"WPFInstallglaryutilities": {
|
||||||
"Winget": "Glarysoft.GlaryUtilities",
|
"Winget": "Glarysoft.GlaryUtilities",
|
||||||
"choco": "glaryutilities-free"
|
"choco": "glaryutilities-free"
|
||||||
@ -195,6 +235,10 @@
|
|||||||
"winget": "HandBrake.HandBrake",
|
"winget": "HandBrake.HandBrake",
|
||||||
"choco": "handbrake"
|
"choco": "handbrake"
|
||||||
},
|
},
|
||||||
|
"WPFInstallheidisql": {
|
||||||
|
"winget": "HeidiSQL.HeidiSQL",
|
||||||
|
"choco": "heidisql"
|
||||||
|
},
|
||||||
"WPFInstallheroiclauncher": {
|
"WPFInstallheroiclauncher": {
|
||||||
"winget": "HeroicGamesLauncher.HeroicGamesLauncher",
|
"winget": "HeroicGamesLauncher.HeroicGamesLauncher",
|
||||||
"choco": "na"
|
"choco": "na"
|
||||||
@ -303,14 +347,26 @@
|
|||||||
"winget": "LibreWolf.LibreWolf",
|
"winget": "LibreWolf.LibreWolf",
|
||||||
"choco": "librewolf"
|
"choco": "librewolf"
|
||||||
},
|
},
|
||||||
|
"WPFInstalllinphone": {
|
||||||
|
"winget": "BelledonneCommunications.Linphone",
|
||||||
|
"choco": "linphone"
|
||||||
|
},
|
||||||
"WPFInstallmalwarebytes": {
|
"WPFInstallmalwarebytes": {
|
||||||
"winget": "Malwarebytes.Malwarebytes",
|
"winget": "Malwarebytes.Malwarebytes",
|
||||||
"choco": "malwarebytes"
|
"choco": "malwarebytes"
|
||||||
},
|
},
|
||||||
|
"WPFInstallmasscode": {
|
||||||
|
"winget": "antonreshetov.massCode",
|
||||||
|
"choco": "na"
|
||||||
|
},
|
||||||
"WPFInstallmatrix": {
|
"WPFInstallmatrix": {
|
||||||
"winget": "Element.Element",
|
"winget": "Element.Element",
|
||||||
"choco": "element-desktop"
|
"choco": "element-desktop"
|
||||||
},
|
},
|
||||||
|
"WPFInstallmercury": {
|
||||||
|
"winget": "Alex313031.Mercury",
|
||||||
|
"choco": "na"
|
||||||
|
},
|
||||||
"WPFInstallmonitorian": {
|
"WPFInstallmonitorian": {
|
||||||
"winget": "emoacht.Monitorian",
|
"winget": "emoacht.Monitorian",
|
||||||
"choco": "monitorian"
|
"choco": "monitorian"
|
||||||
@ -347,6 +403,10 @@
|
|||||||
"winget": "Neovim.Neovim",
|
"winget": "Neovim.Neovim",
|
||||||
"choco": "neovim"
|
"choco": "neovim"
|
||||||
},
|
},
|
||||||
|
"WPFInstallnextclouddesktop": {
|
||||||
|
"winget": "Nextcloud.NextcloudDesktop",
|
||||||
|
"choco": "nextcloud-client"
|
||||||
|
},
|
||||||
"WPFInstallnglide": {
|
"WPFInstallnglide": {
|
||||||
"winget": "ZeusSoftware.nGlide",
|
"winget": "ZeusSoftware.nGlide",
|
||||||
"choco": "na"
|
"choco": "na"
|
||||||
@ -403,6 +463,10 @@
|
|||||||
"winget": "Apache.OpenOffice",
|
"winget": "Apache.OpenOffice",
|
||||||
"choco": "openoffice"
|
"choco": "openoffice"
|
||||||
},
|
},
|
||||||
|
"WPFInstallopenrgb": {
|
||||||
|
"winget": "CalcProgrammer1.OpenRGB",
|
||||||
|
"choco": "openrgb"
|
||||||
|
},
|
||||||
"WPFInstallopenshell": {
|
"WPFInstallopenshell": {
|
||||||
"winget": "Open-Shell.Open-Shell-Menu",
|
"winget": "Open-Shell.Open-Shell-Menu",
|
||||||
"choco": "open-shell"
|
"choco": "open-shell"
|
||||||
@ -415,10 +479,18 @@
|
|||||||
"winget": "Oracle.VirtualBox",
|
"winget": "Oracle.VirtualBox",
|
||||||
"choco": "virtualbox"
|
"choco": "virtualbox"
|
||||||
},
|
},
|
||||||
|
"WPFInstallownclouddesktop": {
|
||||||
|
"winget": "ownCloud.ownCloudDesktop",
|
||||||
|
"choco": "owncloud-client"
|
||||||
|
},
|
||||||
"WPFInstallPaintdotnet": {
|
"WPFInstallPaintdotnet": {
|
||||||
"winget": "dotPDNLLC.paintdotnet",
|
"winget": "dotPDNLLC.paintdotnet",
|
||||||
"choco": "paint.net"
|
"choco": "paint.net"
|
||||||
},
|
},
|
||||||
|
"WPFInstallpdfsam": {
|
||||||
|
"winget": "PDFsam.PDFsam",
|
||||||
|
"choco": "pdfsam"
|
||||||
|
},
|
||||||
"WPFInstallpeazip": {
|
"WPFInstallpeazip": {
|
||||||
"winget": "Giorgiotani.Peazip",
|
"winget": "Giorgiotani.Peazip",
|
||||||
"choco": "peazip"
|
"choco": "peazip"
|
||||||
@ -431,13 +503,21 @@
|
|||||||
"winget": "Microsoft.PowerShell",
|
"winget": "Microsoft.PowerShell",
|
||||||
"choco": "powershell-core"
|
"choco": "powershell-core"
|
||||||
},
|
},
|
||||||
|
"WPFInstallposh": {
|
||||||
|
"winget": "JanDeDobbeleer.OhMyPosh",
|
||||||
|
"choco": "oh-my-posh"
|
||||||
|
},
|
||||||
"WPFInstallpowertoys": {
|
"WPFInstallpowertoys": {
|
||||||
"winget": "Microsoft.PowerToys",
|
"winget": "Microsoft.PowerToys",
|
||||||
"choco": "powertoys"
|
"choco": "powertoys"
|
||||||
},
|
},
|
||||||
|
"WPFInstallportmaster": {
|
||||||
|
"winget": "portmaster",
|
||||||
|
"choco": "portmaster"
|
||||||
|
},
|
||||||
"WPFInstallprismlauncher": {
|
"WPFInstallprismlauncher": {
|
||||||
"winget": "PrismLauncher.PrismLauncher",
|
"winget": "PrismLauncher.PrismLauncher",
|
||||||
"choco": "na"
|
"choco": "prismlauncher"
|
||||||
},
|
},
|
||||||
"WPFInstallprocesslasso": {
|
"WPFInstallprocesslasso": {
|
||||||
"winget": "BitSum.ProcessLasso",
|
"winget": "BitSum.ProcessLasso",
|
||||||
@ -493,7 +573,7 @@
|
|||||||
},
|
},
|
||||||
"WPFInstallshell": {
|
"WPFInstallshell": {
|
||||||
"winget": "Nilesoft.Shell",
|
"winget": "Nilesoft.Shell",
|
||||||
"choco": "na"
|
"choco": "nilesoft-shell"
|
||||||
},
|
},
|
||||||
"WPFInstallsignal": {
|
"WPFInstallsignal": {
|
||||||
"winget": "OpenWhisperSystems.Signal",
|
"winget": "OpenWhisperSystems.Signal",
|
||||||
@ -519,11 +599,19 @@
|
|||||||
"winget": "Valve.Steam",
|
"winget": "Valve.Steam",
|
||||||
"choco": "steam-client"
|
"choco": "steam-client"
|
||||||
},
|
},
|
||||||
|
"WPFInstallstarship": {
|
||||||
|
"winget": "starship",
|
||||||
|
"choco": "starship"
|
||||||
|
},
|
||||||
"WPFInstallstrawberry": {
|
"WPFInstallstrawberry": {
|
||||||
"winget": "StrawberryMusicPlayer.Strawberry",
|
"winget": "StrawberryMusicPlayer.Strawberry",
|
||||||
"choco": "strawberrymusicplayer"
|
"choco": "strawberrymusicplayer"
|
||||||
},
|
},
|
||||||
"WPFInstallsublime": {
|
"WPFInstallsublimemerge": {
|
||||||
|
"winget": "SublimeHQ.SublimeMerge",
|
||||||
|
"choco": "sublimemerge"
|
||||||
|
},
|
||||||
|
"WPFInstallsublimetext": {
|
||||||
"winget": "SublimeHQ.SublimeText.4",
|
"winget": "SublimeHQ.SublimeText.4",
|
||||||
"choco": "sublimetext4"
|
"choco": "sublimetext4"
|
||||||
},
|
},
|
||||||
|
@ -11,9 +11,13 @@
|
|||||||
"ButtonConfigBackgroundColor": "#444444",
|
"ButtonConfigBackgroundColor": "#444444",
|
||||||
"ButtonUpdatesBackgroundColor": "#555555",
|
"ButtonUpdatesBackgroundColor": "#555555",
|
||||||
"ButtonInstallForegroundColor": "#FFFFFF",
|
"ButtonInstallForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonTweaksForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonConfigForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonUpdatesForegroundColor": "#FFFFFF",
|
||||||
"ButtonBackgroundColor": "#CACACA",
|
"ButtonBackgroundColor": "#CACACA",
|
||||||
"ButtonBackgroundPressedColor": "#FFFFFF",
|
"ButtonBackgroundPressedColor": "#FFFFFF",
|
||||||
"ButtonBackgroundMouseoverColor": "AliceBlue",
|
"ButtonBackgroundMouseoverColor": "#A55A64",
|
||||||
|
"ButtonBackgroundSelectedColor": "#BADFFF",
|
||||||
"ButtonForegroundColor": "#000000",
|
"ButtonForegroundColor": "#000000",
|
||||||
"ButtonBorderThickness": "0",
|
"ButtonBorderThickness": "0",
|
||||||
"ButtonMargin": "0,3,0,3",
|
"ButtonMargin": "0,3,0,3",
|
||||||
@ -31,12 +35,16 @@
|
|||||||
"ButtonConfigBackgroundColor": "#444444",
|
"ButtonConfigBackgroundColor": "#444444",
|
||||||
"ButtonUpdatesBackgroundColor": "#555555",
|
"ButtonUpdatesBackgroundColor": "#555555",
|
||||||
"ButtonInstallForegroundColor": "#FFFFFF",
|
"ButtonInstallForegroundColor": "#FFFFFF",
|
||||||
"ButtonBackgroundColor": "#000000",
|
"ButtonTweaksForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonConfigForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonUpdatesForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonBackgroundColor": "#000019",
|
||||||
"ButtonBackgroundPressedColor": "#FFFFFF",
|
"ButtonBackgroundPressedColor": "#FFFFFF",
|
||||||
"ButtonBackgroundMouseoverColor": "#A55A64",
|
"ButtonBackgroundMouseoverColor": "#A55A64",
|
||||||
|
"ButtonBackgroundSelectedColor": "#FF5733",
|
||||||
"ButtonForegroundColor": "#9CCC65",
|
"ButtonForegroundColor": "#9CCC65",
|
||||||
"ButtonBorderThickness": "3",
|
"ButtonBorderThickness": "1",
|
||||||
"ButtonMargin": "2",
|
"ButtonMargin": "1",
|
||||||
"ButtonCornerRadius": "4"
|
"ButtonCornerRadius": "2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
48
functions/private/Copy-Files.ps1
Normal file
48
functions/private/Copy-Files.ps1
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
function Copy-Files {
|
||||||
|
<#
|
||||||
|
|
||||||
|
.DESCRIPTION
|
||||||
|
This function will make all modifications to the registry
|
||||||
|
|
||||||
|
.EXAMPLE
|
||||||
|
|
||||||
|
Set-WinUtilRegistry -Name "PublishUserActivities" -Path "HKLM:\SOFTWARE\Policies\Microsoft\Windows\System" -Type "DWord" -Value "0"
|
||||||
|
|
||||||
|
#>
|
||||||
|
param (
|
||||||
|
[string] $Path,
|
||||||
|
[string] $Destination,
|
||||||
|
[switch] $Recurse = $false,
|
||||||
|
[switch] $Force = $false
|
||||||
|
)
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
$files = Get-ChildItem -Path $path -Recurse:$recurse
|
||||||
|
Write-Host "Copy $($files.Count)(s) from $path to $destination"
|
||||||
|
|
||||||
|
foreach($file in $files)
|
||||||
|
{
|
||||||
|
$status = "Copy files {0} on {1}: {2}" -f $counter, $files.Count, $file.Name
|
||||||
|
Write-Progress -Activity "Copy Windows files" -Status $status -PercentComplete ($counter++/$files.count*100)
|
||||||
|
$restpath = $file.FullName -Replace $path, ''
|
||||||
|
|
||||||
|
if($file.PSIsContainer -eq $true)
|
||||||
|
{
|
||||||
|
Write-Debug "Creating $($destination + $restpath)"
|
||||||
|
New-Item ($destination+$restpath) -Force:$force -Type Directory -ErrorAction SilentlyContinue
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Write-Debug "Copy from $($file.FullName) to $($destination+$restpath)"
|
||||||
|
Copy-Item $file.FullName ($destination+$restpath) -ErrorAction SilentlyContinue -Force:$force
|
||||||
|
Set-ItemProperty -Path ($destination+$restpath) -Name IsReadOnly -Value $false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Write-Progress -Activity "Copy Windows files" -Status "Ready" -Completed
|
||||||
|
}
|
||||||
|
Catch{
|
||||||
|
Write-Warning "Unable to Copy all the files due to unhandled exception"
|
||||||
|
Write-Warning $psitem.Exception.StackTrace
|
||||||
|
}
|
||||||
|
}
|
42
functions/private/Get-LocalizedYesNo.ps1
Normal file
42
functions/private/Get-LocalizedYesNo.ps1
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
function Get-LocalizedYesNo {
|
||||||
|
<#
|
||||||
|
.SYNOPSIS
|
||||||
|
This function runs takeown.exe and captures its output to extract yes no in a localized Windows
|
||||||
|
|
||||||
|
.DESCRIPTION
|
||||||
|
The function retrieves lines from the output of takeown.exe until there are at least 2 characters
|
||||||
|
captured in a specific format, such as "Yes=<first character>, No=<second character>".
|
||||||
|
|
||||||
|
.EXAMPLE
|
||||||
|
$yesNoArray = Get-LocalizedYesNo
|
||||||
|
Write-Host "Yes=$($yesNoArray[0]), No=$($yesNoArray[1])"
|
||||||
|
#>
|
||||||
|
|
||||||
|
# Run takeown.exe and capture its output
|
||||||
|
$takeownOutput = & takeown.exe /? | Out-String
|
||||||
|
|
||||||
|
# Parse the output and retrieve lines until there are at least 2 characters in the array
|
||||||
|
$found = $false
|
||||||
|
$charactersArray = @()
|
||||||
|
foreach ($line in $takeownOutput -split "`r`n")
|
||||||
|
{
|
||||||
|
if ($found)
|
||||||
|
{
|
||||||
|
$characters = $line -split '(")([A-Za-z])(")' | Where-Object { $_ -match '^[A-Za-z]$' }
|
||||||
|
$charactersArray += $characters
|
||||||
|
|
||||||
|
if ($charactersArray.Count -ge 2)
|
||||||
|
{
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
elseif ($line -match "/D ")
|
||||||
|
{
|
||||||
|
$found = $true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Debug "According to takeown.exe local Yes is $charactersArray[0]"
|
||||||
|
# Return the array of characters
|
||||||
|
return $charactersArray
|
||||||
|
}
|
@ -11,7 +11,7 @@ function Get-WinUtilVariables {
|
|||||||
#>
|
#>
|
||||||
param (
|
param (
|
||||||
[Parameter()]
|
[Parameter()]
|
||||||
[ValidateSet("CheckBox", "Button")]
|
[ValidateSet("CheckBox", "Button", "ToggleButton")]
|
||||||
[string]$Type
|
[string]$Type
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -14,6 +14,8 @@ function Install-WinUtilWinget {
|
|||||||
.SYNOPSIS
|
.SYNOPSIS
|
||||||
Installs Winget if it is not already installed
|
Installs Winget if it is not already installed
|
||||||
|
|
||||||
|
.DESCRIPTION
|
||||||
|
This function will download the latest version of winget and install it. If winget is already installed, it will do nothing.
|
||||||
#>
|
#>
|
||||||
Try{
|
Try{
|
||||||
Write-Host "Checking if Winget is Installed..."
|
Write-Host "Checking if Winget is Installed..."
|
||||||
|
564
functions/private/MicroWin-Helper.ps1
Normal file
564
functions/private/MicroWin-Helper.ps1
Normal file
@ -0,0 +1,564 @@
|
|||||||
|
function Remove-Features([switch] $dumpFeatures = $false, [switch] $keepDefender = $false) {
|
||||||
|
<#
|
||||||
|
|
||||||
|
.SYNOPSIS
|
||||||
|
Removes certain features from ISO image
|
||||||
|
|
||||||
|
.PARAMETER Name
|
||||||
|
dumpFeatures - Dumps all features found in the ISO into a file called allfeaturesdump.txt. This file can be examined and used to decide what to remove.
|
||||||
|
keepDefender - Should Defender be removed from the ISO?
|
||||||
|
|
||||||
|
.EXAMPLE
|
||||||
|
Remove-Features -keepDefender:$false
|
||||||
|
|
||||||
|
#>
|
||||||
|
$appxlist = dism /image:$scratchDir /Get-Features | Select-String -Pattern "Feature Name : " -CaseSensitive -SimpleMatch
|
||||||
|
$appxlist = $appxlist -split "Feature Name : " | Where-Object {$_}
|
||||||
|
if ($dumpFeatures)
|
||||||
|
{
|
||||||
|
$appxlist > allfeaturesdump.txt
|
||||||
|
}
|
||||||
|
|
||||||
|
$appxlist = $appxlist | Where-Object {
|
||||||
|
$_ -NotLike "*Printing*" -AND
|
||||||
|
$_ -NotLike "*TelnetClient*" -AND
|
||||||
|
$_ -NotLike "*PowerShell*" -AND
|
||||||
|
$_ -NotLike "*NetFx*"
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($keepDefender) { $appxlist = $appxlist | Where-Object { $_ -NotLike "*Defender*" }}
|
||||||
|
|
||||||
|
foreach($feature in $appxlist)
|
||||||
|
{
|
||||||
|
$status = "Removing feature $feature"
|
||||||
|
Write-Progress -Activity "Removing features" -Status $status -PercentComplete ($counter++/$appxlist.Count*100)
|
||||||
|
Write-Debug "Removing feature $feature"
|
||||||
|
# dism /image:$scratchDir /Disable-Feature /FeatureName:$feature /Remove /NoRestart > $null
|
||||||
|
}
|
||||||
|
Write-Progress -Activity "Removing features" -Status "Ready" -Completed
|
||||||
|
}
|
||||||
|
|
||||||
|
function Remove-Packages
|
||||||
|
{
|
||||||
|
$appxlist = dism /Image:$scratchDir /Get-Packages | Select-String -Pattern "Package Identity : " -CaseSensitive -SimpleMatch
|
||||||
|
$appxlist = $appxlist -split "Package Identity : " | Where-Object {$_}
|
||||||
|
|
||||||
|
$appxlist = $appxlist | Where-Object {
|
||||||
|
$_ -NotLike "*ApplicationModel*" -AND
|
||||||
|
$_ -NotLike "*indows-Client-LanguagePack*" -AND
|
||||||
|
$_ -NotLike "*LanguageFeatures-Basic*" -AND
|
||||||
|
$_ -NotLike "*Package_for_ServicingStack*" -AND
|
||||||
|
$_ -NotLike "*.NET*" -AND
|
||||||
|
$_ -NotLike "*Store*" -AND
|
||||||
|
$_ -NotLike "*VCLibs*" -AND
|
||||||
|
$_ -NotLike "*AAD.BrokerPlugin",
|
||||||
|
$_ -NotLike "*LockApp*" -AND
|
||||||
|
$_ -NotLike "*Notepad*" -AND
|
||||||
|
$_ -NotLike "*immersivecontrolpanel*" -AND
|
||||||
|
$_ -NotLike "*ContentDeliveryManager*" -AND
|
||||||
|
$_ -NotLike "*PinningConfirMationDialog*" -AND
|
||||||
|
$_ -NotLike "*SecHealthUI*" -AND
|
||||||
|
$_ -NotLike "*SecureAssessmentBrowser*" -AND
|
||||||
|
$_ -NotLike "*PrintDialog*" -AND
|
||||||
|
$_ -NotLike "*AssignedAccessLockApp*" -AND
|
||||||
|
$_ -NotLike "*OOBENetworkConnectionFlow*" -AND
|
||||||
|
$_ -NotLike "*Apprep.ChxApp*" -AND
|
||||||
|
$_ -NotLike "*CBS*" -AND
|
||||||
|
$_ -NotLike "*OOBENetworkCaptivePortal*" -AND
|
||||||
|
$_ -NotLike "*PeopleExperienceHost*" -AND
|
||||||
|
$_ -NotLike "*ParentalControls*" -AND
|
||||||
|
$_ -NotLike "*Win32WebViewHost*" -AND
|
||||||
|
$_ -NotLike "*InputApp*" -AND
|
||||||
|
$_ -NotLike "*AccountsControl*" -AND
|
||||||
|
$_ -NotLike "*AsyncTextService*" -AND
|
||||||
|
$_ -NotLike "*CapturePicker*" -AND
|
||||||
|
$_ -NotLike "*CredDialogHost*" -AND
|
||||||
|
$_ -NotLike "*BioEnrollMent*" -AND
|
||||||
|
$_ -NotLike "*ShellExperienceHost*" -AND
|
||||||
|
$_ -NotLike "*DesktopAppInstaller*" -AND
|
||||||
|
$_ -NotLike "*WebMediaExtensions*" -AND
|
||||||
|
$_ -NotLike "*WMIC*" -AND
|
||||||
|
$_ -NotLike "*UI.XaML*"
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($appx in $appxlist)
|
||||||
|
{
|
||||||
|
$status = "Removing $appx"
|
||||||
|
Write-Progress -Activity "Removing Apps" -Status $status -PercentComplete ($counter++/$appxlist.Count*100)
|
||||||
|
dism /image:$scratchDir /Remove-Package /PackageName:$appx /NoRestart
|
||||||
|
}
|
||||||
|
Write-Progress -Activity "Removing Apps" -Status "Ready" -Completed
|
||||||
|
}
|
||||||
|
|
||||||
|
function Remove-ProvisionedPackages
|
||||||
|
{
|
||||||
|
$appxProvisionedPackages = Get-AppxProvisionedPackage -Path "$($scratchDir)" | Where-Object {
|
||||||
|
$_.PackageName -NotLike "*AppInstaller*" -AND
|
||||||
|
$_.PackageName -NotLike "*Store*" -and
|
||||||
|
$_.PackageName -NotLike "*dism*" -and
|
||||||
|
$_.PackageName -NotLike "*Foundation*" -and
|
||||||
|
$_.PackageName -NotLike "*FodMetadata*" -and
|
||||||
|
$_.PackageName -NotLike "*LanguageFeatures*" -and
|
||||||
|
$_.PackageName -NotLike "*Notepad*" -and
|
||||||
|
$_.PackageName -NotLike "*Printing*" -and
|
||||||
|
$_.PackageName -NotLike "*Wifi*" -and
|
||||||
|
$_.PackageName -NotLike "*Foundation*"
|
||||||
|
}
|
||||||
|
|
||||||
|
$counter = 0
|
||||||
|
foreach ($appx in $appxProvisionedPackages)
|
||||||
|
{
|
||||||
|
$status = "Removing Provisioned $appx"
|
||||||
|
Write-Progress -Activity "Removing Provisioned Apps" -Status $status -PercentComplete ($counter++/$appxProvisionedPackages.Count*100)
|
||||||
|
dism /image:$scratchDir /Remove-ProvisionedAppxPackage /PackageName:$appx /NoRestart
|
||||||
|
|
||||||
|
}
|
||||||
|
Write-Progress -Activity "Removing Provisioned Apps" -Status "Ready" -Completed
|
||||||
|
}
|
||||||
|
|
||||||
|
function Copy-ToUSB([string] $fileToCopy)
|
||||||
|
{
|
||||||
|
foreach ($volume in Get-Volume) {
|
||||||
|
if ($volume -and $volume.FileSystemLabel -ieq "ventoy") {
|
||||||
|
$destinationPath = "$($volume.DriveLetter):\"
|
||||||
|
#Copy-Item -Path $fileToCopy -Destination $destinationPath -Force
|
||||||
|
# Get the total size of the file
|
||||||
|
$totalSize = (Get-Item $fileToCopy).length
|
||||||
|
|
||||||
|
Copy-Item -Path $fileToCopy -Destination $destinationPath -Verbose -Force -Recurse -Container -PassThru |
|
||||||
|
ForEach-Object {
|
||||||
|
# Calculate the percentage completed
|
||||||
|
$completed = ($_.BytesTransferred / $totalSize) * 100
|
||||||
|
|
||||||
|
# Display the progress bar
|
||||||
|
Write-Progress -Activity "Copying File" -Status "Progress" -PercentComplete $completed -CurrentOperation ("{0:N2} MB / {1:N2} MB" -f ($_.BytesTransferred / 1MB), ($totalSize / 1MB))
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "File copied to Ventoy drive $($volume.DriveLette)"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Write-Host "Ventoy USB Key is not inserted"
|
||||||
|
}
|
||||||
|
|
||||||
|
function Remove-FileOrDirectory([string] $pathToDelete, [string] $mask = "", [switch] $Directory = $false)
|
||||||
|
{
|
||||||
|
if(([string]::IsNullOrEmpty($pathToDelete))) { return }
|
||||||
|
if (-not (Test-Path -Path "$($pathToDelete)")) { return }
|
||||||
|
|
||||||
|
$yesNo = Get-LocalizedYesNo
|
||||||
|
|
||||||
|
# Specify the path to the directory
|
||||||
|
# $directoryPath = "$($scratchDir)\Windows\System32\LogFiles\WMI\RtBackup"
|
||||||
|
# takeown /a /r /d $yesNo[0] /f "$($directoryPath)" > $null
|
||||||
|
# icacls "$($directoryPath)" /q /c /t /reset > $null
|
||||||
|
# icacls $directoryPath /setowner "*S-1-5-32-544"
|
||||||
|
# icacls $directoryPath /grant "*S-1-5-32-544:(OI)(CI)F" /t /c /q
|
||||||
|
# Remove-Item -Path $directoryPath -Recurse -Force
|
||||||
|
|
||||||
|
# # Grant full control to BUILTIN\Administrators using icacls
|
||||||
|
# $directoryPath = "$($scratchDir)\Windows\System32\WebThreatDefSvc"
|
||||||
|
# takeown /a /r /d $yesNo[0] /f "$($directoryPath)" > $null
|
||||||
|
# icacls "$($directoryPath)" /q /c /t /reset > $null
|
||||||
|
# icacls $directoryPath /setowner "*S-1-5-32-544"
|
||||||
|
# icacls $directoryPath /grant "*S-1-5-32-544:(OI)(CI)F" /t /c /q
|
||||||
|
# Remove-Item -Path $directoryPath -Recurse -Force
|
||||||
|
|
||||||
|
$itemsToDelete = [System.Collections.ArrayList]::new()
|
||||||
|
|
||||||
|
if ($mask -eq "")
|
||||||
|
{
|
||||||
|
Write-Debug "Adding $($pathToDelete) to array."
|
||||||
|
[void]$itemsToDelete.Add($pathToDelete)
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Write-Debug "Adding $($pathToDelete) to array and mask is $($mask)"
|
||||||
|
if ($Directory) { $itemsToDelete = Get-ChildItem $pathToDelete -Include $mask -Recurse -Directory }
|
||||||
|
else { $itemsToDelete = Get-ChildItem $pathToDelete -Include $mask -Recurse }
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach($itemToDelete in $itemsToDelete)
|
||||||
|
{
|
||||||
|
$status = "Deleteing $($itemToDelete)"
|
||||||
|
Write-Progress -Activity "Removing Items" -Status $status -PercentComplete ($counter++/$itemsToDelete.Count*100)
|
||||||
|
|
||||||
|
if (Test-Path -Path "$($itemToDelete)" -PathType Container)
|
||||||
|
{
|
||||||
|
$status = "Deleting directory: $($itemToDelete)"
|
||||||
|
|
||||||
|
takeown /r /d $yesNo[0] /a /f "$($itemToDelete)"
|
||||||
|
icacls "$($itemToDelete)" /q /c /t /reset
|
||||||
|
icacls $itemToDelete /setowner "*S-1-5-32-544"
|
||||||
|
icacls $itemToDelete /grant "*S-1-5-32-544:(OI)(CI)F" /t /c /q
|
||||||
|
Remove-Item -Force -Recurse "$($itemToDelete)"
|
||||||
|
}
|
||||||
|
elseif (Test-Path -Path "$($itemToDelete)" -PathType Leaf)
|
||||||
|
{
|
||||||
|
$status = "Deleting file: $($itemToDelete)"
|
||||||
|
|
||||||
|
takeown /a /f "$($itemToDelete)"
|
||||||
|
icacls "$($itemToDelete)" /q /c /t /reset
|
||||||
|
icacls "$($itemToDelete)" /setowner "*S-1-5-32-544"
|
||||||
|
icacls "$($itemToDelete)" /grant "*S-1-5-32-544:(OI)(CI)F" /t /c /q
|
||||||
|
Remove-Item -Force "$($itemToDelete)"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Write-Progress -Activity "Removing Items" -Status "Ready" -Completed
|
||||||
|
}
|
||||||
|
|
||||||
|
function New-Unattend {
|
||||||
|
|
||||||
|
# later if we wont to remove even more bloat EU requires MS to remove everything from English(world)
|
||||||
|
# Below is an example how to do it we probably should create a drop down with common locals
|
||||||
|
# <settings pass="specialize">
|
||||||
|
# <!-- Specify English (World) locale -->
|
||||||
|
# <component name="Microsoft-Windows-International-Core" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
# <SetupUILanguage>
|
||||||
|
# <UILanguage>en-US</UILanguage>
|
||||||
|
# </SetupUILanguage>
|
||||||
|
# <InputLocale>en-US</InputLocale>
|
||||||
|
# <SystemLocale>en-US</SystemLocale>
|
||||||
|
# <UILanguage>en-US</UILanguage>
|
||||||
|
# <UserLocale>en-US</UserLocale>
|
||||||
|
# </component>
|
||||||
|
# </settings>
|
||||||
|
|
||||||
|
# <settings pass="oobeSystem">
|
||||||
|
# <!-- Specify English (World) locale -->
|
||||||
|
# <component name="Microsoft-Windows-International-Core" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
# <InputLocale>en-US</InputLocale>
|
||||||
|
# <SystemLocale>en-US</SystemLocale>
|
||||||
|
# <UILanguage>en-US</UILanguage>
|
||||||
|
# <UserLocale>en-US</UserLocale>
|
||||||
|
# </component>
|
||||||
|
# </settings>
|
||||||
|
# using here string to embedd unattend
|
||||||
|
# <RunSynchronousCommand wcm:action="add">
|
||||||
|
# <Order>1</Order>
|
||||||
|
# <Path>net user administrator /active:yes</Path>
|
||||||
|
# </RunSynchronousCommand>
|
||||||
|
|
||||||
|
$unattend = @'
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<unattend xmlns="urn:schemas-microsoft-com:unattend"
|
||||||
|
xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<settings pass="specialize">
|
||||||
|
<component name="Microsoft-Windows-SQMApi" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<CEIPEnabled>0</CEIPEnabled>
|
||||||
|
</component>
|
||||||
|
<component name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<ConfigureChatAutoInstall>false</ConfigureChatAutoInstall>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<settings pass="auditUser">
|
||||||
|
<component name="Microsoft-Windows-Deployment" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<RunSynchronous>
|
||||||
|
<RunSynchronousCommand wcm:action="add">
|
||||||
|
<Order>1</Order>
|
||||||
|
<CommandLine>CMD /C echo LAU GG>C:\Windows\LogAuditUser.txt</CommandLine>
|
||||||
|
<Description>StartMenu</Description>
|
||||||
|
</RunSynchronousCommand>
|
||||||
|
</RunSynchronous>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<settings pass="oobeSystem">
|
||||||
|
<component name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<OOBE>
|
||||||
|
<HideOEMRegistrationScreen>true</HideOEMRegistrationScreen>
|
||||||
|
<SkipUserOOBE>false</SkipUserOOBE>
|
||||||
|
<SkipMachineOOBE>false</SkipMachineOOBE>
|
||||||
|
<HideOnlineAccountScreens>true</HideOnlineAccountScreens>
|
||||||
|
<HideWirelessSetupInOOBE>true</HideWirelessSetupInOOBE>
|
||||||
|
<HideEULAPage>true</HideEULAPage>
|
||||||
|
<ProtectYourPC>3</ProtectYourPC>
|
||||||
|
</OOBE>
|
||||||
|
<FirstLogonCommands>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<Order>1</Order>
|
||||||
|
<CommandLine>cmd.exe /c echo 23>c:\windows\csup.txt</CommandLine>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<Order>2</Order>
|
||||||
|
<CommandLine>CMD /C echo GG>C:\Windows\LogOobeSystem.txt</CommandLine>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<Order>3</Order>
|
||||||
|
<CommandLine>powershell -ExecutionPolicy Bypass -File c:\windows\FirstStartup.ps1</CommandLine>
|
||||||
|
</SynchronousCommand>
|
||||||
|
</FirstLogonCommands>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
</unattend>
|
||||||
|
'@
|
||||||
|
$unattend | Out-File -FilePath "$env:temp\unattend.xml" -Force
|
||||||
|
}
|
||||||
|
|
||||||
|
function New-CheckInstall {
|
||||||
|
|
||||||
|
# using here string to embedd firstrun
|
||||||
|
$checkInstall = @'
|
||||||
|
@echo off
|
||||||
|
if exist "C:\windows\cpu.txt" (
|
||||||
|
echo C:\windows\cpu.txt exists
|
||||||
|
) else (
|
||||||
|
echo C:\windows\cpu.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\windows\SerialNumber.txt" (
|
||||||
|
echo C:\windows\SerialNumber.txt exists
|
||||||
|
) else (
|
||||||
|
echo C:\windows\SerialNumber.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\unattend.xml" (
|
||||||
|
echo C:\unattend.xml exists
|
||||||
|
) else (
|
||||||
|
echo C:\unattend.xml does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\Setup\Scripts\SetupComplete.cmd" (
|
||||||
|
echo C:\Windows\Setup\Scripts\SetupComplete.cmd exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\Setup\Scripts\SetupComplete.cmd does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\Panther\unattend.xml" (
|
||||||
|
echo C:\Windows\Panther\unattend.xml exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\Panther\unattend.xml does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\System32\Sysprep\unattend.xml" (
|
||||||
|
echo C:\Windows\System32\Sysprep\unattend.xml exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\System32\Sysprep\unattend.xml does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\FirstStartup.ps1" (
|
||||||
|
echo C:\Windows\FirstStartup.ps1 exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\FirstStartup.ps1 does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\winutil.ps1" (
|
||||||
|
echo C:\Windows\winutil.ps1 exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\winutil.ps1 does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\LogSpecialize.txt" (
|
||||||
|
echo C:\Windows\LogSpecialize.txt exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\LogSpecialize.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\LogAuditUser.txt" (
|
||||||
|
echo C:\Windows\LogAuditUser.txt exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\LogAuditUser.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\LogOobeSystem.txt" (
|
||||||
|
echo C:\Windows\LogOobeSystem.txt exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\LogOobeSystem.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "c:\windows\csup.txt" (
|
||||||
|
echo c:\windows\csup.txt exists
|
||||||
|
) else (
|
||||||
|
echo c:\windows\csup.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "c:\windows\LogFirstRun.txt" (
|
||||||
|
echo c:\windows\LogFirstRun.txt exists
|
||||||
|
) else (
|
||||||
|
echo c:\windows\LogFirstRun.txt does not exist
|
||||||
|
)
|
||||||
|
'@
|
||||||
|
$checkInstall | Out-File -FilePath "$env:temp\checkinstall.cmd" -Force -Encoding Ascii
|
||||||
|
}
|
||||||
|
|
||||||
|
function New-FirstRun {
|
||||||
|
|
||||||
|
# using here string to embedd firstrun
|
||||||
|
$firstRun = @'
|
||||||
|
# Set the global error action preference to continue
|
||||||
|
$ErrorActionPreference = "Continue"
|
||||||
|
function Remove-RegistryValue
|
||||||
|
{
|
||||||
|
param (
|
||||||
|
[Parameter(Mandatory = $true)]
|
||||||
|
[string]$RegistryPath,
|
||||||
|
|
||||||
|
[Parameter(Mandatory = $true)]
|
||||||
|
[string]$ValueName
|
||||||
|
)
|
||||||
|
|
||||||
|
# Check if the registry path exists
|
||||||
|
if (Test-Path -Path $RegistryPath)
|
||||||
|
{
|
||||||
|
$registryValue = Get-ItemProperty -Path $RegistryPath -Name $ValueName -ErrorAction SilentlyContinue
|
||||||
|
|
||||||
|
# Check if the registry value exists
|
||||||
|
if ($registryValue)
|
||||||
|
{
|
||||||
|
# Remove the registry value
|
||||||
|
Remove-ItemProperty -Path $RegistryPath -Name $ValueName -Force
|
||||||
|
Write-Host "Registry value '$ValueName' removed from '$RegistryPath'."
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Write-Host "Registry value '$ValueName' not found in '$RegistryPath'."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Write-Host "Registry path '$RegistryPath' not found."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function Stop-UnnecessaryServices
|
||||||
|
{
|
||||||
|
$servicesAuto = @"
|
||||||
|
"AudioSrv",
|
||||||
|
"AudioEndpointBuilder",
|
||||||
|
"BFE",
|
||||||
|
"BITS",
|
||||||
|
"BrokerInfrastructure",
|
||||||
|
"CDPSvc",
|
||||||
|
"CDPUserSvc_dc2a4",
|
||||||
|
"CoreMessagingRegistrar",
|
||||||
|
"CryptSvc",
|
||||||
|
"DPS",
|
||||||
|
"DcomLaunch",
|
||||||
|
"Dhcp",
|
||||||
|
"DispBrokerDesktopSvc",
|
||||||
|
"Dnscache",
|
||||||
|
"DoSvc",
|
||||||
|
"DusmSvc",
|
||||||
|
"EventLog",
|
||||||
|
"EventSystem",
|
||||||
|
"FontCache",
|
||||||
|
"LSM",
|
||||||
|
"LanmanServer",
|
||||||
|
"LanmanWorkstation",
|
||||||
|
"MapsBroker",
|
||||||
|
"MpsSvc",
|
||||||
|
"OneSyncSvc_dc2a4",
|
||||||
|
"Power",
|
||||||
|
"ProfSvc",
|
||||||
|
"RpcEptMapper",
|
||||||
|
"RpcSs",
|
||||||
|
"SCardSvr",
|
||||||
|
"SENS",
|
||||||
|
"SamSs",
|
||||||
|
"Schedule",
|
||||||
|
"SgrmBroker",
|
||||||
|
"ShellHWDetection",
|
||||||
|
"Spooler",
|
||||||
|
"SysMain",
|
||||||
|
"SystemEventsBroker",
|
||||||
|
"TextInputManagementService",
|
||||||
|
"Themes",
|
||||||
|
"TrkWks",
|
||||||
|
"UserManager",
|
||||||
|
"VGAuthService",
|
||||||
|
"VMTools",
|
||||||
|
"WSearch",
|
||||||
|
"Wcmsvc",
|
||||||
|
"WinDefend",
|
||||||
|
"Winmgmt",
|
||||||
|
"WlanSvc",
|
||||||
|
"WpnService",
|
||||||
|
"WpnUserService_dc2a4",
|
||||||
|
"cbdhsvc_dc2a4",
|
||||||
|
"edgeupdate",
|
||||||
|
"gpsvc",
|
||||||
|
"iphlpsvc",
|
||||||
|
"mpssvc",
|
||||||
|
"nsi",
|
||||||
|
"sppsvc",
|
||||||
|
"tiledatamodelsvc",
|
||||||
|
"vm3dservice",
|
||||||
|
"webthreatdefusersvc_dc2a4",
|
||||||
|
"wscsvc"
|
||||||
|
"@
|
||||||
|
|
||||||
|
$allServices = Get-Service | Where-Object { $_.StartType -eq "Automatic" -and $servicesAuto -NotContains $_.Name}
|
||||||
|
foreach($service in $allServices)
|
||||||
|
{
|
||||||
|
Stop-Service -Name $service.Name -PassThru
|
||||||
|
Set-Service $service.Name -StartupType Manual
|
||||||
|
"Stopping service $($service.Name)" | Out-File -FilePath c:\windows\LogFirstRun.txt -Append -NoClobber
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
"FirstStartup has worked" | Out-File -FilePath c:\windows\LogFirstRun.txt -Append -NoClobber
|
||||||
|
|
||||||
|
$Theme = "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize"
|
||||||
|
Set-ItemProperty -Path $Theme -Name AppsUseLightTheme -Value 1
|
||||||
|
Set-ItemProperty -Path $Theme -Name SystemUsesLightTheme -Value 1
|
||||||
|
|
||||||
|
# figure this out later how to set updates to security only
|
||||||
|
#Import-Module -Name PSWindowsUpdate;
|
||||||
|
#Stop-Service -Name wuauserv
|
||||||
|
#Set-WUSettings -MicrosoftUpdateEnabled -AutoUpdateOption 'Never'
|
||||||
|
#Start-Service -Name wuauserv
|
||||||
|
|
||||||
|
Stop-UnnecessaryServices
|
||||||
|
|
||||||
|
$taskbarPath = "$env:AppData\Microsoft\Internet Explorer\Quick Launch\User Pinned\TaskBar"
|
||||||
|
# Delete all files on the Taskbar
|
||||||
|
Get-ChildItem -Path $taskbarPath -File | Remove-Item -Force
|
||||||
|
Remove-RegistryValue -RegistryPath "HKCU:\Software\Microsoft\Windows\CurrentVersion\Explorer\Taskband" -ValueName "FavoritesRemovedChanges"
|
||||||
|
Remove-RegistryValue -RegistryPath "HKCU:\Software\Microsoft\Windows\CurrentVersion\Explorer\Taskband" -ValueName "FavoritesChanges"
|
||||||
|
Remove-RegistryValue -RegistryPath "HKCU:\Software\Microsoft\Windows\CurrentVersion\Explorer\Taskband" -ValueName "Favorites"
|
||||||
|
|
||||||
|
# Stop-Process -Name explorer -Force
|
||||||
|
|
||||||
|
$process = Get-Process -Name "explorer"
|
||||||
|
Stop-Process -InputObject $process
|
||||||
|
# Wait for the process to exit
|
||||||
|
Wait-Process -InputObject $process
|
||||||
|
Start-Sleep -Seconds 3
|
||||||
|
|
||||||
|
# Delete Edge Icon from the desktop
|
||||||
|
$edgeShortcutFiles = Get-ChildItem -Path $desktopPath -Filter "*Edge*.lnk"
|
||||||
|
# Check if Edge shortcuts exist on the desktop
|
||||||
|
if ($edgeShortcutFiles)
|
||||||
|
{
|
||||||
|
foreach ($shortcutFile in $edgeShortcutFiles)
|
||||||
|
{
|
||||||
|
# Remove each Edge shortcut
|
||||||
|
Remove-Item -Path $shortcutFile.FullName -Force
|
||||||
|
Write-Host "Edge shortcut '$($shortcutFile.Name)' removed from the desktop."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Remove-Item -Path "$env:USERPROFILE\Desktop\*.lnk"
|
||||||
|
Remove-Item -Path "C:\Users\Default\Desktop\*.lnk"
|
||||||
|
|
||||||
|
# ************************************************
|
||||||
|
# Create WinUtil shortcut on the desktop
|
||||||
|
#
|
||||||
|
$desktopPath = "$($env:USERPROFILE)\Desktop"
|
||||||
|
# Specify the target PowerShell command
|
||||||
|
$command = "powershell.exe -NoProfile -ExecutionPolicy Bypass -Command 'irm https://christitus.com/win | iex'"
|
||||||
|
# Specify the path for the shortcut
|
||||||
|
$shortcutPath = Join-Path $desktopPath 'winutil.lnk'
|
||||||
|
# Create a shell object
|
||||||
|
$shell = New-Object -ComObject WScript.Shell
|
||||||
|
|
||||||
|
# Create a shortcut object
|
||||||
|
$shortcut = $shell.CreateShortcut($shortcutPath)
|
||||||
|
|
||||||
|
if (Test-Path -Path "c:\Windows\cttlogo.png")
|
||||||
|
{
|
||||||
|
$shortcut.IconLocation = "c:\Windows\cttlogo.png"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Set properties of the shortcut
|
||||||
|
$shortcut.TargetPath = "powershell.exe"
|
||||||
|
$shortcut.Arguments = "-NoProfile -ExecutionPolicy Bypass -Command `"$command`""
|
||||||
|
# Save the shortcut
|
||||||
|
$shortcut.Save()
|
||||||
|
Write-Host "Shortcut created at: $shortcutPath"
|
||||||
|
#
|
||||||
|
# Done create WinUtil shortcut on the desktop
|
||||||
|
# ************************************************
|
||||||
|
|
||||||
|
Start-Process explorer
|
||||||
|
|
||||||
|
'@
|
||||||
|
$firstRun | Out-File -FilePath "$env:temp\FirstStartup.ps1" -Force
|
||||||
|
}
|
@ -15,16 +15,16 @@ function Remove-WinUtilAPPX {
|
|||||||
$Name
|
$Name
|
||||||
)
|
)
|
||||||
|
|
||||||
Try{
|
Try {
|
||||||
Write-Host "Removing $Name"
|
Write-Host "Removing $Name"
|
||||||
Get-AppxPackage "*$Name*" | Remove-AppxPackage -ErrorAction SilentlyContinue
|
Get-AppxPackage "*$Name*" | Remove-AppxPackage -ErrorAction SilentlyContinue
|
||||||
Get-AppxProvisionedPackage -Online | Where-Object DisplayName -like "*$Name*" | Remove-AppxProvisionedPackage -Online -ErrorAction SilentlyContinue
|
Get-AppxProvisionedPackage -Online | Where-Object DisplayName -like "*$Name*" | Remove-AppxProvisionedPackage -Online -ErrorAction SilentlyContinue
|
||||||
}
|
}
|
||||||
Catch [System.Exception] {
|
Catch [System.Exception] {
|
||||||
if($psitem.Exception.Message -like "*The requested operation requires elevation*"){
|
if ($psitem.Exception.Message -like "*The requested operation requires elevation*") {
|
||||||
Write-Warning "Unable to uninstall $name due to a Security Exception"
|
Write-Warning "Unable to uninstall $name due to a Security Exception"
|
||||||
}
|
}
|
||||||
Else{
|
else {
|
||||||
Write-Warning "Unable to uninstall $name due to unhandled exception"
|
Write-Warning "Unable to uninstall $name due to unhandled exception"
|
||||||
Write-Warning $psitem.Exception.StackTrace
|
Write-Warning $psitem.Exception.StackTrace
|
||||||
}
|
}
|
||||||
|
@ -46,11 +46,14 @@ function Invoke-WPFButton {
|
|||||||
"WPFPaneluser" {Invoke-WPFControlPanel -Panel $button}
|
"WPFPaneluser" {Invoke-WPFControlPanel -Panel $button}
|
||||||
"WPFUpdatesdefault" {Invoke-WPFUpdatesdefault}
|
"WPFUpdatesdefault" {Invoke-WPFUpdatesdefault}
|
||||||
"WPFFixesUpdate" {Invoke-WPFFixesUpdate}
|
"WPFFixesUpdate" {Invoke-WPFFixesUpdate}
|
||||||
|
"WPFFixesWinget" {Invoke-WPFFixesWinget}
|
||||||
"WPFFixesNetwork" {Invoke-WPFFixesNetwork}
|
"WPFFixesNetwork" {Invoke-WPFFixesNetwork}
|
||||||
"WPFUpdatesdisable" {Invoke-WPFUpdatesdisable}
|
"WPFUpdatesdisable" {Invoke-WPFUpdatesdisable}
|
||||||
"WPFUpdatessecurity" {Invoke-WPFUpdatessecurity}
|
"WPFUpdatessecurity" {Invoke-WPFUpdatessecurity}
|
||||||
"WPFWinUtilShortcut" {Invoke-WPFShortcut -ShortcutToAdd "WinUtil"}
|
"WPFWinUtilShortcut" {Invoke-WPFShortcut -ShortcutToAdd "WinUtil"}
|
||||||
"WPFGetInstalled" {Invoke-WPFGetInstalled -CheckBox "winget"}
|
"WPFGetInstalled" {Invoke-WPFGetInstalled -CheckBox "winget"}
|
||||||
"WPFGetInstalledTweaks" {Invoke-WPFGetInstalled -CheckBox "tweaks"}
|
"WPFGetInstalledTweaks" {Invoke-WPFGetInstalled -CheckBox "tweaks"}
|
||||||
|
"WPFGetIso" {Invoke-WPFGetIso}
|
||||||
|
"WPFMicrowin" {Invoke-WPFMicrowin}
|
||||||
}
|
}
|
||||||
}
|
}
|
13
functions/public/Invoke-WPFFixesWinget.ps1
Normal file
13
functions/public/Invoke-WPFFixesWinget.ps1
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
function Invoke-WPFFixesWinget {
|
||||||
|
|
||||||
|
<#
|
||||||
|
|
||||||
|
.SYNOPSIS
|
||||||
|
Fixes Winget by running choco install winget
|
||||||
|
.DESCRIPTION
|
||||||
|
BravoNorris for the fantastic idea of a button to reinstall winget
|
||||||
|
#>
|
||||||
|
|
||||||
|
Start-Process -FilePath "choco" -ArgumentList "install winget -y" -NoNewWindow -Wait
|
||||||
|
|
||||||
|
}
|
@ -29,7 +29,6 @@ Function Invoke-WPFFormVariables {
|
|||||||
Write-Host "====Chris Titus Tech====="
|
Write-Host "====Chris Titus Tech====="
|
||||||
Write-Host "=====Windows Toolbox====="
|
Write-Host "=====Windows Toolbox====="
|
||||||
|
|
||||||
|
|
||||||
#====DEBUG GUI Elements====
|
#====DEBUG GUI Elements====
|
||||||
|
|
||||||
#Write-Host "Found the following interactable elements from our form" -ForegroundColor Cyan
|
#Write-Host "Found the following interactable elements from our form" -ForegroundColor Cyan
|
||||||
|
125
functions/public/Invoke-WPFGetIso.ps1
Normal file
125
functions/public/Invoke-WPFGetIso.ps1
Normal file
@ -0,0 +1,125 @@
|
|||||||
|
function Invoke-WPFGetIso {
|
||||||
|
<#
|
||||||
|
.DESCRIPTION
|
||||||
|
Function to get the path to Iso file for MicroWin, unpack that isom=, read basic information and populate the UI Options
|
||||||
|
#>
|
||||||
|
|
||||||
|
Write-Host "Invoking WPFGetIso"
|
||||||
|
|
||||||
|
if($sync.ProcessRunning){
|
||||||
|
$msg = "GetIso process is currently running."
|
||||||
|
[System.Windows.MessageBox]::Show($msg, "Winutil", [System.Windows.MessageBoxButton]::OK, [System.Windows.MessageBoxImage]::Warning)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host " _ __ __ _ "
|
||||||
|
Write-Host " /\/\ (_) ___ _ __ ___ / / /\ \ \(_) _ __ "
|
||||||
|
Write-Host " / \ | | / __|| '__| / _ \ \ \/ \/ /| || '_ \ "
|
||||||
|
Write-Host "/ /\/\ \| || (__ | | | (_) | \ /\ / | || | | | "
|
||||||
|
Write-Host "\/ \/|_| \___||_| \___/ \/ \/ |_||_| |_| "
|
||||||
|
|
||||||
|
$oscdImgFound = [bool] (Get-Command -ErrorAction Ignore -Type Application oscdimg)
|
||||||
|
Write-Host "oscdimge.exe on system: $oscdImgFound"
|
||||||
|
|
||||||
|
if (!$oscdImgFound)
|
||||||
|
{
|
||||||
|
[System.Windows.MessageBox]::Show("oscdimge.exe is not found on the system, you need to download it first before running this function!")
|
||||||
|
|
||||||
|
# the step below needs choco to download oscdimg
|
||||||
|
$chocoFound = [bool] (Get-Command -ErrorAction Ignore -Type Application choco)
|
||||||
|
Write-Host "choco on system: $oscdImgFound"
|
||||||
|
if (!$chocoFound)
|
||||||
|
{
|
||||||
|
[System.Windows.MessageBox]::Show("choco.exe is not found on the system, you need choco to download oscdimg.exe")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
Start-Process -Verb runas -FilePath powershell.exe -ArgumentList "choco install windows-adk-oscdimg"
|
||||||
|
[System.Windows.MessageBox]::Show("oscdimg is installed, now close, reopen PowerShell terminal and re-launch winutil.ps1 !!!")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
[System.Reflection.Assembly]::LoadWithPartialName("System.windows.forms") | Out-Null
|
||||||
|
$openFileDialog = New-Object System.Windows.Forms.OpenFileDialog
|
||||||
|
$openFileDialog.initialDirectory = $initialDirectory
|
||||||
|
$openFileDialog.filter = "ISO files (*.iso)| *.iso"
|
||||||
|
$openFileDialog.ShowDialog() | Out-Null
|
||||||
|
$filePath = $openFileDialog.FileName
|
||||||
|
|
||||||
|
if ([string]::IsNullOrEmpty($filePath))
|
||||||
|
{
|
||||||
|
Write-Host "No ISO is chosen"
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "File path $($filePath)"
|
||||||
|
if (-not (Test-Path -Path $filePath -PathType Leaf))
|
||||||
|
{
|
||||||
|
$msg = "File you've chosen doesn't exist"
|
||||||
|
[System.Windows.MessageBox]::Show($msg, "Winutil", [System.Windows.MessageBoxButton]::OK, [System.Windows.MessageBoxImage]::Error)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "Mounting Iso. Please wait."
|
||||||
|
$mountedISO = Mount-DiskImage -PassThru "$filePath"
|
||||||
|
Write-Host "Done mounting Iso $mountedISO"
|
||||||
|
$driveLetter = (Get-Volume -DiskImage $mountedISO).DriveLetter
|
||||||
|
Write-Host "Iso mounted to '$driveLetter'"
|
||||||
|
# storing off values in hidden fields for further steps
|
||||||
|
# there is probably a better way of doing this, I don't have time to figure this out
|
||||||
|
$sync.MicrowinIsoDrive.Text = $driveLetter
|
||||||
|
|
||||||
|
Write-Host "Setting up mount dir and scratch dirs"
|
||||||
|
$mountDir = "c:\microwin"
|
||||||
|
$scratchDir = "c:\microwinscratch"
|
||||||
|
$sync.MicrowinMountDir.Text = $mountDir
|
||||||
|
$sync.MicrowinScratchDir.Text = $scratchDir
|
||||||
|
Write-Host "Done setting up mount dir and scratch dirs"
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
$data = @($driveLetter, $filePath)
|
||||||
|
New-Item -ItemType Directory -Force -Path "$($mountDir)" | Out-Null
|
||||||
|
New-Item -ItemType Directory -Force -Path "$($scratchDir)" | Out-Null
|
||||||
|
Write-Host "Copying Windows image. This will take awhile, please don't use UI or cancel this step!"
|
||||||
|
|
||||||
|
# xcopy we can verify files and also not copy files that already exist, but hard to measure
|
||||||
|
# xcopy.exe /E /I /H /R /Y /J $DriveLetter":" $mountDir >$null
|
||||||
|
$totalTime = Measure-Command { Copy-Files "$($driveLetter):" $mountDir -Recurse -Force }
|
||||||
|
Write-Host "Copy complete! Total Time: $($totalTime.Minutes)m$($totalTime.Seconds)s"
|
||||||
|
|
||||||
|
$wimFile = "$mountDir\sources\install.wim"
|
||||||
|
Write-Host "Getting image information $wimFile"
|
||||||
|
|
||||||
|
if (-not (Test-Path -Path $wimFile -PathType Leaf))
|
||||||
|
{
|
||||||
|
$msg = "install wim file doesn't exist in the image, are you sure you used Windows image??"
|
||||||
|
[System.Windows.MessageBox]::Show($msg, "Winutil", [System.Windows.MessageBoxButton]::OK, [System.Windows.MessageBoxImage]::Error)
|
||||||
|
throw
|
||||||
|
}
|
||||||
|
Get-WindowsImage -ImagePath $wimFile | ForEach-Object {
|
||||||
|
$imageIdx = $_.ImageIndex
|
||||||
|
$imageName = $_.ImageName
|
||||||
|
$sync.MicrowinWindowsFlavors.Items.Add("$imageIdx : $imageName")
|
||||||
|
}
|
||||||
|
$sync.MicrowinWindowsFlavors.SelectedIndex = 0
|
||||||
|
Get-Volume $driveLetter | Get-DiskImage | Dismount-DiskImage
|
||||||
|
Write-Host "Selected value '$($sync.MicrowinWindowsFlavors.SelectedValue)'....."
|
||||||
|
|
||||||
|
$sync.MicrowinOptionsPanel.Visibility = 'Visible'
|
||||||
|
} catch {
|
||||||
|
Write-Host "Dismounting bad image..."
|
||||||
|
Get-Volume $driveLetter | Get-DiskImage | Dismount-DiskImage
|
||||||
|
Remove-Item -Recurse -Force "$($scratchDir)"
|
||||||
|
Remove-Item -Recurse -Force "$($mountDir)"
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "Done reading and unpacking ISO"
|
||||||
|
Write-Host ""
|
||||||
|
Write-Host "*********************************"
|
||||||
|
Write-Host "Check the UI for further steps!!!"
|
||||||
|
|
||||||
|
$sync.ProcessRunning = $false
|
||||||
|
}
|
||||||
|
|
||||||
|
|
335
functions/public/Invoke-WPFMicrowin.ps1
Normal file
335
functions/public/Invoke-WPFMicrowin.ps1
Normal file
@ -0,0 +1,335 @@
|
|||||||
|
function Invoke-WPFMicrowin {
|
||||||
|
<#
|
||||||
|
.DESCRIPTION
|
||||||
|
Invoke MicroWin routines...
|
||||||
|
#>
|
||||||
|
|
||||||
|
if($sync.ProcessRunning) {
|
||||||
|
$msg = "GetIso process is currently running."
|
||||||
|
[System.Windows.MessageBox]::Show($msg, "Winutil", [System.Windows.MessageBoxButton]::OK, [System.Windows.MessageBoxImage]::Warning)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
$index = $sync.MicrowinWindowsFlavors.SelectedValue.Split(":")[0].Trim()
|
||||||
|
Write-Host "Index chosen: '$index' from $($sync.MicrowinWindowsFlavors.SelectedValue)"
|
||||||
|
|
||||||
|
$keepPackages = $sync.WPFMicrowinKeepProvisionedPackages.IsChecked
|
||||||
|
$keepProvisionedPackages = $sync.WPFMicrowinKeepAppxPackages.IsChecked
|
||||||
|
$keepDefender = $sync.WPFMicrowinKeepDefender.IsChecked
|
||||||
|
$keepEdge = $sync.WPFMicrowinKeepEdge.IsChecked
|
||||||
|
$copyToUSB = $sync.WPFMicrowinCopyToUsb.IsChecked
|
||||||
|
$injectDrivers = $sync.MicrowinInjectDrivers.IsChecked
|
||||||
|
|
||||||
|
$mountDir = $sync.MicrowinMountDir.Text
|
||||||
|
$scratchDir = $sync.MicrowinScratchDir.Text
|
||||||
|
|
||||||
|
$mountDirExists = Test-Path $mountDir
|
||||||
|
$scratchDirExists = Test-Path $scratchDir
|
||||||
|
if (-not $mountDirExists -or -not $scratchDirExists)
|
||||||
|
{
|
||||||
|
Write-Error "Required directories '$mountDirExists' '$scratchDirExists' and do not exist."
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
Write-Host "Mounting Windows image. This may take a while."
|
||||||
|
dism /mount-image /imagefile:$mountDir\sources\install.wim /index:$index /mountdir:$scratchDir
|
||||||
|
Write-Host "Mounting complete! Performing removal of applications..."
|
||||||
|
|
||||||
|
if ($injectDrivers)
|
||||||
|
{
|
||||||
|
$driverPath = $sync.MicrowinDriverLocation.Text
|
||||||
|
if (Test-Path $driverPath)
|
||||||
|
{
|
||||||
|
Write-Host "Adding Windows Drivers image($scratchDir) drivers($driverPath) "
|
||||||
|
dism /image:$scratchDir /add-driver /driver:$driverPath /recurse | Out-Host
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Write-Host "Path to drivers is invalid continuing without driver injection"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "Remove Features from the image"
|
||||||
|
Remove-Features -keepDefender:$keepDefender
|
||||||
|
Write-Host "Removing features complete!"
|
||||||
|
|
||||||
|
Write-Host "Removing Appx Bloat"
|
||||||
|
if (!$keepPackages)
|
||||||
|
{
|
||||||
|
Remove-Packages
|
||||||
|
}
|
||||||
|
if (!$keepProvisionedPackages)
|
||||||
|
{
|
||||||
|
Remove-ProvisionedPackages
|
||||||
|
}
|
||||||
|
|
||||||
|
# special code, for some reason when you try to delete some inbox apps
|
||||||
|
# we have to get and delete log files directory.
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\LogFiles\WMI\RtBackup" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\WebThreatDefSvc" -Directory
|
||||||
|
|
||||||
|
# Defender is hidden in 2 places we removed a feature above now need to remove it from the disk
|
||||||
|
if (!$keepDefender)
|
||||||
|
{
|
||||||
|
Write-Host "Removing Defender"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Windows Defender" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Windows Defender"
|
||||||
|
}
|
||||||
|
if (!$keepEdge)
|
||||||
|
{
|
||||||
|
Write-Host "Removing Edge"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Microsoft" -mask "*edge*" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Microsoft" -mask "*edge*" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\SystemApps" -mask "*edge*" -Directory
|
||||||
|
}
|
||||||
|
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\DiagTrack" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\InboxApps" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\SecurityHealthSystray.exe"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\LocationNotificationWindows.exe"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Windows Photo Viewer" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Windows Photo Viewer" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Windows Media Player" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Windows Media Player" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Windows Mail" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Windows Mail" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Internet Explorer" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Internet Explorer" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\GameBarPresenceWriter"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\OneDriveSetup.exe"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\OneDrive.ico"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\SystemApps" -mask "*Windows.Search*" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\SystemApps" -mask "*narratorquickstart*" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\SystemApps" -mask "*Xbox*" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\SystemApps" -mask "*ParentalControls*" -Directory
|
||||||
|
Write-Host "Removal complete!"
|
||||||
|
|
||||||
|
# *************************** Automation black ***************************
|
||||||
|
# this doesn't work for some reason, this script is not being run at the end of the install
|
||||||
|
# if someone knows how to fix this, feel free to modify
|
||||||
|
New-Item -ItemType Directory -Force -Path $scratchDir\Windows\Setup\Scripts\
|
||||||
|
"wmic cpu get Name > C:\windows\cpu.txt" | Out-File -FilePath "$($scratchDir)\Windows\Setup\Scripts\SetupComplete.cmd" -NoClobber -Append
|
||||||
|
"wmic bios get serialnumber > C:\windows\SerialNumber.txt" | Out-File -FilePath "$($scratchDir)\Windows\Setup\Scripts\SetupComplete.cmd" -NoClobber -Append
|
||||||
|
"devmgmt.msc /s" | Out-File -FilePath "$($scratchDir)\Windows\Setup\Scripts\SetupComplete.cmd" -NoClobber -Append
|
||||||
|
|
||||||
|
Write-Host "Create unattend.xml"
|
||||||
|
New-Unattend
|
||||||
|
Write-Host "Done Create unattend.xml"
|
||||||
|
Write-Host "Copy unattend.xml file into the ISO"
|
||||||
|
New-Item -ItemType Directory -Force -Path "$($scratchDir)\Windows\Panther"
|
||||||
|
Copy-Item "$env:temp\unattend.xml" "$($scratchDir)\Windows\Panther\unattend.xml" -force
|
||||||
|
New-Item -ItemType Directory -Force -Path "$($scratchDir)\Windows\System32\Sysprep"
|
||||||
|
Copy-Item "$env:temp\unattend.xml" "$($scratchDir)\Windows\System32\Sysprep\unattend.xml" -force
|
||||||
|
Copy-Item "$env:temp\unattend.xml" "$($scratchDir)\unattend.xml" -force
|
||||||
|
Write-Host "Done Copy unattend.xml"
|
||||||
|
|
||||||
|
Write-Host "Create FirstRun"
|
||||||
|
New-FirstRun
|
||||||
|
Write-Host "Done create FirstRun"
|
||||||
|
Write-Host "Copy FirstRun.ps1 into the ISO"
|
||||||
|
Copy-Item "$env:temp\FirstStartup.ps1" "$($scratchDir)\Windows\FirstStartup.ps1" -force
|
||||||
|
Write-Host "Done copy FirstRun.ps1"
|
||||||
|
|
||||||
|
Write-Host "Copy link to winutil.ps1 into the ISO"
|
||||||
|
$desktopDir = "$($scratchDir)\Windows\Users\Default\Desktop"
|
||||||
|
New-Item -ItemType Directory -Force -Path "$desktopDir"
|
||||||
|
dism /image:$($scratchDir) /set-profilepath:"$($scratchDir)\Windows\Users\Default"
|
||||||
|
$command = "powershell.exe -NoProfile -ExecutionPolicy Bypass -Command 'irm https://christitus.com/win | iex'"
|
||||||
|
$shortcutPath = "$desktopDir\WinUtil.lnk"
|
||||||
|
$shell = New-Object -ComObject WScript.Shell
|
||||||
|
$shortcut = $shell.CreateShortcut($shortcutPath)
|
||||||
|
|
||||||
|
if (Test-Path -Path "$env:TEMP\cttlogo.png")
|
||||||
|
{
|
||||||
|
$pngPath = "$env:TEMP\cttlogo.png"
|
||||||
|
$icoPath = "$env:TEMP\cttlogo.ico"
|
||||||
|
Add-Type -AssemblyName System.Drawing
|
||||||
|
$pngImage = [System.Drawing.Image]::FromFile($pngPath)
|
||||||
|
$pngImage.Save($icoPath, [System.Drawing.Imaging.ImageFormat]::Icon)
|
||||||
|
Write-Host "ICO file created at: $icoPath"
|
||||||
|
Copy-Item "$env:TEMP\cttlogo.png" "$($scratchDir)\Windows\cttlogo.png" -force
|
||||||
|
Copy-Item "$env:TEMP\cttlogo.ico" "$($scratchDir)\cttlogo.ico" -force
|
||||||
|
$shortcut.IconLocation = "c:\cttlogo.ico"
|
||||||
|
}
|
||||||
|
|
||||||
|
$shortcut.TargetPath = "powershell.exe"
|
||||||
|
$shortcut.Arguments = "-NoProfile -ExecutionPolicy Bypass -Command `"$command`""
|
||||||
|
$shortcut.Save()
|
||||||
|
Write-Host "Shortcut to winutil created at: $shortcutPath"
|
||||||
|
# *************************** Automation black ***************************
|
||||||
|
|
||||||
|
Write-Host "Copy checkinstall.cmd into the ISO"
|
||||||
|
New-CheckInstall
|
||||||
|
Copy-Item "$env:temp\checkinstall.cmd" "$($scratchDir)\Windows\checkinstall.cmd" -force
|
||||||
|
Write-Host "Done copy checkinstall.cmd"
|
||||||
|
|
||||||
|
Write-Host "Creating a directory that allows to bypass Wifi setup"
|
||||||
|
New-Item -ItemType Directory -Force -Path "$($scratchDir)\Windows\System32\OOBE\BYPASSNRO"
|
||||||
|
|
||||||
|
Write-Host "Loading registry"
|
||||||
|
reg load HKLM\zCOMPONENTS "$($scratchDir)\Windows\System32\config\COMPONENTS"
|
||||||
|
reg load HKLM\zDEFAULT "$($scratchDir)\Windows\System32\config\default"
|
||||||
|
reg load HKLM\zNTUSER "$($scratchDir)\Users\Default\ntuser.dat"
|
||||||
|
reg load HKLM\zSOFTWARE "$($scratchDir)\Windows\System32\config\SOFTWARE"
|
||||||
|
reg load HKLM\zSYSTEM "$($scratchDir)\Windows\System32\config\SYSTEM"
|
||||||
|
|
||||||
|
Write-Host "Disabling Teams"
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Communications" /v "ConfigureChatAutoInstall" /t REG_DWORD /d 0 /f >$null 2>&1
|
||||||
|
reg add "HKLM\zSOFTWARE\Policies\Microsoft\Windows\Windows Chat" /v ChatIcon /t REG_DWORD /d 2 /f >$null 2>&1
|
||||||
|
reg add "HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarMn" /t REG_DWORD /d 0 /f >$null 2>&1
|
||||||
|
reg query "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Communications" /v "ConfigureChatAutoInstall" >$null 2>&1
|
||||||
|
# Write-Host Error code $LASTEXITCODE
|
||||||
|
Write-Host "Done disabling Teams"
|
||||||
|
|
||||||
|
Write-Host "Bypassing system requirements (system image)"
|
||||||
|
reg add "HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache" /v "SV1" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache" /v "SV2" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache" /v "SV1" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache" /v "SV2" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassCPUCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassRAMCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassSecureBootCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassStorageCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassTPMCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\MoSetup" /v "AllowUpgradesWithUnsupportedTPMOrCPU" /t REG_DWORD /d 1 /f
|
||||||
|
|
||||||
|
if (!$keepEdge)
|
||||||
|
{
|
||||||
|
Write-Host "Removing Edge icon from taskbar"
|
||||||
|
reg delete "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Taskband" /v "Favorites" /f >$null 2>&1
|
||||||
|
reg delete "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Taskband" /v "FavoritesChanges" /f >$null 2>&1
|
||||||
|
reg delete "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Taskband" /v "Pinned" /f >$null 2>&1
|
||||||
|
reg delete "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Taskband" /v "LayoutCycle" /f >$null 2>&1
|
||||||
|
Write-Host "Edge icon removed from taskbar"
|
||||||
|
}
|
||||||
|
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Search" /v "SearchboxTaskbarMode" /t REG_DWORD /d 0 /f
|
||||||
|
Write-Host "Setting all services to start manually"
|
||||||
|
reg add "HKLM\zSOFTWARE\CurrentControlSet\Services" /v Start /t REG_DWORD /d 3 /f
|
||||||
|
# Write-Host $LASTEXITCODE
|
||||||
|
|
||||||
|
Write-Host "Enabling Local Accounts on OOBE"
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\OOBE" /v "BypassNRO" /t REG_DWORD /d "1" /f
|
||||||
|
|
||||||
|
Write-Host "Disabling Sponsored Apps"
|
||||||
|
reg add "HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "OemPreInstalledAppsEnabled" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "PreInstalledAppsEnabled" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SilentInstalledAppsEnabled" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zSOFTWARE\Policies\Microsoft\Windows\CloudContent" /v "DisableWindowsConsumerFeatures" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\PolicyManager\current\device\Start" /v "ConfigureStartPins" /t REG_SZ /d '{\"pinnedList\": [{}]}' /f
|
||||||
|
Write-Host "Done removing Sponsored Apps"
|
||||||
|
|
||||||
|
Write-Host "Disabling Reserved Storage"
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\ReserveManager" /v "ShippedWithReserves" /t REG_DWORD /d 0 /f
|
||||||
|
|
||||||
|
Write-Host "Changing theme to dark. This only works on Activated Windows"
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize" /v "AppsUseLightTheme" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize" /v "SystemUsesLightTheme" /t REG_DWORD /d 0 /f
|
||||||
|
|
||||||
|
} catch {
|
||||||
|
Write-Error "An unexpected error occurred: $_"
|
||||||
|
} finally {
|
||||||
|
Write-Host "Unmounting Registry..."
|
||||||
|
reg unload HKLM\zCOMPONENTS
|
||||||
|
reg unload HKLM\zDEFAULT
|
||||||
|
reg unload HKLM\zNTUSER
|
||||||
|
reg unload HKLM\zSOFTWARE
|
||||||
|
reg unload HKLM\zSYSTEM
|
||||||
|
|
||||||
|
Write-Host "Cleaning up image..."
|
||||||
|
dism /image:$scratchDir /Cleanup-Image /StartComponentCleanup /ResetBase
|
||||||
|
Write-Host "Cleanup complete."
|
||||||
|
|
||||||
|
Write-Host "Unmounting image..."
|
||||||
|
dism /unmount-image /mountdir:$scratchDir /commit
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
Write-Host "Exporting image into $mountDir\sources\install2.wim"
|
||||||
|
dism /Export-Image /SourceImageFile:"$mountDir\sources\install.wim" /SourceIndex:$index /DestinationImageFile:"$mountDir\sources\install2.wim" /compress:max
|
||||||
|
Write-Host "Remove old '$mountDir\sources\install.wim' and rename $mountDir\sources\install2.wim"
|
||||||
|
Remove-Item "$mountDir\sources\install.wim"
|
||||||
|
Rename-Item "$mountDir\sources\install2.wim" "$mountDir\sources\install.wim"
|
||||||
|
|
||||||
|
if (-not (Test-Path -Path "$mountDir\sources\install.wim"))
|
||||||
|
{
|
||||||
|
Write-Error "Somethig went wrong and '$mountDir\sources\install.wim' doesn't exist. Please report this bug to the devs"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
Write-Host "Windows image completed. Continuing with boot.wim."
|
||||||
|
|
||||||
|
# Next step boot image
|
||||||
|
Write-Host "Mounting boot image $mountDir\sources\boot.wim into $scratchDir"
|
||||||
|
dism /mount-image /imagefile:"$mountDir\sources\boot.wim" /index:2 /mountdir:"$scratchDir"
|
||||||
|
|
||||||
|
Write-Host "Loading registry..."
|
||||||
|
reg load HKLM\zCOMPONENTS "$($scratchDir)\Windows\System32\config\COMPONENTS" >$null
|
||||||
|
reg load HKLM\zDEFAULT "$($scratchDir)\Windows\System32\config\default" >$null
|
||||||
|
reg load HKLM\zNTUSER "$($scratchDir)\Users\Default\ntuser.dat" >$null
|
||||||
|
reg load HKLM\zSOFTWARE "$($scratchDir)\Windows\System32\config\SOFTWARE" >$null
|
||||||
|
reg load HKLM\zSYSTEM "$($scratchDir)\Windows\System32\config\SYSTEM" >$null
|
||||||
|
Write-Host "Bypassing system requirements on the setup image"
|
||||||
|
reg add "HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache" /v "SV1" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache" /v "SV2" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache" /v "SV1" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache" /v "SV2" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassCPUCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassRAMCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassSecureBootCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassStorageCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassTPMCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\MoSetup" /v "AllowUpgradesWithUnsupportedTPMOrCPU" /t REG_DWORD /d 1 /f
|
||||||
|
# Fix Computer Restarted Unexpectedly Error on New Bare Metal Install
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\Status\ChildCompletion" /v "setup.exe" /t REG_DWORD /d 3 /f
|
||||||
|
} catch {
|
||||||
|
Write-Error "An unexpected error occurred: $_"
|
||||||
|
} finally {
|
||||||
|
Write-Host "Unmounting Registry..."
|
||||||
|
reg unload HKLM\zCOMPONENTS
|
||||||
|
reg unload HKLM\zDEFAULT
|
||||||
|
reg unload HKLM\zNTUSER
|
||||||
|
reg unload HKLM\zSOFTWARE
|
||||||
|
reg unload HKLM\zSYSTEM
|
||||||
|
|
||||||
|
Write-Host "Unmounting image..."
|
||||||
|
dism /unmount-image /mountdir:$scratchDir /commit
|
||||||
|
|
||||||
|
Write-Host "Creating ISO image"
|
||||||
|
#& oscdimg.exe -m -o -u2 -udfver102 -bootdata:2#p0,e,b$mountDir\boot\etfsboot.com#pEF,e,b$mountDir\efi\microsoft\boot\efisys.bin $mountDir $env:temp\microwin.iso
|
||||||
|
Start-Process -FilePath "oscdimg.exe" -ArgumentList "-m -o -u2 -udfver102 -bootdata:2#p0,e,b$mountDir\boot\etfsboot.com#pEF,e,b$mountDir\efi\microsoft\boot\efisys.bin $mountDir $env:temp\microwin.iso" -NoNewWindow -Wait
|
||||||
|
|
||||||
|
if ($copyToUSB)
|
||||||
|
{
|
||||||
|
Write-Host "Copying microwin.iso to the USB drive"
|
||||||
|
Copy-ToUSB("$env:temp\microwin.iso")
|
||||||
|
Write-Host "Done Copying microwin.iso to USB drive!"
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host " _____ "
|
||||||
|
Write-Host "(____ \ "
|
||||||
|
Write-Host " _ \ \ ___ ____ ____ "
|
||||||
|
Write-Host "| | | / _ \| _ \ / _ ) "
|
||||||
|
Write-Host "| |__/ / |_| | | | ( (/ / "
|
||||||
|
Write-Host "|_____/ \___/|_| |_|\____) "
|
||||||
|
|
||||||
|
# Check if the ISO was successfully created - CTT edit
|
||||||
|
if ($LASTEXITCODE -eq 0) {
|
||||||
|
Write-Host "Done. ISO image is located here: $env:temp\microwin.iso"
|
||||||
|
Write-Host "Performing Cleanup"
|
||||||
|
Remove-Item -Recurse -Force "$($scratchDir)"
|
||||||
|
Remove-Item -Recurse -Force "$($mountDir)"
|
||||||
|
} else {
|
||||||
|
Write-Host "ISO creation failed. The "$($mountDir)" directory has not been removed."
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$sync.MicrowinOptionsPanel.Visibility = 'Collapsed'
|
||||||
|
|
||||||
|
$sync.MicrowinFinalIsoLocation.Text = "$env:temp\microwin.iso"
|
||||||
|
|
||||||
|
$sync.ProcessRunning = $false
|
||||||
|
}
|
||||||
|
}
|
@ -11,17 +11,21 @@ function Invoke-WPFTab {
|
|||||||
#>
|
#>
|
||||||
|
|
||||||
Param ($ClickedTab)
|
Param ($ClickedTab)
|
||||||
$Tabs = Get-WinUtilVariables | Where-Object {$psitem -like "WPFTab?BT"}
|
|
||||||
$TabNav = Get-WinUtilVariables | Where-Object {$psitem -like "WPFTabNav"}
|
|
||||||
$x = [int]($ClickedTab -replace "WPFTab","" -replace "BT","") - 1
|
|
||||||
|
|
||||||
0..($Tabs.Count -1 ) | ForEach-Object {
|
$tabNav = Get-WinUtilVariables | Where-Object {$psitem -like "WPFTabNav"}
|
||||||
|
$tabNumber = [int]($ClickedTab -replace "WPFTab","" -replace "BT","") - 1
|
||||||
|
|
||||||
if ($x -eq $psitem){
|
$filter = Get-WinUtilVariables -Type ToggleButton | Where-Object {$psitem -like "WPFTab?BT"}
|
||||||
$sync.$TabNav.Items[$psitem].IsSelected = $true
|
$sync.GetEnumerator() | Where-Object {$psitem.Key -in $filter} | ForEach-Object {
|
||||||
|
if ($ClickedTab -ne $PSItem.name) {
|
||||||
|
$sync[$PSItem.Name].IsChecked = $false
|
||||||
|
# $tabNumber = [int]($PSItem.Name -replace "WPFTab","" -replace "BT","") - 1
|
||||||
|
# $sync.$tabNav.Items[$tabNumber].IsSelected = $false
|
||||||
}
|
}
|
||||||
else{
|
else {
|
||||||
$sync.$TabNav.Items[$psitem].IsSelected = $false
|
$sync["$ClickedTab"].IsChecked = $true
|
||||||
|
$tabNumber = [int]($ClickedTab-replace "WPFTab","" -replace "BT","") - 1
|
||||||
|
$sync.$tabNav.Items[$tabNumber].IsSelected = $true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,8 +16,6 @@ Describe "Functions"{
|
|||||||
fullname = $psitem.FullName
|
fullname = $psitem.FullName
|
||||||
} {
|
} {
|
||||||
Get-ChildItem function:\$basename | should -Not -BeNullOrEmpty
|
Get-ChildItem function:\$basename | should -Not -BeNullOrEmpty
|
||||||
} {
|
|
||||||
get-help $basename -ErrorAction SilentlyContinue | Select-Object -ExpandProperty Description | should -Not -BeNullOrEmpty
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
191
scripts/main.ps1
191
scripts/main.ps1
@ -96,6 +96,16 @@ $sync.keys | ForEach-Object {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$sync.keys | ForEach-Object {
|
||||||
|
if($sync.$psitem){
|
||||||
|
if($($sync["$psitem"].GetType() | Select-Object -ExpandProperty Name) -eq "ToggleButton"){
|
||||||
|
$sync["$psitem"].Add_Click({
|
||||||
|
[System.Object]$Sender = $args[0]
|
||||||
|
Invoke-WPFButton $Sender.name
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$sync.keys | ForEach-Object {
|
$sync.keys | ForEach-Object {
|
||||||
if($sync.$psitem){
|
if($sync.$psitem){
|
||||||
@ -113,7 +123,6 @@ $sync.keys | ForEach-Object {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#===========================================================================
|
#===========================================================================
|
||||||
# Setup background config
|
# Setup background config
|
||||||
#===========================================================================
|
#===========================================================================
|
||||||
@ -121,9 +130,7 @@ $sync.keys | ForEach-Object {
|
|||||||
# Load computer information in the background
|
# Load computer information in the background
|
||||||
Invoke-WPFRunspace -ScriptBlock {
|
Invoke-WPFRunspace -ScriptBlock {
|
||||||
$sync.ConfigLoaded = $False
|
$sync.ConfigLoaded = $False
|
||||||
|
|
||||||
$sync.ComputerInfo = Get-ComputerInfo
|
$sync.ComputerInfo = Get-ComputerInfo
|
||||||
|
|
||||||
$sync.ConfigLoaded = $True
|
$sync.ConfigLoaded = $True
|
||||||
} | Out-Null
|
} | Out-Null
|
||||||
|
|
||||||
@ -146,7 +153,181 @@ $sync["Form"].Add_Closing({
|
|||||||
[System.GC]::Collect()
|
[System.GC]::Collect()
|
||||||
})
|
})
|
||||||
|
|
||||||
# Show the form
|
# add some shortcuts for people that don't like clicking
|
||||||
$sync["Form"].ShowDialog() | out-null
|
$commonKeyEvents = {
|
||||||
|
if ($sync.ProcessRunning -eq $true) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
# Escape removes focus from the searchbox that way all shortcuts will start workinf again
|
||||||
|
if ($_.Key -eq "Escape") {
|
||||||
|
if ($sync.CheckboxFilter.IsFocused)
|
||||||
|
{
|
||||||
|
$sync.CheckboxFilter.SelectAll()
|
||||||
|
$sync.CheckboxFilter.Text = ""
|
||||||
|
$sync.CheckboxFilter.Focus()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# don't ask, I know what I'm doing, just go...
|
||||||
|
if (($_.Key -eq "Q" -and $_.KeyboardDevice.Modifiers -eq "Ctrl"))
|
||||||
|
{
|
||||||
|
$this.Close()
|
||||||
|
}
|
||||||
|
|
||||||
|
# $ret = [System.Windows.Forms.MessageBox]::Show("Are you sure you want to Exit?", "Winutil", [System.Windows.Forms.MessageBoxButtons]::YesNo,
|
||||||
|
# [System.Windows.Forms.MessageBoxIcon]::Question, [System.Windows.Forms.MessageBoxDefaultButton]::Button2)
|
||||||
|
|
||||||
|
# switch ($ret) {
|
||||||
|
# "Yes" {
|
||||||
|
# $this.Close()
|
||||||
|
# }
|
||||||
|
# "No" {
|
||||||
|
# return
|
||||||
|
# }
|
||||||
|
# }
|
||||||
|
|
||||||
|
|
||||||
|
if ($_.KeyboardDevice.Modifiers -eq "Alt") {
|
||||||
|
# this is an example how to handle shortcuts per tab
|
||||||
|
# Alt-I on the MicroWin tab (4) would press GetIso Button
|
||||||
|
# NOTE: All per tab shortcuts have to be handled *before* regular tab keys
|
||||||
|
# if ($_.SystemKey -eq "I") {
|
||||||
|
# $TabNav = Get-WinUtilVariables | Where-Object {$psitem -like "WPFTabNav"}
|
||||||
|
# if ($sync.$TabNav.Items[4].IsSelected -eq $true) {
|
||||||
|
# Invoke-WPFButton "WPFGetIso"
|
||||||
|
# break
|
||||||
|
# }
|
||||||
|
# }
|
||||||
|
if ($_.SystemKey -eq "I") {
|
||||||
|
Invoke-WPFButton "WPFTab1BT"
|
||||||
|
}
|
||||||
|
if ($_.SystemKey -eq "T") {
|
||||||
|
Invoke-WPFButton "WPFTab2BT"
|
||||||
|
}
|
||||||
|
if ($_.SystemKey -eq "C") {
|
||||||
|
Invoke-WPFButton "WPFTab3BT"
|
||||||
|
}
|
||||||
|
if ($_.SystemKey -eq "U") {
|
||||||
|
Invoke-WPFButton "WPFTab4BT"
|
||||||
|
}
|
||||||
|
if ($_.SystemKey -eq "M") {
|
||||||
|
Invoke-WPFButton "WPFTab5BT"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
# shortcut for the filter box
|
||||||
|
if ($_.Key -eq "F" -and $_.KeyboardDevice.Modifiers -eq "Ctrl") {
|
||||||
|
if ($sync.CheckboxFilter.Text -eq "Ctrl-F to filter") {
|
||||||
|
$sync.CheckboxFilter.SelectAll()
|
||||||
|
$sync.CheckboxFilter.Text = ""
|
||||||
|
}
|
||||||
|
$sync.CheckboxFilter.Focus()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$sync["Form"].Add_PreViewKeyDown($commonKeyEvents)
|
||||||
|
|
||||||
|
# adding some left mouse window move on drag capability
|
||||||
|
$sync["Form"].Add_MouseLeftButtonDown({
|
||||||
|
$sync["Form"].DragMove()
|
||||||
|
})
|
||||||
|
|
||||||
|
# setting window icon to make it look more professional
|
||||||
|
$sync["Form"].Add_Loaded({
|
||||||
|
|
||||||
|
$downloadUrl = "https://christitus.com/images/logo-full.png"
|
||||||
|
$destinationPath = Join-Path $env:TEMP "cttlogo.png"
|
||||||
|
|
||||||
|
# Check if the file already exists
|
||||||
|
if (-not (Test-Path $destinationPath)) {
|
||||||
|
# File does not exist, download it
|
||||||
|
$wc = New-Object System.Net.WebClient
|
||||||
|
$wc.DownloadFile($downloadUrl, $destinationPath)
|
||||||
|
Write-Output "File downloaded to: $destinationPath"
|
||||||
|
} else {
|
||||||
|
Write-Output "File already exists at: $destinationPath"
|
||||||
|
}
|
||||||
|
$sync["Form"].Icon = $destinationPath
|
||||||
|
|
||||||
|
Try {
|
||||||
|
[Void][Window]
|
||||||
|
} Catch {
|
||||||
|
Add-Type @"
|
||||||
|
using System;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
|
public class Window {
|
||||||
|
[DllImport("user32.dll")]
|
||||||
|
[return: MarshalAs(UnmanagedType.Bool)]
|
||||||
|
public static extern bool GetWindowRect(IntPtr hWnd, out RECT lpRect);
|
||||||
|
[DllImport("user32.dll")]
|
||||||
|
[return: MarshalAs(UnmanagedType.Bool)]
|
||||||
|
public static extern bool MoveWindow(IntPtr handle, int x, int y, int width, int height, bool redraw);
|
||||||
|
[DllImport("user32.dll")]
|
||||||
|
[return: MarshalAs(UnmanagedType.Bool)]
|
||||||
|
public static extern bool ShowWindow(IntPtr handle, int state);
|
||||||
|
}
|
||||||
|
public struct RECT {
|
||||||
|
public int Left; // x position of upper-left corner
|
||||||
|
public int Top; // y position of upper-left corner
|
||||||
|
public int Right; // x position of lower-right corner
|
||||||
|
public int Bottom; // y position of lower-right corner
|
||||||
|
}
|
||||||
|
"@
|
||||||
|
}
|
||||||
|
|
||||||
|
$processId = [System.Diagnostics.Process]::GetCurrentProcess().Id
|
||||||
|
$windowHandle = (Get-Process -Id $processId).MainWindowHandle
|
||||||
|
$rect = New-Object RECT
|
||||||
|
[Void][Window]::GetWindowRect($windowHandle,[ref]$rect)
|
||||||
|
|
||||||
|
# only snap upper edge don't move left to right, in case people have multimon setup
|
||||||
|
$x = $rect.Left
|
||||||
|
$y = 0
|
||||||
|
$width = $rect.Right - $rect.Left
|
||||||
|
$height = $rect.Bottom - $rect.Top
|
||||||
|
|
||||||
|
# Move the window to that position...
|
||||||
|
[Void][Window]::MoveWindow($windowHandle, $x, $y, $width, $height, $True)
|
||||||
|
Invoke-WPFTab "WPFTab1BT"
|
||||||
|
$sync["Form"].Focus()
|
||||||
|
})
|
||||||
|
|
||||||
|
$sync["CheckboxFilter"].Add_TextChanged({
|
||||||
|
#Write-host $sync.CheckboxFilter.Text
|
||||||
|
|
||||||
|
$filter = Get-WinUtilVariables -Type Checkbox
|
||||||
|
$CheckBoxes = $sync.GetEnumerator() | Where-Object {$psitem.Key -in $filter}
|
||||||
|
$textToSearch = $sync.CheckboxFilter.Text
|
||||||
|
Foreach ($CheckBox in $CheckBoxes) {
|
||||||
|
#Write-Host "$($sync.CheckboxFilter.Text)"
|
||||||
|
if ($CheckBox -eq $null -or $CheckBox.Value -eq $null -or $CheckBox.Value.Content -eq $null) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if ($CheckBox.Value.Content.ToLower().Contains($textToSearch)) {
|
||||||
|
$CheckBox.Value.Visibility = "Visible"
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$CheckBox.Value.Visibility = "Collapsed"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
$downloadUrl = "https://christitus.com/images/logo-full.png"
|
||||||
|
$destinationPath = Join-Path $env:TEMP "cttlogo.png"
|
||||||
|
|
||||||
|
# Check if the file already exists
|
||||||
|
if (-not (Test-Path $destinationPath)) {
|
||||||
|
# File does not exist, download it
|
||||||
|
$wc = New-Object System.Net.WebClient
|
||||||
|
$wc.DownloadFile($downloadUrl, $destinationPath)
|
||||||
|
Write-Output "File downloaded to: $destinationPath"
|
||||||
|
} else {
|
||||||
|
Write-Output "File already exists at: $destinationPath"
|
||||||
|
}
|
||||||
|
|
||||||
|
# show current windowsd Product ID
|
||||||
|
#Write-Host "Your Windows Product Key: $((Get-WmiObject -query 'select * from SoftwareLicensingService').OA3xOriginalProductKey)"
|
||||||
|
|
||||||
|
$sync["Form"].ShowDialog() | out-null
|
||||||
Stop-Transcript
|
Stop-Transcript
|
@ -9,6 +9,7 @@
|
|||||||
Start-Transcript $ENV:TEMP\Winutil.log -Append
|
Start-Transcript $ENV:TEMP\Winutil.log -Append
|
||||||
|
|
||||||
# Load DLLs
|
# Load DLLs
|
||||||
|
Add-Type -AssemblyName PresentationFramework
|
||||||
Add-Type -AssemblyName System.Windows.Forms
|
Add-Type -AssemblyName System.Windows.Forms
|
||||||
|
|
||||||
# Variable to sync between runspaces
|
# Variable to sync between runspaces
|
||||||
@ -18,9 +19,20 @@ $sync.version = "#{replaceme}"
|
|||||||
$sync.configs = @{}
|
$sync.configs = @{}
|
||||||
$sync.ProcessRunning = $false
|
$sync.ProcessRunning = $false
|
||||||
|
|
||||||
|
$currentPid = [System.Security.Principal.WindowsIdentity]::GetCurrent()
|
||||||
|
$principal = new-object System.Security.Principal.WindowsPrincipal($currentPid)
|
||||||
|
$adminRole=[System.Security.Principal.WindowsBuiltInRole]::Administrator
|
||||||
|
|
||||||
if (!([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole]::Administrator)) {
|
if ($principal.IsInRole($adminRole))
|
||||||
Write-Output "Winutil needs to be run as Administrator. Attempting to relaunch."
|
{
|
||||||
Start-Process -Verb runas -FilePath powershell.exe -ArgumentList "iwr -useb https://christitus.com/win | iex"
|
$Host.UI.RawUI.WindowTitle = $myInvocation.MyCommand.Definition + "(Admin)"
|
||||||
|
clear-host
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$newProcess = new-object System.Diagnostics.ProcessStartInfo "PowerShell";
|
||||||
|
$newProcess.Arguments = $myInvocation.MyCommand.Definition;
|
||||||
|
$newProcess.Verb = "runas";
|
||||||
|
[System.Diagnostics.Process]::Start($newProcess);
|
||||||
break
|
break
|
||||||
}
|
}
|
1880
winutil.ps1
1880
winutil.ps1
File diff suppressed because it is too large
Load Diff
@ -10,6 +10,86 @@
|
|||||||
Title="Chris Titus Tech's Windows Utility" Height="800" Width="1200">
|
Title="Chris Titus Tech's Windows Utility" Height="800" Width="1200">
|
||||||
|
|
||||||
<Window.Resources>
|
<Window.Resources>
|
||||||
|
<!--Scrollbar Thumbs-->
|
||||||
|
<Style x:Key="ScrollThumbs" TargetType="{x:Type Thumb}">
|
||||||
|
<Setter Property="Template">
|
||||||
|
<Setter.Value>
|
||||||
|
<ControlTemplate TargetType="{x:Type Thumb}">
|
||||||
|
<Grid x:Name="Grid">
|
||||||
|
<Rectangle HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Width="Auto" Height="Auto" Fill="Transparent" />
|
||||||
|
<Border x:Name="Rectangle1" CornerRadius="5" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Width="Auto" Height="Auto" Background="{TemplateBinding Background}" />
|
||||||
|
</Grid>
|
||||||
|
<ControlTemplate.Triggers>
|
||||||
|
<Trigger Property="Tag" Value="Horizontal">
|
||||||
|
<Setter TargetName="Rectangle1" Property="Width" Value="Auto" />
|
||||||
|
<Setter TargetName="Rectangle1" Property="Height" Value="7" />
|
||||||
|
</Trigger>
|
||||||
|
</ControlTemplate.Triggers>
|
||||||
|
</ControlTemplate>
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
</Style>
|
||||||
|
|
||||||
|
<!--ScrollBars-->
|
||||||
|
<Style x:Key="{x:Type ScrollBar}" TargetType="{x:Type ScrollBar}">
|
||||||
|
<Setter Property="Stylus.IsFlicksEnabled" Value="false" />
|
||||||
|
<Setter Property="Foreground" Value="{MainForegroundColor}" />
|
||||||
|
<Setter Property="Background" Value="{MainBackgroundColor}" />
|
||||||
|
<Setter Property="Width" Value="6" />
|
||||||
|
<Setter Property="Template">
|
||||||
|
<Setter.Value>
|
||||||
|
<ControlTemplate TargetType="{x:Type ScrollBar}">
|
||||||
|
<Grid x:Name="GridRoot" Width="7" Background="{TemplateBinding Background}" >
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="0.00001*" />
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
|
<Track x:Name="PART_Track" Grid.Row="0" IsDirectionReversed="true" Focusable="false">
|
||||||
|
<Track.Thumb>
|
||||||
|
<Thumb x:Name="Thumb" Background="{TemplateBinding Foreground}" Style="{DynamicResource ScrollThumbs}" />
|
||||||
|
</Track.Thumb>
|
||||||
|
<Track.IncreaseRepeatButton>
|
||||||
|
<RepeatButton x:Name="PageUp" Command="ScrollBar.PageDownCommand" Opacity="0" Focusable="false" />
|
||||||
|
</Track.IncreaseRepeatButton>
|
||||||
|
<Track.DecreaseRepeatButton>
|
||||||
|
<RepeatButton x:Name="PageDown" Command="ScrollBar.PageUpCommand" Opacity="0" Focusable="false" />
|
||||||
|
</Track.DecreaseRepeatButton>
|
||||||
|
</Track>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
<ControlTemplate.Triggers>
|
||||||
|
<Trigger SourceName="Thumb" Property="IsMouseOver" Value="true">
|
||||||
|
<Setter Value="{ButtonBackgroundMouseoverColor}" TargetName="Thumb" Property="Background" />
|
||||||
|
</Trigger>
|
||||||
|
<Trigger SourceName="Thumb" Property="IsDragging" Value="true">
|
||||||
|
<Setter Value="{ButtonBackgroundSelectedColor}" TargetName="Thumb" Property="Background" />
|
||||||
|
</Trigger>
|
||||||
|
|
||||||
|
<Trigger Property="IsEnabled" Value="false">
|
||||||
|
<Setter TargetName="Thumb" Property="Visibility" Value="Collapsed" />
|
||||||
|
</Trigger>
|
||||||
|
<Trigger Property="Orientation" Value="Horizontal">
|
||||||
|
<Setter TargetName="GridRoot" Property="LayoutTransform">
|
||||||
|
<Setter.Value>
|
||||||
|
<RotateTransform Angle="-90" />
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
<Setter TargetName="PART_Track" Property="LayoutTransform">
|
||||||
|
<Setter.Value>
|
||||||
|
<RotateTransform Angle="-90" />
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
<Setter Property="Width" Value="Auto" />
|
||||||
|
<Setter Property="Height" Value="8" />
|
||||||
|
<Setter TargetName="Thumb" Property="Tag" Value="Horizontal" />
|
||||||
|
<Setter TargetName="PageDown" Property="Command" Value="ScrollBar.PageLeftCommand" />
|
||||||
|
<Setter TargetName="PageUp" Property="Command" Value="ScrollBar.PageRightCommand" />
|
||||||
|
</Trigger>
|
||||||
|
</ControlTemplate.Triggers>
|
||||||
|
</ControlTemplate>
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
</Style>
|
||||||
<Style TargetType="ComboBox">
|
<Style TargetType="ComboBox">
|
||||||
<Setter Property="Foreground" Value="{ComboBoxForegroundColor}" />
|
<Setter Property="Foreground" Value="{ComboBoxForegroundColor}" />
|
||||||
<Setter Property="Background" Value="{ComboBoxBackgroundColor}" />
|
<Setter Property="Background" Value="{ComboBoxBackgroundColor}" />
|
||||||
@ -25,7 +105,8 @@
|
|||||||
ClickMode="Press">
|
ClickMode="Press">
|
||||||
<TextBlock Text="{TemplateBinding SelectionBoxItem}"
|
<TextBlock Text="{TemplateBinding SelectionBoxItem}"
|
||||||
Foreground="{TemplateBinding Foreground}"
|
Foreground="{TemplateBinding Foreground}"
|
||||||
Background="{TemplateBinding Background}"
|
Background="Transparent"
|
||||||
|
HorizontalAlignment="Center" VerticalAlignment="Center" Margin="2"
|
||||||
/>
|
/>
|
||||||
</ToggleButton>
|
</ToggleButton>
|
||||||
<Popup x:Name="Popup"
|
<Popup x:Name="Popup"
|
||||||
@ -40,7 +121,7 @@
|
|||||||
BorderThickness="1"
|
BorderThickness="1"
|
||||||
CornerRadius="4">
|
CornerRadius="4">
|
||||||
<ScrollViewer>
|
<ScrollViewer>
|
||||||
<ItemsPresenter />
|
<ItemsPresenter HorizontalAlignment="Center" VerticalAlignment="Center" Margin="2"/>
|
||||||
</ScrollViewer>
|
</ScrollViewer>
|
||||||
</Border>
|
</Border>
|
||||||
</Popup>
|
</Popup>
|
||||||
@ -53,14 +134,70 @@
|
|||||||
<Setter Property="Foreground" Value="{LabelboxForegroundColor}"/>
|
<Setter Property="Foreground" Value="{LabelboxForegroundColor}"/>
|
||||||
<Setter Property="Background" Value="{LabelBackgroundColor}"/>
|
<Setter Property="Background" Value="{LabelBackgroundColor}"/>
|
||||||
</Style>
|
</Style>
|
||||||
|
<!-- TextBlock template -->
|
||||||
<Style TargetType="TextBlock">
|
<Style TargetType="TextBlock">
|
||||||
<Setter Property="Foreground" Value="{LabelboxForegroundColor}"/>
|
<Setter Property="Foreground" Value="{LabelboxForegroundColor}"/>
|
||||||
<Setter Property="Background" Value="{LabelBackgroundColor}"/>
|
<Setter Property="Background" Value="{LabelBackgroundColor}"/>
|
||||||
</Style>
|
</Style>
|
||||||
|
<!-- Toggle button template x:Key="TabToggleButton" -->
|
||||||
|
<Style TargetType="{x:Type ToggleButton}">
|
||||||
|
<Setter Property="Margin" Value="{ButtonMargin}"/>
|
||||||
|
<Setter Property="Content" Value=""/>
|
||||||
|
<Setter Property="Template">
|
||||||
|
<Setter.Value>
|
||||||
|
<ControlTemplate TargetType="ToggleButton">
|
||||||
|
<Grid>
|
||||||
|
<Border x:Name="ButtonGlow"
|
||||||
|
Background="{TemplateBinding Background}"
|
||||||
|
BorderBrush="{ButtonForegroundColor}"
|
||||||
|
BorderThickness="{ButtonBorderThickness}"
|
||||||
|
CornerRadius="{ButtonCornerRadius}">
|
||||||
|
<Grid>
|
||||||
|
<Border x:Name="BackgroundBorder"
|
||||||
|
Background="{TemplateBinding Background}"
|
||||||
|
BorderBrush="{ButtonBackgroundColor}"
|
||||||
|
BorderThickness="{ButtonBorderThickness}"
|
||||||
|
CornerRadius="{ButtonCornerRadius}">
|
||||||
|
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" Margin="10,2,10,2"/>
|
||||||
|
</Border>
|
||||||
|
</Grid>
|
||||||
|
</Border>
|
||||||
|
</Grid>
|
||||||
|
<ControlTemplate.Triggers>
|
||||||
|
<Trigger Property="IsMouseOver" Value="True">
|
||||||
|
<Setter TargetName="BackgroundBorder" Property="Background" Value="{ButtonBackgroundMouseoverColor}"/>
|
||||||
|
<Setter Property="Effect">
|
||||||
|
<Setter.Value>
|
||||||
|
<DropShadowEffect Opacity="1" ShadowDepth="5" Color="Gold" Direction="-100" BlurRadius="45"/>
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
<Setter Property="Panel.ZIndex" Value="2000"/>
|
||||||
|
</Trigger>
|
||||||
|
<Trigger Property="IsChecked" Value="True">
|
||||||
|
<Setter Property="BorderBrush" Value="Pink"/>
|
||||||
|
<Setter Property="BorderThickness" Value="2"/>
|
||||||
|
<Setter TargetName="BackgroundBorder" Property="Background" Value="{ButtonBackgroundSelectedColor}"/>
|
||||||
|
<Setter Property="Effect">
|
||||||
|
<Setter.Value>
|
||||||
|
<DropShadowEffect Opacity="1" ShadowDepth="2" Color="Gold" Direction="-111" BlurRadius="25"/>
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
</Trigger>
|
||||||
|
<Trigger Property="IsChecked" Value="False">
|
||||||
|
<Setter Property="BorderBrush" Value="Transparent"/>
|
||||||
|
<Setter Property="BorderThickness" Value="{ButtonBorderThickness}"/>
|
||||||
|
</Trigger>
|
||||||
|
</ControlTemplate.Triggers>
|
||||||
|
</ControlTemplate>
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
</Style>
|
||||||
|
<!-- Button Template -->
|
||||||
<Style TargetType="Button">
|
<Style TargetType="Button">
|
||||||
|
<Setter Property="Margin" Value="{ButtonMargin}"/>
|
||||||
<Setter Property="Foreground" Value="{ButtonForegroundColor}"/>
|
<Setter Property="Foreground" Value="{ButtonForegroundColor}"/>
|
||||||
<Setter Property="Background" Value="{ButtonBackgroundColor}"/>
|
<Setter Property="Background" Value="{ButtonBackgroundColor}"/>
|
||||||
<Setter Property="Margin" Value="{ButtonMargin}"/>
|
|
||||||
<Setter Property="Template">
|
<Setter Property="Template">
|
||||||
<Setter.Value>
|
<Setter.Value>
|
||||||
<ControlTemplate TargetType="Button">
|
<ControlTemplate TargetType="Button">
|
||||||
@ -70,7 +207,7 @@
|
|||||||
BorderBrush="{TemplateBinding BorderBrush}"
|
BorderBrush="{TemplateBinding BorderBrush}"
|
||||||
BorderThickness="{ButtonBorderThickness}"
|
BorderThickness="{ButtonBorderThickness}"
|
||||||
CornerRadius="{ButtonCornerRadius}">
|
CornerRadius="{ButtonCornerRadius}">
|
||||||
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center"/>
|
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" Margin="10,2,10,2"/>
|
||||||
</Border>
|
</Border>
|
||||||
</Grid>
|
</Grid>
|
||||||
<ControlTemplate.Triggers>
|
<ControlTemplate.Triggers>
|
||||||
@ -81,7 +218,7 @@
|
|||||||
<Setter TargetName="BackgroundBorder" Property="Background" Value="{ButtonBackgroundMouseoverColor}"/>
|
<Setter TargetName="BackgroundBorder" Property="Background" Value="{ButtonBackgroundMouseoverColor}"/>
|
||||||
</Trigger>
|
</Trigger>
|
||||||
<Trigger Property="IsEnabled" Value="False">
|
<Trigger Property="IsEnabled" Value="False">
|
||||||
<Setter TargetName="BackgroundBorder" Property="Background" Value="Gray"/>
|
<Setter TargetName="BackgroundBorder" Property="Background" Value="{ButtonBackgroundSelectedColor}"/>
|
||||||
<Setter Property="Foreground" Value="DimGray"/>
|
<Setter Property="Foreground" Value="DimGray"/>
|
||||||
</Trigger>
|
</Trigger>
|
||||||
</ControlTemplate.Triggers>
|
</ControlTemplate.Triggers>
|
||||||
@ -89,6 +226,7 @@
|
|||||||
</Setter.Value>
|
</Setter.Value>
|
||||||
</Setter>
|
</Setter>
|
||||||
</Style>
|
</Style>
|
||||||
|
<!-- Checkbox template -->
|
||||||
<Style TargetType="CheckBox">
|
<Style TargetType="CheckBox">
|
||||||
<Setter Property="Foreground" Value="{MainForegroundColor}"/>
|
<Setter Property="Foreground" Value="{MainForegroundColor}"/>
|
||||||
<Setter Property="Background" Value="{MainBackgroundColor}"/>
|
<Setter Property="Background" Value="{MainBackgroundColor}"/>
|
||||||
@ -122,7 +260,6 @@
|
|||||||
</Grid>
|
</Grid>
|
||||||
<ControlTemplate.Triggers>
|
<ControlTemplate.Triggers>
|
||||||
<Trigger Property="IsChecked" Value="True">
|
<Trigger Property="IsChecked" Value="True">
|
||||||
|
|
||||||
<Setter TargetName="CheckMark" Property="Visibility" Value="Visible"/>
|
<Setter TargetName="CheckMark" Property="Visibility" Value="Visible"/>
|
||||||
</Trigger>
|
</Trigger>
|
||||||
<Trigger Property="IsMouseOver" Value="True">
|
<Trigger Property="IsMouseOver" Value="True">
|
||||||
@ -247,7 +384,7 @@
|
|||||||
|
|
||||||
<ThicknessAnimation Storyboard.TargetName="Ellipse"
|
<ThicknessAnimation Storyboard.TargetName="Ellipse"
|
||||||
Storyboard.TargetProperty="Margin"
|
Storyboard.TargetProperty="Margin"
|
||||||
To="56 2 2 1" Duration="0:0:0.1" />
|
To="46 2 2 1" Duration="0:0:0.1" />
|
||||||
|
|
||||||
<DoubleAnimation Storyboard.TargetName="txtDisable"
|
<DoubleAnimation Storyboard.TargetName="txtDisable"
|
||||||
Storyboard.TargetProperty="(TextBlock.Opacity)"
|
Storyboard.TargetProperty="(TextBlock.Opacity)"
|
||||||
@ -300,13 +437,9 @@
|
|||||||
</Trigger>
|
</Trigger>
|
||||||
</Style.Triggers>
|
</Style.Triggers>
|
||||||
</Style>
|
</Style>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</Window.Resources>
|
</Window.Resources>
|
||||||
<Border Name="WPFdummy" Grid.Column="0" Grid.Row="1">
|
<Border Name="WPFdummy" Grid.Column="0" Grid.Row="1">
|
||||||
<Viewbox Stretch="Uniform" VerticalAlignment="Top">
|
<Grid Background="{MainBackgroundColor}" ShowGridLines="False" Name="WPFMainGrid" Width="Auto" Height="Auto">
|
||||||
<Grid Background="{MainBackgroundColor}" ShowGridLines="False" Name="WPFMainGrid">
|
|
||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height=".1*"/>
|
<RowDefinition Height=".1*"/>
|
||||||
<RowDefinition Height=".9*"/>
|
<RowDefinition Height=".9*"/>
|
||||||
@ -316,18 +449,54 @@
|
|||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<DockPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Row="0" Width="1100">
|
<DockPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Row="0" Width="1100">
|
||||||
<Image Height="50" Width="50" Name="WPFIcon" SnapsToDevicePixels="True" Source="https://christitus.com/images/logo-full.png" Margin="0,10,0,10"/>
|
<Image Height="50" Width="50" Name="WPFIcon" SnapsToDevicePixels="True" Source="https://christitus.com/images/logo-full.png" Margin="0,10,0,10"/>
|
||||||
<Button Content="Install" HorizontalAlignment="Left" Height="40" Width="100"
|
<ToggleButton HorizontalAlignment="Left" Height="40" Width="100"
|
||||||
Background="{ButtonInstallBackgroundColor}" Foreground="{ButtonInstallForegroundColor}" FontWeight="Bold" Name="WPFTab1BT"/>
|
Background="{ButtonInstallBackgroundColor}" Foreground="white" FontWeight="Bold" Name="WPFTab1BT">
|
||||||
<Button Content="Tweaks" HorizontalAlignment="Left" Height="40" Width="100"
|
<ToggleButton.Content>
|
||||||
Background="{ButtonTweaksBackgroundColor}" Foreground="{ButtonInstallForegroundColor}" FontWeight="Bold" Name="WPFTab2BT"/>
|
<TextBlock Background="Transparent" Foreground="{ButtonInstallForegroundColor}" >
|
||||||
<Button Content="Config" HorizontalAlignment="Left" Height="40" Width="100"
|
<Underline>I</Underline>nstall
|
||||||
Background="{ButtonConfigBackgroundColor}" Foreground="{ButtonInstallForegroundColor}" FontWeight="Bold" Name="WPFTab3BT"/>
|
</TextBlock>
|
||||||
<Button Content="Updates" HorizontalAlignment="Left" Height="40" Width="100"
|
</ToggleButton.Content>
|
||||||
Background="{ButtonUpdatesBackgroundColor}" Foreground="{ButtonInstallForegroundColor}" FontWeight="Bold" Name="WPFTab4BT"/>
|
</ToggleButton>
|
||||||
|
<ToggleButton HorizontalAlignment="Left" Height="40" Width="100"
|
||||||
|
Background="{ButtonTweaksBackgroundColor}" Foreground="{ButtonTweaksForegroundColor}" FontWeight="Bold" Name="WPFTab2BT">
|
||||||
|
<ToggleButton.Content>
|
||||||
|
<TextBlock Background="Transparent" Foreground="{ButtonTweaksForegroundColor}">
|
||||||
|
<Underline>T</Underline>weaks
|
||||||
|
</TextBlock>
|
||||||
|
</ToggleButton.Content>
|
||||||
|
</ToggleButton>
|
||||||
|
<ToggleButton HorizontalAlignment="Left" Height="40" Width="100"
|
||||||
|
Background="{ButtonConfigBackgroundColor}" Foreground="{ButtonConfigForegroundColor}" FontWeight="Bold" Name="WPFTab3BT">
|
||||||
|
<ToggleButton.Content>
|
||||||
|
<TextBlock Background="Transparent" Foreground="{ButtonConfigForegroundColor}">
|
||||||
|
<Underline>C</Underline>onfig
|
||||||
|
</TextBlock>
|
||||||
|
</ToggleButton.Content>
|
||||||
|
</ToggleButton>
|
||||||
|
<ToggleButton HorizontalAlignment="Left" Height="40" Width="100"
|
||||||
|
Background="{ButtonUpdatesBackgroundColor}" Foreground="{ButtonUpdatesForegroundColor}" FontWeight="Bold" Name="WPFTab4BT">
|
||||||
|
<ToggleButton.Content>
|
||||||
|
<TextBlock Background="Transparent" Foreground="{ButtonUpdatesForegroundColor}">
|
||||||
|
<Underline>U</Underline>pdates
|
||||||
|
</TextBlock>
|
||||||
|
</ToggleButton.Content>
|
||||||
|
</ToggleButton>
|
||||||
|
<ToggleButton HorizontalAlignment="Left" Height="40" Width="100"
|
||||||
|
Background="{ButtonUpdatesBackgroundColor}" Foreground="{ButtonUpdatesForegroundColor}" FontWeight="Bold" Name="WPFTab5BT">
|
||||||
|
<ToggleButton.Content>
|
||||||
|
<TextBlock Background="Transparent" Foreground="{ButtonUpdatesForegroundColor}">
|
||||||
|
<Underline>M</Underline>icroWin
|
||||||
|
</TextBlock>
|
||||||
|
</ToggleButton.Content>
|
||||||
|
</ToggleButton>
|
||||||
|
<TextBox VerticalContentAlignment="Center" HorizontalAlignment="Right" Name="CheckboxFilter" ToolTip="Press Ctrl-F and type app name to filter application list below. Press Esc to reset the filter"
|
||||||
|
Height="25" Width="200"
|
||||||
|
Foreground="{MainForegroundColor}" Background="{MainBackgroundColor}">Ctrl-F to filter</TextBox>
|
||||||
</DockPanel>
|
</DockPanel>
|
||||||
<TabControl Grid.Row="1" Padding="-1" Name="WPFTabNav" Background="#222222">
|
<ScrollViewer Grid.Row="1" Padding="-1" VerticalScrollBarVisibility="Auto" HorizontalScrollBarVisibility="Auto" Background="Transparent">
|
||||||
|
<TabControl Name="WPFTabNav" Background="#222222" Width="Auto" Height="Auto">
|
||||||
<TabItem Header="Install" Visibility="Collapsed" Name="WPFTab1">
|
<TabItem Header="Install" Visibility="Collapsed" Name="WPFTab1">
|
||||||
<Grid Background="#222222">
|
<Grid Background="Transparent">
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="*"/>
|
<ColumnDefinition Width="*"/>
|
||||||
<ColumnDefinition Width="*"/>
|
<ColumnDefinition Width="*"/>
|
||||||
@ -360,7 +529,9 @@
|
|||||||
<CheckBox Name="WPFInstallchromium" Content="Chromium" Margin="5,0"/>
|
<CheckBox Name="WPFInstallchromium" Content="Chromium" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalledge" Content="Edge" Margin="5,0"/>
|
<CheckBox Name="WPFInstalledge" Content="Edge" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallfirefox" Content="Firefox" Margin="5,0"/>
|
<CheckBox Name="WPFInstallfirefox" Content="Firefox" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallfloorp" Content="Floorp" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalllibrewolf" Content="LibreWolf" Margin="5,0"/>
|
<CheckBox Name="WPFInstalllibrewolf" Content="LibreWolf" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallmercury" Content="Mercury" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallthorium" Content="Thorium Browser" Margin="5,0"/>
|
<CheckBox Name="WPFInstallthorium" Content="Thorium Browser" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalltor" Content="Tor Browser" Margin="5,0"/>
|
<CheckBox Name="WPFInstalltor" Content="Tor Browser" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallvivaldi" Content="Vivaldi" Margin="5,0"/>
|
<CheckBox Name="WPFInstallvivaldi" Content="Vivaldi" Margin="5,0"/>
|
||||||
@ -371,6 +542,7 @@
|
|||||||
<CheckBox Name="WPFInstallguilded" Content="Guilded" Margin="5,0"/>
|
<CheckBox Name="WPFInstallguilded" Content="Guilded" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallhexchat" Content="Hexchat" Margin="5,0"/>
|
<CheckBox Name="WPFInstallhexchat" Content="Hexchat" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljami" Content="Jami" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljami" Content="Jami" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstalllinphone" Content="Linphone" Margin="5,0" />
|
||||||
<CheckBox Name="WPFInstallmatrix" Content="Matrix" Margin="5,0"/>
|
<CheckBox Name="WPFInstallmatrix" Content="Matrix" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallsession" Content="Session" Margin="5,0"/>
|
<CheckBox Name="WPFInstallsession" Content="Session" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallsignal" Content="Signal" Margin="5,0"/>
|
<CheckBox Name="WPFInstallsignal" Content="Signal" Margin="5,0"/>
|
||||||
@ -385,8 +557,10 @@
|
|||||||
<StackPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Row="1" Grid.Column="1" Margin="10">
|
<StackPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Row="1" Grid.Column="1" Margin="10">
|
||||||
<Label Content="Development" FontSize="16" Margin="5,0"/>
|
<Label Content="Development" FontSize="16" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljava20" Content="Azul Zulu JDK 20" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljava20" Content="Azul Zulu JDK 20" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallclink" Content="Clink" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalldockerdesktop" Content="Docker Desktop" Margin="5,0"/>
|
<CheckBox Name="WPFInstalldockerdesktop" Content="Docker Desktop" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallgit" Content="Git" Margin="5,0"/>
|
<CheckBox Name="WPFInstallgit" Content="Git" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallgitextensions" Content="Git Extensions" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallgithubdesktop" Content="GitHub Desktop" Margin="5,0"/>
|
<CheckBox Name="WPFInstallgithubdesktop" Content="GitHub Desktop" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallgolang" Content="GoLang" Margin="5,0"/>
|
<CheckBox Name="WPFInstallgolang" Content="GoLang" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljetbrains" Content="Jetbrains Toolbox" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljetbrains" Content="Jetbrains Toolbox" Margin="5,0"/>
|
||||||
@ -398,26 +572,33 @@
|
|||||||
<CheckBox Name="WPFInstalljava8" Content="OpenJDK Java 8" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljava8" Content="OpenJDK Java 8" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljava16" Content="OpenJDK Java 16" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljava16" Content="OpenJDK Java 16" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljava18" Content="Oracle Java 18" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljava18" Content="Oracle Java 18" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallposh" Content="Oh My Posh (Prompt)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallpython3" Content="Python3" Margin="5,0"/>
|
<CheckBox Name="WPFInstallpython3" Content="Python3" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallpostman" Content="Postman" Margin="5,0"/>
|
<CheckBox Name="WPFInstallpostman" Content="Postman" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallrustlang" Content="Rust" Margin="5,0"/>
|
<CheckBox Name="WPFInstallrustlang" Content="Rust" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallsublime" Content="Sublime" Margin="5,0"/>
|
<CheckBox Name="WPFInstallstarship" Content="Starship (Shell Prompt)" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallsublimemerge" Content="Sublime Merge" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallsublimetext" Content="Sublime Text" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallunity" Content="Unity Game Engine" Margin="5,0"/>
|
<CheckBox Name="WPFInstallunity" Content="Unity Game Engine" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallvisualstudio" Content="Visual Studio 2022" Margin="5,0"/>
|
<CheckBox Name="WPFInstallvisualstudio" Content="Visual Studio 2022" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallvscode" Content="VS Code" Margin="5,0"/>
|
<CheckBox Name="WPFInstallvscode" Content="VS Code" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallvscodium" Content="VS Codium" Margin="5,0"/>
|
<CheckBox Name="WPFInstallvscodium" Content="VS Codium" Margin="5,0"/>
|
||||||
|
|
||||||
<Label Content="Document" FontSize="16" Margin="5,0"/>
|
<Label Content="Document" FontSize="16" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallanki" Content="Anki" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalladobe" Content="Adobe Reader DC" Margin="5,0"/>
|
<CheckBox Name="WPFInstalladobe" Content="Adobe Reader DC" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallopenoffice" Content="Apache OpenOffice" Margin="5,0"/>
|
<CheckBox Name="WPFInstallopenoffice" Content="Apache OpenOffice" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallcalibre" Content="Calibre" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallfoxpdf" Content="Foxit PDF" Margin="5,0"/>
|
<CheckBox Name="WPFInstallfoxpdf" Content="Foxit PDF" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljoplin" Content="Joplin (FOSS Notes)" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljoplin" Content="Joplin (FOSS Notes)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalllibreoffice" Content="LibreOffice" Margin="5,0"/>
|
<CheckBox Name="WPFInstalllibreoffice" Content="LibreOffice" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallmasscode" Content="massCode (Snippet Manager)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallnaps2" Content="NAPS2 (Document Scanner)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallnaps2" Content="NAPS2 (Document Scanner)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallnotepadplus" Content="Notepad++" Margin="5,0"/>
|
<CheckBox Name="WPFInstallnotepadplus" Content="Notepad++" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallobsidian" Content="Obsidian" Margin="5,0"/>
|
<CheckBox Name="WPFInstallobsidian" Content="Obsidian" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallokular" Content="Okular" Margin="5,0"/>
|
<CheckBox Name="WPFInstallokular" Content="Okular" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallonlyoffice" Content="ONLYOffice Desktop" Margin="5,0"/>
|
<CheckBox Name="WPFInstallonlyoffice" Content="ONLYOffice Desktop" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallpdfsam" Content="PDFsam Basic" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallsumatra" Content="Sumatra PDF" Margin="5,0"/>
|
<CheckBox Name="WPFInstallsumatra" Content="Sumatra PDF" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallwinmerge" Content="WinMerge" Margin="5,0"/>
|
<CheckBox Name="WPFInstallwinmerge" Content="WinMerge" Margin="5,0"/>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
@ -454,6 +635,8 @@
|
|||||||
<CheckBox Name="WPFInstallaudacity" Content="Audacity" Margin="5,0"/>
|
<CheckBox Name="WPFInstallaudacity" Content="Audacity" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallblender" Content="Blender (3D Graphics)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallblender" Content="Blender (3D Graphics)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallcider" Content="Cider (FOSS Music Player)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallcider" Content="Cider (FOSS Music Player)" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallclipgrab" Content="Clipgrab" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallcopyq" Content="Copyq (Clipboard Manager)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalleartrumpet" Content="Eartrumpet (Audio)" Margin="5,0"/>
|
<CheckBox Name="WPFInstalleartrumpet" Content="Eartrumpet (Audio)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallflameshot" Content="Flameshot (Screenshots)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallflameshot" Content="Flameshot (Screenshots)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallfoobar" Content="Foobar2000 (Music Player)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallfoobar" Content="Foobar2000 (Music Player)" Margin="5,0"/>
|
||||||
@ -483,8 +666,11 @@
|
|||||||
|
|
||||||
<Label Content="Pro Tools" FontSize="16" Margin="5,0"/>
|
<Label Content="Pro Tools" FontSize="16" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalladvancedip" Content="Advanced IP Scanner" Margin="5,0"/>
|
<CheckBox Name="WPFInstalladvancedip" Content="Advanced IP Scanner" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallangryipscanner" Content="Angry IP Scanner" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallheidisql" Content="HeidiSQL" Margin="5,0" />
|
||||||
<CheckBox Name="WPFInstallmremoteng" Content="mRemoteNG" Margin="5,0"/>
|
<CheckBox Name="WPFInstallmremoteng" Content="mRemoteNG" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallOpenVPN" Content="OpenVPN Connect" Margin="5,0"/>
|
<CheckBox Name="WPFInstallOpenVPN" Content="OpenVPN Connect" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallportmaster" Content="Portmaster" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallputty" Content="Putty" Margin="5,0"/>
|
<CheckBox Name="WPFInstallputty" Content="Putty" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallrustdesk" Content="Rust Remote Desktop (FOSS)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallrustdesk" Content="Rust Remote Desktop (FOSS)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallsimplewall" Content="SimpleWall" Margin="5,0"/>
|
<CheckBox Name="WPFInstallsimplewall" Content="SimpleWall" Margin="5,0"/>
|
||||||
@ -503,7 +689,9 @@
|
|||||||
<CheckBox Name="WPFInstallcpuz" Content="CPU-Z" Margin="5,0"/>
|
<CheckBox Name="WPFInstallcpuz" Content="CPU-Z" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallddu" Content="Display Driver Uninstaller" Margin="5,0"/>
|
<CheckBox Name="WPFInstallddu" Content="Display Driver Uninstaller" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalldeluge" Content="Deluge" Margin="5,0"/>
|
<CheckBox Name="WPFInstalldeluge" Content="Deluge" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstalldolphin" Content="Dolphin File manager" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallduplicati" Content="Duplicati 2" Margin="5,0"/>
|
<CheckBox Name="WPFInstallduplicati" Content="Duplicati 2" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstalldevtoys" Content="Devtoys" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalletcher" Content="Etcher USB Creator" Margin="5,0"/>
|
<CheckBox Name="WPFInstalletcher" Content="Etcher USB Creator" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallesearch" Content="Everything Search" Margin="5,0"/>
|
<CheckBox Name="WPFInstallesearch" Content="Everything Search" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallflux" Content="f.lux Redshift" Margin="5,0"/>
|
<CheckBox Name="WPFInstallflux" Content="f.lux Redshift" Margin="5,0"/>
|
||||||
@ -518,9 +706,12 @@
|
|||||||
<CheckBox Name="WPFInstallmonitorian" Content="Monitorian" Margin="5,0"/>
|
<CheckBox Name="WPFInstallmonitorian" Content="Monitorian" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallmsiafterburner" Content="MSI Afterburner" Margin="5,0"/>
|
<CheckBox Name="WPFInstallmsiafterburner" Content="MSI Afterburner" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallnanazip" Content="NanaZip" Margin="5,0"/>
|
<CheckBox Name="WPFInstallnanazip" Content="NanaZip" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallnextclouddesktop" Content="Nextcloud Desktop" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallnvclean" Content="NVCleanstall" Margin="5,0"/>
|
<CheckBox Name="WPFInstallnvclean" Content="NVCleanstall" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallOVirtualBox" Content="Oracle VirtualBox" Margin="5,0"/>
|
<CheckBox Name="WPFInstallOVirtualBox" Content="Oracle VirtualBox" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallopenrgb" Content="OpenRGB" Margin="5,0" />
|
||||||
<CheckBox Name="WPFInstallopenshell" Content="Open Shell (Start Menu)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallopenshell" Content="Open Shell (Start Menu)" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallownclouddesktop" Content="ownCloud Desktop" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallpeazip" Content="Peazip" Margin="5,0"/>
|
<CheckBox Name="WPFInstallpeazip" Content="Peazip" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallprocesslasso" Content="Process Lasso" Margin="5,0"/>
|
<CheckBox Name="WPFInstallprocesslasso" Content="Process Lasso" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallqbittorrent" Content="qBittorrent" Margin="5,0"/>
|
<CheckBox Name="WPFInstallqbittorrent" Content="qBittorrent" Margin="5,0"/>
|
||||||
@ -610,8 +801,8 @@
|
|||||||
<CheckBox Name="WPFMiscTweaksEnableipsix" Content="Enable IPv6" Margin="5,0" ToolTip="Enables IPv6."/>
|
<CheckBox Name="WPFMiscTweaksEnableipsix" Content="Enable IPv6" Margin="5,0" ToolTip="Enables IPv6."/>
|
||||||
|
|
||||||
<StackPanel Orientation="Horizontal" Margin="0,5,0,0">
|
<StackPanel Orientation="Horizontal" Margin="0,5,0,0">
|
||||||
<Label Content="DNS" />
|
<Label Content="DNS" HorizontalAlignment="Left" VerticalAlignment="Center"/>
|
||||||
<ComboBox Name="WPFchangedns" Height = "20" Width = "160" HorizontalAlignment = "Left" Margin="5,5">
|
<ComboBox Name="WPFchangedns" Height="32" Width="186" HorizontalAlignment="Left" VerticalAlignment="Center" Margin="5,5">
|
||||||
<ComboBoxItem IsSelected="True" Content = "Default"/>
|
<ComboBoxItem IsSelected="True" Content = "Default"/>
|
||||||
<ComboBoxItem Content = "DHCP"/>
|
<ComboBoxItem Content = "DHCP"/>
|
||||||
<ComboBoxItem Content = "Google"/>
|
<ComboBoxItem Content = "Google"/>
|
||||||
@ -654,7 +845,7 @@
|
|||||||
</StackPanel>
|
</StackPanel>
|
||||||
|
|
||||||
<StackPanel Orientation="Horizontal" Margin="0,10,0,0">
|
<StackPanel Orientation="Horizontal" Margin="0,10,0,0">
|
||||||
<Label Content="Show File Extentions" Style="{StaticResource labelfortweaks}" ToolTip="If enabled then File extensions (e.g., .txt, .jpg) are visible." />
|
<Label Content="Show File Extensions" Style="{StaticResource labelfortweaks}" ToolTip="If enabled then File extensions (e.g., .txt, .jpg) are visible." />
|
||||||
<CheckBox Name="WPFToggleShowExt" Style="{StaticResource ColorfulToggleSwitchStyle}" Margin="2.5,0"/>
|
<CheckBox Name="WPFToggleShowExt" Style="{StaticResource ColorfulToggleSwitchStyle}" Margin="2.5,0"/>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
|
|
||||||
@ -687,6 +878,7 @@
|
|||||||
<Button Name="WPFFixesUpdate" FontSize="14" Content="Reset Windows Update" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
<Button Name="WPFFixesUpdate" FontSize="14" Content="Reset Windows Update" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
||||||
<Button Name="WPFFixesNetwork" FontSize="14" Content="Reset Network" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
<Button Name="WPFFixesNetwork" FontSize="14" Content="Reset Network" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
||||||
<Button Name="WPFPanelDISM" FontSize="14" Content="System Corruption Scan" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
<Button Name="WPFPanelDISM" FontSize="14" Content="System Corruption Scan" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
||||||
|
<Button Name="WPFFixesWinget" FontSize="14" Content="WinGet Reinstall" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
<StackPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Column="1" Margin="10,5">
|
<StackPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Column="1" Margin="10,5">
|
||||||
<Label Content="Legacy Windows Panels" FontSize="16"/>
|
<Label Content="Legacy Windows Panels" FontSize="16"/>
|
||||||
@ -719,13 +911,155 @@
|
|||||||
<Button Name="WPFUpdatesdisable" FontSize="16" Content="Disable ALL Updates (NOT RECOMMENDED!)" Margin="20,4,20,10" Padding="10,10,10,10"/>
|
<Button Name="WPFUpdatesdisable" FontSize="16" Content="Disable ALL Updates (NOT RECOMMENDED!)" Margin="20,4,20,10" Padding="10,10,10,10"/>
|
||||||
<TextBlock Margin="20,0,20,0" Padding="10" TextWrapping="WrapWithOverflow" MaxWidth="300">This completely disables ALL Windows Updates and is NOT RECOMMENDED.<LineBreak/><LineBreak/> However, it can be suitable if you use your system for a select purpose and do not actively browse the internet. <LineBreak/><LineBreak/>Note: Your system will be easier to hack and infect without security updates.</TextBlock>
|
<TextBlock Margin="20,0,20,0" Padding="10" TextWrapping="WrapWithOverflow" MaxWidth="300">This completely disables ALL Windows Updates and is NOT RECOMMENDED.<LineBreak/><LineBreak/> However, it can be suitable if you use your system for a select purpose and do not actively browse the internet. <LineBreak/><LineBreak/>Note: Your system will be easier to hack and infect without security updates.</TextBlock>
|
||||||
<TextBlock Text=" " Margin="20,0,20,0" Padding="10" TextWrapping="WrapWithOverflow" MaxWidth="300"/>
|
<TextBlock Text=" " Margin="20,0,20,0" Padding="10" TextWrapping="WrapWithOverflow" MaxWidth="300"/>
|
||||||
|
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
|
</Grid>
|
||||||
|
</TabItem>
|
||||||
|
<TabItem Header="MicroWin" Visibility="Collapsed" Name="WPFTab5" Width="Auto" Height="Auto">
|
||||||
|
<Grid Width="Auto" Height="Auto">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
<ColumnDefinition Width="4*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*" />
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<Border BorderBrush="Yellow" CornerRadius="2" BorderThickness="2" Margin="1" Grid.Row="0" Grid.Column="0">
|
||||||
|
<StackPanel Name="MicrowinMain" Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Column="0" Grid.Row="0">
|
||||||
|
<StackPanel Background="Transparent" SnapsToDevicePixels="True" Margin="1">
|
||||||
|
<TextBlock Margin="1" Padding="1" TextWrapping="Wrap" Foreground="{ComboBoxForegroundColor}">
|
||||||
|
Choose a Windows ISO file that you've downloaded. <LineBreak/>
|
||||||
|
Check for status in the console.
|
||||||
|
</TextBlock>
|
||||||
|
<TextBox Name="MicrowinFinalIsoLocation" Background="Transparent" BorderThickness="1" BorderBrush="{MainForegroundColor}"
|
||||||
|
Text="ISO location will be printed here"
|
||||||
|
IsReadOnly="True"
|
||||||
|
TextWrapping="Wrap"
|
||||||
|
Foreground="{LabelboxForegroundColor}"
|
||||||
|
/>
|
||||||
|
<Button Name="WPFGetIso" Margin="2" Padding="15">
|
||||||
|
<Button.Content>
|
||||||
|
<TextBlock Background="Transparent" Foreground="{ButtonForegroundColor}">
|
||||||
|
Select Windows <Underline>I</Underline>SO
|
||||||
|
</TextBlock>
|
||||||
|
</Button.Content>
|
||||||
|
</Button>
|
||||||
|
</StackPanel>
|
||||||
|
<!-- Visibility="Hidden" -->
|
||||||
|
<StackPanel Name="MicrowinOptionsPanel" HorizontalAlignment="Left" SnapsToDevicePixels="True" Margin="1" Visibility="Hidden">
|
||||||
|
<TextBlock Margin="6" Padding="1" TextWrapping="Wrap">Chose Windows SKU</TextBlock>
|
||||||
|
<ComboBox x:Name = "MicrowinWindowsFlavors" Margin="1" />
|
||||||
|
<TextBlock Margin="6" Padding="1" TextWrapping="Wrap">Choose Windows features you want to remove from the ISO</TextBlock>
|
||||||
|
<CheckBox Name="WPFMicrowinKeepProvisionedPackages" Content="Keep Provisioned Packages" Margin="5,0" ToolTip="Do not remove Microsoft Provisioned packages from the ISO."/>
|
||||||
|
<CheckBox Name="WPFMicrowinKeepAppxPackages" Content="Keep Appx Packages" Margin="5,0" ToolTip="Do not remove Microsoft Appx packages from the ISO."/>
|
||||||
|
<CheckBox Name="WPFMicrowinKeepDefender" Content="Keep Defender" Margin="5,0" IsChecked="True" ToolTip="Do not remove Microsoft Antivirus from the ISO."/>
|
||||||
|
<CheckBox Name="WPFMicrowinKeepEdge" Content="Keep Edge" Margin="5,0" IsChecked="True" ToolTip="Do not remove Microsoft Edge from the ISO."/>
|
||||||
|
<Rectangle Fill="{MainForegroundColor}" Height="2" HorizontalAlignment="Stretch" Margin="0,10,0,10"/>
|
||||||
|
<CheckBox Name="MicrowinInjectDrivers" Content="Inject drivers (I KNOW WHAT I'M DOING)" Margin="5,0" IsChecked="False" ToolTip="Path to unpacked drivers all sys and inf files for devices that need drivers"/>
|
||||||
|
<TextBox Name="MicrowinDriverLocation" Background="Transparent" BorderThickness="1" BorderBrush="{MainForegroundColor}"
|
||||||
|
Margin="6"
|
||||||
|
Text=""
|
||||||
|
IsReadOnly="False"
|
||||||
|
TextWrapping="Wrap"
|
||||||
|
Foreground="{LabelboxForegroundColor}"
|
||||||
|
ToolTip="Path to unpacked drivers all sys and inf files for devices that need drivers"
|
||||||
|
/>
|
||||||
|
<Rectangle Fill="{MainForegroundColor}" Height="2" HorizontalAlignment="Stretch" Margin="0,10,0,10"/>
|
||||||
|
<CheckBox Name="WPFMicrowinCopyToUsb" Content="Copy to Ventoy" Margin="5,0" IsChecked="False" ToolTip="Copy to USB disk with a label Ventoy"/>
|
||||||
|
<Rectangle Fill="{MainForegroundColor}" Height="2" HorizontalAlignment="Stretch" Margin="0,10,0,10"/>
|
||||||
|
<Button Name="WPFMicrowin" Content="Start the process" Margin="2" Padding="15"/>
|
||||||
|
</StackPanel>
|
||||||
|
<StackPanel HorizontalAlignment="Left" SnapsToDevicePixels="True" Margin="1" Visibility="Collapsed">
|
||||||
|
<TextBlock Name="MicrowinIsoDrive" VerticalAlignment="Center" Margin="1" Padding="1" TextWrapping="WrapWithOverflow" Foreground="{ComboBoxForegroundColor}"/>
|
||||||
|
<TextBlock Name="MicrowinIsoLocation" VerticalAlignment="Center" Margin="1" Padding="1" TextWrapping="WrapWithOverflow" Foreground="{ComboBoxForegroundColor}"/>
|
||||||
|
<TextBlock Name="MicrowinMountDir" VerticalAlignment="Center" Margin="1" Padding="1" TextWrapping="WrapWithOverflow" Foreground="{ComboBoxForegroundColor}"/>
|
||||||
|
<TextBlock Name="MicrowinScratchDir" VerticalAlignment="Center" Margin="1" Padding="1" TextWrapping="WrapWithOverflow" Foreground="{ComboBoxForegroundColor}"/>
|
||||||
|
</StackPanel>
|
||||||
|
</StackPanel>
|
||||||
|
</Border>
|
||||||
|
<Border Background="{MainBackgroundColor}"
|
||||||
|
VerticalAlignment="Stretch"
|
||||||
|
HorizontalAlignment="Stretch"
|
||||||
|
BorderBrush="Yellow"
|
||||||
|
CornerRadius="2"
|
||||||
|
BorderThickness="2"
|
||||||
|
Grid.Row="0" Grid.Column="1"
|
||||||
|
Margin="1">
|
||||||
|
<StackPanel HorizontalAlignment="Left" Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Visibility="Visible"
|
||||||
|
>
|
||||||
|
<TextBlock x:Name = "asciiTextBlock"
|
||||||
|
xml:space ="preserve"
|
||||||
|
HorizontalAlignment = "Center"
|
||||||
|
Margin = "0"
|
||||||
|
VerticalAlignment = "Top"
|
||||||
|
Height = "Auto"
|
||||||
|
Width = "Auto"
|
||||||
|
FontSize = "10"
|
||||||
|
FontFamily = "Courier New"
|
||||||
|
>
|
||||||
|
/\/\ (_) ___ _ __ ___ / / /\ \ \(_) _ __
|
||||||
|
/ \ | | / __|| '__| / _ \ \ \/ \/ /| || '_ \
|
||||||
|
/ /\/\ \| || (__ | | | (_) | \ /\ / | || | | |
|
||||||
|
\/ \/|_| \___||_| \___/ \/ \/ |_||_| |_|
|
||||||
|
</TextBlock>
|
||||||
|
<TextBlock Margin="15,15,15,0"
|
||||||
|
Padding="8,8,8,0"
|
||||||
|
VerticalAlignment="Center"
|
||||||
|
TextWrapping="WrapWithOverflow"
|
||||||
|
Height = "Auto"
|
||||||
|
Width = "Auto"
|
||||||
|
Foreground="{ComboBoxForegroundColor}">
|
||||||
|
<Bold>MicroWin features:</Bold><LineBreak/>
|
||||||
|
- Remove Telemetry and Tracking <LineBreak/>
|
||||||
|
- Add ability to use local accounts <LineBreak/>
|
||||||
|
- Remove Wifi requirement to finish install <LineBreak/>
|
||||||
|
- Ability to remove Edge <LineBreak/>
|
||||||
|
- Ability to remove Defender <LineBreak/>
|
||||||
|
- Remove Teams <LineBreak/>
|
||||||
|
- Apps debloat <LineBreak/>
|
||||||
|
<LineBreak/>
|
||||||
|
<LineBreak/>
|
||||||
|
|
||||||
|
<Bold>INSTRUCTIONS</Bold> <LineBreak/>
|
||||||
|
- Download latest Windows 11 image from Microsoft <LineBreak/>
|
||||||
|
https://www.microsoft.com/software-download/windows11
|
||||||
|
several minutes to process the ISO depending on your machine. <LineBreak/>
|
||||||
|
- Put it somewhere on the C: drive so it is easily accessible <LineBreak/>
|
||||||
|
- Launch WinUtil and MicroWin <LineBreak/>
|
||||||
|
- Click on Get Iso image button and wait for WinUtil to process the Image <LineBreak/>
|
||||||
|
It will be processed and unpacked which could take some time <LineBreak/>
|
||||||
|
- Once done, chose which Windows flavor you want to base your image on <LineBreak/>
|
||||||
|
- Chose which features you want to keep <LineBreak/>
|
||||||
|
- Click Start Process button <LineBreak/>
|
||||||
|
NOTE: Process of creating Windows image will take a long time, please check the Console and wait for it to say "Done" <LineBreak/>
|
||||||
|
<Bold>Once it is done the microwin.iso will be in the %temp% directory</Bold> <LineBreak/>
|
||||||
|
Copy this image to your Ventoy USB Stick, boot to this image. gg,
|
||||||
|
<LineBreak/>
|
||||||
|
If you are injecting drivers make sure to put all your inf, sys and dll file for each driver into a separate directory. For example:
|
||||||
|
</TextBlock>
|
||||||
|
<TextBlock Margin="15,0,15,15"
|
||||||
|
Padding = "1"
|
||||||
|
TextWrapping="WrapWithOverflow"
|
||||||
|
Height = "Auto"
|
||||||
|
Width = "Auto"
|
||||||
|
VerticalAlignment = "Top"
|
||||||
|
Foreground = "{ComboBoxForegroundColor}"
|
||||||
|
xml:space = "preserve"
|
||||||
|
>
|
||||||
|
C:\drivers\
|
||||||
|
|-- Driver1\
|
||||||
|
| |-- Driver1.inf
|
||||||
|
| |-- Driver1.sys
|
||||||
|
|-- Driver2\
|
||||||
|
| |-- Driver2.inf
|
||||||
|
| |-- Driver2.sys
|
||||||
|
|-- OtherFiles...
|
||||||
|
</TextBlock>
|
||||||
|
</StackPanel>
|
||||||
|
</Border>
|
||||||
</Grid>
|
</Grid>
|
||||||
</TabItem>
|
</TabItem>
|
||||||
</TabControl>
|
</TabControl>
|
||||||
|
</ScrollViewer>
|
||||||
</Grid>
|
</Grid>
|
||||||
</Viewbox>
|
|
||||||
</Border>
|
</Border>
|
||||||
</Window>
|
</Window>
|
||||||
|
Loading…
Reference in New Issue
Block a user