2024-04-24 03:48:03 +00:00
# Enable debugging
#Set-PSDebug -Trace 1
# Check if PowerShell execution is restricted
2024-04-21 00:02:55 +00:00
if ( ( Get-ExecutionPolicy ) -eq 'Restricted' ) {
Write-Host " Your current PowerShell Execution Policy is set to Restricted, which prevents scripts from running. Do you want to change it to RemoteSigned? (yes/no) "
$response = Read-Host
if ( $response -eq 'yes' ) {
Set-ExecutionPolicy RemoteSigned -Scope CurrentUser -Confirm: $false
} else {
Write-Host " The script cannot be run without changing the execution policy. Exiting... "
exit
}
}
2024-04-24 03:48:03 +00:00
# Check and run the script as admin if required
2024-04-21 00:02:55 +00:00
$myWindowsID = [ System.Security.Principal.WindowsIdentity ] :: GetCurrent ( )
$myWindowsPrincipal = new-object System . Security . Principal . WindowsPrincipal ( $myWindowsID )
$adminRole = [ System.Security.Principal.WindowsBuiltInRole ] :: Administrator
2024-04-24 03:48:03 +00:00
if ( ! $myWindowsPrincipal . IsInRole ( $adminRole ) )
2024-04-21 00:02:55 +00:00
{
2024-04-24 03:48:03 +00:00
Write-Host " Restarting Tiny11 image creator as admin in a new window, you can close this one. "
2024-04-22 08:40:16 +00:00
$newProcess = new-object System . Diagnostics . ProcessStartInfo " PowerShell " ;
$newProcess . Arguments = $myInvocation . MyCommand . Definition ;
$newProcess . Verb = " runas " ;
[ System.Diagnostics.Process ] :: Start ( $newProcess ) ;
exit
2024-04-21 00:02:55 +00:00
}
2024-04-24 03:48:03 +00:00
# Start the transcript and prepare the window
Start-Transcript -Path " $PSScriptRoot \tiny11.log " -UseMinimalHeader
$Host . UI . RawUI . WindowTitle = " Tiny11 image creator "
2024-04-21 00:02:55 +00:00
Clear-Host
2024-04-24 03:48:03 +00:00
Write-Host " Welcome to the tiny11 image creator! Release: 04-29-2024 "
2024-04-21 00:02:55 +00:00
$mainOSDrive = $env:SystemDrive
2024-04-24 03:48:03 +00:00
$hostArchitecture = $Env:PROCESSOR_ARCHITECTURE
2024-04-21 00:02:55 +00:00
$DriveLetter = Read-Host " Please enter the drive letter for the Windows 11 image "
$DriveLetter = $DriveLetter + " : "
if ( ( Test-Path " $DriveLetter \sources\boot.wim " ) -eq $false -or ( Test-Path " $DriveLetter \sources\install.wim " ) -eq $false ) {
2024-04-22 08:40:16 +00:00
Write-Host " Can't find Windows OS Installation files in the specified Drive Letter.. "
Write-Host " Please enter the correct DVD Drive Letter.. "
exit
2024-04-21 00:02:55 +00:00
}
New-Item -ItemType Directory -Force -Path " $mainOSDrive \tiny11 "
Write-Host " Copying Windows image... "
Copy-Item -Path " $DriveLetter \* " -Destination " $mainOSDrive \tiny11 " -Recurse -Force
Write-Host " Copy complete! "
Start-Sleep -Seconds 2
Clear-Host
Write-Host " Getting image information: "
2024-04-23 22:13:55 +00:00
& 'dism' '/English' " /Get-WimInfo " " /wimfile: $mainOSDrive \tiny11\sources\install.wim "
2024-04-21 00:02:55 +00:00
$index = Read-Host " Please enter the image index "
Write-Host " Mounting Windows image. This may take a while. "
$wimFilePath = " $( $env:SystemDrive ) \tiny11\sources\install.wim "
& takeown " /F " $wimFilePath
& icacls $wimFilePath " /grant " " Administrators:(F) "
Set-ItemProperty -Path $wimFilePath -Name IsReadOnly -Value $false
New-Item -ItemType Directory -Force -Path " $mainOSDrive \scratchdir "
2024-04-23 22:13:55 +00:00
& dism / English " /mount-image " " /imagefile: $( $env:SystemDrive ) \tiny11\sources\install.wim " " /index: $index " " /mountdir: $( $env:SystemDrive ) \scratchdir "
2024-04-21 00:02:55 +00:00
2024-04-23 22:13:55 +00:00
$imageIntl = & dism / English / Get-Intl " /Image: $( $env:SystemDrive ) \scratchdir "
2024-04-21 00:02:55 +00:00
$languageLine = $imageIntl -split '\n' | Where-Object { $_ -match 'Default system UI language : ([a-zA-Z]{2}-[a-zA-Z]{2})' }
if ( $languageLine ) {
$languageCode = $Matches [ 1 ]
Write-Host " Default system UI language code: $languageCode "
} else {
Write-Host " Default system UI language code not found. "
}
2024-04-23 22:13:55 +00:00
$imageInfo = & 'dism' '/English' '/Get-WimInfo' " /wimFile: $( $env:SystemDrive ) \tiny11\sources\install.wim " " /index: $index "
2024-04-21 00:02:55 +00:00
$lines = $imageInfo -split '\r?\n'
foreach ( $line in $lines ) {
if ( $line -like '*Architecture : *' ) {
$architecture = $line -replace 'Architecture : ' , ''
# If the architecture is x64, replace it with amd64
if ( $architecture -eq 'x64' ) {
$architecture = 'amd64'
}
Write-Host " Architecture: $architecture "
break
}
}
if ( -not $architecture ) {
Write-Host " Architecture information not found. "
}
Write-Host " Mounting complete! Performing removal of applications... "
2024-04-23 22:13:55 +00:00
$packages = & 'dism' '/English' " /image: $( $env:SystemDrive ) \scratchdir " '/Get-ProvisionedAppxPackages' |
2024-04-21 00:02:55 +00:00
ForEach-Object {
if ( $_ -match 'PackageName : (.*)' ) {
$matches [ 1 ]
}
}
$packagePrefixes = 'Clipchamp.Clipchamp_' , 'Microsoft.BingNews_' , 'Microsoft.BingWeather_' , 'Microsoft.GamingApp_' , 'Microsoft.GetHelp_' , 'Microsoft.Getstarted_' , 'Microsoft.MicrosoftOfficeHub_' , 'Microsoft.MicrosoftSolitaireCollection_' , 'Microsoft.People_' , 'Microsoft.PowerAutomateDesktop_' , 'Microsoft.Todos_' , 'Microsoft.WindowsAlarms_' , 'microsoft.windowscommunicationsapps_' , 'Microsoft.WindowsFeedbackHub_' , 'Microsoft.WindowsMaps_' , 'Microsoft.WindowsSoundRecorder_' , 'Microsoft.Xbox.TCUI_' , 'Microsoft.XboxGamingOverlay_' , 'Microsoft.XboxGameOverlay_' , 'Microsoft.XboxSpeechToTextOverlay_' , 'Microsoft.YourPhone_' , 'Microsoft.ZuneMusic_' , 'Microsoft.ZuneVideo_' , 'MicrosoftCorporationII.MicrosoftFamily_' , 'MicrosoftCorporationII.QuickAssist_' , 'MicrosoftTeams_' , 'Microsoft.549981C3F5F10_'
$packagesToRemove = $packages | Where-Object {
$packageName = $_
$packagePrefixes -contains ( $packagePrefixes | Where-Object { $packageName -like " $_ * " } )
}
foreach ( $package in $packagesToRemove ) {
2024-04-23 22:13:55 +00:00
& 'dism' '/English' " /image: $( $env:SystemDrive ) \scratchdir " '/Remove-ProvisionedAppxPackage' " /PackageName: $package "
2024-04-21 00:02:55 +00:00
}
Write-Host " Removing Edge: "
Remove-Item -Path " $mainOSDrive \scratchdir\Program Files (x86)\Microsoft\Edge " -Recurse -Force
Remove-Item -Path " $mainOSDrive \scratchdir\Program Files (x86)\Microsoft\EdgeUpdate " -Recurse -Force
Remove-Item -Path " $mainOSDrive \scratchdir\Program Files (x86)\Microsoft\EdgeCore " -Recurse -Force
if ( $architecture -eq 'amd64' ) {
$folderPath = Get-ChildItem -Path " $mainOSDrive \scratchdir\Windows\WinSxS " -Filter " amd64_microsoft-edge-webview_31bf3856ad364e35* " -Directory | Select-Object -ExpandProperty FullName
if ( $folderPath ) {
& 'takeown' '/f' $folderPath '/r'
& 'icacls' $folderPath '/grant' 'Administrators:F' '/T' '/C'
Remove-Item -Path $folderPath -Recurse -Force
} else {
Write-Host " Folder not found. "
}
} elseif ( $architecture -eq 'arm64' ) {
$folderPath = Get-ChildItem -Path " $mainOSDrive \scratchdir\Windows\WinSxS " -Filter " arm64_microsoft-edge-webview_31bf3856ad364e35* " -Directory | Select-Object -ExpandProperty FullName
if ( $folderPath ) {
& 'takeown' '/f' $folderPath '/r'
& 'icacls' $folderPath '/grant' 'Administrators:F' '/T' '/C'
Remove-Item -Path $folderPath -Recurse -Force
} else {
Write-Host " Folder not found. "
}
} else {
Write-Host " Unknown architecture: $architecture "
}
& 'takeown' '/f' " $mainOSDrive \scratchdir\Windows\System32\Microsoft-Edge-Webview " '/r'
& 'icacls' " $mainOSDrive \scratchdir\Windows\System32\Microsoft-Edge-Webview " '/grant' 'Administrators:F' '/T' '/C'
Remove-Item -Path " $mainOSDrive \scratchdir\Windows\System32\Microsoft-Edge-Webview " -Recurse -Force
Write-Host " Removing OneDrive: "
& 'takeown' '/f' " $mainOSDrive \scratchdir\Windows\System32\OneDriveSetup.exe "
& 'icacls' " $mainOSDrive \scratchdir\Windows\System32\OneDriveSetup.exe " '/grant' 'Administrators:F' '/T' '/C'
Remove-Item -Path " $mainOSDrive \scratchdir\Windows\System32\OneDriveSetup.exe " -Force
Write-Host " Removal complete! "
Start-Sleep -Seconds 2
Clear-Host
Write-Host " Loading registry... "
reg load HKLM \ zCOMPONENTS $mainOSDrive \ scratchdir \ Windows \ System32 \ config \ COMPONENTS
reg load HKLM \ zDEFAULT $mainOSDrive \ scratchdir \ Windows \ System32 \ config \ default
reg load HKLM \ zNTUSER $mainOSDrive \ scratchdir \ Users \ Default \ ntuser . dat
reg load HKLM \ zSOFTWARE $mainOSDrive \ scratchdir \ Windows \ System32 \ config \ SOFTWARE
reg load HKLM \ zSYSTEM $mainOSDrive \ scratchdir \ Windows \ System32 \ config \ SYSTEM
Write-Host " Bypassing system requirements(on the system image): "
& 'reg' 'add' 'HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache' '/v' 'SV1' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache' '/v' 'SV2' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache' '/v' 'SV1' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache' '/v' 'SV2' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\LabConfig' '/v' 'BypassCPUCheck' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\LabConfig' '/v' 'BypassRAMCheck' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\LabConfig' '/v' 'BypassSecureBootCheck' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\LabConfig' '/v' 'BypassStorageCheck' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\LabConfig' '/v' 'BypassTPMCheck' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\MoSetup' '/v' 'AllowUpgradesWithUnsupportedTPMOrCPU' '/t' 'REG_DWORD' '/d' '1' '/f'
Write-Host " Disabling Teams: "
& 'reg' 'add' 'HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Communications' '/v' 'ConfigureChatAutoInstall' '/t' 'REG_DWORD' '/d' '0' '/f'
Write-Host " Disabling Sponsored Apps: "
& 'reg' 'add' 'HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'OemPreInstalledAppsEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'PreInstalledAppsEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SilentInstalledAppsEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zSOFTWARE\Policies\Microsoft\Windows\CloudContent' '/v' 'DisableWindowsConsumerFeatures' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'ContentDeliveryAllowed' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zSOFTWARE\Microsoft\PolicyManager\current\device\Start' '/v' 'ConfigureStartPins' '/t' 'REG_SZ' '/d' '{"pinnedList": [{}]}' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'ContentDeliveryAllowed' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'ContentDeliveryAllowed' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'FeatureManagementEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'OemPreInstalledAppsEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'PreInstalledAppsEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'PreInstalledAppsEverEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SilentInstalledAppsEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SoftLandingEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SubscribedContentEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SubscribedContent-310093Enabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SubscribedContent-338388Enabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SubscribedContent-338389Enabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SubscribedContent-338393Enabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SubscribedContent-353694Enabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SubscribedContent-353696Enabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SubscribedContentEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager' '/v' 'SystemPaneSuggestionsEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
2024-04-29 16:59:03 +00:00
& 'reg' 'add' 'HKLM\zSOFTWARE\Policies\Microsoft\PushToInstall' '/v' 'DisablePushToInstall' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSOFTWARE\Policies\Microsoft\MRT' '/v' 'DontOfferThroughWUAU' '/t' 'REG_DWORD' '/d' '1' '/f'
2024-04-21 00:02:55 +00:00
& 'reg' 'delete' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager\Subscriptions' '/f'
& 'reg' 'delete' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager\SuggestedApps' '/f'
& 'reg' 'add' 'HKLM\zSOFTWARE\Policies\Microsoft\Windows\CloudContent' '/v' 'DisableConsumerAccountStateContent' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSOFTWARE\Policies\Microsoft\Windows\CloudContent' '/v' 'DisableCloudOptimizedContent' '/t' 'REG_DWORD' '/d' '1' '/f'
Write-Host " Enabling Local Accounts on OOBE: "
& 'reg' 'add' 'HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\OOBE' '/v' 'BypassNRO' '/t' 'REG_DWORD' '/d' '1' '/f'
Copy-Item -Path " $PSScriptRoot \autounattend.xml " -Destination " $mainOSDrive \scratchdir\Windows\System32\Sysprep\autounattend.xml " -Force
Write-Host " Disabling Reserved Storage: "
& 'reg' 'add' 'HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\ReserveManager' '/v' 'ShippedWithReserves' '/t' 'REG_DWORD' '/d' '0' '/f'
Write-Host " Disabling Chat icon: "
& 'reg' 'add' 'HKLM\zSOFTWARE\Policies\Microsoft\Windows\Windows Chat' '/v' 'ChatIcon' '/t' 'REG_DWORD' '/d' '3' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced' '/v' 'TaskbarMn' '/t' 'REG_DWORD' '/d' '0' '/f'
2024-04-29 16:59:03 +00:00
Write-Host " Disabling Telemetry: "
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\AdvertisingInfo' '/v' 'Enabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Windows\CurrentVersion\Privacy' '/v' 'TailoredExperiencesWithDiagnosticDataEnabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Speech_OneCore\Settings\OnlineSpeechPrivacy' '/v' 'HasAccepted' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Input\TIPC' '/v' 'Enabled' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\InputPersonalization' '/v' 'RestrictImplicitInkCollection' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\InputPersonalization' '/v' 'RestrictImplicitTextCollection' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\InputPersonalization\TrainedDataStore' '/v' 'HarvestContacts' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Software\Microsoft\Personalization\Settings' '/v' 'AcceptedPrivacyPolicy' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zSOFTWARE\Policies\Microsoft\Windows\DataCollection' '/v' 'AllowTelemetry' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\ControlSet001\Services\dmwappushservice' '/v' 'Start' '/t' 'REG_DWORD' '/d' '4' '/f'
## this function allows PowerShell to take ownership of the Scheduled Tasks registry key from TrustedInstaller. Based on Jose Espitia's script.
function Enable-Privilege {
param (
[ ValidateSet (
" SeAssignPrimaryTokenPrivilege " , " SeAuditPrivilege " , " SeBackupPrivilege " ,
" SeChangeNotifyPrivilege " , " SeCreateGlobalPrivilege " , " SeCreatePagefilePrivilege " ,
" SeCreatePermanentPrivilege " , " SeCreateSymbolicLinkPrivilege " , " SeCreateTokenPrivilege " ,
" SeDebugPrivilege " , " SeEnableDelegationPrivilege " , " SeImpersonatePrivilege " , " SeIncreaseBasePriorityPrivilege " ,
" SeIncreaseQuotaPrivilege " , " SeIncreaseWorkingSetPrivilege " , " SeLoadDriverPrivilege " ,
" SeLockMemoryPrivilege " , " SeMachineAccountPrivilege " , " SeManageVolumePrivilege " ,
" SeProfileSingleProcessPrivilege " , " SeRelabelPrivilege " , " SeRemoteShutdownPrivilege " ,
" SeRestorePrivilege " , " SeSecurityPrivilege " , " SeShutdownPrivilege " , " SeSyncAgentPrivilege " ,
" SeSystemEnvironmentPrivilege " , " SeSystemProfilePrivilege " , " SeSystemtimePrivilege " ,
" SeTakeOwnershipPrivilege " , " SeTcbPrivilege " , " SeTimeZonePrivilege " , " SeTrustedCredManAccessPrivilege " ,
" SeUndockPrivilege " , " SeUnsolicitedInputPrivilege " ) ]
$Privilege ,
## The process on which to adjust the privilege. Defaults to the current process.
$ProcessId = $pid ,
## Switch to disable the privilege, rather than enable it.
[ Switch ] $Disable
)
$definition = @ '
using System ;
using System . Runtime . InteropServices ;
public class AdjPriv
{
[ DllImport ( " advapi32.dll " , ExactSpelling = true , SetLastError = true ) ]
internal static extern bool AdjustTokenPrivileges ( IntPtr htok , bool disall ,
ref TokPriv1Luid newst , int len , IntPtr prev , IntPtr relen ) ;
[ DllImport ( " advapi32.dll " , ExactSpelling = true , SetLastError = true ) ]
internal static extern bool OpenProcessToken ( IntPtr h , int acc , ref IntPtr phtok ) ;
[ DllImport ( " advapi32.dll " , SetLastError = true ) ]
internal static extern bool LookupPrivilegeValue ( string host , string name , ref long pluid ) ;
[ StructLayout ( LayoutKind . Sequential , Pack = 1 ) ]
internal struct TokPriv1Luid
{
public int Count ;
public long Luid ;
public int Attr ;
}
internal const int SE_PRIVILEGE_ENABLED = 0x00000002 ;
internal const int SE_PRIVILEGE_DISABLED = 0x00000000 ;
internal const int TOKEN_QUERY = 0x00000008 ;
internal const int TOKEN_ADJUST_PRIVILEGES = 0x00000020 ;
public static bool EnablePrivilege ( long processHandle , string privilege , bool disable )
{
bool retVal ;
TokPriv1Luid tp ;
IntPtr hproc = new IntPtr ( processHandle ) ;
IntPtr htok = IntPtr . Zero ;
retVal = OpenProcessToken ( hproc , TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY , ref htok ) ;
tp . Count = 1 ;
tp . Luid = 0 ;
if ( disable )
{
tp . Attr = SE_PRIVILEGE_DISABLED ;
}
else
{
tp . Attr = SE_PRIVILEGE_ENABLED ;
}
retVal = LookupPrivilegeValue ( null , privilege , ref tp . Luid ) ;
retVal = AdjustTokenPrivileges ( htok , false , ref tp , 0 , IntPtr . Zero , IntPtr . Zero ) ;
return retVal ;
}
}
' @
$processHandle = ( Get-Process -id $ProcessId ) . Handle
$type = Add-Type $definition -PassThru
$type [ 0 ] :: EnablePrivilege ( $processHandle , $Privilege , $Disable )
}
Enable-Privilege SeTakeOwnershipPrivilege
$regKey = [ Microsoft.Win32.Registry ] :: LocalMachine . OpenSubKey ( " zSOFTWARE\Microsoft\Windows NT\CurrentVersion\Schedule\TaskCache\Tasks " , [ Microsoft.Win32.RegistryKeyPermissionCheck ] :: ReadWriteSubTree , [ System.Security.AccessControl.RegistryRights ] :: TakeOwnership )
$regACL = $regKey . GetAccessControl ( )
$regACL . SetOwner ( [ System.Security.Principal.NTAccount ] " Administrators " )
$regKey . SetAccessControl ( $regACL )
$regKey . Close ( )
Write-Host " Owner changed to Administrators. "
$regKey = [ Microsoft.Win32.Registry ] :: LocalMachine . OpenSubKey ( " zSOFTWARE\Microsoft\Windows NT\CurrentVersion\Schedule\TaskCache\Tasks " , [ Microsoft.Win32.RegistryKeyPermissionCheck ] :: ReadWriteSubTree , [ System.Security.AccessControl.RegistryRights ] :: ChangePermissions )
$regACL = $regKey . GetAccessControl ( )
$regRule = New-Object System . Security . AccessControl . RegistryAccessRule ( " Administrators " , " FullControl " , " ContainerInherit " , " None " , " Allow " )
$regACL . SetAccessRule ( $regRule )
$regKey . SetAccessControl ( $regACL )
Write-Host " Permissions modified for Administrators group. "
Write-Host " Registry key permissions successfully updated. "
$regKey . Close ( )
Write-Host 'Deleting Application Compatibility Appraiser'
reg delete " HKEY_LOCAL_MACHINE\zSOFTWARE\Microsoft\Windows NT\CurrentVersion\Schedule\TaskCache\Tasks\{0600DD45-FAF2-4131-A006-0B17509B9F78} " / f
Write-Host 'Deleting Customer Experience Improvement Program'
reg delete " HKEY_LOCAL_MACHINE\zSOFTWARE\Microsoft\Windows NT\CurrentVersion\Schedule\TaskCache\Tasks\{4738DE7A-BCC1-4E2D-B1B0-CADB044BFA81} " / f
reg delete " HKEY_LOCAL_MACHINE\zSOFTWARE\Microsoft\Windows NT\CurrentVersion\Schedule\TaskCache\Tasks\{6FAC31FA-4A85-4E64-BFD5-2154FF4594B3} " / f
reg delete " HKEY_LOCAL_MACHINE\zSOFTWARE\Microsoft\Windows NT\CurrentVersion\Schedule\TaskCache\Tasks\{FC931F16-B50A-472E-B061-B6F79A71EF59} " / f
Write-Host 'Deleting Program Data Updater'
reg delete " HKEY_LOCAL_MACHINE\zSOFTWARE\Microsoft\Windows NT\CurrentVersion\Schedule\TaskCache\Tasks\{0671EB05-7D95-4153-A32B-1426B9FE61DB} " / f
Write-Host 'Deleting autochk proxy'
reg delete " HKEY_LOCAL_MACHINE\zSOFTWARE\Microsoft\Windows NT\CurrentVersion\Schedule\TaskCache\Tasks\{87BF85F4-2CE1-4160-96EA-52F554AA28A2} " / f
reg delete " HKEY_LOCAL_MACHINE\zSOFTWARE\Microsoft\Windows NT\CurrentVersion\Schedule\TaskCache\Tasks\{8A9C643C-3D74-4099-B6BD-9C6D170898B1} " / f
Write-Host 'Deleting QueueReporting'
reg delete " HKEY_LOCAL_MACHINE\zSOFTWARE\Microsoft\Windows NT\CurrentVersion\Schedule\TaskCache\Tasks\{E3176A65-4E44-4ED3-AA73-3283660ACB9C} " / f
2024-04-21 00:02:55 +00:00
Write-Host " Tweaking complete! "
Write-Host " Unmounting Registry... "
2024-04-29 16:59:03 +00:00
$regKey . Close ( )
2024-04-21 00:02:55 +00:00
reg unload HKLM \ zCOMPONENTS
reg unload HKLM \ zDRIVERS
reg unload HKLM \ zDEFAULT
reg unload HKLM \ zNTUSER
reg unload HKLM \ zSCHEMA
reg unload HKLM \ zSOFTWARE
reg unload HKLM \ zSYSTEM
Write-Host " Cleaning up image... "
2024-04-23 22:13:55 +00:00
& 'dism' '/English' " /image: $mainOSDrive \scratchdir " '/Cleanup-Image' '/StartComponentCleanup' '/ResetBase'
2024-04-21 00:02:55 +00:00
Write-Host " Cleanup complete. "
Write-Host " Unmounting image... "
2024-04-23 22:13:55 +00:00
& 'dism' '/English' '/unmount-image' " /mountdir: $mainOSDrive \scratchdir " '/commit'
2024-04-21 00:02:55 +00:00
Write-Host " Exporting image... "
2024-04-23 22:13:55 +00:00
& 'dism' '/English' '/Export-Image' " /SourceImageFile: $mainOSDrive \tiny11\sources\install.wim " " /SourceIndex: $index " " /DestinationImageFile: $mainOSDrive \tiny11\sources\install2.wim " '/compress:max'
2024-04-21 00:02:55 +00:00
Remove-Item -Path " $mainOSDrive \tiny11\sources\install.wim " -Force
Rename-Item -Path " $mainOSDrive \tiny11\sources\install2.wim " -NewName " install.wim "
Write-Host " Windows image completed. Continuing with boot.wim. "
Start-Sleep -Seconds 2
Clear-Host
Write-Host " Mounting boot image: "
$wimFilePath = " $( $env:SystemDrive ) \tiny11\sources\boot.wim "
& takeown " /F " $wimFilePath
& icacls $wimFilePath " /grant " " Administrators:(F) "
Set-ItemProperty -Path $wimFilePath -Name IsReadOnly -Value $false
2024-04-23 22:13:55 +00:00
& 'dism' '/English' '/mount-image' " /imagefile: $mainOSDrive \tiny11\sources\boot.wim " '/index:2' " /mountdir: $mainOSDrive \scratchdir "
2024-04-21 00:02:55 +00:00
Write-Host " Loading registry... "
reg load HKLM \ zCOMPONENTS $mainOSDrive \ scratchdir \ Windows \ System32 \ config \ COMPONENTS
reg load HKLM \ zDEFAULT $mainOSDrive \ scratchdir \ Windows \ System32 \ config \ default
reg load HKLM \ zNTUSER $mainOSDrive \ scratchdir \ Users \ Default \ ntuser . dat
reg load HKLM \ zSOFTWARE $mainOSDrive \ scratchdir \ Windows \ System32 \ config \ SOFTWARE
reg load HKLM \ zSYSTEM $mainOSDrive \ scratchdir \ Windows \ System32 \ config \ SYSTEM
Write-Host " Bypassing system requirements(on the setup image): "
& 'reg' 'add' 'HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache' '/v' 'SV1' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache' '/v' 'SV2' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache' '/v' 'SV1' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache' '/v' 'SV2' '/t' 'REG_DWORD' '/d' '0' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\LabConfig' '/v' 'BypassCPUCheck' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\LabConfig' '/v' 'BypassRAMCheck' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\LabConfig' '/v' 'BypassSecureBootCheck' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\LabConfig' '/v' 'BypassStorageCheck' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\LabConfig' '/v' 'BypassTPMCheck' '/t' 'REG_DWORD' '/d' '1' '/f'
& 'reg' 'add' 'HKLM\zSYSTEM\Setup\MoSetup' '/v' 'AllowUpgradesWithUnsupportedTPMOrCPU' '/t' 'REG_DWORD' '/d' '1' '/f'
Write-Host " Tweaking complete! "
Write-Host " Unmounting Registry... "
2024-04-29 16:59:03 +00:00
$regKey . Close ( )
2024-04-21 00:02:55 +00:00
reg unload HKLM \ zCOMPONENTS
reg unload HKLM \ zDRIVERS
reg unload HKLM \ zDEFAULT
reg unload HKLM \ zNTUSER
reg unload HKLM \ zSCHEMA
2024-04-29 16:59:03 +00:00
$regKey . Close ( )
2024-04-21 00:02:55 +00:00
reg unload HKLM \ zSOFTWARE
reg unload HKLM \ zSYSTEM
Write-Host " Unmounting image... "
2024-04-23 22:13:55 +00:00
& 'dism' '/English' '/unmount-image' " /mountdir: $mainOSDrive \scratchdir " '/commit'
2024-04-21 00:02:55 +00:00
Clear-Host
Write-Host " The tiny11 image is now completed. Proceeding with the making of the ISO... "
Write-Host " Copying unattended file for bypassing MS account on OOBE... "
Copy-Item -Path " $PSScriptRoot \autounattend.xml " -Destination " $mainOSDrive \tiny11\autounattend.xml " -Force
Write-Host " Creating ISO image... "
2024-04-24 03:48:03 +00:00
$ADKDepTools = " C:\Program Files (x86)\Windows Kits\10\Assessment and Deployment Kit\Deployment Tools\ $hostarchitecture \Oscdimg "
if ( [ System.IO.Directory ] :: Exists ( $ADKDepTools ) ) {
Write-Host " Will be using oscdimg.exe from system ADK. "
$OSCDIMG = " $ADKDepTools \oscdimg.exe "
} else {
Write-Host " Will be using bundled oscdimg.exe. "
$OSCDIMG = " $PSScriptRoot \oscdimg.exe "
}
& " $OSCDIMG " '-m' '-o' '-u2' '-udfver102' " -bootdata:2#p0,e,b $mainOSDrive \tiny11\boot\etfsboot.com#pEF,e,b $mainOSDrive \tiny11\efi\microsoft\boot\efisys.bin " " $mainOSDrive \tiny11 " " $PSScriptRoot \tiny11.iso "
# Finishing up
2024-04-21 00:02:55 +00:00
Write-Host " Creation completed! Press any key to exit the script... "
Read-Host " Press Enter to continue "
Write-Host " Performing Cleanup... "
Remove-Item -Path " $mainOSDrive \tiny11 " -Recurse -Force
Remove-Item -Path " $mainOSDrive \scratchdir " -Recurse -Force
2024-04-24 03:48:03 +00:00
# Stop the transcript
Stop-Transcript
exit