Created
December 24, 2025 01:17
-
-
Save bchase/cd5fbbe40d9aedc749eae92a162a64fb to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| <?xml version="1.0" encoding="utf-8"?> | |
| <unattend xmlns="urn:schemas-microsoft-com:unattend" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State"> | |
| <!--https://schneegans.de/windows/unattend-generator/?LanguageMode=Unattended&UILanguage=en-US&Locale=en-US&Keyboard=00000409&GeoLocation=244&ProcessorArchitecture=amd64&BypassRequirementsCheck=true&HidePowerShellWindows=true&ComputerNameMode=Random&CompactOsMode=Never&TimeZoneMode=Implicit&PartitionMode=Interactive&DiskAssertionMode=Skip&WindowsEditionMode=Generic&WindowsEdition=home&InstallFromMode=Automatic&PEMode=Default&UserAccountMode=InteractiveLocal&PasswordExpirationMode=Unlimited&LockoutMode=Default&HideFiles=Hidden&ClassicContextMenu=true&LaunchToThisPC=true&TaskbarSearch=Hide&TaskbarIconsMode=Empty&DisableWidgets=true&LeftTaskbar=true&HideTaskViewButton=true&DisableBingResults=true&StartTilesMode=Empty&StartPinsMode=Empty&EnableLongPaths=true&DisableAppSuggestions=true&PreventDeviceEncryption=true&HideEdgeFre=true&DisableEdgeStartupBoost=true&MakeEdgeUninstallable=true&EffectsMode=Default&DeleteEdgeDesktopIcon=true&DesktopIconsMode=Default&StartFoldersMode=Default&WifiMode=Interactive&ExpressSettings=DisableAll&LockKeysMode=Skip&StickyKeysMode=Disabled&ColorMode=Default&WallpaperMode=Default&LockScreenMode=Default&RemoveBingSearch=true&RemoveClipchamp=true&RemoveCopilot=true&RemoveCortana=true&RemoveInternetExplorer=true&RemoveZuneVideo=true&RemoveOffice365=true&RemoveOneDrive=true&RemoveOneNote=true&RemoveOneSync=true&RemoveOutlook=true&RemoveRecall=true&RemoveSkype=true&RemoveTeams=true&RemoveXboxApps=true&WdacMode=Skip&AppLockerMode=Skip--> | |
| <settings pass="offlineServicing"></settings> | |
| <settings pass="windowsPE"> | |
| <component name="Microsoft-Windows-International-Core-WinPE" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS"> | |
| <UILanguage>en-US</UILanguage> | |
| </component> | |
| <component name="Microsoft-Windows-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS"> | |
| <ImageInstall> | |
| <OSImage> | |
| <Compact>false</Compact> | |
| </OSImage> | |
| </ImageInstall> | |
| <UserData> | |
| <ProductKey> | |
| <Key>YTMG3-N6DKC-DKB77-7M9GH-8HVX7</Key> | |
| <WillShowUI>OnError</WillShowUI> | |
| </ProductKey> | |
| <AcceptEula>true</AcceptEula> | |
| </UserData> | |
| <UseConfigurationSet>false</UseConfigurationSet> | |
| <RunSynchronous> | |
| <RunSynchronousCommand wcm:action="add"> | |
| <Order>1</Order> | |
| <Path>reg.exe add "HKLM\SYSTEM\Setup\LabConfig" /v BypassTPMCheck /t REG_DWORD /d 1 /f</Path> | |
| </RunSynchronousCommand> | |
| <RunSynchronousCommand wcm:action="add"> | |
| <Order>2</Order> | |
| <Path>reg.exe add "HKLM\SYSTEM\Setup\LabConfig" /v BypassSecureBootCheck /t REG_DWORD /d 1 /f</Path> | |
| </RunSynchronousCommand> | |
| <RunSynchronousCommand wcm:action="add"> | |
| <Order>3</Order> | |
| <Path>reg.exe add "HKLM\SYSTEM\Setup\LabConfig" /v BypassRAMCheck /t REG_DWORD /d 1 /f</Path> | |
| </RunSynchronousCommand> | |
| </RunSynchronous> | |
| </component> | |
| </settings> | |
| <settings pass="generalize"></settings> | |
| <settings pass="specialize"> | |
| <component name="Microsoft-Windows-Deployment" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS"> | |
| <RunSynchronous> | |
| <RunSynchronousCommand wcm:action="add"> | |
| <Order>1</Order> | |
| <Path>powershell.exe -WindowStyle "Hidden" -NoProfile -Command "$xml = [xml]::new(); $xml.Load('C:\Windows\Panther\unattend.xml'); $sb = [scriptblock]::Create( $xml.unattend.Extensions.ExtractScript ); Invoke-Command -ScriptBlock $sb -ArgumentList $xml;"</Path> | |
| </RunSynchronousCommand> | |
| <RunSynchronousCommand wcm:action="add"> | |
| <Order>2</Order> | |
| <Path>powershell.exe -WindowStyle "Hidden" -ExecutionPolicy "Unrestricted" -NoProfile -File "C:\Windows\Setup\Scripts\Specialize.ps1"</Path> | |
| </RunSynchronousCommand> | |
| <RunSynchronousCommand wcm:action="add"> | |
| <Order>3</Order> | |
| <Path>reg.exe load "HKU\DefaultUser" "C:\Users\Default\NTUSER.DAT"</Path> | |
| </RunSynchronousCommand> | |
| <RunSynchronousCommand wcm:action="add"> | |
| <Order>4</Order> | |
| <Path>powershell.exe -WindowStyle "Hidden" -ExecutionPolicy "Unrestricted" -NoProfile -File "C:\Windows\Setup\Scripts\DefaultUser.ps1"</Path> | |
| </RunSynchronousCommand> | |
| <RunSynchronousCommand wcm:action="add"> | |
| <Order>5</Order> | |
| <Path>reg.exe unload "HKU\DefaultUser"</Path> | |
| </RunSynchronousCommand> | |
| </RunSynchronous> | |
| </component> | |
| </settings> | |
| <settings pass="auditSystem"></settings> | |
| <settings pass="auditUser"></settings> | |
| <settings pass="oobeSystem"> | |
| <component name="Microsoft-Windows-International-Core" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS"> | |
| <InputLocale>0409:00000409</InputLocale> | |
| <SystemLocale>en-US</SystemLocale> | |
| <UILanguage>en-US</UILanguage> | |
| <UserLocale>en-US</UserLocale> | |
| </component> | |
| <component name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS"> | |
| <OOBE> | |
| <ProtectYourPC>3</ProtectYourPC> | |
| <HideEULAPage>true</HideEULAPage> | |
| <HideWirelessSetupInOOBE>false</HideWirelessSetupInOOBE> | |
| <HideOnlineAccountScreens>true</HideOnlineAccountScreens> | |
| </OOBE> | |
| <FirstLogonCommands> | |
| <SynchronousCommand wcm:action="add"> | |
| <Order>1</Order> | |
| <CommandLine>powershell.exe -WindowStyle "Hidden" -ExecutionPolicy "Unrestricted" -NoProfile -File "C:\Windows\Setup\Scripts\FirstLogon.ps1"</CommandLine> | |
| </SynchronousCommand> | |
| </FirstLogonCommands> | |
| </component> | |
| </settings> | |
| <Extensions xmlns="https://schneegans.de/windows/unattend-generator/"> | |
| <ExtractScript> | |
| param( | |
| [xml] $Document | |
| ); | |
| foreach( $file in $Document.unattend.Extensions.File ) { | |
| $path = [System.Environment]::ExpandEnvironmentVariables( $file.GetAttribute( 'path' ) ); | |
| mkdir -Path( $path | Split-Path -Parent ) -ErrorAction 'SilentlyContinue'; | |
| $encoding = switch( [System.IO.Path]::GetExtension( $path ) ) { | |
| { $_ -in '.ps1', '.xml' } { [System.Text.Encoding]::UTF8; } | |
| { $_ -in '.reg', '.vbs', '.js' } { [System.Text.UnicodeEncoding]::new( $false, $true ); } | |
| default { [System.Text.Encoding]::Default; } | |
| }; | |
| $bytes = $encoding.GetPreamble() + $encoding.GetBytes( $file.InnerText.Trim() ); | |
| [System.IO.File]::WriteAllBytes( $path, $bytes ); | |
| } | |
| </ExtractScript> | |
| <File path="C:\Windows\Setup\Scripts\RemovePackages.ps1"> | |
| $selectors = @( | |
| 'Microsoft.BingSearch'; | |
| 'Clipchamp.Clipchamp'; | |
| 'Microsoft.Copilot'; | |
| 'Microsoft.549981C3F5F10'; | |
| 'Microsoft.MicrosoftOfficeHub'; | |
| 'Microsoft.Office.OneNote'; | |
| 'Microsoft.OutlookForWindows'; | |
| 'Microsoft.SkypeApp'; | |
| 'MicrosoftTeams'; | |
| 'MSTeams'; | |
| 'Microsoft.Xbox.TCUI'; | |
| 'Microsoft.XboxApp'; | |
| 'Microsoft.XboxGameOverlay'; | |
| 'Microsoft.XboxGamingOverlay'; | |
| 'Microsoft.XboxIdentityProvider'; | |
| 'Microsoft.XboxSpeechToTextOverlay'; | |
| 'Microsoft.GamingApp'; | |
| 'Microsoft.ZuneVideo'; | |
| ); | |
| $getCommand = { | |
| Get-AppxProvisionedPackage -Online; | |
| }; | |
| $filterCommand = { | |
| $_.DisplayName -eq $selector; | |
| }; | |
| $removeCommand = { | |
| [CmdletBinding()] | |
| param( | |
| [Parameter( Mandatory, ValueFromPipeline )] | |
| $InputObject | |
| ); | |
| process { | |
| $InputObject | Remove-AppxProvisionedPackage -AllUsers -Online -ErrorAction 'Continue'; | |
| } | |
| }; | |
| $type = 'Package'; | |
| $logfile = 'C:\Windows\Setup\Scripts\RemovePackages.log'; | |
| & { | |
| $installed = & $getCommand; | |
| foreach( $selector in $selectors ) { | |
| $result = [ordered] @{ | |
| Selector = $selector; | |
| }; | |
| $found = $installed | Where-Object -FilterScript $filterCommand; | |
| if( $found ) { | |
| $result.Output = $found | & $removeCommand; | |
| if( $? ) { | |
| $result.Message = "$type removed."; | |
| } else { | |
| $result.Message = "$type not removed."; | |
| $result.Error = $Error[0]; | |
| } | |
| } else { | |
| $result.Message = "$type not installed."; | |
| } | |
| $result | ConvertTo-Json -Depth 3 -Compress; | |
| } | |
| } *>&1 | Out-String -Width 1KB -Stream >> $logfile; | |
| </File> | |
| <File path="C:\Windows\Setup\Scripts\RemoveCapabilities.ps1"> | |
| $selectors = @( | |
| 'Browser.InternetExplorer'; | |
| 'OneCoreUAP.OneSync'; | |
| ); | |
| $getCommand = { | |
| Get-WindowsCapability -Online | Where-Object -Property 'State' -NotIn -Value @( | |
| 'NotPresent'; | |
| 'Removed'; | |
| ); | |
| }; | |
| $filterCommand = { | |
| ($_.Name -split '~')[0] -eq $selector; | |
| }; | |
| $removeCommand = { | |
| [CmdletBinding()] | |
| param( | |
| [Parameter( Mandatory, ValueFromPipeline )] | |
| $InputObject | |
| ); | |
| process { | |
| $InputObject | Remove-WindowsCapability -Online -ErrorAction 'Continue'; | |
| } | |
| }; | |
| $type = 'Capability'; | |
| $logfile = 'C:\Windows\Setup\Scripts\RemoveCapabilities.log'; | |
| & { | |
| $installed = & $getCommand; | |
| foreach( $selector in $selectors ) { | |
| $result = [ordered] @{ | |
| Selector = $selector; | |
| }; | |
| $found = $installed | Where-Object -FilterScript $filterCommand; | |
| if( $found ) { | |
| $result.Output = $found | & $removeCommand; | |
| if( $? ) { | |
| $result.Message = "$type removed."; | |
| } else { | |
| $result.Message = "$type not removed."; | |
| $result.Error = $Error[0]; | |
| } | |
| } else { | |
| $result.Message = "$type not installed."; | |
| } | |
| $result | ConvertTo-Json -Depth 3 -Compress; | |
| } | |
| } *>&1 | Out-String -Width 1KB -Stream >> $logfile; | |
| </File> | |
| <File path="C:\Windows\Setup\Scripts\RemoveFeatures.ps1"> | |
| $selectors = @( | |
| 'Recall'; | |
| ); | |
| $getCommand = { | |
| Get-WindowsOptionalFeature -Online | Where-Object -Property 'State' -NotIn -Value @( | |
| 'Disabled'; | |
| 'DisabledWithPayloadRemoved'; | |
| ); | |
| }; | |
| $filterCommand = { | |
| $_.FeatureName -eq $selector; | |
| }; | |
| $removeCommand = { | |
| [CmdletBinding()] | |
| param( | |
| [Parameter( Mandatory, ValueFromPipeline )] | |
| $InputObject | |
| ); | |
| process { | |
| $InputObject | Disable-WindowsOptionalFeature -Online -Remove -NoRestart -ErrorAction 'Continue'; | |
| } | |
| }; | |
| $type = 'Feature'; | |
| $logfile = 'C:\Windows\Setup\Scripts\RemoveFeatures.log'; | |
| & { | |
| $installed = & $getCommand; | |
| foreach( $selector in $selectors ) { | |
| $result = [ordered] @{ | |
| Selector = $selector; | |
| }; | |
| $found = $installed | Where-Object -FilterScript $filterCommand; | |
| if( $found ) { | |
| $result.Output = $found | & $removeCommand; | |
| if( $? ) { | |
| $result.Message = "$type removed."; | |
| } else { | |
| $result.Message = "$type not removed."; | |
| $result.Error = $Error[0]; | |
| } | |
| } else { | |
| $result.Message = "$type not installed."; | |
| } | |
| $result | ConvertTo-Json -Depth 3 -Compress; | |
| } | |
| } *>&1 | Out-String -Width 1KB -Stream >> $logfile; | |
| </File> | |
| <File path="C:\Windows\Setup\Scripts\TaskbarLayoutModification.xml"> | |
| <LayoutModificationTemplate xmlns="http://schemas.microsoft.com/Start/2014/LayoutModification" xmlns:defaultlayout="http://schemas.microsoft.com/Start/2014/FullDefaultLayout" xmlns:start="http://schemas.microsoft.com/Start/2014/StartLayout" xmlns:taskbar="http://schemas.microsoft.com/Start/2014/TaskbarLayout" Version="1"> | |
| <CustomTaskbarLayoutCollection PinListPlacement="Replace"> | |
| <defaultlayout:TaskbarLayout> | |
| <taskbar:TaskbarPinList> | |
| <taskbar:DesktopApp DesktopApplicationLinkPath="#leaveempty" /> | |
| </taskbar:TaskbarPinList> | |
| </defaultlayout:TaskbarLayout> | |
| </CustomTaskbarLayoutCollection> | |
| </LayoutModificationTemplate> | |
| </File> | |
| <File path="C:\Windows\Setup\Scripts\UnlockStartLayout.vbs"> | |
| HKU = &H80000003 | |
| Set reg = GetObject("winmgmts://./root/default:StdRegProv") | |
| Set fso = CreateObject("Scripting.FileSystemObject") | |
| If reg.EnumKey(HKU, "", sids) = 0 Then | |
| If Not IsNull(sids) Then | |
| For Each sid In sids | |
| key = sid + "\Software\Policies\Microsoft\Windows\Explorer" | |
| name = "LockedStartLayout" | |
| If reg.GetDWORDValue(HKU, key, name, existing) = 0 Then | |
| reg.SetDWORDValue HKU, key, name, 0 | |
| End If | |
| Next | |
| End If | |
| End If | |
| </File> | |
| <File path="C:\Windows\Setup\Scripts\UnlockStartLayout.xml"> | |
| <Task version="1.2" xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task"> | |
| <Triggers> | |
| <EventTrigger> | |
| <Enabled>true</Enabled> | |
| <Subscription>&lt;QueryList&gt;&lt;Query Id="0" Path="Application"&gt;&lt;Select Path="Application"&gt;*[System[Provider[@Name='UnattendGenerator'] and EventID=1]]&lt;/Select&gt;&lt;/Query&gt;&lt;/QueryList&gt;</Subscription> | |
| </EventTrigger> | |
| </Triggers> | |
| <Principals> | |
| <Principal id="Author"> | |
| <UserId>S-1-5-18</UserId> | |
| <RunLevel>LeastPrivilege</RunLevel> | |
| </Principal> | |
| </Principals> | |
| <Settings> | |
| <MultipleInstancesPolicy>IgnoreNew</MultipleInstancesPolicy> | |
| <DisallowStartIfOnBatteries>false</DisallowStartIfOnBatteries> | |
| <StopIfGoingOnBatteries>false</StopIfGoingOnBatteries> | |
| <AllowHardTerminate>true</AllowHardTerminate> | |
| <StartWhenAvailable>false</StartWhenAvailable> | |
| <RunOnlyIfNetworkAvailable>false</RunOnlyIfNetworkAvailable> | |
| <IdleSettings> | |
| <StopOnIdleEnd>true</StopOnIdleEnd> | |
| <RestartOnIdle>false</RestartOnIdle> | |
| </IdleSettings> | |
| <AllowStartOnDemand>true</AllowStartOnDemand> | |
| <Enabled>true</Enabled> | |
| <Hidden>false</Hidden> | |
| <RunOnlyIfIdle>false</RunOnlyIfIdle> | |
| <WakeToRun>false</WakeToRun> | |
| <ExecutionTimeLimit>PT72H</ExecutionTimeLimit> | |
| <Priority>7</Priority> | |
| </Settings> | |
| <Actions Context="Author"> | |
| <Exec> | |
| <Command>C:\Windows\System32\wscript.exe</Command> | |
| <Arguments>C:\Windows\Setup\Scripts\UnlockStartLayout.vbs</Arguments> | |
| </Exec> | |
| </Actions> | |
| </Task> | |
| </File> | |
| <File path="C:\Windows\Setup\Scripts\MakeEdgeUninstallable.ps1"> | |
| $ErrorActionPreference = 'Stop'; | |
| & { | |
| try { | |
| $params = @{ | |
| LiteralPath = 'C:\Windows\System32\IntegratedServicesRegionPolicySet.json'; | |
| Encoding = 'Utf8'; | |
| }; | |
| $o = Get-Content @params | ConvertFrom-Json; | |
| $o.policies | ForEach-Object -Process { | |
| if( $_.guid -eq '{1bca278a-5d11-4acf-ad2f-f9ab6d7f93a6}' ) { | |
| $_.defaultState = 'enabled'; | |
| } | |
| }; | |
| $o | ConvertTo-Json -Depth 9 | Out-File @params; | |
| } catch { | |
| $_; | |
| } | |
| } *>&1 | Out-String -Width 1KB -Stream >> 'C:\Windows\Setup\Scripts\MakeEdgeUninstallable.log'; | |
| </File> | |
| <File path="C:\Windows\Setup\Scripts\SetStartPins.ps1"> | |
| $json = '{"pinnedList":[]}'; | |
| if( [System.Environment]::OSVersion.Version.Build -lt 20000 ) { | |
| return; | |
| } | |
| $key = 'Registry::HKLM\SOFTWARE\Microsoft\PolicyManager\current\device\Start'; | |
| New-Item -Path $key -ItemType 'Directory' -ErrorAction 'SilentlyContinue'; | |
| Set-ItemProperty -LiteralPath $key -Name 'ConfigureStartPins' -Value $json -Type 'String'; | |
| </File> | |
| <File path="C:\Users\Default\AppData\Local\Microsoft\Windows\Shell\LayoutModification.xml"> | |
| <LayoutModificationTemplate Version="1" xmlns="http://schemas.microsoft.com/Start/2014/LayoutModification"> | |
| <LayoutOptions StartTileGroupCellWidth="6" /> | |
| <DefaultLayoutOverride> | |
| <StartLayoutCollection> | |
| <StartLayout GroupCellWidth="6" xmlns="http://schemas.microsoft.com/Start/2014/FullDefaultLayout" /> | |
| </StartLayoutCollection> | |
| </DefaultLayoutOverride> | |
| </LayoutModificationTemplate> | |
| </File> | |
| <File path="C:\Windows\Setup\Scripts\Specialize.ps1"> | |
| $scripts = @( | |
| { | |
| reg.exe add "HKLM\SYSTEM\Setup\MoSetup" /v AllowUpgradesWithUnsupportedTPMOrCPU /t REG_DWORD /d 1 /f; | |
| }; | |
| { | |
| Remove-Item -LiteralPath 'C:\Users\Default\AppData\Roaming\Microsoft\Windows\Start Menu\Programs\OneDrive.lnk', 'C:\Windows\System32\OneDriveSetup.exe', 'C:\Windows\SysWOW64\OneDriveSetup.exe' -ErrorAction 'Continue'; | |
| }; | |
| { | |
| Remove-Item -LiteralPath 'Registry::HKLM\Software\Microsoft\WindowsUpdate\Orchestrator\UScheduler_Oobe\OutlookUpdate' -Force -ErrorAction 'SilentlyContinue'; | |
| }; | |
| { | |
| reg.exe add "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Communications" /v ConfigureChatAutoInstall /t REG_DWORD /d 0 /f; | |
| }; | |
| { | |
| & 'C:\Windows\Setup\Scripts\RemovePackages.ps1'; | |
| }; | |
| { | |
| & 'C:\Windows\Setup\Scripts\RemoveCapabilities.ps1'; | |
| }; | |
| { | |
| & 'C:\Windows\Setup\Scripts\RemoveFeatures.ps1'; | |
| }; | |
| { | |
| net.exe accounts /maxpwage:UNLIMITED; | |
| }; | |
| { | |
| reg.exe add "HKLM\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableCloudOptimizedContent" /t REG_DWORD /d 1 /f; | |
| [System.Diagnostics.EventLog]::CreateEventSource( 'UnattendGenerator', 'Application' ); | |
| }; | |
| { | |
| Register-ScheduledTask -TaskName 'UnlockStartLayout' -Xml $( Get-Content -LiteralPath 'C:\Windows\Setup\Scripts\UnlockStartLayout.xml' -Raw ); | |
| }; | |
| { | |
| reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\FileSystem" /v LongPathsEnabled /t REG_DWORD /d 1 /f | |
| }; | |
| { | |
| Remove-Item -LiteralPath 'C:\Users\Public\Desktop\Microsoft Edge.lnk' -ErrorAction 'SilentlyContinue' -Verbose; | |
| }; | |
| { | |
| reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Dsh" /v AllowNewsAndInterests /t REG_DWORD /d 0 /f; | |
| }; | |
| { | |
| reg.exe add "HKLM\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableWindowsConsumerFeatures" /t REG_DWORD /d 1 /f; | |
| }; | |
| { | |
| reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\BitLocker" /v "PreventDeviceEncryption" /t REG_DWORD /d 1 /f; | |
| }; | |
| { | |
| reg.exe add "HKLM\Software\Policies\Microsoft\Edge" /v HideFirstRunExperience /t REG_DWORD /d 1 /f; | |
| }; | |
| { | |
| reg.exe add "HKLM\Software\Policies\Microsoft\Edge\Recommended" /v BackgroundModeEnabled /t REG_DWORD /d 0 /f; | |
| reg.exe add "HKLM\Software\Policies\Microsoft\Edge\Recommended" /v StartupBoostEnabled /t REG_DWORD /d 0 /f; | |
| }; | |
| { | |
| & 'C:\Windows\Setup\Scripts\MakeEdgeUninstallable.ps1'; | |
| }; | |
| { | |
| & 'C:\Windows\Setup\Scripts\SetStartPins.ps1'; | |
| }; | |
| { | |
| reg.exe add "HKU\.DEFAULT\Control Panel\Accessibility\StickyKeys" /v Flags /t REG_SZ /d 10 /f; | |
| }; | |
| ); | |
| & { | |
| [float] $complete = 0; | |
| [float] $increment = 100 / $scripts.Count; | |
| foreach( $script in $scripts ) { | |
| Write-Progress -Activity 'Running scripts to customize your Windows installation. Do not close this window.' -PercentComplete $complete; | |
| '*** Will now execute command «{0}».' -f $( | |
| $str = $script.ToString().Trim() -replace '\s+', ' '; | |
| $max = 100; | |
| if( $str.Length -le $max ) { | |
| $str; | |
| } else { | |
| $str.Substring( 0, $max - 1 ) + '…'; | |
| } | |
| ); | |
| $start = [datetime]::Now; | |
| & $script; | |
| '*** Finished executing command after {0:0} ms.' -f [datetime]::Now.Subtract( $start ).TotalMilliseconds; | |
| "`r`n" * 3; | |
| $complete += $increment; | |
| } | |
| } *>&1 | Out-String -Width 1KB -Stream >> "C:\Windows\Setup\Scripts\Specialize.log"; | |
| </File> | |
| <File path="C:\Windows\Setup\Scripts\UserOnce.ps1"> | |
| $scripts = @( | |
| { | |
| Get-AppxPackage -Name 'Microsoft.Windows.Ai.Copilot.Provider' | Remove-AppxPackage; | |
| }; | |
| { | |
| [System.Diagnostics.EventLog]::WriteEntry( 'UnattendGenerator', "User '$env:USERNAME' has requested to unlock the Start menu layout.", [System.Diagnostics.EventLogEntryType]::Information, 1 ); | |
| }; | |
| { | |
| Remove-Item -LiteralPath "${env:USERPROFILE}\Desktop\Microsoft Edge.lnk" -ErrorAction 'SilentlyContinue' -Verbose; | |
| }; | |
| { | |
| reg.exe add "HKCU\Software\Classes\CLSID\{86ca1aa0-34aa-4e8b-a509-50c905bae2a2}\InprocServer32" /ve /f; | |
| }; | |
| { | |
| Set-ItemProperty -LiteralPath 'Registry::HKCU\Software\Microsoft\Windows\CurrentVersion\Explorer\Advanced' -Name 'LaunchTo' -Type 'DWord' -Value 1; | |
| }; | |
| { | |
| Set-ItemProperty -LiteralPath 'Registry::HKCU\Software\Microsoft\Windows\CurrentVersion\Search' -Name 'SearchboxTaskbarMode' -Type 'DWord' -Value 0; | |
| }; | |
| { | |
| Get-Process -Name 'explorer' -ErrorAction 'SilentlyContinue' | Where-Object -FilterScript { | |
| $_.SessionId -eq ( Get-Process -Id $PID ).SessionId; | |
| } | Stop-Process -Force; | |
| }; | |
| ); | |
| & { | |
| [float] $complete = 0; | |
| [float] $increment = 100 / $scripts.Count; | |
| foreach( $script in $scripts ) { | |
| Write-Progress -Activity 'Running scripts to configure this user account. Do not close this window.' -PercentComplete $complete; | |
| '*** Will now execute command «{0}».' -f $( | |
| $str = $script.ToString().Trim() -replace '\s+', ' '; | |
| $max = 100; | |
| if( $str.Length -le $max ) { | |
| $str; | |
| } else { | |
| $str.Substring( 0, $max - 1 ) + '…'; | |
| } | |
| ); | |
| $start = [datetime]::Now; | |
| & $script; | |
| '*** Finished executing command after {0:0} ms.' -f [datetime]::Now.Subtract( $start ).TotalMilliseconds; | |
| "`r`n" * 3; | |
| $complete += $increment; | |
| } | |
| } *>&1 | Out-String -Width 1KB -Stream >> "$env:TEMP\UserOnce.log"; | |
| </File> | |
| <File path="C:\Windows\Setup\Scripts\DefaultUser.ps1"> | |
| $scripts = @( | |
| { | |
| reg.exe add "HKU\DefaultUser\Software\Policies\Microsoft\Windows\WindowsCopilot" /v TurnOffWindowsCopilot /t REG_DWORD /d 1 /f; | |
| }; | |
| { | |
| reg.exe add "HKU\DefaultUser\Software\Microsoft\Internet Explorer\LowRegistry\Audio\PolicyConfig\PropertyStore" /f; | |
| }; | |
| { | |
| Remove-ItemProperty -LiteralPath 'Registry::HKU\DefaultUser\Software\Microsoft\Windows\CurrentVersion\Run' -Name 'OneDriveSetup' -Force -ErrorAction 'Continue'; | |
| }; | |
| { | |
| reg.exe add "HKU\DefaultUser\Software\Microsoft\Windows\CurrentVersion\GameDVR" /v AppCaptureEnabled /t REG_DWORD /d 0 /f; | |
| }; | |
| { | |
| reg.exe add "HKU\DefaultUser\Software\Policies\Microsoft\Windows\Explorer" /v "StartLayoutFile" /t REG_SZ /d "C:\Windows\Setup\Scripts\TaskbarLayoutModification.xml" /f; | |
| reg.exe add "HKU\DefaultUser\Software\Policies\Microsoft\Windows\Explorer" /v "LockedStartLayout" /t REG_DWORD /d 1 /f; | |
| }; | |
| { | |
| reg.exe add "HKU\DefaultUser\Software\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v ShowTaskViewButton /t REG_DWORD /d 0 /f; | |
| }; | |
| { | |
| $names = @( | |
| 'ContentDeliveryAllowed'; | |
| 'FeatureManagementEnabled'; | |
| 'OEMPreInstalledAppsEnabled'; | |
| 'PreInstalledAppsEnabled'; | |
| 'PreInstalledAppsEverEnabled'; | |
| 'SilentInstalledAppsEnabled'; | |
| 'SoftLandingEnabled'; | |
| 'SubscribedContentEnabled'; | |
| 'SubscribedContent-310093Enabled'; | |
| 'SubscribedContent-338387Enabled'; | |
| 'SubscribedContent-338388Enabled'; | |
| 'SubscribedContent-338389Enabled'; | |
| 'SubscribedContent-338393Enabled'; | |
| 'SubscribedContent-353694Enabled'; | |
| 'SubscribedContent-353696Enabled'; | |
| 'SubscribedContent-353698Enabled'; | |
| 'SystemPaneSuggestionsEnabled'; | |
| ); | |
| foreach( $name in $names ) { | |
| reg.exe add "HKU\DefaultUser\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v $name /t REG_DWORD /d 0 /f; | |
| } | |
| }; | |
| { | |
| reg.exe add "HKU\DefaultUser\Software\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v TaskbarAl /t REG_DWORD /d 0 /f; | |
| }; | |
| { | |
| reg.exe add "HKU\DefaultUser\Software\Policies\Microsoft\Windows\Explorer" /v DisableSearchBoxSuggestions /t REG_DWORD /d 1 /f; | |
| }; | |
| { | |
| reg.exe add "HKU\DefaultUser\Control Panel\Accessibility\StickyKeys" /v Flags /t REG_SZ /d 10 /f; | |
| }; | |
| { | |
| reg.exe add "HKU\DefaultUser\Software\Microsoft\Windows\CurrentVersion\RunOnce" /v "UnattendedSetup" /t REG_SZ /d "powershell.exe -WindowStyle \""Hidden\"" -ExecutionPolicy \""Unrestricted\"" -NoProfile -File \""C:\Windows\Setup\Scripts\UserOnce.ps1\""" /f; | |
| }; | |
| ); | |
| & { | |
| [float] $complete = 0; | |
| [float] $increment = 100 / $scripts.Count; | |
| foreach( $script in $scripts ) { | |
| Write-Progress -Activity 'Running scripts to modify the default user’’s registry hive. Do not close this window.' -PercentComplete $complete; | |
| '*** Will now execute command «{0}».' -f $( | |
| $str = $script.ToString().Trim() -replace '\s+', ' '; | |
| $max = 100; | |
| if( $str.Length -le $max ) { | |
| $str; | |
| } else { | |
| $str.Substring( 0, $max - 1 ) + '…'; | |
| } | |
| ); | |
| $start = [datetime]::Now; | |
| & $script; | |
| '*** Finished executing command after {0:0} ms.' -f [datetime]::Now.Subtract( $start ).TotalMilliseconds; | |
| "`r`n" * 3; | |
| $complete += $increment; | |
| } | |
| } *>&1 | Out-String -Width 1KB -Stream >> "C:\Windows\Setup\Scripts\DefaultUser.log"; | |
| </File> | |
| <File path="C:\Windows\Setup\Scripts\FirstLogon.ps1"> | |
| $scripts = @( | |
| { | |
| Remove-Item -LiteralPath @( | |
| 'C:\Windows\Panther\unattend.xml'; | |
| 'C:\Windows\Panther\unattend-original.xml'; | |
| 'C:\Windows\Setup\Scripts\Wifi.xml'; | |
| ) -Force -ErrorAction 'SilentlyContinue' -Verbose; | |
| }; | |
| ); | |
| & { | |
| [float] $complete = 0; | |
| [float] $increment = 100 / $scripts.Count; | |
| foreach( $script in $scripts ) { | |
| Write-Progress -Activity 'Running scripts to finalize your Windows installation. Do not close this window.' -PercentComplete $complete; | |
| '*** Will now execute command «{0}».' -f $( | |
| $str = $script.ToString().Trim() -replace '\s+', ' '; | |
| $max = 100; | |
| if( $str.Length -le $max ) { | |
| $str; | |
| } else { | |
| $str.Substring( 0, $max - 1 ) + '…'; | |
| } | |
| ); | |
| $start = [datetime]::Now; | |
| & $script; | |
| '*** Finished executing command after {0:0} ms.' -f [datetime]::Now.Subtract( $start ).TotalMilliseconds; | |
| "`r`n" * 3; | |
| $complete += $increment; | |
| } | |
| } *>&1 | Out-String -Width 1KB -Stream >> "C:\Windows\Setup\Scripts\FirstLogon.log"; | |
| </File> | |
| </Extensions> | |
| </unattend> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment