You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
2574 lines
109 KiB
2574 lines
109 KiB
4 years ago
|
<#
|
||
4 years ago
|
.SYNOPSIS
|
||
|
"Windows 10 Setup Script" is a set of tweaks for OS fine-tuning and automating the routine tasks
|
||
4 years ago
|
|
||
4 years ago
|
Version: v4.5
|
||
|
Date: 18.09.2020
|
||
4 years ago
|
Copyright (c) 2020 farag & oZ-Zo
|
||
|
|
||
|
Thanks to all http://forum.ru-board.com members involved
|
||
|
|
||
4 years ago
|
.DESCRIPTION
|
||
|
Supported Windows 10 version: 1809 Enterprise LTSC, 17763 build, x64
|
||
|
|
||
4 years ago
|
Due to the fact that the script includes about 140 functions,
|
||
4 years ago
|
you must read the entire script and comment out those sections that you do not want to be executed,
|
||
|
otherwise likely you will enable features that you do not want to be enabled
|
||
4 years ago
|
|
||
4 years ago
|
Running the script is best done on a fresh install because running it on tweaked system may result in errors occurring
|
||
|
|
||
|
Some third-party antiviruses flag this script or its' part as malicious one. This is a false positive due to $EncodedScript variable
|
||
|
You can read more about in "Create a task to clean up unused files and Windows updates in the Task Scheduler" section
|
||
|
You might need to disable tamper protection from your antivirus settings,re-enable it after running the script, and reboot
|
||
4 years ago
|
|
||
4 years ago
|
Check whether the .ps1 file is encoded in UTF-8 with BOM
|
||
|
The script can not be executed via PowerShell ISE
|
||
|
PowerShell must be run with elevated privileges
|
||
|
|
||
|
Set execution policy to be able to run scripts only in the current PowerShell session:
|
||
|
Set-ExecutionPolicy -ExecutionPolicy Bypass -Scope Process -Force
|
||
|
|
||
|
.EXAMPLE
|
||
|
PS C:\> & '.\LTSC.ps1'
|
||
4 years ago
|
|
||
4 years ago
|
.NOTES
|
||
|
Ask a question on
|
||
|
http://forum.ru-board.com/topic.cgi?forum=62&topic=30617#15
|
||
|
https://habr.com/en/post/465365/
|
||
4 years ago
|
https://4pda.ru/forum/index.php?s=&showtopic=523489&view=findpost&p=95909388
|
||
4 years ago
|
https://forums.mydigitallife.net/threads/powershell-script-setup-windows-10.81675/
|
||
|
https://www.reddit.com/r/PowerShell/comments/go2n5v/powershell_script_setup_windows_10/
|
||
|
|
||
|
.LINK
|
||
|
https://github.com/farag2/Windows-10-Setup-Script
|
||
|
#>
|
||
|
|
||
|
#Requires -RunAsAdministrator
|
||
|
#Requires -Version 5.1
|
||
|
|
||
|
#region Check
|
||
|
Clear-Host
|
||
|
|
||
|
# Get information about the current culture settings
|
||
|
# Получить сведения о параметрах текущей культуры
|
||
4 years ago
|
$RU = $PSUICulture -eq "ru-RU"
|
||
4 years ago
|
|
||
|
# Detect the OS bitness
|
||
|
# Определить разрядность ОС
|
||
|
switch ([Environment]::Is64BitOperatingSystem)
|
||
|
{
|
||
|
$false
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Warning -Message "Скрипт поддерживает только Windows 10 x64"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Warning -Message "The script supports Windows 10 x64 only"
|
||
|
}
|
||
|
break
|
||
|
}
|
||
|
Default {}
|
||
|
}
|
||
|
|
||
|
# Detect the PowerShell bitness
|
||
|
# Определить разрядность PowerShell
|
||
|
switch ([IntPtr]::Size -eq 8)
|
||
|
{
|
||
|
$false
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Warning -Message "Скрипт поддерживает только PowerShell x64"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Warning -Message "The script supports PowerShell x64 only"
|
||
|
}
|
||
|
break
|
||
|
}
|
||
|
Default {}
|
||
|
}
|
||
|
|
||
|
# Detect whether the script is running via PowerShell ISE
|
||
|
# Определить, запущен ли скрипт в PowerShell ISE
|
||
|
if ($psISE)
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Warning -Message "Скрипт не может быть запущен в PowerShell ISE"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
4 years ago
|
Write-Warning -Message "The script cannot be run via PowerShell ISE"
|
||
4 years ago
|
}
|
||
|
break
|
||
|
}
|
||
|
#endregion Check
|
||
|
|
||
|
#region Begin
|
||
|
Set-StrictMode -Version Latest
|
||
|
|
||
|
# Сlear $Error variable
|
||
|
# Очистка переменной $Error
|
||
|
$Error.Clear()
|
||
|
|
||
|
# Create a restore point
|
||
|
# Создать точку восстановления
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "Точка восстановления"
|
||
4 years ago
|
$Message = "Хотите включить защиту системы и создать точку восстановления?"
|
||
4 years ago
|
$Options = "&Создать", "&Не создавать", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "Restore point"
|
||
4 years ago
|
$Message = "Would you like to enable System Restore and create a restore point?"
|
||
4 years ago
|
$Options = "&Create", "&Do not create", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 2
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
|
||
|
switch ($Result)
|
||
|
{
|
||
|
"0"
|
||
|
{
|
||
4 years ago
|
# Enable System Restore
|
||
|
# Включить функцию восстановления системы
|
||
4 years ago
|
if (-not (Get-ComputerRestorePoint))
|
||
|
{
|
||
|
Enable-ComputerRestore -Drive $env:SystemDrive
|
||
|
}
|
||
4 years ago
|
|
||
4 years ago
|
# Set system restore point creation frequency to 5 minutes
|
||
|
# Установить частоту создания точек восстановления на 5 минут
|
||
|
New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\SystemRestore" -Name SystemRestorePointCreationFrequency -PropertyType DWord -Value 5 -Force
|
||
4 years ago
|
Checkpoint-Computer -Description "Windows 10 Setup Script.ps1" -RestorePointType MODIFY_SETTINGS
|
||
|
# Revert the System Restore checkpoint creation frequency to 1440 minutes
|
||
|
# Вернуть частоту создания точек восстановления на 1440 минут
|
||
4 years ago
|
New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\SystemRestore" -Name SystemRestorePointCreationFrequency -PropertyType DWord -Value 1440 -Force
|
||
|
}
|
||
|
"1"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "Точки восстановления"
|
||
4 years ago
|
$Message = "Удалить все точки восстановления?"
|
||
4 years ago
|
$Options = "&Удалить", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "Restore point"
|
||
4 years ago
|
$Message = "Would you like to delete all System restore checkpoints?"
|
||
4 years ago
|
$Options = "&Delete", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
|
||
|
switch ($Result)
|
||
|
{
|
||
|
"0"
|
||
|
{
|
||
|
# Delete all restore points
|
||
|
# Удалить все точки восстановения
|
||
|
Get-CimInstance -ClassName Win32_ShadowCopy | Remove-CimInstance
|
||
|
}
|
||
|
"1"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
"2"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
#endregion Begin
|
||
|
|
||
|
#region Privacy & Telemetry
|
||
4 years ago
|
# Disable the "Connected User Experiences and Telemetry" service (DiagTrack)
|
||
|
# Отключить службу "Функциональные возможности для подключенных пользователей и телеметрия" (DiagTrack)
|
||
4 years ago
|
Get-Service -Name DiagTrack | Stop-Service -Force
|
||
|
Get-Service -Name DiagTrack | Set-Service -StartupType Disabled
|
||
|
|
||
4 years ago
|
# Set the OS level of diagnostic data gathering to minimum
|
||
|
# Установить уровень сбора диагностических сведений ОС на минимальный
|
||
|
New-ItemProperty -Path HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\DataCollection -Name AllowTelemetry -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Turn off Windows Error Reporting for the current user
|
||
|
# Отключить отчеты об ошибках Windows для текущего пользователя
|
||
|
New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\Windows Error Reporting" -Name Disabled -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Change Windows feedback frequency to "Never" for the current user
|
||
|
# Изменить частоту формирования отзывов на "Никогда" для текущего пользователя
|
||
|
if (-not (Test-Path -Path HKCU:\SOFTWARE\Microsoft\Siuf\Rules))
|
||
4 years ago
|
{
|
||
4 years ago
|
New-Item -Path HKCU:\SOFTWARE\Microsoft\Siuf\Rules -Force
|
||
4 years ago
|
}
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Siuf\Rules -Name NumberOfSIUFInPeriod -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
|
# Turn off diagnostics tracking scheduled tasks
|
||
|
# Отключить задачи диагностического отслеживания
|
||
4 years ago
|
$ScheduledTaskList = @(
|
||
4 years ago
|
# Collects program telemetry information if opted-in to the Microsoft Customer Experience Improvement Program.
|
||
|
# Собирает телеметрические данные программы при участии в Программе улучшения качества программного обеспечения Майкрософт
|
||
4 years ago
|
"Microsoft Compatibility Appraiser",
|
||
|
|
||
4 years ago
|
# Collects program telemetry information if opted-in to the Microsoft Customer Experience Improvement Program
|
||
|
# Сбор телеметрических данных программы при участии в программе улучшения качества ПО
|
||
4 years ago
|
"ProgramDataUpdater",
|
||
|
|
||
4 years ago
|
# This task collects and uploads autochk SQM data if opted-in to the Microsoft Customer Experience Improvement Program
|
||
|
# Эта задача собирает и загружает данные SQM при участии в программе улучшения качества программного обеспечения
|
||
4 years ago
|
"Proxy",
|
||
|
|
||
4 years ago
|
# If the user has consented to participate in the Windows Customer Experience Improvement Program, this job collects and sends usage data to Microsoft
|
||
|
# Если пользователь изъявил желание участвовать в программе по улучшению качества программного обеспечения Windows, эта задача будет собирать и отправлять сведения о работе программного обеспечения в Майкрософт
|
||
4 years ago
|
"Consolidator",
|
||
|
|
||
|
# The USB CEIP (Customer Experience Improvement Program) task collects Universal Serial Bus related statistics and information about your machine and sends it to the Windows Device Connectivity engineering group at Microsoft
|
||
|
# При выполнении задачи программы улучшения качества ПО шины USB (USB CEIP) осуществляется сбор статистических данных об использовании универсальной последовательной шины USB и с ведений о компьютере, которые направляются инженерной группе Майкрософт по вопросам подключения устройств в Windows
|
||
|
"UsbCeip",
|
||
|
|
||
4 years ago
|
# The Windows Disk Diagnostic reports general disk and system information to Microsoft for users participating in the Customer Experience Program
|
||
|
# Для пользователей, участвующих в программе контроля качества программного обеспечения, служба диагностики дисков Windows предоставляет общие сведения о дисках и системе в корпорацию Майкрософт
|
||
4 years ago
|
"Microsoft-Windows-DiskDiagnosticDataCollector",
|
||
|
|
||
4 years ago
|
# Protects user files from accidental loss by copying them to a backup location when the system is unattended
|
||
|
# Защищает файлы пользователя от случайной потери за счет их копирования в резервное расположение, когда система находится в автоматическом режиме
|
||
4 years ago
|
"File History (maintenance mode)",
|
||
|
|
||
4 years ago
|
# Measures a system's performance and capabilities
|
||
|
# Измеряет быстродействие и возможности системы
|
||
4 years ago
|
"WinSAT",
|
||
|
|
||
4 years ago
|
# This task shows various Map related toasts
|
||
|
# Эта задача показывает различные тосты (всплывающие уведомления) приложения "Карты"
|
||
4 years ago
|
"MapsToastTask",
|
||
|
|
||
|
# This task checks for updates to maps which you have downloaded for offline use
|
||
|
# Эта задача проверяет наличие обновлений для карт, загруженных для автономного использования
|
||
|
"MapsUpdateTask",
|
||
|
|
||
4 years ago
|
# Initializes Family Safety monitoring and enforcement
|
||
|
# Инициализация контроля и применения правил семейной безопасности
|
||
4 years ago
|
"FamilySafetyMonitor",
|
||
|
|
||
4 years ago
|
# Synchronizes the latest settings with the Microsoft family features service
|
||
|
# Синхронизирует последние параметры со службой функций семьи учетных записей Майкрософт
|
||
4 years ago
|
"FamilySafetyRefreshTask",
|
||
|
|
||
4 years ago
|
# Windows Error Reporting task to process queued reports
|
||
|
# Задача отчетов об ошибках обрабатывает очередь отчетов
|
||
4 years ago
|
"QueueReporting",
|
||
|
|
||
4 years ago
|
# XblGameSave Standby Task
|
||
|
"XblGameSaveTask"
|
||
|
)
|
||
4 years ago
|
|
||
|
# If device is not a laptop disable FODCleanupTask too
|
||
|
# Если устройство не является ноутбуком, отключить также и FODCleanupTask
|
||
4 years ago
|
if ((Get-CimInstance -ClassName Win32_ComputerSystem).PCSystemType -ne 2)
|
||
|
{
|
||
4 years ago
|
# Windows Hello
|
||
|
$ScheduledTaskList += "FODCleanupTask"
|
||
4 years ago
|
}
|
||
|
|
||
4 years ago
|
Get-ScheduledTask -TaskName $ScheduledTaskList | Disable-ScheduledTask
|
||
|
|
||
|
# Do not use sign-in info to automatically finish setting up device and reopen apps after an update or restart (current user only)
|
||
|
# Не использовать данные для входа для автоматического завершения настройки устройства и открытия приложений после перезапуска или обновления (только для текущего пользователя)
|
||
4 years ago
|
$SID = (Get-CimInstance -ClassName Win32_UserAccount | Where-Object -FilterScript {$_.Name -eq $env:USERNAME}).SID
|
||
4 years ago
|
if (-not (Test-Path -Path "HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon\UserARSO\$SID"))
|
||
4 years ago
|
{
|
||
|
New-Item -Path "HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon\UserARSO\$SID" -Force
|
||
|
}
|
||
4 years ago
|
New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon\UserARSO\$SID" -Name OptOut -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Do not let websites provide locally relevant content by accessing language list (current user only)
|
||
|
# Не позволять веб-сайтам предоставлять местную информацию за счет доступа к списку языков (только для текущего пользователя)
|
||
4 years ago
|
New-ItemProperty -Path "HKCU:\Control Panel\International\User Profile" -Name HttpAcceptLanguageOptOut -PropertyType DWord -Value 1 -Force
|
||
|
|
||
4 years ago
|
# Do not allow apps to use advertising ID (current user only)
|
||
|
# Не разрешать приложениям использовать идентификатор рекламы (только для текущего пользователя)
|
||
|
if (-not (Test-Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\AdvertisingInfo))
|
||
4 years ago
|
{
|
||
4 years ago
|
New-Item -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\AdvertisingInfo -Force
|
||
4 years ago
|
}
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\AdvertisingInfo -Name Enabled -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Do not let apps on other devices open and message apps on this device, and vice versa (current user only)
|
||
|
# Не разрешать приложениям на других устройствах запускать приложения и отправлять сообщения на этом устройстве и наоборот (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\CDP -Name RomeSdkChannelUserAuthzPolicy -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
#endregion Privacy & Telemetry
|
||
|
|
||
|
#region UI & Personalization
|
||
4 years ago
|
# Show "This PC" on Desktop (current user only)
|
||
|
# Отобразить "Этот компьютер" на рабочем столе (только для текущего пользователя)
|
||
4 years ago
|
if (-not (Test-Path HKCU:\Software\Microsoft\Windows\CurrentVersion\Explorer\HideDesktopIcons\NewStartPanel))
|
||
|
{
|
||
|
New-Item -Path HKCU:\Software\Microsoft\Windows\CurrentVersion\Explorer\HideDesktopIcons\NewStartPanel -Force
|
||
|
}
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\HideDesktopIcons\NewStartPanel -Name "{20D04FE0-3AEA-1069-A2D8-08002B30309D}" -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Do not use check boxes to select items (current user only)
|
||
|
# Не использовать флажки для выбора элементов (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced -Name AutoCheckSelect -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Show hidden files, folders, and drives (current user only)
|
||
|
# Показывать скрытые файлы, папки и диски (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced -Name Hidden -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Show file name extensions (current user only)
|
||
|
# Показывать расширения имён файлов (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced -Name HideFileExt -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Do not hide folder merge conflicts (current user only)
|
||
|
# Не скрывать конфликт слияния папок (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced -Name HideMergeConflicts -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Open File Explorer to: "This PC" (current user only)
|
||
|
# Открывать проводник для: "Этот компьютер" (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced -Name LaunchTo -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Do not show all folders in the navigation pane (current user only)
|
||
|
# Не отображать все папки в области навигации (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced -Name NavPaneShowAllFolders -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Do not show Task View button on the taskbar (current user only)
|
||
|
# Не показывать кнопку Просмотра задач (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced -Name ShowTaskViewButton -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Do not show People button on the taskbar (current user only)
|
||
|
# Не показывать панель "Люди" на панели задач (только для текущего пользователя)
|
||
|
if (-not (Test-Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\People))
|
||
4 years ago
|
{
|
||
4 years ago
|
New-Item -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\People -Force
|
||
4 years ago
|
}
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\People -Name PeopleBand -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Show seconds on the taskbar clock (current user only)
|
||
|
# Отображать секунды в системных часах на панели задач (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced -Name ShowSecondsInSystemClock -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Do not show when snapping a window, what can be attached next to it (current user only)
|
||
|
# Не показывать при прикреплении окна, что можно прикрепить рядом с ним (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced -Name SnapAssist -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Always open the file transfer dialog box in the detailed mode (current user only)
|
||
|
# Всегда открывать диалоговое окно передачи файлов в развернутом виде (только для текущего пользователя)
|
||
|
if (-not (Test-Path -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\OperationStatusManager))
|
||
4 years ago
|
{
|
||
4 years ago
|
New-Item -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\OperationStatusManager -Force
|
||
4 years ago
|
}
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\OperationStatusManager -Name EnthusiastMode -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Show the ribbon expanded in File Explorer (current user only)
|
||
|
# Отображать ленту проводника в развернутом виде (только для текущего пользователя)
|
||
|
if (-not (Test-Path -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Ribbon))
|
||
4 years ago
|
{
|
||
4 years ago
|
New-Item -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Ribbon -Force
|
||
4 years ago
|
}
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Ribbon -Name MinimizedStateTabletModeOff -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
|
<#
|
||
|
Display recycle bin files delete confirmation
|
||
|
Function [WinAPI.UpdateExplorer]::PostMessage() call required at the end
|
||
|
|
||
|
Запрашивать подтверждение на удаление файлов в корзину
|
||
|
В конце необходим вызов функции [WinAPI.UpdateExplorer]::PostMessage()
|
||
|
#>
|
||
4 years ago
|
$ShellState = Get-ItemPropertyValue -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer -Name ShellState
|
||
4 years ago
|
$ShellState[4] = 51
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer -Name ShellState -PropertyType Binary -Value $ShellState -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Hide the "3D Objects" folder from "This PC" and "Quick access" (current user only)
|
||
|
# Скрыть папку "Объемные объекты" из "Этот компьютер" и из панели быстрого доступа (только для текущего пользователя)
|
||
4 years ago
|
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
|
||
|
|
||
4 years ago
|
# Do not show frequently used folders in "Quick access" (current user only)
|
||
|
# Не показывать недавно используемые папки на панели быстрого доступа (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer -Name ShowFrequent -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Do not show recently used files in Quick access (current user only)
|
||
|
# Не показывать недавно использовавшиеся файлы на панели быстрого доступа (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer -Name ShowRecent -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Hide the search box or the search icon from the taskbar (current user only)
|
||
|
# Скрыть поле или значок поиска на панели задач (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Search -Name SearchboxTaskbarMode -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Always show all icons in the notification area (current user only)
|
||
|
# Всегда отображать все значки в области уведомлений (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer -Name EnableAutoTray -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# View the Control Panel icons by: large icons (current user only)
|
||
|
# Просмотр иконок Панели управления как: крупные значки (только для текущего пользователя)
|
||
|
if (-not (Test-Path -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\ControlPanel))
|
||
4 years ago
|
{
|
||
4 years ago
|
New-Item -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\ControlPanel -Force
|
||
4 years ago
|
}
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\ControlPanel -Name AllItemsIconView -PropertyType DWord -Value 0 -Force
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\ControlPanel -Name StartupPage -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# The color scheme for Windows shell (current user only)
|
||
|
# Режим цвета для Windows (только для текущего пользователя)
|
||
4 years ago
|
if ($RU)
|
||
|
{
|
||
4 years ago
|
$Title = "Режим Windows"
|
||
|
$Message = "Установить цветовую схему Windows на светлую или темную"
|
||
4 years ago
|
$Options = "&Светлый", "&Темный", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
4 years ago
|
$Title = "Windows mode"
|
||
|
$Message = "Set the Windows color scheme to either Light or Dark"
|
||
4 years ago
|
$Options = "&Light", "&Dark", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
|
||
|
switch ($Result)
|
||
|
{
|
||
|
"0"
|
||
|
{
|
||
4 years ago
|
# Light color scheme
|
||
|
# Светлая цветовая схема
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize -Name SystemUsesLightTheme -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
}
|
||
|
"1"
|
||
|
{
|
||
4 years ago
|
# Dark color scheme
|
||
|
# Темная цветовая схема
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize -Name SystemUsesLightTheme -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
}
|
||
|
"2"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
4 years ago
|
# The color scheme for apps (current user only)
|
||
|
# Режим цвета для приложений (только для текущего пользователя)
|
||
4 years ago
|
if ($RU)
|
||
|
{
|
||
4 years ago
|
$Title = "Режим приложений"
|
||
4 years ago
|
$Message = "Чтобы выбрать режим приложения по умолчанию, введите необходимую букву"
|
||
|
$Options = "&Светлый", "&Темный", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
4 years ago
|
$Title = "Apps mode"
|
||
|
$Message = "Set apps color scheme to either Light or Dark"
|
||
4 years ago
|
$Options = "&Light", "&Dark", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
|
||
|
switch ($Result)
|
||
|
{
|
||
|
"0"
|
||
|
{
|
||
4 years ago
|
# Light color scheme
|
||
|
# Светлый цветовая схема
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize -Name AppsUseLightTheme -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
}
|
||
|
"1"
|
||
|
{
|
||
4 years ago
|
# Dark color scheme
|
||
|
# Темная цветовая схема
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize -Name AppsUseLightTheme -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
}
|
||
|
"2"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
4 years ago
|
# Do not show the "New App Installed" indicator
|
||
4 years ago
|
# Не показывать уведомление "Установлено новое приложение"
|
||
|
if (-not (Test-Path -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\Explorer))
|
||
|
{
|
||
|
New-Item -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\Explorer -Force
|
||
|
}
|
||
|
New-ItemProperty -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\Explorer -Name NoNewAppAlert -PropertyType DWord -Value 1 -Force
|
||
|
|
||
4 years ago
|
# Do not show user first sign-in animation after the upgrade
|
||
|
# Не показывать анимацию при первом входе в систему после обновления
|
||
4 years ago
|
New-ItemProperty -Path HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System -Name EnableFirstLogonAnimation -PropertyType DWord -Value 0 -Force
|
||
|
|
||
4 years ago
|
# Set the quality factor of the JPEG desktop wallpapers to maximum (current user only)
|
||
|
# Установить коэффициент качества обоев рабочего стола в формате JPEG на максимальный (только для текущего пользователя)
|
||
4 years ago
|
New-ItemProperty -Path "HKCU:\Control Panel\Desktop" -Name JPEGImportQuality -PropertyType DWord -Value 100 -Force
|
||
|
|
||
4 years ago
|
# Start Task Manager in expanded mode (current user only)
|
||
|
# Запускать Диспетчера задач в развернутом виде (только для текущего пользователя)
|
||
|
$Taskmgr = Get-Process -Name Taskmgr -ErrorAction Ignore
|
||
|
if ($Taskmgr)
|
||
4 years ago
|
{
|
||
4 years ago
|
$Taskmgr.CloseMainWindow()
|
||
4 years ago
|
}
|
||
4 years ago
|
|
||
4 years ago
|
Start-Process -FilePath Taskmgr.exe -WindowStyle Hidden -PassThru
|
||
|
do
|
||
|
{
|
||
|
Start-Sleep -Milliseconds 100
|
||
4 years ago
|
$Preferences = Get-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\TaskManager -Name Preferences -ErrorAction Ignore
|
||
4 years ago
|
}
|
||
4 years ago
|
until ($Preferences)
|
||
4 years ago
|
Stop-Process -Name Taskmgr
|
||
4 years ago
|
|
||
|
$Preferences.Preferences[28] = 0
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\TaskManager -Name Preferences -PropertyType Binary -Value $Preferences.Preferences -Force
|
||
4 years ago
|
|
||
|
# Show a notification when your PC requires a restart to finish updating
|
||
|
# Показывать уведомление, когда компьютеру требуется перезагрузка для завершения обновления
|
||
|
New-ItemProperty -Path HKLM:\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings -Name RestartNotificationsAllowed2 -PropertyType DWord -Value 1 -Force
|
||
|
|
||
4 years ago
|
# Do not add the "- Shortcut" suffix to the file name of created shortcuts (current user only)
|
||
|
# Нe дoбaвлять "- яpлык" к имени coздaвaeмых яpлыков (только для текущего пользователя)
|
||
|
if (-not (Test-Path -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\NamingTemplates))
|
||
|
{
|
||
|
New-Item -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\NamingTemplates -Force
|
||
|
}
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\NamingTemplates -Name ShortcutNameTemplate -PropertyType String -Value "%s.lnk" -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Use the PrtScn button to open screen snipping (current user only)
|
||
|
# Использовать кнопку PRINT SCREEN, чтобы запустить функцию создания фрагмента экрана (только для текущего пользователя)
|
||
4 years ago
|
New-ItemProperty -Path "HKCU:\Control Panel\Keyboard" -Name PrintScreenKeyForSnippingEnabled -PropertyType DWord -Value 1 -Force
|
||
|
#endregion UI & Personalization
|
||
|
|
||
|
#region System
|
||
4 years ago
|
# Turn on Storage Sense (current user only)
|
||
|
# Включить Контроль памяти (только для текущего пользователя)
|
||
|
if (-not (Test-Path -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\StorageSense\Parameters\StoragePolicy))
|
||
|
{
|
||
|
New-Item -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\StorageSense\Parameters\StoragePolicy -ItemType Directory -Force
|
||
|
}
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\StorageSense\Parameters\StoragePolicy -Name 01 -PropertyType DWord -Value 1 -Force
|
||
|
|
||
|
if ((Get-ItemPropertyValue -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\StorageSense\Parameters\StoragePolicy -Name 01) -eq "1")
|
||
|
{
|
||
|
# Run Storage Sense every month (current user only)
|
||
|
# Запускать Контроль памяти каждый месяц (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\StorageSense\Parameters\StoragePolicy -Name 2048 -PropertyType DWord -Value 30 -Force
|
||
|
|
||
|
# Delete temporary files that apps aren't using (current user only)
|
||
|
# Удалять временные файлы, не используемые в приложениях (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\StorageSense\Parameters\StoragePolicy -Name 04 -PropertyType DWord -Value 1 -Force
|
||
|
|
||
|
# Delete files in recycle bin if they have been there for over 30 days (current user only)
|
||
|
# Удалять файлы из корзины, если они находятся в корзине более 30 дней (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\StorageSense\Parameters\StoragePolicy -Name 08 -PropertyType DWord -Value 1 -Force
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\StorageSense\Parameters\StoragePolicy -Name 256 -PropertyType DWord -Value 30 -Force
|
||
|
}
|
||
|
|
||
|
# Disable hibernation if the device is not a laptop
|
||
4 years ago
|
# Отключить режим гибернации, если устройство не является ноутбуком
|
||
|
if ((Get-CimInstance -ClassName Win32_ComputerSystem).PCSystemType -ne 2)
|
||
|
{
|
||
|
POWERCFG /HIBERNATE OFF
|
||
|
}
|
||
|
|
||
4 years ago
|
# Change the %TEMP% environment variable path to the %SystemDrive%\Temp (both machine-wide, and for the current user)
|
||
|
# Изменить путь переменной среды для %TEMP% на %SystemDrive%\Temp (для всех пользователей)
|
||
4 years ago
|
$Title = ""
|
||
|
if ($RU)
|
||
4 years ago
|
{
|
||
4 years ago
|
$Message = "Изменить путь переменной среды для $env:TEMP на `"$env:SystemDrive\Temp`"?"
|
||
|
Write-Warning -Message "`nПеред выполнением закройте все работающие программы!"
|
||
4 years ago
|
$Options = "&Изменить", "&Пропустить"
|
||
4 years ago
|
}
|
||
4 years ago
|
else
|
||
|
{
|
||
4 years ago
|
$Message = "Would you like to change the target of the $env:TEMP environment variable to the `"$env:SystemDrive\Temp`"?"
|
||
|
Write-Warning -Message "`nClose all running programs before proceeding!"
|
||
4 years ago
|
$Options = "&Change", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
|
||
|
switch ($Result)
|
||
|
{
|
||
|
"0"
|
||
|
{
|
||
|
if (-not (Test-Path -Path $env:SystemDrive\Temp))
|
||
|
{
|
||
|
New-Item -Path $env:SystemDrive\Temp -ItemType Directory -Force
|
||
|
}
|
||
|
|
||
|
[Environment]::SetEnvironmentVariable("TMP", "$env:SystemDrive\Temp", "User")
|
||
|
[Environment]::SetEnvironmentVariable("TMP", "$env:SystemDrive\Temp", "Machine")
|
||
|
[Environment]::SetEnvironmentVariable("TMP", "$env:SystemDrive\Temp", "Process")
|
||
|
New-ItemProperty -Path HKCU:\Environment -Name TMP -PropertyType ExpandString -Value %SystemDrive%\Temp -Force
|
||
|
|
||
|
[Environment]::SetEnvironmentVariable("TEMP", "$env:SystemDrive\Temp", "User")
|
||
|
[Environment]::SetEnvironmentVariable("TEMP", "$env:SystemDrive\Temp", "Machine")
|
||
|
[Environment]::SetEnvironmentVariable("TEMP", "$env:SystemDrive\Temp", "Process")
|
||
|
New-ItemProperty -Path HKCU:\Environment -Name TEMP -PropertyType ExpandString -Value %SystemDrive%\Temp -Force
|
||
|
|
||
|
New-ItemProperty -Path "HKLM:\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" -Name TMP -PropertyType ExpandString -Value %SystemDrive%\Temp -Force
|
||
|
New-ItemProperty -Path "HKLM:\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" -Name TEMP -PropertyType ExpandString -Value %SystemDrive%\Temp -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Restart the Printer Spooler service (Spooler)
|
||
|
# Перезапустить службу "Диспетчер печати" (Spooler)
|
||
4 years ago
|
Restart-Service -Name Spooler -Force
|
||
4 years ago
|
|
||
4 years ago
|
Stop-Process -Name OneDrive -Force -ErrorAction Ignore
|
||
|
Stop-Process -Name FileCoAuth -Force -ErrorAction Ignore
|
||
4 years ago
|
|
||
4 years ago
|
Remove-Item -Path $env:SystemRoot\Temp -Recurse -Force -ErrorAction Ignore
|
||
|
Remove-Item -Path $env:LOCALAPPDATA\Temp -Recurse -Force -ErrorAction Ignore
|
||
|
|
||
|
# Create a symbolic link to the %SystemDrive%\Temp folder
|
||
|
# Создать символическую ссылку к папке %SystemDrive%\Temp
|
||
4 years ago
|
try
|
||
|
{
|
||
|
New-Item -Path $env:LOCALAPPDATA\Temp -ItemType SymbolicLink -Value $env:SystemDrive\Temp -Force
|
||
|
}
|
||
|
catch
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Error -Message "Папка $env:LOCALAPPDATA\Temp не пуста. Очистите ее вручную" -ErrorAction SilentlyContinue
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Error -Message "The $env:LOCALAPPDATA\Temp folder is not empty. Clear it manually" -ErrorAction SilentlyContinue
|
||
|
}
|
||
|
Invoke-Item -Path $env:LOCALAPPDATA\Temp
|
||
|
}
|
||
4 years ago
|
}
|
||
|
"1"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
|
}
|
||
|
}
|
||
4 years ago
|
|
||
4 years ago
|
# Disable Windows 260 character path limit
|
||
|
# Отключить ограничение Windows на 260 символов в пути
|
||
4 years ago
|
New-ItemProperty -Path HKLM:\SYSTEM\CurrentControlSet\Control\FileSystem -Name LongPathsEnabled -PropertyType DWord -Value 1 -Force
|
||
|
|
||
|
# Display the Stop error information on the BSoD
|
||
|
# Отображать Stop-ошибку при появлении BSoD
|
||
4 years ago
|
New-ItemProperty -Path HKLM:\SYSTEM\CurrentControlSet\Control\CrashControl -Name DisplayParameters -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Change "Behavior of the elevation prompt for administrators in Admin Approval Mode" to "Elevate without prompting"
|
||
|
# Изменить "Поведение запроса на повышение прав для администраторов в режиме одобрения администратором" на "Повышение прав без запроса"
|
||
4 years ago
|
New-ItemProperty -Path HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System -Name ConsentPromptBehaviorAdmin -PropertyType DWord -Value 0 -Force
|
||
|
|
||
|
# Turn on access to mapped drives from app running with elevated permissions with Admin Approval Mode enabled
|
||
|
# Включить доступ к сетевым дискам при включенном режиме одобрения администратором при доступе из программ, запущенных с повышенными правами
|
||
|
New-ItemProperty -Path HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System -Name EnableLinkedConnections -PropertyType DWord -Value 1 -Force
|
||
|
|
||
4 years ago
|
# Opt out of the Delivery Optimization-assisted updates downloading
|
||
|
# Отказаться от загрузки обновлений с помощью оптимизации доставки
|
||
|
New-ItemProperty -Path Registry::HKEY_USERS\S-1-5-20\SOFTWARE\Microsoft\Windows\CurrentVersion\DeliveryOptimization\Settings -Name DownloadMode -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Always wait for the network at computer startup and logon for workgroup networks
|
||
|
# Всегда ждать сеть при запуске и входе в систему для рабочих групп
|
||
|
if ((Get-CimInstance -ClassName CIM_ComputerSystem).PartOfDomain -eq $true)
|
||
4 years ago
|
{
|
||
4 years ago
|
if (-not (Test-Path -Path "HKLM:\SOFTWARE\Policies\Microsoft\Windows NT\CurrentVersion\Winlogon"))
|
||
|
{
|
||
|
New-Item -Path "HKLM:\SOFTWARE\Policies\Microsoft\Windows NT\CurrentVersion\Winlogon" -Force
|
||
|
}
|
||
|
New-ItemProperty -Path "HKLM:\SOFTWARE\Policies\Microsoft\Windows NT\CurrentVersion\Winlogon" -Name SyncForegroundPolicy -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
}
|
||
|
|
||
4 years ago
|
# Do not let Windows decide which printer should be the default one (current user only)
|
||
|
# Не разрешать Windows решать, какой принтер должен использоваться по умолчанию (только для текущего пользователя)
|
||
|
New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Windows" -Name LegacyDefaultPrinterMode -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Disable the following Windows features
|
||
|
# Отключить следующие компоненты Windows
|
||
4 years ago
|
$WindowsOptionalFeatures = @(
|
||
|
# Legacy Components
|
||
|
# Компоненты прежних версий
|
||
4 years ago
|
"LegacyComponents",
|
||
|
|
||
4 years ago
|
# Media Features
|
||
|
# Компоненты работы с мультимедиа
|
||
4 years ago
|
"MediaPlayback",
|
||
|
|
||
4 years ago
|
# PowerShell 2.0
|
||
4 years ago
|
"MicrosoftWindowsPowerShellV2",
|
||
|
"MicrosoftWindowsPowershellV2Root",
|
||
|
|
||
4 years ago
|
# Microsoft XPS Document Writer
|
||
|
# Средство записи XPS-документов (Microsoft)
|
||
4 years ago
|
"Printing-XPSServices-Features",
|
||
|
|
||
4 years ago
|
# Work Folders Client
|
||
|
# Клиент рабочих папок
|
||
|
"WorkFolders-Client"
|
||
|
)
|
||
|
Disable-WindowsOptionalFeature -Online -FeatureName $WindowsOptionalFeatures -NoRestart
|
||
|
|
||
4 years ago
|
# Disable certain Feature On Demand v2 (FODv2) capabilities
|
||
|
# Отключить определенные компоненты "Функции по требованию" (FODv2)
|
||
4 years ago
|
Add-Type -AssemblyName PresentationCore, PresentationFramework
|
||
|
|
||
|
#region Variables
|
||
4 years ago
|
# Initialize an array list to store the FODv2 items to remove
|
||
|
# Создать массив имен дополнительных компонентов для удаления
|
||
4 years ago
|
$Capabilities = New-Object -TypeName System.Collections.ArrayList($null)
|
||
|
|
||
4 years ago
|
# The following FODv2 items will have their checkboxes checked, recommending the user to remove them
|
||
|
# Следующие дополнительные компоненты будут иметь чекбоксы отмеченными. Рекомендуются к удалению
|
||
4 years ago
|
$CheckedCapabilities = @(
|
||
|
# Steps Recorder
|
||
|
# Средство записи действий
|
||
4 years ago
|
"App.StepsRecorder*",
|
||
|
|
||
4 years ago
|
# Microsoft Quick Assist
|
||
|
# Быстрая поддержка (Майкрософт)
|
||
4 years ago
|
"App.Support.QuickAssist*",
|
||
|
|
||
4 years ago
|
# Windows Media Player
|
||
|
# Проигрыватель Windows Media
|
||
4 years ago
|
"Media.WindowsMediaPlayer*",
|
||
|
|
||
4 years ago
|
# Integrated faxing and scanning application for Windows
|
||
|
# Факсы и сканирование Windows
|
||
|
"Print.Fax.Scan*"
|
||
|
)
|
||
4 years ago
|
# If device is not a laptop disable "Hello.Face*" too
|
||
|
# Если устройство не является ноутбуком, отключить также и "Hello.Face"
|
||
4 years ago
|
if ((Get-CimInstance -ClassName Win32_ComputerSystem).PCSystemType -ne 2)
|
||
|
{
|
||
4 years ago
|
# Windows Hello
|
||
4 years ago
|
$CheckedCapabilities += "Hello.Face*"
|
||
|
}
|
||
4 years ago
|
|
||
|
# The following FODv2 items will be shown, but their checkboxes would be clear
|
||
|
# Следующие дополнительные компоненты будут видны, но их чекбоксы не будут отмечены
|
||
4 years ago
|
$ExcludedCapabilities = @(
|
||
|
# The DirectX Database to configure and optimize apps when multiple Graphics Adapters are present
|
||
|
# База данных DirectX для настройки и оптимизации приложений при наличии нескольких графических адаптеров
|
||
4 years ago
|
"DirectX\.Configuration\.Database",
|
||
|
|
||
4 years ago
|
# Language components
|
||
|
# Языковые компоненты
|
||
4 years ago
|
"Language\.",
|
||
|
|
||
4 years ago
|
# Mail, contacts, and calendar sync component
|
||
4 years ago
|
# Компонент синхронизации почты, контактов и календаря
|
||
4 years ago
|
"OneCoreUAP\.OneSync"
|
||
|
)
|
||
|
#endregion Variables
|
||
|
|
||
|
#region XAML Markup
|
||
4 years ago
|
# The section defines the design of the upcoming dialog box
|
||
|
# Раздел, определяющий форму диалогового окна
|
||
4 years ago
|
[xml]$XAML = '
|
||
|
<Window
|
||
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||
|
Name="Window"
|
||
|
MinHeight="450" MinWidth="400"
|
||
|
SizeToContent="Width" WindowStartupLocation="CenterScreen"
|
||
|
TextOptions.TextFormattingMode="Display" SnapsToDevicePixels="True"
|
||
|
FontFamily="Segoe UI" FontSize="12" ShowInTaskbar="False">
|
||
|
<Window.Resources>
|
||
|
<Style TargetType="StackPanel">
|
||
|
<Setter Property="Orientation" Value="Horizontal"/>
|
||
|
</Style>
|
||
|
<Style TargetType="CheckBox">
|
||
|
<Setter Property="Margin" Value="10, 10, 5, 10"/>
|
||
|
<Setter Property="IsChecked" Value="True"/>
|
||
|
</Style>
|
||
|
<Style TargetType="TextBlock">
|
||
|
<Setter Property="Margin" Value="5, 10, 10, 10"/>
|
||
|
</Style>
|
||
|
<Style TargetType="Button">
|
||
|
<Setter Property="Margin" Value="20"/>
|
||
|
<Setter Property="Padding" Value="10"/>
|
||
|
</Style>
|
||
|
</Window.Resources>
|
||
|
<Grid>
|
||
|
<Grid.RowDefinitions>
|
||
|
<RowDefinition Height="*"/>
|
||
|
<RowDefinition Height="Auto"/>
|
||
|
</Grid.RowDefinitions>
|
||
|
<ScrollViewer Name="Scroll" Grid.Row="0"
|
||
|
HorizontalScrollBarVisibility="Disabled"
|
||
|
VerticalScrollBarVisibility="Auto">
|
||
|
<StackPanel Name="PanelContainer" Orientation="Vertical"/>
|
||
|
</ScrollViewer>
|
||
|
<Button Name="Button" Grid.Row="1"/>
|
||
|
</Grid>
|
||
|
</Window>
|
||
|
'
|
||
|
#endregion XAML Markup
|
||
|
|
||
|
$Reader = (New-Object -TypeName System.Xml.XmlNodeReader -ArgumentList $XAML)
|
||
|
$Form = [Windows.Markup.XamlReader]::Load($Reader)
|
||
|
$XAML.SelectNodes("//*[@*[contains(translate(name(.),'n','N'),'Name')]]") | ForEach-Object -Process {
|
||
|
Set-Variable -Name ($_.Name) -Value $Form.FindName($_.Name) -Scope Global
|
||
|
}
|
||
|
|
||
|
#region Functions
|
||
|
function Get-CheckboxClicked
|
||
|
{
|
||
|
[CmdletBinding()]
|
||
|
param
|
||
|
(
|
||
|
[Parameter(
|
||
|
Mandatory = $true,
|
||
|
ValueFromPipeline = $true
|
||
|
)]
|
||
|
[ValidateNotNull()]
|
||
|
$CheckBox
|
||
|
)
|
||
|
|
||
|
$Capability = $CheckBox.Parent.Children[1].Text
|
||
|
if ($CheckBox.IsChecked)
|
||
|
{
|
||
|
[void]$Capabilities.Add($Capability)
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
[void]$Capabilities.Remove($Capability)
|
||
|
}
|
||
|
if ($Capabilities.Count -gt 0)
|
||
|
{
|
||
|
$Button.IsEnabled = $true
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Button.IsEnabled = $false
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function DeleteButton
|
||
|
{
|
||
|
[void]$Window.Close()
|
||
|
$OFS = "|"
|
||
|
Get-WindowsCapability -Online | Where-Object -FilterScript {$_.Name -cmatch $Capabilities} | Remove-WindowsCapability -Online
|
||
|
$OFS = " "
|
||
|
}
|
||
|
|
||
|
function Add-CapabilityControl
|
||
|
{
|
||
|
[CmdletBinding()]
|
||
|
param
|
||
|
(
|
||
|
[Parameter(
|
||
|
Mandatory = $true,
|
||
|
ValueFromPipeline = $true
|
||
|
)]
|
||
|
[ValidateNotNull()]
|
||
|
[string]
|
||
|
$Capability
|
||
|
)
|
||
|
|
||
|
$CheckBox = New-Object -TypeName System.Windows.Controls.CheckBox
|
||
|
$CheckBox.Add_Click({Get-CheckboxClicked -CheckBox $_.Source})
|
||
|
|
||
|
$TextBlock = New-Object -TypeName System.Windows.Controls.TextBlock
|
||
|
$TextBlock.Text = $Capability
|
||
|
|
||
|
$StackPanel = New-Object -TypeName System.Windows.Controls.StackPanel
|
||
|
[void]$StackPanel.Children.Add($CheckBox)
|
||
|
[void]$StackPanel.Children.Add($TextBlock)
|
||
|
|
||
|
[void]$PanelContainer.Children.Add($StackPanel)
|
||
|
|
||
|
$CheckBox.IsChecked = $false
|
||
|
|
||
|
if ($CheckedCapabilities | Where-Object -FilterScript {$Capability -like $_})
|
||
|
{
|
||
|
$CheckBox.IsChecked = $true
|
||
|
# If capability checked, add to the array list to remove
|
||
|
# Если пакет выделен, то добавить в массив для удаления
|
||
|
[void]$Capabilities.Add($Capability)
|
||
|
}
|
||
|
}
|
||
|
#endregion Functions
|
||
|
|
||
|
#region Events Handlers
|
||
|
# Window Loaded Event
|
||
|
$Window.Add_Loaded({
|
||
|
$OFS = "|"
|
||
|
(Get-WindowsCapability -Online | Where-Object -FilterScript {($_.State -eq "Installed") -and ($_.Name -cnotmatch $ExcludedCapabilities)}).Name | ForEach-Object -Process {
|
||
|
Add-CapabilityControl -Capability $_
|
||
|
}
|
||
|
$OFS = " "
|
||
|
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Window.Title = "Удалить дополнительные компоненты"
|
||
|
$Button.Content = "Удалить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
4 years ago
|
$Window.Title = "Optional features (FODv2) to remove"
|
||
4 years ago
|
$Button.Content = "Uninstall"
|
||
|
}
|
||
|
})
|
||
|
|
||
|
# Button Click Event
|
||
|
$Button.Add_Click({DeleteButton})
|
||
|
#endregion Events Handlers
|
||
|
|
||
|
if (Get-WindowsCapability -Online | Where-Object -FilterScript {($_.State -eq "Installed") -and ($_.Name -cnotmatch ($ExcludedCapabilities -join "|"))})
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
4 years ago
|
Write-Verbose -Message "Диалоговое окно открывается..." -Verbose
|
||
4 years ago
|
}
|
||
|
else
|
||
|
{
|
||
4 years ago
|
Write-Verbose -Message "Displaying the dialog box..." -Verbose
|
||
4 years ago
|
}
|
||
4 years ago
|
# Display the dialog box
|
||
|
# Отобразить диалоговое окно
|
||
4 years ago
|
$Form.ShowDialog() | Out-Null
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
4 years ago
|
Write-Verbose -Message "Отсутствуют данные" -Verbose
|
||
4 years ago
|
}
|
||
|
else
|
||
|
{
|
||
4 years ago
|
Write-Verbose -Message "Nothing to display" -Verbose
|
||
4 years ago
|
}
|
||
|
}
|
||
|
|
||
4 years ago
|
# Opt-in to Microsoft Update service, so to receive updates for other Microsoft products
|
||
|
# Подключаться к службе Microsoft Update так, чтобы при обновлении Windows получать обновления для других продуктов Майкрософт
|
||
4 years ago
|
(New-Object -ComObject Microsoft.Update.ServiceManager).AddService2("7971f918-a847-4430-9279-4a52d1efe18d", 7, "")
|
||
|
|
||
|
# Open "Background apps" page
|
||
|
# Открыть раздел "Фоновые приложения"
|
||
|
Start-Process -FilePath ms-settings:privacy-backgroundapps
|
||
|
|
||
4 years ago
|
# Set the power management scheme based on a device category
|
||
|
# Установить схему управления питанием в зависимости от категории устройства
|
||
4 years ago
|
if ((Get-CimInstance -ClassName Win32_ComputerSystem).PCSystemType -eq 2)
|
||
|
{
|
||
|
# Balanced for laptop
|
||
|
# Сбалансированная для ноутбука
|
||
|
POWERCFG /SETACTIVE SCHEME_BALANCED
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
# High performance for desktop
|
||
|
# Высокая производительность для стационарного ПК
|
||
|
POWERCFG /SETACTIVE SCHEME_MIN
|
||
|
}
|
||
|
|
||
|
# Use latest installed .NET runtime for all apps
|
||
4 years ago
|
# Использовать последнюю установленную среду выполнения .NET для всех приложений
|
||
4 years ago
|
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
|
||
|
|
||
4 years ago
|
# Do not allow the computer (if device is not a laptop) to turn off all the network adapters to save power
|
||
|
# Запретить отключение всех сетевых адаптеров для экономии энергии (если устройство не является ноутбуком)
|
||
4 years ago
|
if ((Get-CimInstance -ClassName Win32_ComputerSystem).PCSystemType -ne 2)
|
||
|
{
|
||
4 years ago
|
$Adapters = Get-NetAdapter -Physical | Get-NetAdapterPowerManagement | Where-Object -FilterScript {$_.AllowComputerToTurnOffDevice -ne "Unsupported"}
|
||
|
foreach ($Adapter in $Adapters)
|
||
4 years ago
|
{
|
||
4 years ago
|
$Adapter.AllowComputerToTurnOffDevice = "Disabled"
|
||
|
$Adapter | Set-NetAdapterPowerManagement
|
||
4 years ago
|
}
|
||
|
}
|
||
|
|
||
|
# Set the default input method to the English language
|
||
|
# Установить метод ввода по умолчанию на английский язык
|
||
4 years ago
|
Set-WinDefaultInputMethodOverride -InputTip "0409:00000409"
|
||
4 years ago
|
|
||
4 years ago
|
# Enable Windows Sandbox
|
||
4 years ago
|
# Включить Windows Sandbox
|
||
4 years ago
|
# Checking whether x86 virtualization is enabled in the firmware
|
||
|
# Проверка: включена ли в настройках UEFI аппаратная виртуализация x86
|
||
|
if ((Get-CimInstance -ClassName CIM_Processor).VirtualizationFirmwareEnabled -eq $true)
|
||
|
{
|
||
|
Enable-WindowsOptionalFeature -FeatureName Containers-DisposableClientVM -All -Online -NoRestart
|
||
|
}
|
||
|
else
|
||
4 years ago
|
{
|
||
4 years ago
|
try
|
||
4 years ago
|
{
|
||
4 years ago
|
# Determining whether Hyper-V is enabled
|
||
|
# Проверка: включен ли Hyper-V
|
||
|
if ((Get-CimInstance -ClassName CIM_ComputerSystem).HypervisorPresent -eq $true)
|
||
|
{
|
||
|
Enable-WindowsOptionalFeature -FeatureName Containers-DisposableClientVM -All -Online -NoRestart
|
||
|
}
|
||
4 years ago
|
}
|
||
4 years ago
|
catch [Exception]
|
||
4 years ago
|
{
|
||
4 years ago
|
if ($RU)
|
||
4 years ago
|
{
|
||
4 years ago
|
Write-Error -Message "Включите в BIOS виртуализацию" -ErrorAction SilentlyContinue
|
||
4 years ago
|
}
|
||
4 years ago
|
else
|
||
4 years ago
|
{
|
||
4 years ago
|
Write-Error -Message "Enable Virtualization in BIOS" -ErrorAction SilentlyContinue
|
||
4 years ago
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
4 years ago
|
# Change the location of the user folders to %SystemDrive% (current user only)
|
||
|
# Изменить расположение пользовательских папок на %SystemDrive% (только для текущего пользователя)
|
||
4 years ago
|
function UserShellFolder
|
||
|
{
|
||
4 years ago
|
<#
|
||
|
.SYNOPSIS
|
||
4 years ago
|
Change the location of the each user folders using SHSetKnownFolderPath function
|
||
4 years ago
|
.EXAMPLE
|
||
4 years ago
|
UserShellFolder -UserFolder Desktop -FolderPath "$env:SystemDrive:\Desktop" -RemoveDesktopINI
|
||
4 years ago
|
.NOTES
|
||
|
User files or folders won't me moved to the new location
|
||
4 years ago
|
The RemoveDesktopINI argument removes desktop.ini in the old user shell folder
|
||
4 years ago
|
#>
|
||
|
[CmdletBinding()]
|
||
|
param
|
||
|
(
|
||
|
[Parameter(Mandatory = $true)]
|
||
|
[ValidateSet("Desktop", "Documents", "Downloads", "Music", "Pictures", "Videos")]
|
||
|
[string]
|
||
4 years ago
|
$UserFolder,
|
||
4 years ago
|
|
||
|
[Parameter(Mandatory = $true)]
|
||
|
[string]
|
||
4 years ago
|
$FolderPath,
|
||
|
|
||
|
[Parameter(Mandatory = $false)]
|
||
|
[switch]
|
||
|
$RemoveDesktopINI
|
||
4 years ago
|
)
|
||
|
|
||
4 years ago
|
function KnownFolderPath
|
||
4 years ago
|
{
|
||
4 years ago
|
<#
|
||
|
.SYNOPSIS
|
||
|
Redirect user folders to a new location
|
||
|
.EXAMPLE
|
||
4 years ago
|
KnownFolderPath -KnownFolder Desktop -Path "$env:SystemDrive:\Desktop"
|
||
4 years ago
|
.NOTES
|
||
|
User files or folders won't me moved to the new location
|
||
|
#>
|
||
|
[CmdletBinding()]
|
||
|
param
|
||
|
(
|
||
|
[Parameter(Mandatory = $true)]
|
||
|
[ValidateSet("Desktop", "Documents", "Downloads", "Music", "Pictures", "Videos")]
|
||
|
[string]
|
||
|
$KnownFolder,
|
||
|
|
||
|
[Parameter(Mandatory = $true)]
|
||
|
[string]
|
||
|
$Path
|
||
|
)
|
||
|
|
||
|
$KnownFolders = @{
|
||
|
"Desktop" = @("B4BFCC3A-DB2C-424C-B029-7FE99A87C641");
|
||
|
"Documents" = @("FDD39AD0-238F-46AF-ADB4-6C85480369C7", "f42ee2d3-909f-4907-8871-4c22fc0bf756");
|
||
|
"Downloads" = @("374DE290-123F-4565-9164-39C4925E467B", "7d83ee9b-2244-4e70-b1f5-5393042af1e4");
|
||
|
"Music" = @("4BD8D571-6D19-48D3-BE97-422220080E43", "a0c69a99-21c8-4671-8703-7934162fcf1d");
|
||
|
"Pictures" = @("33E28130-4E1E-4676-835A-98395C3BC3BB", "0ddd015d-b06c-45d5-8c4c-f59713854639");
|
||
|
"Videos" = @("18989B1D-99B5-455B-841C-AB7C74E4DDFC", "35286a68-3c57-41a1-bbb1-0eae73d76c95");
|
||
|
}
|
||
|
|
||
|
$Signature = @{
|
||
|
Namespace = "WinAPI"
|
||
|
Name = "KnownFolders"
|
||
|
Language = "CSharp"
|
||
|
MemberDefinition = @"
|
||
4 years ago
|
[DllImport("shell32.dll")]
|
||
|
public extern static int SHSetKnownFolderPath(ref Guid folderId, uint flags, IntPtr token, [MarshalAs(UnmanagedType.LPWStr)] string path);
|
||
4 years ago
|
"@
|
||
|
}
|
||
|
if (-not ("WinAPI.KnownFolders" -as [type]))
|
||
|
{
|
||
|
Add-Type @Signature
|
||
|
}
|
||
4 years ago
|
|
||
4 years ago
|
foreach ($guid in $KnownFolders[$KnownFolder])
|
||
|
{
|
||
|
[WinAPI.KnownFolders]::SHSetKnownFolderPath([ref]$guid, 0, 0, $Path)
|
||
|
}
|
||
|
(Get-Item -Path $Path -Force).Attributes = "ReadOnly"
|
||
4 years ago
|
}
|
||
|
|
||
|
$UserShellFoldersRegName = @{
|
||
|
"Desktop" = "Desktop"
|
||
|
"Documents" = "Personal"
|
||
|
"Downloads" = "{374DE290-123F-4565-9164-39C4925E467B}"
|
||
|
"Music" = "My Music"
|
||
|
"Pictures" = "My Pictures"
|
||
|
"Videos" = "My Video"
|
||
|
}
|
||
|
|
||
|
$UserShellFoldersGUID = @{
|
||
|
"Desktop" = "{754AC886-DF64-4CBA-86B5-F7FBF4FBCEF5}"
|
||
|
"Documents" = "{F42EE2D3-909F-4907-8871-4C22FC0BF756}"
|
||
|
"Downloads" = "{7D83EE9B-2244-4E70-B1F5-5393042AF1E4}"
|
||
|
"Music" = "{A0C69A99-21C8-4671-8703-7934162FCF1D}"
|
||
|
"Pictures" = "{0DDD015D-B06C-45D5-8C4C-F59713854639}"
|
||
|
"Videos" = "{35286A68-3C57-41A1-BBB1-0EAE73D76C95}"
|
||
|
}
|
||
|
|
||
4 years ago
|
# Contents of the hidden desktop.ini file for each type of user folders
|
||
|
# Содержимое скрытого файла desktop.ini для каждого типа пользовательских папок
|
||
4 years ago
|
$DesktopINI = @{
|
||
|
"Desktop" = "",
|
||
|
"[.ShellClassInfo]",
|
||
|
"LocalizedResourceName=@%SystemRoot%\system32\shell32.dll,-21769",
|
||
|
"IconResource=%SystemRoot%\system32\imageres.dll,-183"
|
||
|
"Documents" = "",
|
||
|
"[.ShellClassInfo]",
|
||
|
"LocalizedResourceName=@%SystemRoot%\system32\shell32.dll,-21770",
|
||
|
"IconResource=%SystemRoot%\system32\imageres.dll,-112",
|
||
|
"IconFile=%SystemRoot%\system32\shell32.dll",
|
||
|
"IconIndex=-235"
|
||
|
"Downloads" = "",
|
||
|
"[.ShellClassInfo]","LocalizedResourceName=@%SystemRoot%\system32\shell32.dll,-21798",
|
||
|
"IconResource=%SystemRoot%\system32\imageres.dll,-184"
|
||
|
"Music" = "",
|
||
|
"[.ShellClassInfo]","LocalizedResourceName=@%SystemRoot%\system32\shell32.dll,-21790",
|
||
|
"InfoTip=@%SystemRoot%\system32\shell32.dll,-12689",
|
||
|
"IconResource=%SystemRoot%\system32\imageres.dll,-108",
|
||
|
"IconFile=%SystemRoot%\system32\shell32.dll","IconIndex=-237"
|
||
|
"Pictures" = "",
|
||
|
"[.ShellClassInfo]",
|
||
|
"LocalizedResourceName=@%SystemRoot%\system32\shell32.dll,-21779",
|
||
|
"InfoTip=@%SystemRoot%\system32\shell32.dll,-12688",
|
||
|
"IconResource=%SystemRoot%\system32\imageres.dll,-113",
|
||
|
"IconFile=%SystemRoot%\system32\shell32.dll",
|
||
|
"IconIndex=-236"
|
||
|
"Videos" = "",
|
||
|
"[.ShellClassInfo]",
|
||
|
"LocalizedResourceName=@%SystemRoot%\system32\shell32.dll,-21791",
|
||
|
"InfoTip=@%SystemRoot%\system32\shell32.dll,-12690",
|
||
|
"IconResource=%SystemRoot%\system32\imageres.dll,-189",
|
||
|
"IconFile=%SystemRoot%\system32\shell32.dll","IconIndex=-238"
|
||
|
}
|
||
|
|
||
4 years ago
|
# Determining the current user folder path
|
||
|
# Определяем текущее значение пути пользовательской папки
|
||
4 years ago
|
$UserShellFolderRegValue = Get-ItemPropertyValue -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\User Shell Folders" -Name $UserShellFoldersRegName[$UserFolder]
|
||
4 years ago
|
if ($UserShellFolderRegValue -ne $FolderPath)
|
||
|
{
|
||
|
if ((Get-ChildItem -Path $UserShellFolderRegValue | Measure-Object).Count -ne 0)
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Error -Message "В папке $UserShellFolderRegValue осталась файлы. Переместите их вручную в новое расположение" -ErrorAction SilentlyContinue
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Error -Message "Some files left in the $UserShellFolderRegValue folder. Move them manually to a new location" -ErrorAction SilentlyContinue
|
||
|
}
|
||
|
}
|
||
|
|
||
|
# Creating a new folder if there is no one
|
||
|
# Создаем новую папку, если таковая отсутствует
|
||
|
if (-not (Test-Path -Path $FolderPath))
|
||
|
{
|
||
|
New-Item -Path $FolderPath -ItemType Directory -Force
|
||
|
}
|
||
|
|
||
4 years ago
|
# Removing old desktop.ini
|
||
|
# Удаляем старый desktop.ini
|
||
|
if ($RemoveDesktopINI.IsPresent)
|
||
|
{
|
||
|
Remove-Item -Path "$UserShellFolderRegValue\desktop.ini" -Force
|
||
|
}
|
||
|
|
||
4 years ago
|
KnownFolderPath -KnownFolder $UserFolder -Path $FolderPath
|
||
4 years ago
|
New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\User Shell Folders" -Name $UserShellFoldersGUID[$UserFolder] -PropertyType ExpandString -Value $FolderPath -Force
|
||
4 years ago
|
|
||
|
Set-Content -Path "$FolderPath\desktop.ini" -Value $DesktopINI[$UserFolder] -Encoding Unicode -Force
|
||
|
(Get-Item -Path "$FolderPath\desktop.ini" -Force).Attributes = "Hidden", "System", "Archive"
|
||
|
(Get-Item -Path "$FolderPath\desktop.ini" -Force).Refresh()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
<#
|
||
|
.SYNOPSIS
|
||
|
The "Show menu" function using PowerShell with the up/down arrow keys and enter key to make a selection
|
||
|
.EXAMPLE
|
||
|
ShowMenu -Menu $ListOfItems -Default $DefaultChoice
|
||
|
.NOTES
|
||
|
Doesn't work in PowerShell ISE
|
||
|
#>
|
||
|
function ShowMenu
|
||
|
{
|
||
|
[CmdletBinding()]
|
||
|
param
|
||
|
(
|
||
|
[Parameter()]
|
||
|
[string]
|
||
|
$Title,
|
||
|
|
||
|
[Parameter(Mandatory = $true)]
|
||
|
[array]
|
||
|
$Menu,
|
||
|
|
||
|
[Parameter(Mandatory = $true)]
|
||
|
[int]
|
||
|
$Default
|
||
|
)
|
||
|
|
||
|
Write-Information -MessageData $Title -InformationAction Continue
|
||
|
|
||
|
$minY = [Console]::CursorTop
|
||
|
$y = [Math]::Max([Math]::Min($Default, $Menu.Count), 0)
|
||
|
do
|
||
|
{
|
||
|
[Console]::CursorTop = $minY
|
||
|
[Console]::CursorLeft = 0
|
||
|
$i = 0
|
||
|
foreach ($item in $Menu)
|
||
|
{
|
||
|
if ($i -ne $y)
|
||
|
{
|
||
|
Write-Information -MessageData (' {0}. {1} ' -f ($i+1), $item) -InformationAction Continue
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Information -MessageData ('[ {0}. {1} ]' -f ($i+1), $item) -InformationAction Continue
|
||
|
}
|
||
|
$i++
|
||
|
}
|
||
|
|
||
|
$k = [Console]::ReadKey()
|
||
|
switch ($k.Key)
|
||
|
{
|
||
|
"UpArrow"
|
||
|
{
|
||
|
if ($y -gt 0)
|
||
|
{
|
||
|
$y--
|
||
|
}
|
||
|
}
|
||
|
"DownArrow"
|
||
|
{
|
||
|
if ($y -lt ($Menu.Count - 1))
|
||
|
{
|
||
|
$y++
|
||
|
}
|
||
|
}
|
||
|
"Enter"
|
||
|
{
|
||
|
return $Menu[$y]
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
while ($k.Key -notin ([ConsoleKey]::Escape, [ConsoleKey]::Enter))
|
||
|
}
|
||
|
|
||
|
# Store all drives letters to use them within ShowMenu function
|
||
|
# Сохранить все буквы диска, чтобы использовать их в функции ShowMenu
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose "Получение дисков..." -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose "Retrieving drives..." -Verbose
|
||
|
}
|
||
|
$DriveLetters = @((Get-Disk | Where-Object -FilterScript {$_.BusType -ne "USB"} | Get-Partition | Get-Volume | Where-Object -FilterScript {$null -ne $_.DriveLetter}).DriveLetter | Sort-Object)
|
||
|
|
||
4 years ago
|
# If the number of disks is more than one, set the second drive in the list as default drive
|
||
|
# Если количество дисков больше одного, сделать второй диск в списке диском по умолчанию
|
||
4 years ago
|
if ($DriveLetters.Count -gt 1)
|
||
|
{
|
||
|
$Default = 1
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Default = 0
|
||
|
}
|
||
|
|
||
|
# Desktop
|
||
|
# Рабочий стол
|
||
|
$Title = ""
|
||
|
if ($RU)
|
||
|
{
|
||
4 years ago
|
$Message = "Изменить местоположение папки `"Рабочий стол`"?"
|
||
4 years ago
|
Write-Warning -Message "`nФайлы не будут перенесены"
|
||
4 years ago
|
$Options = "&Изменить", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
4 years ago
|
$Message = "Would you like to change the location of the Desktop folder?"
|
||
4 years ago
|
Write-Warning -Message "`nFiles will not be moved"
|
||
4 years ago
|
$Options = "&Change", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
|
||
|
switch ($Result)
|
||
|
{
|
||
|
"0"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "`nВыберите диск, в корне которого будет создана папка для `"Рабочий стол`""
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "`nSelect the drive within the root of which the `"Desktop`" folder will be created"
|
||
|
}
|
||
|
$SelectedDrive = ShowMenu -Title $Title -Menu $DriveLetters -Default $Default
|
||
4 years ago
|
UserShellFolder -UserFolder Desktop -FolderPath "${SelectedDrive}:\Desktop" -RemoveDesktopINI
|
||
4 years ago
|
}
|
||
|
"1"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
# Documents
|
||
|
# Документы
|
||
|
$Title = ""
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Message = "Чтобы изменить местоположение папки `"Документы`", введите необходимую букву"
|
||
4 years ago
|
Write-Warning -Message "`nФайлы не будут перенесены"
|
||
4 years ago
|
$Options = "&Изменить", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Message = "To change the location of the Documents folder enter the required letter"
|
||
4 years ago
|
Write-Warning -Message "`nFiles will not be moved"
|
||
4 years ago
|
$Options = "&Change", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
|
||
|
switch ($Result)
|
||
|
{
|
||
|
"0"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "`nВыберите диск, в корне которого будет создана папка для `"Документы`""
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "`nSelect the drive within the root of which the `"Documents`" folder will be created"
|
||
|
}
|
||
|
$SelectedDrive = ShowMenu -Title $Title -Menu $DriveLetters -Default $Default
|
||
4 years ago
|
UserShellFolder -UserFolder Documents -FolderPath "${SelectedDrive}:\Documents" -RemoveDesktopINI
|
||
4 years ago
|
}
|
||
|
"1"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
# Downloads
|
||
|
# Загрузки
|
||
|
$Title = ""
|
||
|
if ($RU)
|
||
|
{
|
||
4 years ago
|
$Message = "Изменить местоположение папки `"Загрузки`"?"
|
||
4 years ago
|
Write-Warning -Message "`nФайлы не будут перенесены"
|
||
4 years ago
|
$Options = "&Изменить", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
4 years ago
|
$Message = "Would you like to change the location of the Downloads folder?"
|
||
4 years ago
|
Write-Warning -Message "`nFiles will not be moved"
|
||
4 years ago
|
$Options = "&Change", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
|
||
|
switch ($Result)
|
||
|
{
|
||
|
"0"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "`nВыберите диск, в корне которого будет создана папка для `"Загрузки`""
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "`nSelect the drive within the root of which the `"Downloads`" folder will be created"
|
||
|
}
|
||
|
$SelectedDrive = ShowMenu -Title $Title -Menu $DriveLetters -Default $Default
|
||
4 years ago
|
UserShellFolder -UserFolder Downloads -FolderPath "${SelectedDrive}:\Downloads" -RemoveDesktopINI
|
||
4 years ago
|
}
|
||
|
"1"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
# Music
|
||
|
# Музыка
|
||
|
$Title = ""
|
||
|
if ($RU)
|
||
|
{
|
||
4 years ago
|
$Message = "Изменить местоположение папки `"Музыка`"?"
|
||
4 years ago
|
Write-Warning -Message "`nФайлы не будут перенесены"
|
||
4 years ago
|
$Options = "&Изменить", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
4 years ago
|
$Message = "Would you like to change the location of the Music folder?"
|
||
4 years ago
|
Write-Warning -Message "`nFiles will not be moved"
|
||
4 years ago
|
$Options = "&Change", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
|
||
|
switch ($Result)
|
||
|
{
|
||
|
"0"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "`nВыберите диск, в корне которого будет создана папка для `"Музыка`""
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "`nSelect the drive within the root of which the `"Music`" folder will be created"
|
||
|
}
|
||
|
$SelectedDrive = ShowMenu -Title $Title -Menu $DriveLetters -Default $Default
|
||
4 years ago
|
UserShellFolder -UserFolder Music -FolderPath "${SelectedDrive}:\Music" -RemoveDesktopINI
|
||
4 years ago
|
}
|
||
|
"1"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
# Pictures
|
||
|
# Изображения
|
||
|
$Title = ""
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Message = "Чтобы изменить местоположение папки `"Изображения`", введите необходимую букву"
|
||
4 years ago
|
Write-Warning -Message "`nФайлы не будут перенесены"
|
||
4 years ago
|
$Options = "&Изменить", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Message = "To change the location of the Pictures folder enter the required letter"
|
||
4 years ago
|
Write-Warning -Message "`nFiles will not be moved"
|
||
4 years ago
|
$Options = "&Change", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
|
||
|
switch ($Result)
|
||
|
{
|
||
|
"0"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "`nВыберите диск, в корне которого будет создана папка для `"Изображения`""
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "`nSelect the drive within the root of which the `"Pictures`" folder will be created"
|
||
|
}
|
||
|
$SelectedDrive = ShowMenu -Title $Title -Menu $DriveLetters -Default $Default
|
||
4 years ago
|
UserShellFolder -UserFolder Pictures -FolderPath "${SelectedDrive}:\Pictures" -RemoveDesktopINI
|
||
4 years ago
|
}
|
||
|
"1"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
# Videos
|
||
|
# Видео
|
||
|
$Title = ""
|
||
|
if ($RU)
|
||
|
{
|
||
4 years ago
|
$Message = "Изменить местоположение папки `"Видео`"?"
|
||
4 years ago
|
Write-Warning -Message "`nФайлы не будут перенесены"
|
||
4 years ago
|
$Options = "&Изменить", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
4 years ago
|
$Message = "Would you like to change the location of the Videos folder?"
|
||
4 years ago
|
Write-Warning -Message "`nFiles will not be moved"
|
||
4 years ago
|
$Options = "&Change", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
|
||
|
switch ($Result)
|
||
|
{
|
||
|
"0"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "`nВыберите диск, в корне которого будет создана папка для `"Видео`""
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "`nSelect the drive within the root of which the `"Videos`" folder will be created"
|
||
|
}
|
||
|
$SelectedDrive = ShowMenu -Title $Title -Menu $DriveLetters -Default $Default
|
||
4 years ago
|
UserShellFolder -UserFolder Videos -FolderPath "${SelectedDrive}:\Videos" -RemoveDesktopINI
|
||
4 years ago
|
}
|
||
|
"1"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
4 years ago
|
# Save screenshots by pressing Win+PrtScr to the Desktop folder (current user only)
|
||
|
# Сохранять скриншоты по нажатию Win+PrtScr в папку "рабочий стол" (только для текущего пользователя)
|
||
|
$DesktopFolder = Get-ItemPropertyValue -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\User Shell Folders" -Name Desktop
|
||
|
Set-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\User Shell Folders" -Name "{B7BEDE81-DF94-4682-A7D8-57A52620B86F}" -Type ExpandString -Value $DesktopFolder -Force
|
||
|
|
||
4 years ago
|
# Save all opened folders in order to restore them after File Explorer restart
|
||
|
# Сохранить все открытые папки, чтобы восстановить их после перезапуска проводника
|
||
|
Clear-Variable -Name OpenedFolders -Force -ErrorAction Ignore
|
||
|
$OpenedFolders = {(New-Object -ComObject Shell.Application).Windows() | ForEach-Object -Process {$_.Document.Folder.Self.Path}}.Invoke()
|
||
4 years ago
|
|
||
4 years ago
|
# In order for the changes to take effect the File Explorer process has to be restarted
|
||
|
# Чтобы изменения вступили в силу, необходимо перезапустить процесс проводника
|
||
|
Stop-Process -Name explorer -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Restore closed folders
|
||
|
# Восстановить закрытые папки
|
||
|
foreach ($OpenedFolder in $OpenedFolders)
|
||
|
{
|
||
|
if (Test-Path -Path $OpenedFolder)
|
||
|
{
|
||
|
Invoke-Item -Path $OpenedFolder
|
||
|
}
|
||
|
}
|
||
|
|
||
4 years ago
|
# Launch folder windows in a separate process (current user only)
|
||
|
# Запускать окна с папками в отдельном процессе (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced -Name SeparateProcess -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
|
|
||
4 years ago
|
# Disable help lookup via F1 (current user only)
|
||
|
# Отключить открытие справки по нажатию F1 (только для текущего пользователя)
|
||
|
if (-not (Test-Path -Path "HKCU:\SOFTWARE\Classes\Typelib\{8cec5860-07a1-11d9-b15e-000d56bfe6ee}\1.0\0\win64"))
|
||
4 years ago
|
{
|
||
4 years ago
|
New-Item -Path "HKCU:\SOFTWARE\Classes\Typelib\{8cec5860-07a1-11d9-b15e-000d56bfe6ee}\1.0\0\win64" -Force
|
||
4 years ago
|
}
|
||
4 years ago
|
New-ItemProperty -Path "HKCU:\SOFTWARE\Classes\Typelib\{8cec5860-07a1-11d9-b15e-000d56bfe6ee}\1.0\0\win64" -Name "(Default)" -PropertyType String -Value "" -Force
|
||
4 years ago
|
|
||
|
# Turn on Num Lock at startup
|
||
|
# Включить Num Lock при загрузке
|
||
|
New-ItemProperty -Path "Registry::HKEY_USERS\.DEFAULT\Control Panel\Keyboard" -Name InitialKeyboardIndicators -PropertyType String -Value 2147483650 -Force
|
||
|
|
||
4 years ago
|
# Do not activate StickyKey after tapping the Shift key 5 times (current user only)
|
||
|
# Не включать залипание клавиши Shift после 5 нажатий (только для текущего пользователя)
|
||
4 years ago
|
New-ItemProperty -Path "HKCU:\Control Panel\Accessibility\StickyKeys" -Name Flags -PropertyType String -Value 506 -Force
|
||
|
|
||
4 years ago
|
# Do not use AutoPlay for all media and devices (current user only)
|
||
|
# Не использовать автозапуск для всех носителей и устройств (только для текущего пользователя)
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\AutoplayHandlers -Name DisableAutoplay -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Disable thumbnail cache removal
|
||
4 years ago
|
# Отключить удаление кэша миниатюр
|
||
|
New-ItemProperty -Path "HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Explorer\VolumeCaches\Thumbnail Cache" -Name Autorun -PropertyType DWord -Value 0 -Force
|
||
|
|
||
4 years ago
|
# Enable "Network Discovery" and "File and Printers Sharing" for workgroup networks
|
||
|
# Включить сетевое обнаружение и общий доступ к файлам и принтерам для рабочих групп
|
||
4 years ago
|
if ((Get-CimInstance -ClassName CIM_ComputerSystem).PartOfDomain -eq $false)
|
||
4 years ago
|
{
|
||
4 years ago
|
$FirewallRules = @(
|
||
|
# File and printer sharing
|
||
|
# Общий доступ к файлам и принтерам
|
||
|
"@FirewallAPI.dll,-32752",
|
||
|
|
||
|
# Network discovery
|
||
|
# Сетевое обнаружение
|
||
|
"@FirewallAPI.dll,-28502"
|
||
|
)
|
||
|
Set-NetFirewallRule -Group $FirewallRules -Profile Private -Enabled True
|
||
4 years ago
|
}
|
||
4 years ago
|
|
||
|
# Automatically adjust active hours for me based on daily usage
|
||
|
# Автоматически изменять период активности для этого устройства на основе действий
|
||
|
New-ItemProperty -Path HKLM:\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings -Name SmartActiveHoursState -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
#endregion System
|
||
|
|
||
|
#region Start menu
|
||
4 years ago
|
# Do not show recently added apps in the Start menu
|
||
4 years ago
|
# Не показывать недавно добавленные приложения в меню "Пуск"
|
||
|
if (-not (Test-Path -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\Explorer))
|
||
|
{
|
||
|
New-Item -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\Explorer -Force
|
||
|
}
|
||
|
New-ItemProperty -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\Explorer -Name HideRecentlyAddedApps -PropertyType DWord -Value 1 -Force
|
||
|
|
||
4 years ago
|
# Do not show app suggestions in the Start menu
|
||
|
# Не показывать рекомендации в меню "Пуск"
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\ContentDeliveryManager -Name SubscribedContent-338388Enabled -PropertyType DWord -Value 0 -Force
|
||
|
|
||
4 years ago
|
# Run the Command Prompt shortcut from the Start menu as Administrator
|
||
|
# Запускать ярлык командной строки в меню "Пуск" от имени Администратора
|
||
|
[byte[]]$bytes = Get-Content -Path "$env:APPDATA\Microsoft\Windows\Start menu\Programs\System Tools\Command Prompt.lnk" -Encoding Byte -Raw
|
||
|
$bytes[0x15] = $bytes[0x15] -bor 0x20
|
||
|
Set-Content -Path "$env:APPDATA\Microsoft\Windows\Start menu\Programs\System Tools\Command Prompt.lnk" -Value $bytes -Encoding Byte -Force
|
||
|
|
||
|
#endregion Start menu
|
||
|
|
||
|
#region Gaming
|
||
|
# Turn off Xbox Game Bar
|
||
|
# Отключить Xbox Game Bar
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\GameDVR -Name AppCaptureEnabled -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\System\GameConfigStore -Name GameDVR_Enabled -PropertyType DWord -Value 0 -Force
|
||
|
|
||
|
# Turn off Xbox Game Bar tips
|
||
|
# Отключить советы Xbox Game Bar
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\GameBar -Name ShowStartupPanel -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
|
# Set "High performance" in graphics performance preference for apps
|
||
|
# Установить параметры производительности графики для отдельных приложений на "Высокая производительность"
|
||
|
if (Get-CimInstance -ClassName Win32_VideoController | Where-Object -FilterScript {$_.AdapterDACType -ne "Internal" -and $null -ne $_.AdapterDACType})
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "Настройка производительности графики"
|
||
4 years ago
|
$Message = "Установить для любого приложения по вашему выбору настройки производительности графики на `"Высокая производительность`"?"
|
||
4 years ago
|
$Options = "&Создать", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "Graphics performance preference"
|
||
4 years ago
|
$Message = "Would you like to set the graphics performance setting of an app of your choice to `"High performance`"?"
|
||
4 years ago
|
$Options = "&Add", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
|
|
||
4 years ago
|
do
|
||
4 years ago
|
{
|
||
4 years ago
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
switch ($Result)
|
||
4 years ago
|
{
|
||
4 years ago
|
"0"
|
||
4 years ago
|
{
|
||
4 years ago
|
Add-Type -AssemblyName System.Windows.Forms
|
||
|
$OpenFileDialog = New-Object -TypeName System.Windows.Forms.OpenFileDialog
|
||
|
if ($RU)
|
||
|
{
|
||
|
$OpenFileDialog.Filter = "*.exe|*.exe|Все файлы (*.*)|*.*"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$OpenFileDialog.Filter = "*.exe|*.exe|All Files (*.*)|*.*"
|
||
|
}
|
||
|
$OpenFileDialog.InitialDirectory = "${env:ProgramFiles(x86)}"
|
||
|
$OpenFileDialog.Multiselect = $false
|
||
|
# Focus on open file dialog
|
||
|
# Перевести фокус на диалог открытия файла
|
||
|
$tmp = New-Object -TypeName System.Windows.Forms.Form -Property @{TopMost = $true}
|
||
|
$OpenFileDialog.ShowDialog($tmp)
|
||
|
if ($OpenFileDialog.FileName)
|
||
|
{
|
||
4 years ago
|
if (-not (Test-Path -Path HKCU:\SOFTWARE\Microsoft\DirectX\UserGpuPreferences))
|
||
4 years ago
|
{
|
||
4 years ago
|
New-Item -Path HKCU:\SOFTWARE\Microsoft\DirectX\UserGpuPreferences -Force
|
||
4 years ago
|
}
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\DirectX\UserGpuPreferences -Name $OpenFileDialog.FileName -PropertyType String -Value "GpuPreference=2;" -Force
|
||
4 years ago
|
}
|
||
4 years ago
|
}
|
||
4 years ago
|
"1"
|
||
4 years ago
|
{
|
||
4 years ago
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
4 years ago
|
}
|
||
|
}
|
||
|
}
|
||
4 years ago
|
until ($Result -eq 1)
|
||
4 years ago
|
}
|
||
|
#endregion Gaming
|
||
|
|
||
|
#region Scheduled tasks
|
||
|
<#
|
||
4 years ago
|
Create a task to clean up unused files and Windows updates in the Task Scheduler
|
||
4 years ago
|
The task runs every 90 days
|
||
4 years ago
|
|
||
4 years ago
|
Создать задачу в Планировщике задач по очистке неиспользуемых файлов и обновлений Windows
|
||
4 years ago
|
Задача выполняется каждые 90 дней
|
||
|
#>
|
||
|
Get-ChildItem -Path HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\VolumeCaches | ForEach-Object -Process {
|
||
|
Remove-ItemProperty -Path $_.PsPath -Name StateFlags1337 -Force -ErrorAction Ignore
|
||
|
}
|
||
|
|
||
|
$VolumeCaches = @(
|
||
|
# Delivery Optimization Files
|
||
|
# Файлы оптимизации доставки
|
||
|
"Delivery Optimization Files",
|
||
4 years ago
|
|
||
4 years ago
|
# Device driver packages
|
||
|
# Пакеты драйверов устройств
|
||
|
"Device Driver Packages",
|
||
4 years ago
|
|
||
4 years ago
|
# Previous Windows Installation(s)
|
||
|
# Предыдущие установки Windows
|
||
|
"Previous Installations",
|
||
4 years ago
|
|
||
|
# Setup log files
|
||
4 years ago
|
# Файлы журнала установки
|
||
|
"Setup Log Files",
|
||
4 years ago
|
|
||
4 years ago
|
# Temporary Setup Files
|
||
4 years ago
|
# Временные файлы установки
|
||
4 years ago
|
"Temporary Setup Files",
|
||
4 years ago
|
|
||
|
# Microsoft Defender
|
||
4 years ago
|
"Windows Defender",
|
||
4 years ago
|
|
||
4 years ago
|
# Windows upgrade log files
|
||
|
# Файлы журнала обновления Windows
|
||
|
"Windows Upgrade Log Files"
|
||
|
)
|
||
|
foreach ($VolumeCache in $VolumeCaches)
|
||
|
{
|
||
|
New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\VolumeCaches\$VolumeCache" -Name StateFlags1337 -PropertyType DWord -Value 2 -Force
|
||
|
}
|
||
|
|
||
|
$PS1Script = '
|
||
|
$app = "{1AC14E77-02E7-4E5D-B744-2EB1AE5198B7}\cleanmgr.exe"
|
||
|
|
||
|
[Windows.UI.Notifications.ToastNotificationManager, Windows.UI.Notifications, ContentType = WindowsRuntime]
|
||
|
$Template = [Windows.UI.Notifications.ToastTemplateType]::ToastImageAndText01
|
||
|
[xml]$ToastTemplate = ([Windows.UI.Notifications.ToastNotificationManager]::GetTemplateContent($Template).GetXml())
|
||
|
|
||
|
if ($PSUICulture -eq "ru-RU")
|
||
|
{
|
||
|
[xml]$ToastTemplate = @"
|
||
4 years ago
|
<toast launch="app-defined-string">
|
||
|
<visual>
|
||
|
<binding template="ToastGeneric">
|
||
|
<text>Очистка неиспользуемых файлов и обновлений Windows начнется через минуту</text>
|
||
|
</binding>
|
||
|
</visual>
|
||
|
<actions>
|
||
|
<action activationType="background" content="Хорошо" arguments="later"/>
|
||
|
</actions>
|
||
|
</toast>
|
||
4 years ago
|
"@
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
[xml]$ToastTemplate = @"
|
||
4 years ago
|
<toast launch="app-defined-string">
|
||
|
<visual>
|
||
|
<binding template="ToastGeneric">
|
||
4 years ago
|
<text>Cleaning up unused Windows files and updates starts in a minute</text>
|
||
4 years ago
|
</binding>
|
||
|
</visual>
|
||
|
<actions>
|
||
|
<action activationType="background" content="OK" arguments="later"/>
|
||
|
</actions>
|
||
|
</toast>
|
||
4 years ago
|
"@
|
||
|
}
|
||
|
|
||
|
$ToastXml = New-Object -TypeName Windows.Data.Xml.Dom.XmlDocument
|
||
|
$ToastXml.LoadXml($ToastTemplate.OuterXml)
|
||
|
|
||
|
[Windows.UI.Notifications.ToastNotificationManager]::CreateToastNotifier($app).Show($ToastXml)
|
||
|
|
||
|
Start-Sleep -Seconds 60
|
||
|
|
||
|
# Process startup info
|
||
|
# Параметры запуска процесса
|
||
|
$ProcessInfo = New-Object -TypeName System.Diagnostics.ProcessStartInfo
|
||
|
$ProcessInfo.FileName = "$env:SystemRoot\system32\cleanmgr.exe"
|
||
|
$ProcessInfo.Arguments = "/sagerun:1337"
|
||
|
$ProcessInfo.UseShellExecute = $true
|
||
|
$ProcessInfo.WindowStyle = [System.Diagnostics.ProcessWindowStyle]::Minimized
|
||
|
|
||
|
# Process object using the startup info
|
||
|
# Объект процесса, используя заданные параметры
|
||
|
$Process = New-Object System.Diagnostics.Process
|
||
|
$Process.StartInfo = $ProcessInfo
|
||
|
|
||
|
# Start the process
|
||
|
# Запуск процесса
|
||
|
$Process.Start() | Out-Null
|
||
|
|
||
|
Start-Sleep -Seconds 3
|
||
|
$SourceMainWindowHandle = (Get-Process -Name cleanmgr).MainWindowHandle
|
||
|
|
||
|
function MinimizeWindow
|
||
|
{
|
||
|
[CmdletBinding()]
|
||
4 years ago
|
param
|
||
4 years ago
|
(
|
||
|
[Parameter(Mandatory = $true)]
|
||
4 years ago
|
$Process
|
||
4 years ago
|
)
|
||
4 years ago
|
|
||
|
$ShowWindowAsync = @{
|
||
|
Namespace = "WinAPI"
|
||
|
Name = "Win32ShowWindowAsync"
|
||
|
Language = "CSharp"
|
||
|
MemberDefinition = @"
|
||
4 years ago
|
[DllImport("user32.dll")]
|
||
|
public static extern bool ShowWindowAsync(IntPtr hWnd, int nCmdShow);
|
||
4 years ago
|
"@
|
||
|
}
|
||
|
if (-not ("WinAPI.Win32ShowWindowAsync" -as [type]))
|
||
|
{
|
||
|
Add-Type @ShowWindowAsync
|
||
|
}
|
||
|
|
||
|
$MainWindowHandle = (Get-Process -Name $Process).MainWindowHandle
|
||
|
[WinAPI.Win32ShowWindowAsync]::ShowWindowAsync($MainWindowHandle, 2)
|
||
|
}
|
||
|
|
||
|
while ($true)
|
||
|
{
|
||
|
$CurrentMainWindowHandle = (Get-Process -Name cleanmgr).MainWindowHandle
|
||
|
if ([int]$SourceMainWindowHandle -ne [int]$CurrentMainWindowHandle)
|
||
|
{
|
||
|
MinimizeWindow -Process cleanmgr
|
||
|
break
|
||
|
}
|
||
|
Start-Sleep -Milliseconds 5
|
||
|
}
|
||
|
|
||
|
$ProcessInfo = New-Object -TypeName System.Diagnostics.ProcessStartInfo
|
||
|
# Cleaning up unused updates
|
||
|
# Очистка неиспользованных обновлений
|
||
|
$ProcessInfo.FileName = "$env:SystemRoot\system32\dism.exe"
|
||
|
$ProcessInfo.Arguments = "/Online /English /Cleanup-Image /StartComponentCleanup /NoRestart"
|
||
|
$ProcessInfo.UseShellExecute = $true
|
||
|
$ProcessInfo.WindowStyle = [System.Diagnostics.ProcessWindowStyle]::Minimized
|
||
|
|
||
|
# Process object using the startup info
|
||
|
# Объект процесса, используя заданные параметры
|
||
|
$Process = New-Object System.Diagnostics.Process
|
||
|
$Process.StartInfo = $ProcessInfo
|
||
|
|
||
|
# Start the process
|
||
|
# Запуск процесса
|
||
|
$Process.Start() | Out-Null
|
||
|
'
|
||
|
$EncodedScript = [Convert]::ToBase64String([System.Text.Encoding]::Unicode.GetBytes($PS1Script))
|
||
|
|
||
|
$Action = New-ScheduledTaskAction -Execute powershell.exe -Argument "-WindowStyle Hidden -EncodedCommand $EncodedScript"
|
||
|
$Trigger = New-ScheduledTaskTrigger -Daily -DaysInterval 90 -At 9am
|
||
|
$Settings = New-ScheduledTaskSettingsSet -Compatibility Win8 -StartWhenAvailable
|
||
|
$Principal = New-ScheduledTaskPrincipal -UserId $env:USERNAME -RunLevel Highest
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Description =
|
||
|
"Очистка неиспользуемых файлов и обновлений Windows, используя встроенную программу Очистка диска. Чтобы расшифровать закодированную строку используйте [System.Text.Encoding]::UTF8.GetString([System.Convert]::FromBase64String(`"строка`"))"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Description =
|
||
|
"Cleaning up unused Windows files and updates using built-in Disk cleanup app. To decode encoded command use [System.Text.Encoding]::UTF8.GetString([System.Convert]::FromBase64String(`"string`"))"
|
||
|
}
|
||
|
$Parameters = @{
|
||
|
"TaskName" = "Windows Cleanup"
|
||
|
"TaskPath" = "Setup Script"
|
||
|
"Principal" = $Principal
|
||
|
"Action" = $Action
|
||
|
"Description" = $Description
|
||
|
"Settings" = $Settings
|
||
|
"Trigger" = $Trigger
|
||
|
}
|
||
|
Register-ScheduledTask @Parameters -Force
|
||
|
|
||
|
<#
|
||
4 years ago
|
Create a task to clear the %SystemRoot%\SoftwareDistribution\Download folder in the Task Scheduler
|
||
4 years ago
|
The task runs on Thursdays every 4 weeks
|
||
4 years ago
|
|
||
4 years ago
|
Создать задачу в Планировщике задач по очистке папки %SystemRoot%\SoftwareDistribution\Download
|
||
|
Задача выполняется по четвергам каждую 4 неделю
|
||
|
#>
|
||
|
$Argument = "
|
||
|
(Get-Service -Name wuauserv).WaitForStatus('Stopped', '01:00:00')
|
||
|
Get-ChildItem -Path $env:SystemRoot\SoftwareDistribution\Download -Recurse -Force | Remove-Item -Recurse -Force
|
||
|
"
|
||
|
$Action = New-ScheduledTaskAction -Execute powershell.exe -Argument $Argument
|
||
|
$Trigger = New-JobTrigger -Weekly -WeeksInterval 4 -DaysOfWeek Thursday -At 9am
|
||
|
$Settings = New-ScheduledTaskSettingsSet -Compatibility Win8 -StartWhenAvailable
|
||
|
$Principal = New-ScheduledTaskPrincipal -UserId "NT AUTHORITY\SYSTEM" -RunLevel Highest
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Description = "Очистка папки %SystemRoot%\SoftwareDistribution\Download"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Description = "The %SystemRoot%\SoftwareDistribution\Download folder cleaning"
|
||
|
}
|
||
|
$Parameters = @{
|
||
|
"TaskName" = "SoftwareDistribution"
|
||
|
"TaskPath" = "Setup Script"
|
||
|
"Principal" = $Principal
|
||
|
"Action" = $Action
|
||
|
"Description" = $Description
|
||
|
"Settings" = $Settings
|
||
|
"Trigger" = $Trigger
|
||
|
}
|
||
|
Register-ScheduledTask @Parameters -Force
|
||
|
|
||
|
<#
|
||
4 years ago
|
Create a task to clear the %TEMP% folder in the Task Scheduler
|
||
4 years ago
|
The task runs every 62 days
|
||
4 years ago
|
|
||
4 years ago
|
Создать задачу в Планировщике задач по очистке папки %TEMP%
|
||
|
Задача выполняется каждые 62 дня
|
||
|
#>
|
||
|
$Argument = "Get-ChildItem -Path $env:TEMP -Force -Recurse | Remove-Item -Force -Recurse"
|
||
|
$Action = New-ScheduledTaskAction -Execute powershell.exe -Argument $Argument
|
||
|
$Trigger = New-ScheduledTaskTrigger -Daily -DaysInterval 62 -At 9am
|
||
|
$Settings = New-ScheduledTaskSettingsSet -Compatibility Win8 -StartWhenAvailable
|
||
|
$Principal = New-ScheduledTaskPrincipal -UserId "NT AUTHORITY\SYSTEM" -RunLevel Highest
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Description = "Очистка папки %TEMP%"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Description = "The %TEMP% folder cleaning"
|
||
|
}
|
||
|
$Parameters = @{
|
||
|
"TaskName" = "Temp"
|
||
|
"TaskPath" = "Setup Script"
|
||
|
"Principal" = $Principal
|
||
|
"Action" = $Action
|
||
4 years ago
|
"Description" = $Description
|
||
4 years ago
|
"Settings" = $Settings
|
||
|
"Trigger" = $Trigger
|
||
|
}
|
||
|
Register-ScheduledTask @Parameters -Force
|
||
|
#endregion Scheduled tasks
|
||
|
|
||
|
#region Windows Defender & Security
|
||
|
# Turn on Controlled folder access and add protected folders
|
||
|
# Включить контролируемый доступ к папкам и добавить защищенные папки
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "Контролируемый доступ к папкам"
|
||
4 years ago
|
$Message = "Хотите, чтобы Защитник Windows ограничивал доступ к указанным вами папкам с конфиденциальной информацией?"
|
||
|
$Options = "&Добавить", "&Пропустить"
|
||
4 years ago
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "Controlled folder access"
|
||
4 years ago
|
$Message = "Would you like Windows Defender to restrict access to sensitive folders that you specify?"
|
||
|
$Options = "&Add", "&Skip"
|
||
4 years ago
|
}
|
||
|
$DefaultChoice = 1
|
||
|
|
||
4 years ago
|
do
|
||
4 years ago
|
{
|
||
4 years ago
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
switch ($Result)
|
||
4 years ago
|
{
|
||
4 years ago
|
"0"
|
||
4 years ago
|
{
|
||
4 years ago
|
Add-Type -AssemblyName System.Windows.Forms
|
||
|
$FolderBrowserDialog = New-Object -TypeName System.Windows.Forms.FolderBrowserDialog
|
||
|
if ($RU)
|
||
|
{
|
||
|
$FolderBrowserDialog.Description = "Выберите папку"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$FolderBrowserDialog.Description = "Select a folder"
|
||
|
}
|
||
|
$FolderBrowserDialog.RootFolder = "MyComputer"
|
||
|
# Focus on open file dialog
|
||
|
# Перевести фокус на диалог открытия файла
|
||
|
$tmp = New-Object -TypeName System.Windows.Forms.Form -Property @{TopMost = $true}
|
||
4 years ago
|
|
||
4 years ago
|
$FolderBrowserDialog.ShowDialog($tmp)
|
||
|
if ($FolderBrowserDialog.SelectedPath)
|
||
|
{
|
||
|
Set-MpPreference -EnableControlledFolderAccess Enabled
|
||
|
Add-MpPreference -ControlledFolderAccessProtectedFolders $FolderBrowserDialog.SelectedPath -Force
|
||
|
}
|
||
4 years ago
|
}
|
||
4 years ago
|
"1"
|
||
4 years ago
|
{
|
||
4 years ago
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
4 years ago
|
}
|
||
|
}
|
||
|
}
|
||
4 years ago
|
until ($Result -eq 1)
|
||
4 years ago
|
|
||
|
# Allow an app through Controlled folder access
|
||
|
# Разрешить работу приложения через контролируемый доступ к папкам
|
||
4 years ago
|
if ($RU)
|
||
4 years ago
|
{
|
||
4 years ago
|
$Title = "Контролируемый доступ к папкам"
|
||
|
$Message = "Указать приложение, которому разрешена работа через контролируемый доступ к папкам"
|
||
|
$Options = "&Добавить", "&Пропустить"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "Controlled folder access"
|
||
|
$Message = "Would you like to specify an app that is allowed through Controlled Folder access?"
|
||
|
$Options = "&Add", "&Skip"
|
||
|
}
|
||
|
$DefaultChoice = 1
|
||
4 years ago
|
|
||
4 years ago
|
do
|
||
|
{
|
||
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
switch ($Result)
|
||
4 years ago
|
{
|
||
4 years ago
|
"0"
|
||
4 years ago
|
{
|
||
4 years ago
|
Add-Type -AssemblyName System.Windows.Forms
|
||
|
$OpenFileDialog = New-Object -TypeName System.Windows.Forms.OpenFileDialog
|
||
|
if ($RU)
|
||
4 years ago
|
{
|
||
4 years ago
|
$OpenFileDialog.Filter = "*.exe|*.exe|Все файлы (*.*)|*.*"
|
||
4 years ago
|
}
|
||
4 years ago
|
else
|
||
4 years ago
|
{
|
||
4 years ago
|
$OpenFileDialog.Filter = "*.exe|*.exe|All Files (*.*)|*.*"
|
||
|
}
|
||
|
$OpenFileDialog.InitialDirectory = "::{20D04FE0-3AEA-1069-A2D8-08002B30309D}"
|
||
|
$OpenFileDialog.Multiselect = $false
|
||
|
# Focus on open file dialog
|
||
|
# Перевести фокус на диалог открытия файла
|
||
|
$tmp = New-Object -TypeName System.Windows.Forms.Form -Property @{TopMost = $true}
|
||
|
|
||
|
$OpenFileDialog.ShowDialog($tmp)
|
||
|
if ($OpenFileDialog.FileName)
|
||
|
{
|
||
|
Add-MpPreference -ControlledFolderAccessAllowedApplications $OpenFileDialog.FileName -Force
|
||
|
}
|
||
|
}
|
||
|
"1"
|
||
|
{
|
||
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
4 years ago
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
4 years ago
|
until ($Result -eq 1)
|
||
4 years ago
|
|
||
4 years ago
|
# Add a folder to the exclusion from Windows Defender scanning
|
||
4 years ago
|
# Добавить папку в список исключений сканирования Windows Defender
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "Windows Defender"
|
||
4 years ago
|
$Message = "Указать папку, чтобы исключить ее из списка сканирования Microsoft Defender?"
|
||
|
$Options = "&Исключить", "&Пропустить"
|
||
4 years ago
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "Windows Defender"
|
||
4 years ago
|
$Message = "Would you like to specify a folder to be excluded from Microsoft Defender malware scans?"
|
||
|
$Options = "&Exclude", "&Skip"
|
||
4 years ago
|
}
|
||
|
$DefaultChoice = 1
|
||
|
|
||
4 years ago
|
do
|
||
4 years ago
|
{
|
||
4 years ago
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
switch ($Result)
|
||
4 years ago
|
{
|
||
4 years ago
|
"0"
|
||
4 years ago
|
{
|
||
4 years ago
|
Add-Type -AssemblyName System.Windows.Forms
|
||
|
$FolderBrowserDialog = New-Object -TypeName System.Windows.Forms.FolderBrowserDialog
|
||
|
if ($RU)
|
||
|
{
|
||
|
$FolderBrowserDialog.Description = "Выберите папку"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$FolderBrowserDialog.Description = "Select a folder"
|
||
|
}
|
||
|
$FolderBrowserDialog.RootFolder = "MyComputer"
|
||
|
# Focus on open file dialog
|
||
|
# Перевести фокус на диалог открытия файла
|
||
|
$tmp = New-Object -TypeName System.Windows.Forms.Form -Property @{TopMost = $true}
|
||
4 years ago
|
|
||
4 years ago
|
$FolderBrowserDialog.ShowDialog($tmp)
|
||
|
if ($FolderBrowserDialog.SelectedPath)
|
||
|
{
|
||
|
Add-MpPreference -ExclusionPath $FolderBrowserDialog.SelectedPath -Force
|
||
|
}
|
||
4 years ago
|
}
|
||
4 years ago
|
"1"
|
||
4 years ago
|
{
|
||
4 years ago
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
4 years ago
|
}
|
||
|
}
|
||
|
}
|
||
4 years ago
|
until ($Result -eq 1)
|
||
4 years ago
|
|
||
4 years ago
|
# Add a file to the exclusion from Windows Defender scanning
|
||
4 years ago
|
# Добавить файл в список исключений сканирования Windows Defender
|
||
|
if ($RU)
|
||
|
{
|
||
|
$Title = "Windows Defender"
|
||
4 years ago
|
$Message = "Указать файл, чтобы исключить его из списка сканирования Microsoft Defender?"
|
||
|
$Options = "&Исключить", "&Пропустить"
|
||
4 years ago
|
}
|
||
|
else
|
||
|
{
|
||
|
$Title = "Windows Defender"
|
||
4 years ago
|
$Message = "Would you like to specify a file to be excluded from Microsoft Defender malware scans?"
|
||
|
$Options = "&Exclude", "&Skip"
|
||
4 years ago
|
}
|
||
|
$DefaultChoice = 1
|
||
|
|
||
4 years ago
|
do
|
||
4 years ago
|
{
|
||
4 years ago
|
$Result = $Host.UI.PromptForChoice($Title, $Message, $Options, $DefaultChoice)
|
||
|
switch ($Result)
|
||
4 years ago
|
{
|
||
4 years ago
|
"0"
|
||
4 years ago
|
{
|
||
4 years ago
|
Add-Type -AssemblyName System.Windows.Forms
|
||
|
$OpenFileDialog = New-Object -TypeName System.Windows.Forms.OpenFileDialog
|
||
|
if ($RU)
|
||
|
{
|
||
|
$OpenFileDialog.Filter = "Все файлы (*.*)|*.*"
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$OpenFileDialog.Filter = "All Files (*.*)|*.*"
|
||
|
}
|
||
|
$OpenFileDialog.InitialDirectory = "::{20D04FE0-3AEA-1069-A2D8-08002B30309D}"
|
||
|
$OpenFileDialog.Multiselect = $false
|
||
|
# Focus on open file dialog
|
||
|
# Перевести фокус на диалог открытия файла
|
||
|
$tmp = New-Object -TypeName System.Windows.Forms.Form -Property @{TopMost = $true}
|
||
4 years ago
|
|
||
4 years ago
|
$OpenFileDialog.ShowDialog($tmp)
|
||
|
if ($OpenFileDialog.FileName)
|
||
|
{
|
||
|
Add-MpPreference -ExclusionPath $OpenFileDialog.FileName -Force
|
||
|
}
|
||
4 years ago
|
}
|
||
4 years ago
|
"1"
|
||
4 years ago
|
{
|
||
4 years ago
|
if ($RU)
|
||
|
{
|
||
|
Write-Verbose -Message "Пропущено" -Verbose
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Write-Verbose -Message "Skipped" -Verbose
|
||
|
}
|
||
4 years ago
|
}
|
||
|
}
|
||
|
}
|
||
4 years ago
|
until ($Result -eq 1)
|
||
4 years ago
|
|
||
|
# Turn on Windows Defender Exploit Guard network protection
|
||
|
# Включить защиту сети в Windows Defender Exploit Guard
|
||
|
Set-MpPreference -EnableNetworkProtection Enabled
|
||
|
|
||
4 years ago
|
# Turn on detection for potentially unwanted applications and block them
|
||
|
# Включить обнаружение потенциально нежелательных приложений и блокировать их
|
||
4 years ago
|
Set-MpPreference -PUAProtection Enabled
|
||
|
|
||
|
# Run Windows Defender within a sandbox
|
||
4 years ago
|
# Запускать Защитника Windows в песочнице
|
||
4 years ago
|
setx /M MP_FORCE_USE_SANDBOX 1
|
||
|
|
||
|
# Dismiss Windows Defender offer in the Windows Security about signing in Microsoft account
|
||
4 years ago
|
# Отклонить предложение Защитника Windows в "Безопасность Windows" о входе в аккаунт Microsoft
|
||
|
New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows Security Health\State" -Name AccountProtection_MicrosoftAccount_Disconnected -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
|
||
4 years ago
|
# Dismiss Windows Defender offer in the Windows Security about turning on the SmartScreen filter for Microsoft Edge
|
||
|
# Отклонить предложение Защитника Windows в "Безопасность Windows" включить фильтр SmartScreen для Microsoft Edge
|
||
|
New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows Security Health\State" -Name AppAndBrowser_EdgeSmartScreenOff -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
|
||
|
# Turn on events auditing generated when a process is created or starts
|
||
|
# Включить аудит событий, возникающих при создании или запуске процесса
|
||
|
auditpol /set /subcategory:"{0CCE922B-69AE-11D9-BED3-505054503030}" /success:enable /failure:enable
|
||
|
|
||
4 years ago
|
<#
|
||
|
Include command line in process creation events
|
||
|
In order this feature to work events auditing must be enabled
|
||
|
|
||
|
Включать командную строку в событиях создания процесса
|
||
|
Необходимо включить аудит событий, чтобы работала данная опция
|
||
|
#>
|
||
|
New-ItemProperty -Path HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System\Audit -Name ProcessCreationIncludeCmdLine_Enabled -PropertyType DWord -Value 1 -Force
|
||
|
|
||
|
<#
|
||
|
Create "Process Creation" Event Viewer Custom View
|
||
|
In order this feature to work events auditing and command line in process creation events must be enabled
|
||
4 years ago
|
|
||
4 years ago
|
Создать настаиваемое представление "Создание процесса" в Просмотре событий
|
||
4 years ago
|
Необходимо включить аудит событий и командной строки в событиях создания процесса, чтобы работала данная опция
|
||
4 years ago
|
#>
|
||
|
$XML = @"
|
||
|
<ViewerConfig>
|
||
|
<QueryConfig>
|
||
|
<QueryParams>
|
||
|
<UserQuery />
|
||
|
</QueryParams>
|
||
|
<QueryNode>
|
||
|
<Name>Process Creation</Name>
|
||
|
<Description>Process Creation and Command-line Auditing Events</Description>
|
||
|
<QueryList>
|
||
|
<Query Id="0" Path="Security">
|
||
|
<Select Path="Security">*[System[(EventID=4688)]]</Select>
|
||
|
</Query>
|
||
|
</QueryList>
|
||
|
</QueryNode>
|
||
|
</QueryConfig>
|
||
|
</ViewerConfig>
|
||
4 years ago
|
"@
|
||
4 years ago
|
if (-not (Test-Path -Path "$env:ProgramData\Microsoft\Event Viewer\Views"))
|
||
|
{
|
||
|
New-Item -Path "$env:ProgramData\Microsoft\Event Viewer\Views" -ItemType Directory -Force
|
||
|
}
|
||
|
$ProcessCreationFilePath = "$env:ProgramData\Microsoft\Event Viewer\Views\ProcessCreation.xml"
|
||
|
# Saving ProcessCreation.xml in UTF-8 encoding
|
||
|
# Сохраняем ProcessCreation.xml в кодировке UTF-8
|
||
4 years ago
|
Set-Content -Path $ProcessCreationFilePath -Value (New-Object System.Text.UTF8Encoding).GetBytes($XML) -Encoding Byte -Force
|
||
4 years ago
|
|
||
4 years ago
|
if ($RU)
|
||
|
{
|
||
|
[xml]$XML = Get-Content -Path $ProcessCreationFilePath
|
||
|
$XML.ViewerConfig.QueryConfig.QueryNode.Name = "Создание процесса"
|
||
|
$XML.ViewerConfig.QueryConfig.QueryNode.Description = "События содания нового процесса и аудит командной строки"
|
||
|
$xml.Save("$env:ProgramData\Microsoft\Event Viewer\Views\ProcessCreation.xml")
|
||
4 years ago
|
}
|
||
|
|
||
4 years ago
|
# Log for all Windows PowerShell modules
|
||
|
# Вести журнал для всех модулей Windows PowerShell
|
||
4 years ago
|
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
|
||
|
}
|
||
4 years ago
|
New-ItemProperty -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\PowerShell\ModuleLogging -Name EnableModuleLogging -PropertyType DWord -Value 1 -Force
|
||
4 years ago
|
New-ItemProperty -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\PowerShell\ModuleLogging\ModuleNames -Name * -PropertyType String -Value * -Force
|
||
|
|
||
4 years ago
|
# Log all PowerShell scripts input to the Windows PowerShell event log
|
||
|
# Вести регистрацию всех вводимых сценариев PowerShell в журнале событий Windows PowerShell
|
||
4 years ago
|
if (-not (Test-Path -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\PowerShell\ScriptBlockLogging))
|
||
|
{
|
||
|
New-Item -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\PowerShell\ScriptBlockLogging -Force
|
||
|
}
|
||
|
New-ItemProperty -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\PowerShell\ScriptBlockLogging -Name EnableScriptBlockLogging -PropertyType DWord -Value 1 -Force
|
||
|
|
||
4 years ago
|
# Check apps and files within Microsofot Defender SmartScreen
|
||
|
# Проверять приложения и файлы фильтром SmartScreen в Microsoft Defender
|
||
4 years ago
|
New-ItemProperty -Path HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer -Name SmartScreenEnabled -PropertyType String -Value Off -Force
|
||
|
|
||
4 years ago
|
# Prevent SmartScreen from marking files that have been downloaded from the Internet as unsafe (current user only)
|
||
|
# Не позволять SmartScreen отмечать файлы, скачанные из интернета, как небезопасные (только для текущего пользователя)
|
||
|
if (-not (Test-Path -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\Attachments))
|
||
|
{
|
||
|
New-Item -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\Attachments -Force
|
||
|
}
|
||
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\Attachments -Name SaveZoneInformation -PropertyType DWord -Value 1 -Force
|
||
|
|
||
|
# Turn off Windows Script Host (current user only)
|
||
|
# Отключить Windows Script Host (только для текущего пользователя)
|
||
|
if (-not (Test-Path -Path "HKCU:\SOFTWARE\Microsoft\Windows Script Host\Settings"))
|
||
|
{
|
||
|
New-Item -Path "HKCU:\SOFTWARE\Microsoft\Windows Script Host\Settings" -Force
|
||
|
}
|
||
|
New-ItemProperty -Path "HKCU:\SOFTWARE\Microsoft\Windows Script Host\Settings" -Name Enabled -PropertyType DWord -Value 0 -Force
|
||
4 years ago
|
#endregion Windows Defender & Security
|
||
|
|
||
|
#region Context menu
|
||
4 years ago
|
# Add the "Extract all" item to Windows Installer (.msi) context menu
|
||
|
# Добавить пункт "Извлечь все" в контекстное меню Windows Installer (.msi)
|
||
4 years ago
|
if (-not (Test-Path -Path Registry::HKEY_CLASSES_ROOT\Msi.Package\shell\Extract\Command))
|
||
|
{
|
||
|
New-Item -Path Registry::HKEY_CLASSES_ROOT\Msi.Package\shell\Extract\Command -Force
|
||
|
}
|
||
|
$Value = "{0}" -f 'msiexec.exe /a "%1" /qb TARGETDIR="%1 extracted"'
|
||
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\Msi.Package\shell\Extract\Command -Name "(Default)" -PropertyType String -Value $Value -Force
|
||
4 years ago
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\Msi.Package\shell\Extract -Name MUIVerb -PropertyType String -Value "@shell32.dll,-37514" -Force
|
||
4 years ago
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\Msi.Package\shell\Extract -Name Icon -PropertyType String -Value "shell32.dll,-16817" -Force
|
||
|
|
||
|
# Add the "Install" item to the .cab archives context menu
|
||
|
# Добавить пункт "Установить" в контекстное меню .cab архивов
|
||
|
if (-not (Test-Path -Path Registry::HKEY_CLASSES_ROOT\CABFolder\Shell\RunAs\Command))
|
||
|
{
|
||
|
New-Item -Path Registry::HKEY_CLASSES_ROOT\CABFolder\Shell\RunAs\Command -Force
|
||
|
}
|
||
4 years ago
|
$Value = "{0}" -f "cmd /c DISM.exe /Online /Add-Package /PackagePath:`"%1`" /NoRestart & pause"
|
||
4 years ago
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\CABFolder\Shell\RunAs\Command -Name "(Default)" -PropertyType String -Value $Value -Force
|
||
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\CABFolder\Shell\RunAs -Name MUIVerb -PropertyType String -Value "@shell32.dll,-10210" -Force
|
||
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\CABFolder\Shell\RunAs -Name HasLUAShield -PropertyType String -Value "" -Force
|
||
|
|
||
|
# Add the "Run as different user" item to the .exe files types context menu
|
||
4 years ago
|
# Добавить пункт "Запуск от имени другого пользователя" в контекстное меню .exe файлов
|
||
4 years ago
|
Remove-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\exefile\shell\runasuser -Name Extended -Force -ErrorAction Ignore
|
||
|
|
||
|
# Hide the "Cast to Device" item from the context menu
|
||
|
# Скрыть пункт "Передать на устройство" из контекстного меню
|
||
|
if (-not (Test-Path -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Shell Extensions\Blocked"))
|
||
|
{
|
||
|
New-Item -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Shell Extensions\Blocked" -Force
|
||
|
}
|
||
|
New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Shell Extensions\Blocked" -Name "{7AD84985-87B4-4a16-BE58-8B72A5B390F7}" -PropertyType String -Value "Play to menu" -Force
|
||
|
|
||
|
# Hide the "Share" item from the context menu
|
||
|
# Скрыть пункт "Отправить" (поделиться) из контекстного меню
|
||
|
if (-not (Test-Path -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Shell Extensions\Blocked"))
|
||
|
{
|
||
|
New-Item -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Shell Extensions\Blocked" -Force
|
||
|
}
|
||
|
New-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Shell Extensions\Blocked" -Name "{E2BF9676-5F8F-435C-97EB-11607A5BEDF7}" -PropertyType String -Value "" -Force
|
||
|
|
||
|
# Hide the "Edit with Paint 3D" item from the context menu
|
||
|
# Скрыть пункт "Изменить с помощью Paint 3D" из контекстного меню
|
||
|
$extensions = @(".bmp", ".gif", ".jpe", ".jpeg", ".jpg", ".png", ".tif", ".tiff")
|
||
|
foreach ($extension in $extensions)
|
||
|
{
|
||
|
New-ItemProperty -Path "Registry::HKEY_CLASSES_ROOT\SystemFileAssociations\$extension\Shell\3D Edit" -Name ProgrammaticAccessOnly -PropertyType String -Value "" -Force
|
||
|
}
|
||
|
|
||
|
# Hide the "Print" item from the .bat and .cmd context menu
|
||
|
# Скрыть пункт "Печать" из контекстного меню .bat и .cmd файлов
|
||
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\batfile\shell\print -Name ProgrammaticAccessOnly -PropertyType String -Value "" -Force
|
||
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\cmdfile\shell\print -Name ProgrammaticAccessOnly -PropertyType String -Value "" -Force
|
||
|
|
||
|
# Hide the "Include in Library" item from the context menu
|
||
|
# Скрыть пункт "Добавить в библиотеку" из контекстного меню
|
||
|
New-ItemProperty -Path "Registry::HKEY_CLASSES_ROOT\Folder\shellex\ContextMenuHandlers\Library Location" -Name "(Default)" -PropertyType String -Value "-{3dad6c5d-2167-4cae-9914-f99e41c12cfa}" -Force
|
||
|
|
||
|
# Hide the "Send to" item from the folders context menu
|
||
|
# Скрыть пункт "Отправить" из контекстного меню папок
|
||
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\AllFilesystemObjects\shellex\ContextMenuHandlers\SendTo -Name "(Default)" -PropertyType String -Value "-{7BA4C740-9E81-11CF-99D3-00AA004AE837}" -Force
|
||
|
|
||
|
# Hide the "Turn on BitLocker" item from the context menu
|
||
|
# Скрыть пункт "Включить BitLocker" из контекстного меню
|
||
4 years ago
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\Drive\shell\encrypt-bde -Name ProgrammaticAccessOnly -PropertyType String -Value "" -Force
|
||
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\Drive\shell\encrypt-bde-elev -Name ProgrammaticAccessOnly -PropertyType String -Value "" -Force
|
||
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\Drive\shell\manage-bde -Name ProgrammaticAccessOnly -PropertyType String -Value "" -Force
|
||
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\Drive\shell\resume-bde -Name ProgrammaticAccessOnly -PropertyType String -Value "" -Force
|
||
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\Drive\shell\resume-bde-elev -Name ProgrammaticAccessOnly -PropertyType String -Value "" -Force
|
||
|
New-ItemProperty -Path Registry::HKEY_CLASSES_ROOT\Drive\shell\unlock-bde -Name ProgrammaticAccessOnly -PropertyType String -Value "" -Force
|
||
4 years ago
|
|
||
|
# Remove the "Bitmap image" item from the "New" context menu
|
||
|
# Удалить пункт "Точечный рисунок" из контекстного меню "Создать"
|
||
|
Remove-Item -Path Registry::HKEY_CLASSES_ROOT\.bmp\ShellNew -Force -ErrorAction Ignore
|
||
|
|
||
|
# Remove the "Rich Text Document" item from the "New" context menu
|
||
|
# Удалить пункт "Документ в формате RTF" из контекстного меню "Создать"
|
||
|
Remove-Item -Path Registry::HKEY_CLASSES_ROOT\.rtf\ShellNew -Force -ErrorAction Ignore
|
||
|
|
||
|
# Remove the "Compressed (zipped) Folder" item from the "New" context menu
|
||
|
# Удалить пункт "Сжатая ZIP-папка" из контекстного меню "Создать"
|
||
|
Remove-Item -Path Registry::HKEY_CLASSES_ROOT\.zip\CompressedFolder\ShellNew -Force -ErrorAction Ignore
|
||
|
|
||
4 years ago
|
# Make the "Open", "Print", and "Edit" context menu items available, when more than 15 items selected
|
||
4 years ago
|
# Сделать доступными элементы контекстного меню "Открыть", "Изменить" и "Печать" при выделении более 15 элементов
|
||
4 years ago
|
New-ItemProperty -Path HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer -Name MultipleInvokePromptMinimum -PropertyType DWord -Value 300 -Force
|
||
4 years ago
|
|
||
|
# Hide the "Look for an app in the Microsoft Store" item in "Open with" dialog
|
||
|
# Скрыть пункт "Поиск приложения в Microsoft Store" в диалоге "Открыть с помощью"
|
||
|
if (-not (Test-Path -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\Explorer))
|
||
|
{
|
||
|
New-Item -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\Explorer -Force
|
||
|
}
|
||
|
New-ItemProperty -Path HKLM:\SOFTWARE\Policies\Microsoft\Windows\Explorer -Name NoUseStoreOpenWith -PropertyType DWord -Value 1 -Force
|
||
|
|
||
4 years ago
|
# Hide the "Previous Versions" tab from files and folders context menu and also the "Restore previous versions" context menu item
|
||
|
# Скрыть вкладку "Предыдущие версии" в свойствах файлов и папок, а также пункт контекстного меню "Восстановить прежнюю версию"
|
||
4 years ago
|
New-ItemProperty -Path HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer -Name NoPreviousVersionsPage -PropertyType DWord -Value 1 -Force
|
||
|
#endregion Context menu
|
||
|
|
||
|
#region Refresh
|
||
|
$UpdateExplorer = @{
|
||
|
Namespace = "WinAPI"
|
||
|
Name = "UpdateExplorer"
|
||
|
Language = "CSharp"
|
||
|
MemberDefinition = @"
|
||
4 years ago
|
private static readonly IntPtr HWND_BROADCAST = new IntPtr(0xffff);
|
||
|
private const int WM_SETTINGCHANGE = 0x1a;
|
||
|
private const int SMTO_ABORTIFHUNG = 0x0002;
|
||
|
|
||
|
[DllImport("user32.dll", CharSet = CharSet.Auto, SetLastError = false)]
|
||
|
static extern bool SendNotifyMessage(IntPtr hWnd, uint Msg, IntPtr wParam, string lParam);
|
||
|
[DllImport("user32.dll", CharSet = CharSet.Auto, SetLastError = false)]
|
||
|
private static extern IntPtr SendMessageTimeout(IntPtr hWnd, int Msg, IntPtr wParam, string lParam, int fuFlags, int uTimeout, IntPtr lpdwResult);
|
||
|
[DllImport("shell32.dll", CharSet = CharSet.Auto, SetLastError = false)]
|
||
|
private static extern int SHChangeNotify(int eventId, int flags, IntPtr item1, IntPtr item2);
|
||
|
public static void Refresh()
|
||
|
{
|
||
|
// Update desktop icons
|
||
|
// Обновить иконки рабочего стола
|
||
|
SHChangeNotify(0x8000000, 0x1000, IntPtr.Zero, IntPtr.Zero);
|
||
|
// Update environment variables
|
||
|
// Обновить переменные среды
|
||
|
SendMessageTimeout(HWND_BROADCAST, WM_SETTINGCHANGE, IntPtr.Zero, null, SMTO_ABORTIFHUNG, 100, IntPtr.Zero);
|
||
|
// Update taskbar
|
||
|
// Обновить панель задач
|
||
|
SendNotifyMessage(HWND_BROADCAST, WM_SETTINGCHANGE, IntPtr.Zero, "TraySettings");
|
||
|
}
|
||
|
|
||
|
private static readonly IntPtr hWnd = new IntPtr(65535);
|
||
|
private const int Msg = 273;
|
||
|
// Virtual key ID of the F5 in File Explorer
|
||
|
// Виртуальный код клавиши F5 в проводнике
|
||
|
private static readonly UIntPtr UIntPtr = new UIntPtr(41504);
|
||
4 years ago
|
|
||
4 years ago
|
[DllImport("user32.dll", SetLastError=true)]
|
||
|
public static extern int PostMessageW(IntPtr hWnd, uint Msg, UIntPtr wParam, IntPtr lParam);
|
||
|
public static void PostMessage()
|
||
|
{
|
||
4 years ago
|
// Simulate pressing F5 to refresh the desktop
|
||
|
// Симулировать нажатие F5 для обновления рабочего стола
|
||
4 years ago
|
PostMessageW(hWnd, Msg, UIntPtr, IntPtr.Zero);
|
||
|
}
|
||
4 years ago
|
"@
|
||
|
}
|
||
|
if (-not ("WinAPI.UpdateExplorer" -as [type]))
|
||
|
{
|
||
|
Add-Type @UpdateExplorer
|
||
|
}
|
||
|
|
||
4 years ago
|
# Simulate pressing F5 to refresh the desktop
|
||
4 years ago
|
# Симулировать нажатие F5 для обновления рабочего стола
|
||
|
[WinAPI.UpdateExplorer]::PostMessage()
|
||
|
# Refresh desktop icons, environment variables, taskbar
|
||
|
# Обновить иконки рабочего стола, переменные среды, панель задач
|
||
|
[WinAPI.UpdateExplorer]::Refresh()
|
||
|
#endregion Refresh
|
||
|
|
||
|
# Errors output
|
||
|
# Вывод ошибок
|
||
|
if ($Error)
|
||
|
{
|
||
|
($Error | ForEach-Object -Process {
|
||
|
if ($RU)
|
||
|
{
|
||
|
[PSCustomObject] @{
|
||
|
Строка = $_.InvocationInfo.ScriptLineNumber
|
||
|
"Ошибки/предупреждения" = $_.Exception.Message
|
||
|
}
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
[PSCustomObject] @{
|
||
|
Line = $_.InvocationInfo.ScriptLineNumber
|
||
|
"Errors/Warnings" = $_.Exception.Message
|
||
|
}
|
||
|
}
|
||
|
} | Sort-Object -Property Line | Format-Table -AutoSize -Wrap | Out-String).Trim()
|
||
4 years ago
|
}
|