diff --git a/windows10.ps1 b/windows10.ps1
index 28c8427..5e41ea9 100644
--- a/windows10.ps1
+++ b/windows10.ps1
@@ -22,7 +22,7 @@ Start-Job -Name "Install and Configure Chocolatey" -ScriptBlock {
Install-WindowsUpdate -MicrosoftUpdate -AcceptAll -Install
Get-WuInstall -AcceptAll -IgnoreReboot -IgnoreUserInput -nottitle 'preview'
Get-WindowsUpdate –Install
- }
+ }
}
Start-Job -Name "Installing Optional Windows Features" -ScriptBlock {
@@ -33,10 +33,10 @@ Start-Job -Name "Installing Optional Windows Features" -ScriptBlock {
}
#https://docs.microsoft.com/en-us/powershell/scripting/gallery/installing-psget?view=powershell-7.1
- Install-PackageProvider -Name "NuGet -Force
+ Install-PackageProvider -Name "NuGet" -Force
#https://github.com/PowerShell/PowerShellGetv2/issues/303
- Set-PSRepository -Name "PSGallery -InstallationPolicy Trusted
+ Set-PSRepository -Name "PSGallery" -InstallationPolicy Trusted
Install-PackageProvider -Name "PowerShellGet" -Force -Scope CurrentUser
#https://github.com/PowerShell/PowerShellGetv2/issues/295
@@ -61,7 +61,7 @@ Start-Job -Name "Installing Software" -Scriptblock {
$chocopackages = @("googlechrome", "firefox", "chromium", "microsoft-edge", "tor-Browser", "putty", "winscp.install", "teamviewer", "anydesk.install", "sysinternals", "driverbooster", "sdio", "etcher", "rufus.install", "veracrypt", "windirstat", "mysql.workbench", "rsat", "sql-server-management-studio", "laps", "wumt", "openvpn", "wireguard", "wireshark", "nmap", "winbox", "tor", "cheatengine", "sleuthkit", "hxd", "ida-free", "ghidra", "ossec-client", "burp-suite-free-edition", "zap", "openstego", "accessenum", "accesschk", "sysmon", "powershell4", "powershell", "powershellhere-elevated", "powershell.portable", "microsoft-windows-terminal", "carbon", "jre8", "openjdk", "openjdk.portable", "hugo", "hugo-extended", "nodejs", "vscode", "vscodium", "vscode-ansible", "vscode-python", "chocolatey-vscode", "vscode-prettier", "vscode-java", "vscode-yaml", "vscode-haskell", "vscode-mongo", "vscode-beautify", "vscode-intellicode", "vscode-pull-request-github", "vscode-kubernetes-tools", "vscode-autofilename", "vscode-codespellchecker", "vscode-icons", "vscode-csharp", "dsc.powershellcommunity", "notepadplusplus.install", "python", "pip", "github-desktop", "gh", "git.install", "git-lfx", "gnupg", "gpg4win", "openssh", "wsl", "wsl2", "adb", "universal-adb-drivers", "windows-adk-all", "dotnetfx", "vcredist-all", "microsoft-visual-cpp-build-tools", "patch-my-pc", "rocketchat", "discord", "pidgin", "signal", "steam", "obs-studio", "obs-ndi", "vlc", "gimp", "k-litecodecpackfull", "audacity", "audacity-lame", "screentogif", "adobereader", "installroot", "7zip.install", "curl", "autohotkey", "teracopy", "cpu-z.install", "eraser", "openstego")
$PSversion = $PSVersionTable.PSVersion.Major
- If ($PSversion -ge "7"){
+ If ($PSversion -ge "7") {
Write-Output $chocopackages | ForEach-Object -Parallel {
Write-Host "Installing $_" -ForegroundColor White -BackgroundColor Black
Try {
@@ -71,7 +71,8 @@ Start-Job -Name "Installing Software" -Scriptblock {
Write-Host "Failed to install $_" -ForegroundColor Red -BackgroundColor Black
}
}
- } Else {
+ }
+ Else {
Write-Output $chocopackages | ForEach-Object {
Write-Host "Installing $_" -ForegroundColor White -BackgroundColor Black
Try {
@@ -84,7 +85,7 @@ Start-Job -Name "Installing Software" -Scriptblock {
}
#Packages that down't work while installing others
- Choco install vmwareworkstation vmware-horizon-client vmware-powercli-psmodule vmrc --ignore-checksums --force| Out-Null
+ Choco install vmwareworkstation vmware-horizon-client vmware-powercli-psmodule vmrc --ignore-checksums --force | Out-Null
<# Optional Packages
@@ -242,72 +243,24 @@ Start-Job -Name "Configuring Windows - Optimizations, Debloating, and Hardening"
Set-ItemProperty -Path "HKCU:\Software\Microsoft\Windows\CurrentVersion\Themes\Personalize" -Name "ColorPrevalence" -Type "DWORD" -Value "00000000" -Force
Set-ItemProperty -Path "HKCU:\Software\Microsoft\Windows\CurrentVersion\Themes\Personalize" -Name "EnableTransparency" -Type "DWORD" -Value "00000001" -Force
- #Clear Start Menu
- #https://github.com/builtbybel/privatezilla/blob/master/scripts/Unpin%20Startmenu%20Tiles.ps1
- $START_MENU_LAYOUT = @"
-
-
-
-
-
-
-
-
-"@
- $layoutFile = "C:\Windows\StartMenuLayout.xml"
-
- #Delete layout file if it already exists
- If (Test-Path $layoutFile) {
- Remove-Item $layoutFile
- }
- #Creates the blank layout file
- $START_MENU_LAYOUT | Out-File $layoutFile -Encoding ASCII
- $regAliases = @("HKLM", "HKCU")
- #Assign the start layout and force it to apply with "LockedStartLayout" at both the machine and user level
- foreach ($regAlias in $regAliases) {
- $basePath = $regAlias + ":\SOFTWARE\Policies\Microsoft\Windows"
- $keyPath = $basePath + "\Explorer"
- IF (!(Test-Path -Path $keyPath)) {
- New-Item -Path $basePath -Name "Explorer"
+ #https://notes.ponderworthy.com/fsutil-tweaks-for-ntfs-performance-and-reliability
+ fsutil behavior set memoryusage 2
+ #fsutil behavior set disablelastaccess 1
+ fsutil behavior set mftzone 2
+ $DriveLetters = (Get-WmiObject -Class Win32_Volume).DriveLetter
+ ForEach ($Drive in $DriveLetters) {
+ If (-not ([string]::IsNullOrEmpty($Drive))) {
+ Write-Host Optimizing "$Drive" Drive
+ fsutil resource setavailable "$Drive"
+ fsutil resource setlog shrink 10 "$Drive"
+ fsutil repair set "$Drive" 0x01
+ fsutil resource setautoreset true "$Drive"
+ fsutil resource setconsistent "$Drive"
}
- Set-ItemProperty -Path $keyPath -Name "LockedStartLayout" -Value 1
- Set-ItemProperty -Path $keyPath -Name "StartLayoutFile" -Value $layoutFile
}
- #Restart Explorer, open the start menu (necessary to load the new layout), and give it a few seconds to process
- Stop-Process -Force -name explorer
- Start-Sleep -s 5
- $wshell = New-Object -ComObject wscript.shell; $wshell.SendKeys('^{ESCAPE}')
- Start-Sleep -s 5
- #Enable the ability to pin items again by disabling "LockedStartLayout"
- foreach ($regAlias in $regAliases) {
- $basePath = $regAlias + ":\SOFTWARE\Policies\Microsoft\Windows"
- $keyPath = $basePath + "\Explorer"
- Set-ItemProperty -Path $keyPath -Name "LockedStartLayout" -Value 0
- }
- #Restart Explorer and delete the layout file
- Stop-Process -Force -name explorer
- #Uncomment the next line to make clean start menu default for all new users
- Import-StartLayout -LayoutPath $layoutFile -MountPath $env:SystemDrive\
- Remove-Item $layoutFile
- #https://notes.ponderworthy.com/fsutil-tweaks-for-ntfs-performance-and-reliability
- fsutil behavior set memoryusage 2
- #fsutil behavior set disablelastaccess 1
- fsutil behavior set mftzone 2
- $DriveLetters = (Get-WmiObject -Class Win32_Volume).DriveLetter
- ForEach ($Drive in $DriveLetters) {
- If (-not ([string]::IsNullOrEmpty($Drive))) {
- Write-Host Optimizing "$Drive" Drive
- fsutil resource setavailable "$Drive"
- fsutil resource setlog shrink 10 "$Drive"
- fsutil repair set "$Drive" 0x01
- fsutil resource setautoreset true "$Drive"
- fsutil resource setconsistent "$Drive"
- }
- }
-
- #https://docs.microsoft.com/en-us/windows-server/administration/openssh/openssh_server_configuration
- New-ItemProperty -Path "HKLM:\SOFTWARE\OpenSSH" -Name "DefaultShell" -Value "C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe" -PropertyType "String" -Force
+ #https://docs.microsoft.com/en-us/windows-server/administration/openssh/openssh_server_configuration
+ New-ItemProperty -Path "HKLM:\SOFTWARE\OpenSSH" -Name "DefaultShell" -Value "C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe" -PropertyType "String" -Force
Write-Host "Hiding Taskbar Search icon / box..."
Set-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Search" -Name "SearchboxTaskbarMode" -Type "DWORD" -Value 0
@@ -347,145 +300,117 @@ Start-Job -Name "Configuring Windows - Optimizations, Debloating, and Hardening"
}
New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\UserProfileEngagement" -Name "ScoobeSystemSettingEnabled" -PropertyType "DWORD" -Value "0" -Force
- #Do not offer tailored experiences based on the diagnostic data setting
- New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Privacy" -Name "TailoredExperiencesWithDiagnosticDataEnabled" -PropertyType "DWORD" -Value "0" -Force
+ #Do not offer tailored experiences based on the diagnostic data setting
+ New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Privacy" -Name "TailoredExperiencesWithDiagnosticDataEnabled" -PropertyType "DWORD" -Value "0" -Force
#Show hidden items in explorer
New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" -Name "Hidden" -PropertyType "DWORD" -Value "1" -Force
- #Show file extentions in explorer
- New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" -Name "HideFileExt" -PropertyType "DWORD" -Value "0" -Force
+ #Show file extentions in explorer
+ New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" -Name "HideFileExt" -PropertyType "DWORD" -Value "0" -Force
#Open to "this pc" in explorer
New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" -Name "LaunchTo" -PropertyType "DWORD" -Value "1" -Force
- #Hide cortana taskbar button
- New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" -Name "ShowCortanaButton" -PropertyType "DWORD" -Value "0" -Force
+ #Hide cortana taskbar button
+ New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" -Name "ShowCortanaButton" -PropertyType "DWORD" -Value "0" -Force
- #Hide task view button in explorer
- New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" -Name "ShowTaskViewButton" -PropertyType "DWORD" -Value "0" -Force
+ #Hide task view button in explorer
+ New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" -Name "ShowTaskViewButton" -PropertyType "DWORD" -Value "0" -Force
- #Hide people button in taskbar
- if (-not (Test-Path -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\People")) {
- New-Item -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\People" -Force
- }
- New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\People" -Name "PeopleBand" -PropertyType "DWORD" -Value "0" -Force
+ #Hide people button in taskbar
+ if (-not (Test-Path -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\People")) {
+ New-Item -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\People" -Force
+ }
+ New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\People" -Name "PeopleBand" -PropertyType "DWORD" -Value "0" -Force
- #Hide "3D Objects" in explorer
- if (-not (Test-Path -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\FolderDescriptions\{ 31C0DD25-9439-4F12-BF41-7FF4EDA38722 }\PropertyBag")) {
- New-Item -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\FolderDescriptions\{ 31C0DD25-9439-4F12-BF41-7FF4EDA38722 }\PropertyBag" -Force
- }
- New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\FolderDescriptions\{ 31C0DD25-9439-4F12-BF41-7FF4EDA38722 }\PropertyBag" -Name "ThisPCPolicy" -PropertyType "String" -Value "Hide" -Force
+ #Hide "3D Objects" in explorer
+ if (-not (Test-Path -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\FolderDescriptions\{ 31C0DD25-9439-4F12-BF41-7FF4EDA38722 }\PropertyBag")) {
+ New-Item -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\FolderDescriptions\{ 31C0DD25-9439-4F12-BF41-7FF4EDA38722 }\PropertyBag" -Force
+ }
+ New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\FolderDescriptions\{ 31C0DD25-9439-4F12-BF41-7FF4EDA38722 }\PropertyBag" -Name "ThisPCPolicy" -PropertyType "String" -Value "Hide" -Force
- #Disable First Logon Animation
- New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System" -Name "EnableFirstLogonAnimation" -PropertyType "DWord" -Value "0" -Force
+ #Disable First Logon Animation
+ New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System" -Name "EnableFirstLogonAnimation" -PropertyType "DWord" -Value "0" -Force
- #Remove Path Limit
- New-ItemProperty -Path "HKLM:\SYSTEM\CurrentControlSet\Control\FileSystem" -Name "LongPathsEnabled" -PropertyType "DWORD" -Value "1" -Force
+ #Remove Path Limit
+ New-ItemProperty -Path "HKLM:\SYSTEM\CurrentControlSet\Control\FileSystem" -Name "LongPathsEnabled" -PropertyType "DWORD" -Value "1" -Force
- #Verbose BSoD
- New-ItemProperty -Path "HKLM:\SYSTEM\CurrentControlSet\Control\CrashControl" -Name "DisplayParameters" -PropertyType "DWORD" -Value "1" -Force
+ #Verbose BSoD
+ New-ItemProperty -Path "HKLM:\SYSTEM\CurrentControlSet\Control\CrashControl" -Name "DisplayParameters" -PropertyType "DWORD" -Value "1" -Force
- #Use only latest .Net
- New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\.NETFramework" -Name "OnlyUseLatestCLR" -PropertyType "DWORD" -Value "1" -Force
- New-ItemProperty -Path "HKLM:\SOFTWARE\Wow6432Node\Microsoft\.NETFramework" -Name "OnlyUseLatestCLR" -PropertyType "DWORD" -Value "1" -Force
+ #Use only latest .Net
+ New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\.NETFramework" -Name "OnlyUseLatestCLR" -PropertyType "DWORD" -Value "1" -Force
+ New-ItemProperty -Path "HKLM:\SOFTWARE\Wow6432Node\Microsoft\.NETFramework" -Name "OnlyUseLatestCLR" -PropertyType "DWORD" -Value "1" -Force
- #Enable Windows Reserved Storage
- Set-WindowsReservedStorageState -State Enabled
+ #Enable Windows Reserved Storage
+ Set-WindowsReservedStorageState -State Enabled
- #Enable Restartable Apps
- New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon" -Name "RestartApps" -Value "1" -Force
+ #Enable Restartable Apps
+ New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon" -Name "RestartApps" -Value "1" -Force
- #Install HVEC Video Extention
- # Check whether the extension is already installed
- if (-not (Get-AppxPackage -Name "Microsoft.HEVCVideoExtension") -and (Get-AppxPackage -Name "Microsoft.Windows.Photos")) {
- try {
- # Check the internet connection
- if ((Invoke-WebRequest -Uri https://www.google.com -UseBasicParsing -DisableKeepAlive -Method Head).StatusDescription) {
- try {
- # Check whether the https://store.rg-adguard.net site is alive
- if ((Invoke-WebRequest -Uri https://store.rg-adguard.net/api/GetFiles -UseBasicParsing -DisableKeepAlive -Method Head).StatusDescription) {
- $API = "https://store.rg-adguard.net/api/GetFiles"
- # HEVC Video Extensions from Device Manufacturer
- $ProductURL = "https://www.microsoft.com/store/productId/9n4wgh0z6vhq"
+ #Install HVEC Video Extention
+ # Check whether the extension is already installed
+ if (-not (Get-AppxPackage -Name "Microsoft.HEVCVideoExtension") -and (Get-AppxPackage -Name "Microsoft.Windows.Photos")) {
+ try {
+ # Check the internet connection
+ if ((Invoke-WebRequest -Uri https://www.google.com -UseBasicParsing -DisableKeepAlive -Method Head).StatusDescription) {
+ try {
+ # Check whether the https://store.rg-adguard.net site is alive
+ if ((Invoke-WebRequest -Uri https://store.rg-adguard.net/api/GetFiles -UseBasicParsing -DisableKeepAlive -Method Head).StatusDescription) {
+ $API = "https://store.rg-adguard.net/api/GetFiles"
+ # HEVC Video Extensions from Device Manufacturer
+ $ProductURL = "https://www.microsoft.com/store/productId/9n4wgh0z6vhq"
- $Body = @{
- type = "url"
- url = $ProductURL
- ring = "Retail"
- lang = "en-US"
- }
- $Raw = Invoke-RestMethod -Method Post -Uri $API -ContentType 'application/x-www-form-urlencoded' -Body $Body
+ $Body = @{
+ type = "url"
+ url = $ProductURL
+ ring = "Retail"
+ lang = "en-US"
+ }
+ $Raw = Invoke-RestMethod -Method Post -Uri $API -ContentType 'application/x-www-form-urlencoded' -Body $Body
- # Parsing the page
- $Raw | Select-String -Pattern '
.*)"\s.*>(?.*)<\/a>' -AllMatches | ForEach-Object -Process { $_.Matches } | ForEach-Object -Process {
- $TempURL = $_.Groups[1].Value
- $Package = $_.Groups[2].Value
+ # Parsing the page
+ $Raw | Select-String -Pattern '.*)"\s.*>(?.*)<\/a>' -AllMatches | ForEach-Object -Process { $_.Matches } | ForEach-Object -Process {
+ $TempURL = $_.Groups[1].Value
+ $Package = $_.Groups[2].Value
- if ($Package -like "Microsoft.HEVCVideoExtension_*_x64__8wekyb3d8bbwe.appx") {
- Write-Verbose -Message $Localization.HEVCDownloading -Verbose
+ if ($Package -like "Microsoft.HEVCVideoExtension_*_x64__8wekyb3d8bbwe.appx") {
+ Write-Verbose -Message $Localization.HEVCDownloading -Verbose
- [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
+ [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
- $DownloadsFolder = Get-ItemPropertyValue -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\User Shell Folders" -Name "{ 374DE290-123F-4565-9164-39C4925E467B }"
- $Parameters = @{
- Uri = $TempURL
- OutFile = "$DownloadsFolder\$Package"
- Verbose = [switch]::Present
- }
- Invoke-WebRequest @Parameters
-
- # Installing "HEVC Video Extensions from Device Manufacturer"
- Add-AppxPackage -Path "$DownloadsFolder\$Package" -Verbose
-
- Remove-Item -Path "$DownloadsFolder\$Package" -Force
+ $DownloadsFolder = Get-ItemPropertyValue -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\User Shell Folders" -Name "{ 374DE290-123F-4565-9164-39C4925E467B }"
+ $Parameters = @{
+ Uri = $TempURL
+ OutFile = "$DownloadsFolder\$Package"
+ Verbose = [switch]::Present
}
+ Invoke-WebRequest @Parameters
+
+ # Installing "HEVC Video Extensions from Device Manufacturer"
+ Add-AppxPackage -Path "$DownloadsFolder\$Package" -Verbose
+
+ Remove-Item -Path "$DownloadsFolder\$Package" -Force
}
}
}
- catch [System.Net.WebException] {
- Write-Warning -Message $Localization.NoResponse
- Write-Error -Message $Localization.NoResponse -ErrorAction SilentlyContinue
- return
- }
}
- }
- catch [System.Net.WebException] {
- Write-Warning -Message $Localization.NoInternetConnection
- Write-Error -Message $Localization.NoInternetConnection -ErrorAction SilentlyContinue
- return
- }
- }
-
- #Enable Sandboxing for Windows Defender
- setx /M MP_FORCE_USE_SANDBOX 1
-
- # Dismiss Microsoft Defender offer in the Windows Security about signing in Microsoft account
- New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows Security Health\State" -Name "AccountProtection_MicrosoftAccount_Disconnected" -PropertyType "DWORD" -Value "1" -Force
-
- #Enable PowerShell Module Logging
- if (-not (Test-Path -Path "HKLM:\SOFTWARE\Policies\Microsoft\Windows\PowerShell\ModuleLogging\ModuleNames")) {
- New-Item -Path "HKLM:\SOFTWARE\Policies\Microsoft\Windows\PowerShell\ModuleLogging\ModuleNames" -Force
- }
- New-ItemProperty -Path "HKLM:\SOFTWARE\Policies\Microsoft\Windows\PowerShell\ModuleLogging" -Name "EnableModuleLogging" -PropertyType "DWORD" -Value "1" -Force
- New-ItemProperty -Path "HKLM:\SOFTWARE\Policies\Microsoft\Windows\PowerShell\ModuleLogging\ModuleNames" -Name "*" -PropertyType "String" -Value "*" -Force
-
- #Enable Windows Sandbox
- if (Get-WindowsEdition -Online | Where-Object -FilterScript { $_.Edition -eq "Professional" -or $_.Edition -like "Enterprise*" }) {
- # Checking whether x86 virtualization is enabled in the firmware
- if ((Get-CimInstance -ClassName CIM_Processor).VirtualizationFirmwareEnabled -eq $true) {
- Enable-WindowsOptionalFeature -FeatureName Containers-DisposableClientVM -All -Online -NoRestart
- }
- else {
- try {
- # Determining whether Hyper-V is enabled
- if ((Get-CimInstance -ClassName CIM_ComputerSystem).HypervisorPresent -eq $true) {
- Enable-WindowsOptionalFeature -FeatureName Containers-DisposableClientVM -All -Online -NoRestart
- }
- }
- catch [System.Exception] {
- Write-Error -Message $Localization.EnableHardwareVT -ErrorAction SilentlyContinue
- }
+ catch [System.Net.WebException] {
+ Write-Warning -Message $Localization.NoResponse
+ Write-Error -Message $Localization.NoResponse -ErrorAction SilentlyContinue
+ return
}
}
}
+ catch [System.Net.WebException] {
+ Write-Warning -Message $Localization.NoInternetConnection
+ Write-Error -Message $Localization.NoInternetConnection -ErrorAction SilentlyContinue
+ return
+ }
+ }
+
+ #Enable Sandboxing for Windows Defender
+ setx /M MP_FORCE_USE_SANDBOX 1
+
+}
\ No newline at end of file