diff --git a/Dockerfile b/Dockerfile
index a0e982d..5334813 100644
--- a/Dockerfile
+++ b/Dockerfile
@@ -1,5 +1,5 @@
FROM scratch
-COPY --from=qemux/qemu-docker:4.26 / /
+COPY --from=qemux/qemu-docker:4.27 / /
ARG DEBCONF_NOWARNINGS "yes"
ARG DEBIAN_FRONTEND "noninteractive"
diff --git a/assets/win10x64-enterprise-eval.xml b/assets/win10x64-enterprise-eval.xml
index 80183d9..5d282e4 100644
--- a/assets/win10x64-enterprise-eval.xml
+++ b/assets/win10x64-enterprise-eval.xml
@@ -80,7 +80,6 @@
true
Docker
Windows for Docker
-
false
diff --git a/assets/win10x64-enterprise.xml b/assets/win10x64-enterprise.xml
new file mode 100644
index 0000000..8365f38
--- /dev/null
+++ b/assets/win10x64-enterprise.xml
@@ -0,0 +1,475 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+
+
+ 0
+ true
+
+
+
+ 1
+ EFI
+ 128
+
+
+
+ 2
+ MSR
+ 128
+
+
+
+ 3
+ Primary
+ true
+
+
+
+
+
+ 1
+ 1
+
+ FAT32
+
+
+
+ 2
+ 2
+
+
+
+ 3
+ 3
+
+ C
+ NTFS
+
+
+
+
+
+
+
+ 0
+ 3
+
+ false
+
+
+
+ true
+ Never
+
+
+ false
+ Never
+
+
+ true
+ Docker
+ Windows for Docker
+
+ NPPR9-FWDCX-D2C8J-H872K-2YT43
+
+
+ false
+
+ false
+
+
+
+
+
+ D:\viostor\w10\amd64
+
+
+ D:\NetKVM\w10\amd64
+
+
+ D:\Balloon\w10\amd64
+
+
+ D:\pvpanic\w10\amd64
+
+
+ D:\qemupciserial\w10\amd64
+
+
+ D:\qxldod\w10\amd64
+
+
+ D:\vioinput\w10\amd64
+
+
+ D:\viorng\w10\amd64
+
+
+ D:\vioscsi\w10\amd64
+
+
+ D:\vioserial\w10\amd64
+
+
+ D:\viogpudo\w10\amd64
+
+
+ D:\sriov\w10\amd64
+
+
+ D:\viofs\w10\amd64
+
+
+
+
+
+
+ false
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+
+ Dockur
+ Windows for Docker
+ 24/7
+
+ Dockur
+ https://github.com/dockur/windows/issues
+
+ Windows for Docker
+
+
+ 1
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ 0
+
+
+ 1
+
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+
+
+ 1
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\OOBE" /v BypassNRO /t REG_DWORD /d 1 /f
+
+
+ 2
+ reg.exe load "HKU\mount" "C:\Users\Default\NTUSER.DAT"
+
+
+ 3
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "ContentDeliveryAllowed" /t REG_DWORD /d 0 /f
+
+
+ 4
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "FeatureManagementEnabled" /t REG_DWORD /d 0 /f
+
+
+ 5
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "OEMPreInstalledAppsEnabled" /t REG_DWORD /d 0 /f
+
+
+ 6
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "PreInstalledAppsEnabled" /t REG_DWORD /d 0 /f
+
+
+ 7
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "PreInstalledAppsEverEnabled" /t REG_DWORD /d 0 /f
+
+
+ 8
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SilentInstalledAppsEnabled" /t REG_DWORD /d 0 /f
+
+
+ 9
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SoftLandingEnabled" /t REG_DWORD /d 0 /f
+
+
+ 10
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContentEnabled" /t REG_DWORD /d 0 /f
+
+
+ 11
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-310093Enabled" /t REG_DWORD /d 0 /f
+
+
+ 12
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-338387Enabled" /t REG_DWORD /d 0 /f
+
+
+ 13
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-338388Enabled" /t REG_DWORD /d 0 /f
+
+
+ 14
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-338389Enabled" /t REG_DWORD /d 0 /f
+
+
+ 15
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-338393Enabled" /t REG_DWORD /d 0 /f
+
+
+ 16
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-353698Enabled" /t REG_DWORD /d 0 /f
+
+
+ 17
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SystemPaneSuggestionsEnabled" /t REG_DWORD /d 0 /f
+
+
+ 18
+ reg.exe add "HKU\mount\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableCloudOptimizedContent" /t REG_DWORD /d 1 /f
+
+
+ 19
+ reg.exe add "HKU\mount\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableWindowsConsumerFeatures" /t REG_DWORD /d 1 /f
+
+
+ 20
+ reg.exe add "HKU\mount\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableConsumerAccountStateContent" /t REG_DWORD /d 1 /f
+
+
+ 21
+ reg.exe unload "HKU\mount"
+
+
+ 22
+ reg.exe add "HKLM\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableCloudOptimizedContent" /t REG_DWORD /d 1 /f
+
+
+ 23
+ reg.exe add "HKLM\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableWindowsConsumerFeatures" /t REG_DWORD /d 1 /f
+
+
+ 24
+ reg.exe add "HKLM\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableConsumerAccountStateContent" /t REG_DWORD /d 1 /f
+
+
+
+
+ false
+
+
+ 0
+
+
+
+
+ true
+ Remote Desktop
+ all
+
+
+
+
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ true
+ true
+ true
+ true
+ Other
+ 3
+ true
+ true
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\PasswordLess\Device" /v "DevicePasswordLessBuildVersion" /t REG_DWORD /d 0 /f
+ Enable option for passwordless sign-in
+
+
+ 4
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 5
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 6
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 15
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Cortana" /v "IsAvailable" /t REG_DWORD /d 0 /f
+ Disable Cortana
+
+
+ 16
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Search" /v "SearchboxTaskbarMode" /t REG_DWORD /d 0 /f
+ Remove Search from the Taskbar
+
+
+ 17
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "ShowTaskViewButton" /t REG_DWORD /d 0 /f
+ Remove Task View from the Taskbar
+
+
+ 18
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarDa" /t REG_DWORD /d 0 /f
+ Remove Widgets from the Taskbar
+
+
+ 19
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarMn" /t REG_DWORD /d 0 /f
+ Remove Chat from the Taskbar
+
+
+ 20
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU" /v "NoAutoUpdate" /t REG_DWORD /d 1 /f
+ Turn off Windows Update auto download
+
+
+ 21
+ netsh advfirewall firewall set rule group="Network Discovery" new enable=Yes
+ Enable Network Discovery
+
+
+ 22
+ netsh advfirewall firewall set rule group="File and Printer Sharing" new enable=Yes
+ Enable File Sharing
+
+
+ 23
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/assets/win10x64-ltsc.xml b/assets/win10x64-ltsc.xml
index 74417a4..787f8e7 100644
--- a/assets/win10x64-ltsc.xml
+++ b/assets/win10x64-ltsc.xml
@@ -86,7 +86,6 @@
true
Docker
Windows for Docker
-
false
diff --git a/assets/win11x64-enterprise-eval.xml b/assets/win11x64-enterprise-eval.xml
index 987e2d4..f696049 100644
--- a/assets/win11x64-enterprise-eval.xml
+++ b/assets/win11x64-enterprise-eval.xml
@@ -80,7 +80,6 @@
true
Docker
Windows for Docker
-
false
diff --git a/assets/win11x64-enterprise.xml b/assets/win11x64-enterprise.xml
new file mode 100644
index 0000000..37722de
--- /dev/null
+++ b/assets/win11x64-enterprise.xml
@@ -0,0 +1,498 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+
+
+ 0
+ true
+
+
+
+ 1
+ EFI
+ 128
+
+
+
+ 2
+ MSR
+ 128
+
+
+
+ 3
+ Primary
+ true
+
+
+
+
+
+ 1
+ 1
+
+ FAT32
+
+
+
+ 2
+ 2
+
+
+
+ 3
+ 3
+
+ C
+ NTFS
+
+
+
+
+
+
+
+ 0
+ 3
+
+ false
+
+
+
+ true
+ Never
+
+
+ false
+ Never
+
+
+ true
+ Docker
+ Windows for Docker
+
+ NPPR9-FWDCX-D2C8J-H872K-2YT43
+
+
+ false
+
+ false
+
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\Setup\LabConfig" /v BypassTPMCheck /t REG_DWORD /d 1 /f
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\Setup\LabConfig" /v BypassSecureBootCheck /t REG_DWORD /d 1 /f
+
+
+ 3
+ reg.exe add "HKLM\SYSTEM\Setup\LabConfig" /v BypassRAMCheck /t REG_DWORD /d 1 /f
+
+
+ 4
+ reg.exe add "HKLM\SYSTEM\Setup\MoSetup" /v AllowUpgradesWithUnsupportedTPMOrCPU /t REG_DWORD /d 1 /f
+
+
+
+
+
+
+ D:\viostor\w11\amd64
+
+
+ D:\NetKVM\w11\amd64
+
+
+ D:\Balloon\w11\amd64
+
+
+ D:\pvpanic\w11\amd64
+
+
+ D:\qemupciserial\w11\amd64
+
+
+ D:\qxldod\w11\amd64
+
+
+ D:\vioinput\w11\amd64
+
+
+ D:\viorng\w11\amd64
+
+
+ D:\vioscsi\w11\amd64
+
+
+ D:\vioserial\w11\amd64
+
+
+ D:\viogpudo\w11\amd64
+
+
+ D:\sriov\w11\amd64
+
+
+ D:\viofs\w11\amd64
+
+
+
+
+
+
+ false
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+
+ Dockur
+ Windows for Docker
+ 24/7
+
+ Dockur
+ https://github.com/dockur/windows/issues
+
+ Windows for Docker
+
+
+ 1
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ 0
+
+
+ 1
+
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+
+
+ 1
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\OOBE" /v BypassNRO /t REG_DWORD /d 1 /f
+
+
+ 2
+ reg.exe load "HKU\mount" "C:\Users\Default\NTUSER.DAT"
+
+
+ 3
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "ContentDeliveryAllowed" /t REG_DWORD /d 0 /f
+
+
+ 4
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "FeatureManagementEnabled" /t REG_DWORD /d 0 /f
+
+
+ 5
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "OEMPreInstalledAppsEnabled" /t REG_DWORD /d 0 /f
+
+
+ 6
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "PreInstalledAppsEnabled" /t REG_DWORD /d 0 /f
+
+
+ 7
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "PreInstalledAppsEverEnabled" /t REG_DWORD /d 0 /f
+
+
+ 8
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SilentInstalledAppsEnabled" /t REG_DWORD /d 0 /f
+
+
+ 9
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SoftLandingEnabled" /t REG_DWORD /d 0 /f
+
+
+ 10
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContentEnabled" /t REG_DWORD /d 0 /f
+
+
+ 11
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-310093Enabled" /t REG_DWORD /d 0 /f
+
+
+ 12
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-338387Enabled" /t REG_DWORD /d 0 /f
+
+
+ 13
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-338388Enabled" /t REG_DWORD /d 0 /f
+
+
+ 14
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-338389Enabled" /t REG_DWORD /d 0 /f
+
+
+ 15
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-338393Enabled" /t REG_DWORD /d 0 /f
+
+
+ 16
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SubscribedContent-353698Enabled" /t REG_DWORD /d 0 /f
+
+
+ 17
+ reg.exe add "HKU\mount\Software\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SystemPaneSuggestionsEnabled" /t REG_DWORD /d 0 /f
+
+
+ 18
+ reg.exe add "HKU\mount\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableCloudOptimizedContent" /t REG_DWORD /d 1 /f
+
+
+ 19
+ reg.exe add "HKU\mount\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableWindowsConsumerFeatures" /t REG_DWORD /d 1 /f
+
+
+ 20
+ reg.exe add "HKU\mount\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableConsumerAccountStateContent" /t REG_DWORD /d 1 /f
+
+
+ 21
+ reg.exe unload "HKU\mount"
+
+
+ 22
+ reg.exe add "HKLM\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableCloudOptimizedContent" /t REG_DWORD /d 1 /f
+
+
+ 23
+ reg.exe add "HKLM\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableWindowsConsumerFeatures" /t REG_DWORD /d 1 /f
+
+
+ 24
+ reg.exe add "HKLM\Software\Policies\Microsoft\Windows\CloudContent" /v "DisableConsumerAccountStateContent" /t REG_DWORD /d 1 /f
+
+
+
+
+ false
+
+
+ 0
+
+
+
+
+ true
+ Remote Desktop
+ all
+
+
+
+
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ true
+ true
+ true
+ true
+ Other
+ 3
+ true
+ true
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\PasswordLess\Device" /v "DevicePasswordLessBuildVersion" /t REG_DWORD /d 0 /f
+ Enable option for passwordless sign-in
+
+
+ 4
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 5
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 6
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 15
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Cortana" /v "IsAvailable" /t REG_DWORD /d 0 /f
+ Disable Cortana
+
+
+ 16
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "ShowTaskViewButton" /t REG_DWORD /d 0 /f
+ Remove Task View from the Taskbar
+
+
+ 17
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarDa" /t REG_DWORD /d 0 /f
+ Remove Widgets from the Taskbar
+
+
+ 18
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarMn" /t REG_DWORD /d 0 /f
+ Remove Chat from the Taskbar
+
+
+ 19
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU" /v "NoAutoUpdate" /t REG_DWORD /d 1 /f
+ Turn off Windows Update auto download
+
+
+ 20
+ netsh advfirewall firewall set rule group="Network Discovery" new enable=Yes
+ Enable Network Discovery
+
+
+ 21
+ netsh advfirewall firewall set rule group="File and Printer Sharing" new enable=Yes
+ Enable File Sharing
+
+
+ 22
+ reg.exe add "HKCU\Control Panel\UnsupportedHardwareNotificationCache" /v SV1 /d 0 /t REG_DWORD /f
+ Disable unsupported hardware notifications
+
+
+ 23
+ reg.exe add "HKCU\Control Panel\UnsupportedHardwareNotificationCache" /v SV2 /d 0 /t REG_DWORD /f
+ Disable unsupported hardware notifications
+
+
+ 24
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/assets/win2008r2-eval.xml b/assets/win2008r2-eval.xml
new file mode 100644
index 0000000..4f69250
--- /dev/null
+++ b/assets/win2008r2-eval.xml
@@ -0,0 +1,312 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+
+ OnError
+
+ 0
+ true
+
+
+ 1
+ Primary
+ 100
+
+
+ 2
+ Primary
+ true
+
+
+
+
+ NTFS
+
+ 1
+ true
+ 1
+ 0x27
+
+
+ true
+ NTFS
+
+ C
+ 2
+ 2
+
+
+
+
+
+
+
+
+ 1
+ /IMAGE/INDEX
+
+
+
+ 0
+ 2
+
+ false
+
+
+
+ true
+ Never
+
+
+ false
+ Never
+
+
+ true
+ Docker
+ Windows for Docker
+
+ false
+
+ false
+
+
+
+
+
+ D:\viostor\2k8R2\amd64
+
+
+ D:\NetKVM\2k8R2\amd64
+
+
+ D:\Balloon\2k8R2\amd64
+
+
+ D:\pvpanic\2k8R2\amd64
+
+
+ D:\qemupciserial\2k8R2\amd64
+
+
+ D:\qxldod\2k8R2\amd64
+
+
+ D:\vioinput\2k8R2\amd64
+
+
+ D:\viorng\2k8R2\amd64
+
+
+ D:\vioscsi\2k8R2\amd64
+
+
+ D:\vioserial\2k8R2\amd64
+
+
+
+
+
+
+ false
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+
+ Dockur
+ Windows for Docker
+
+
+
+ 1
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ 0
+
+
+ 1
+
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+ false
+
+
+ 0
+
+
+
+
+ true
+ Remote Desktop
+ all
+
+
+
+
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ true
+ Other
+ 3
+ true
+ true
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 4
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 5
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 6
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\NetworkList\NewNetworks" /v NetworkList /t REG_MULTI_SZ /d "" /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 15
+ netsh advfirewall firewall set rule group="Network Discovery" new enable=Yes
+ Enable Network Discovery
+
+
+ 16
+ netsh advfirewall firewall set rule group="File and Printer Sharing" new enable=Yes
+ Enable File Sharing
+
+
+ 17
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/assets/win2008r2.xml b/assets/win2008r2.xml
index 4903645..18bf9f3 100644
--- a/assets/win2008r2.xml
+++ b/assets/win2008r2.xml
@@ -75,7 +75,9 @@
true
Docker
Windows for Docker
-
+
+ YC6KT-GKW9T-YTKYR-T4X34-R7VHC
+
false
diff --git a/assets/win2012r2-eval.xml b/assets/win2012r2-eval.xml
index 00a5e3c..2e1747d 100644
--- a/assets/win2012r2-eval.xml
+++ b/assets/win2012r2-eval.xml
@@ -88,7 +88,6 @@
true
Docker
Windows for Docker
-
false
diff --git a/assets/win2012r2.xml b/assets/win2012r2.xml
new file mode 100644
index 0000000..58c1c80
--- /dev/null
+++ b/assets/win2012r2.xml
@@ -0,0 +1,354 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+ en-US
+
+
+
+
+ 0
+ true
+
+
+
+ 1
+ EFI
+ 128
+
+
+
+ 2
+ MSR
+ 128
+
+
+
+ 3
+ Primary
+ true
+
+
+
+
+
+ 1
+ 1
+
+ FAT32
+
+
+
+ 2
+ 2
+
+
+
+ 3
+ 3
+
+ C
+ NTFS
+
+
+
+
+
+
+
+
+ /image/index
+ 2
+
+
+
+ 0
+ 3
+
+ OnError
+ false
+
+
+
+ true
+ Never
+
+
+ false
+ Never
+
+
+ true
+ Docker
+ Windows for Docker
+
+ D2N9P-3P6X9-2R39C-7RTCD-MDVJX
+
+
+ false
+
+ false
+
+
+
+
+
+ D:\viostor\2k16\amd64
+
+
+ D:\NetKVM\2k16\amd64
+
+
+ D:\Balloon\2k16\amd64
+
+
+ D:\pvpanic\2k16\amd64
+
+
+ D:\qemupciserial\2k16\amd64
+
+
+ D:\qxldod\2k16\amd64
+
+
+ D:\vioinput\2k16\amd64
+
+
+ D:\viorng\2k16\amd64
+
+
+ D:\vioscsi\2k16\amd64
+
+
+ D:\vioserial\2k16\amd64
+
+
+ D:\viogpudo\2k16\amd64
+
+
+ D:\sriov\2k16\amd64
+
+
+ D:\viofs\2k16\amd64
+
+
+
+
+
+
+ false
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+
+ Dockur
+ Windows for Docker
+
+ Windows for Docker
+
+
+ 1
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ 0
+
+
+ 1
+
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+ en-US
+
+
+ true
+
+
+ true
+
+
+ false
+
+
+ 0
+
+
+
+
+ true
+ Remote Desktop
+ all
+
+
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ true
+ true
+ true
+ true
+ Other
+ 3
+ true
+ true
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\PasswordLess\Device" /v "DevicePasswordLessBuildVersion" /t REG_DWORD /d 0 /f
+ Enable option for passwordless sign-in
+
+
+ 4
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 5
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 6
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 15
+ netsh advfirewall firewall set rule group="Network Discovery" new enable=Yes
+ Enable Network Discovery
+
+
+ 16
+ netsh advfirewall firewall set rule group="File and Printer Sharing" new enable=Yes
+ Enable File Sharing
+
+
+ 17
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/assets/win2016-eval.xml b/assets/win2016-eval.xml
index 981b766..78f4329 100644
--- a/assets/win2016-eval.xml
+++ b/assets/win2016-eval.xml
@@ -88,7 +88,6 @@
true
Docker
Windows for Docker
-
false
diff --git a/assets/win2016.xml b/assets/win2016.xml
new file mode 100644
index 0000000..db440a8
--- /dev/null
+++ b/assets/win2016.xml
@@ -0,0 +1,384 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+ en-US
+
+
+
+
+ 0
+ true
+
+
+
+ 1
+ EFI
+ 128
+
+
+
+ 2
+ MSR
+ 128
+
+
+
+ 3
+ Primary
+ true
+
+
+
+
+
+ 1
+ 1
+
+ FAT32
+
+
+
+ 2
+ 2
+
+
+
+ 3
+ 3
+
+ C
+ NTFS
+
+
+
+
+
+
+
+
+ /IMAGE/NAME
+ Windows Server 2016 SERVERSTANDARD
+
+
+
+ 0
+ 3
+
+ OnError
+ false
+
+
+
+ true
+ Never
+
+
+ false
+ Never
+
+
+ true
+ Docker
+ Windows for Docker
+
+ WC2BQ-8NRM3-FDDYY-2BFGV-KHKQY
+
+
+ false
+
+ false
+
+
+
+
+
+ D:\viostor\2k16\amd64
+
+
+ D:\NetKVM\2k16\amd64
+
+
+ D:\Balloon\2k16\amd64
+
+
+ D:\pvpanic\2k16\amd64
+
+
+ D:\qemupciserial\2k16\amd64
+
+
+ D:\qxldod\2k16\amd64
+
+
+ D:\vioinput\2k16\amd64
+
+
+ D:\viorng\2k16\amd64
+
+
+ D:\vioscsi\2k16\amd64
+
+
+ D:\vioserial\2k16\amd64
+
+
+ D:\viogpudo\2k16\amd64
+
+
+ D:\sriov\2k16\amd64
+
+
+ D:\viofs\2k16\amd64
+
+
+
+
+
+
+ false
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+
+ Dockur
+ Windows for Docker
+
+ Windows for Docker
+
+
+ 1
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ 0
+
+
+ 1
+
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+ en-US
+
+
+ true
+
+
+ true
+
+
+ false
+
+
+ 0
+
+
+
+
+ true
+ Remote Desktop
+ all
+
+
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ true
+ true
+ true
+ true
+ Other
+ 3
+ true
+ true
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\PasswordLess\Device" /v "DevicePasswordLessBuildVersion" /t REG_DWORD /d 0 /f
+ Enable option for passwordless sign-in
+
+
+ 4
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 5
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 6
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 15
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Cortana" /v "IsAvailable" /t REG_DWORD /d 0 /f
+ Disable Cortana
+
+
+ 16
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Search" /v "SearchboxTaskbarMode" /t REG_DWORD /d 0 /f
+ Remove Search from the Taskbar
+
+
+ 17
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "ShowTaskViewButton" /t REG_DWORD /d 0 /f
+ Remove Task View from the Taskbar
+
+
+ 18
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarDa" /t REG_DWORD /d 0 /f
+ Remove Widgets from the Taskbar
+
+
+ 19
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarMn" /t REG_DWORD /d 0 /f
+ Remove Chat from the Taskbar
+
+
+ 20
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU" /v "NoAutoUpdate" /t REG_DWORD /d 1 /f
+ Turn off Windows Update auto download
+
+
+ 21
+ netsh advfirewall firewall set rule group="Network Discovery" new enable=Yes
+ Enable Network Discovery
+
+
+ 22
+ netsh advfirewall firewall set rule group="File and Printer Sharing" new enable=Yes
+ Enable File Sharing
+
+
+ 23
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/assets/win2019-eval.xml b/assets/win2019-eval.xml
index 2f9b304..0baa0b7 100644
--- a/assets/win2019-eval.xml
+++ b/assets/win2019-eval.xml
@@ -88,7 +88,6 @@
true
Docker
Windows for Docker
-
false
diff --git a/assets/win2019.xml b/assets/win2019.xml
new file mode 100644
index 0000000..76d2a73
--- /dev/null
+++ b/assets/win2019.xml
@@ -0,0 +1,388 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+ en-US
+
+
+
+
+ 0
+ true
+
+
+
+ 1
+ EFI
+ 128
+
+
+
+ 2
+ MSR
+ 128
+
+
+
+ 3
+ Primary
+ true
+
+
+
+
+
+ 1
+ 1
+
+ FAT32
+
+
+
+ 2
+ 2
+
+
+
+ 3
+ 3
+
+ C
+ NTFS
+
+
+
+
+
+
+
+
+ /IMAGE/NAME
+ Windows Server 2019 SERVERSTANDARD
+
+
+
+ 0
+ 3
+
+ OnError
+ false
+
+
+
+ true
+ Never
+
+
+ false
+ Never
+
+
+ true
+ Docker
+ Windows for Docker
+
+ N69G4-B89J2-4G8F4-WWYCC-J464C
+
+
+ false
+
+ false
+
+
+
+
+
+ D:\viostor\2k19\amd64
+
+
+ D:\NetKVM\2k19\amd64
+
+
+ D:\Balloon\2k19\amd64
+
+
+ D:\pvpanic\2k19\amd64
+
+
+ D:\qemupciserial\2k19\amd64
+
+
+ D:\qxldod\2k19\amd64
+
+
+ D:\vioinput\2k19\amd64
+
+
+ D:\viorng\2k19\amd64
+
+
+ D:\vioscsi\2k19\amd64
+
+
+ D:\vioserial\2k19\amd64
+
+
+ D:\viogpudo\2k19\amd64
+
+
+ D:\sriov\2k19\amd64
+
+
+ D:\viofs\2k19\amd64
+
+
+
+
+
+
+ false
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+
+ Dockur
+ Windows for Docker
+ 24/7
+
+ Dockur
+ https://github.com/dockur/windows/issues
+
+ Windows for Docker
+
+
+ 1
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ 0
+
+
+ 1
+
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+ en-US
+
+
+ true
+
+
+ true
+
+
+ false
+
+
+ 0
+
+
+
+
+ true
+ Remote Desktop
+ all
+
+
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ true
+ true
+ true
+ true
+ Other
+ 3
+ true
+ true
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\PasswordLess\Device" /v "DevicePasswordLessBuildVersion" /t REG_DWORD /d 0 /f
+ Enable option for passwordless sign-in
+
+
+ 4
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 5
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 6
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 15
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Cortana" /v "IsAvailable" /t REG_DWORD /d 0 /f
+ Disable Cortana
+
+
+ 16
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Search" /v "SearchboxTaskbarMode" /t REG_DWORD /d 0 /f
+ Remove Search from the Taskbar
+
+
+ 17
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "ShowTaskViewButton" /t REG_DWORD /d 0 /f
+ Remove Task View from the Taskbar
+
+
+ 18
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarDa" /t REG_DWORD /d 0 /f
+ Remove Widgets from the Taskbar
+
+
+ 19
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarMn" /t REG_DWORD /d 0 /f
+ Remove Chat from the Taskbar
+
+
+ 20
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU" /v "NoAutoUpdate" /t REG_DWORD /d 1 /f
+ Turn off Windows Update auto download
+
+
+ 21
+ netsh advfirewall firewall set rule group="Network Discovery" new enable=Yes
+ Enable Network Discovery
+
+
+ 22
+ netsh advfirewall firewall set rule group="File and Printer Sharing" new enable=Yes
+ Enable File Sharing
+
+
+ 23
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/assets/win2022-eval.xml b/assets/win2022-eval.xml
index badd14c..0e88e0a 100644
--- a/assets/win2022-eval.xml
+++ b/assets/win2022-eval.xml
@@ -88,7 +88,6 @@
true
Docker
Windows for Docker
-
false
diff --git a/assets/win2022.xml b/assets/win2022.xml
new file mode 100644
index 0000000..f844cf6
--- /dev/null
+++ b/assets/win2022.xml
@@ -0,0 +1,388 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+ en-US
+
+
+
+
+ 0
+ true
+
+
+
+ 1
+ EFI
+ 128
+
+
+
+ 2
+ MSR
+ 128
+
+
+
+ 3
+ Primary
+ true
+
+
+
+
+
+ 1
+ 1
+
+ FAT32
+
+
+
+ 2
+ 2
+
+
+
+ 3
+ 3
+
+ C
+ NTFS
+
+
+
+
+
+
+
+
+ /IMAGE/NAME
+ Windows Server 2022 SERVERSTANDARD
+
+
+
+ 0
+ 3
+
+ OnError
+ false
+
+
+
+ true
+ Never
+
+
+ false
+ Never
+
+
+ true
+ Docker
+ Windows for Docker
+
+ VDYBN-27WPP-V4HQT-9VMD4-VMK7H
+
+
+ false
+
+ false
+
+
+
+
+
+ D:\viostor\2k22\amd64
+
+
+ D:\NetKVM\2k22\amd64
+
+
+ D:\Balloon\2k22\amd64
+
+
+ D:\pvpanic\2k22\amd64
+
+
+ D:\qemupciserial\2k22\amd64
+
+
+ D:\qxldod\2k22\amd64
+
+
+ D:\vioinput\2k22\amd64
+
+
+ D:\viorng\2k22\amd64
+
+
+ D:\vioscsi\2k22\amd64
+
+
+ D:\vioserial\2k22\amd64
+
+
+ D:\viogpudo\2k22\amd64
+
+
+ D:\sriov\2k22\amd64
+
+
+ D:\viofs\2k22\amd64
+
+
+
+
+
+
+ false
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+
+ Dockur
+ Windows for Docker
+ 24/7
+
+ Dockur
+ https://github.com/dockur/windows/issues
+
+ Windows for Docker
+
+
+ 1
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ 0
+
+
+ 1
+
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+ en-US
+
+
+ true
+
+
+ true
+
+
+ false
+
+
+ 0
+
+
+
+
+ true
+ Remote Desktop
+ all
+
+
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ true
+ true
+ true
+ true
+ Other
+ 3
+ true
+ true
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\PasswordLess\Device" /v "DevicePasswordLessBuildVersion" /t REG_DWORD /d 0 /f
+ Enable option for passwordless sign-in
+
+
+ 4
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 5
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 6
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 15
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Cortana" /v "IsAvailable" /t REG_DWORD /d 0 /f
+ Disable Cortana
+
+
+ 16
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Search" /v "SearchboxTaskbarMode" /t REG_DWORD /d 0 /f
+ Remove Search from the Taskbar
+
+
+ 17
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "ShowTaskViewButton" /t REG_DWORD /d 0 /f
+ Remove Task View from the Taskbar
+
+
+ 18
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarDa" /t REG_DWORD /d 0 /f
+ Remove Widgets from the Taskbar
+
+
+ 19
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarMn" /t REG_DWORD /d 0 /f
+ Remove Chat from the Taskbar
+
+
+ 20
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU" /v "NoAutoUpdate" /t REG_DWORD /d 1 /f
+ Turn off Windows Update auto download
+
+
+ 21
+ netsh advfirewall firewall set rule group="Network Discovery" new enable=Yes
+ Enable Network Discovery
+
+
+ 22
+ netsh advfirewall firewall set rule group="File and Printer Sharing" new enable=Yes
+ Enable File Sharing
+
+
+ 23
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/assets/win7x64-enterprise.xml b/assets/win7x64-enterprise.xml
new file mode 100644
index 0000000..6934dd5
--- /dev/null
+++ b/assets/win7x64-enterprise.xml
@@ -0,0 +1,316 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+
+ OnError
+
+ 0
+ true
+
+
+ 1
+ Primary
+ 100
+
+
+ 2
+ Primary
+ true
+
+
+
+
+ NTFS
+
+ 1
+ true
+ 1
+ 0x27
+
+
+ true
+ NTFS
+
+ C
+ 2
+ 2
+
+
+
+
+
+
+
+
+ Windows 7 Enterprise
+ /IMAGE/NAME
+
+
+
+ 0
+ 2
+
+ false
+
+
+
+ true
+ Never
+
+
+ false
+ Never
+
+
+ true
+ Docker
+ Windows for Docker
+
+ H7X92-3VPBB-Q799D-Y6JJ3-86WC6
+ OnError
+
+
+ false
+
+ false
+
+
+
+
+
+ D:\viostor\w7\amd64
+
+
+ D:\NetKVM\w7\amd64
+
+
+ D:\Balloon\w7\amd64
+
+
+ D:\pvpanic\w7\amd64
+
+
+ D:\qemupciserial\w7\amd64
+
+
+ D:\qxldod\w8\amd64
+
+
+ D:\vioinput\w7\amd64
+
+
+ D:\viorng\w7\amd64
+
+
+ D:\vioscsi\w7\amd64
+
+
+ D:\vioserial\w7\amd64
+
+
+
+
+
+
+ false
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+
+ Dockur
+ Windows for Docker
+
+
+
+ 1
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ 0
+
+
+ 1
+
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+ false
+
+
+ 0
+
+
+
+
+ true
+ Remote Desktop
+ all
+
+
+
+
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ true
+ Other
+ 3
+ true
+ true
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 4
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 5
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 6
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\NetworkList\NewNetworks" /v NetworkList /t REG_MULTI_SZ /d "" /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 15
+ netsh advfirewall firewall set rule group="Network Discovery" new enable=Yes
+ Enable Network Discovery
+
+
+ 16
+ netsh advfirewall firewall set rule group="File and Printer Sharing" new enable=Yes
+ Enable File Sharing
+
+
+ 17
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/assets/win7x64-ultimate.xml b/assets/win7x64-ultimate.xml
new file mode 100644
index 0000000..6e6e36c
--- /dev/null
+++ b/assets/win7x64-ultimate.xml
@@ -0,0 +1,316 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+
+ OnError
+
+ 0
+ true
+
+
+ 1
+ Primary
+ 100
+
+
+ 2
+ Primary
+ true
+
+
+
+
+ NTFS
+
+ 1
+ true
+ 1
+ 0x27
+
+
+ true
+ NTFS
+
+ C
+ 2
+ 2
+
+
+
+
+
+
+
+
+ Windows 7 Ultimate
+ /IMAGE/NAME
+
+
+
+ 0
+ 2
+
+ false
+
+
+
+ true
+ Never
+
+
+ false
+ Never
+
+
+ true
+ Docker
+ Windows for Docker
+
+ D4F6K-QK3RD-TMVMJ-BBMRX-3MBMV
+ OnError
+
+
+ false
+
+ false
+
+
+
+
+
+ D:\viostor\w7\amd64
+
+
+ D:\NetKVM\w7\amd64
+
+
+ D:\Balloon\w7\amd64
+
+
+ D:\pvpanic\w7\amd64
+
+
+ D:\qemupciserial\w7\amd64
+
+
+ D:\qxldod\w8\amd64
+
+
+ D:\vioinput\w7\amd64
+
+
+ D:\viorng\w7\amd64
+
+
+ D:\vioscsi\w7\amd64
+
+
+ D:\vioserial\w7\amd64
+
+
+
+
+
+
+ false
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+
+ Dockur
+ Windows for Docker
+
+
+
+ 1
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ 0
+
+
+ 1
+
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+ false
+
+
+ 0
+
+
+
+
+ true
+ Remote Desktop
+ all
+
+
+
+
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ true
+ Other
+ 3
+ true
+ true
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 4
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 5
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 6
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\NetworkList\NewNetworks" /v NetworkList /t REG_MULTI_SZ /d "" /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 15
+ netsh advfirewall firewall set rule group="Network Discovery" new enable=Yes
+ Enable Network Discovery
+
+
+ 16
+ netsh advfirewall firewall set rule group="File and Printer Sharing" new enable=Yes
+ Enable File Sharing
+
+
+ 17
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/assets/win81x64-enterprise-eval.xml b/assets/win81x64-enterprise-eval.xml
index b6c9e95..99f9ed3 100644
--- a/assets/win81x64-enterprise-eval.xml
+++ b/assets/win81x64-enterprise-eval.xml
@@ -80,7 +80,6 @@
true
Docker
Windows for Docker
-
false
diff --git a/assets/win81x64-enterprise.xml b/assets/win81x64-enterprise.xml
new file mode 100644
index 0000000..b43038e
--- /dev/null
+++ b/assets/win81x64-enterprise.xml
@@ -0,0 +1,339 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+
+
+ 0
+ true
+
+
+
+ 1
+ EFI
+ 128
+
+
+
+ 2
+ MSR
+ 128
+
+
+
+ 3
+ Primary
+ true
+
+
+
+
+
+ 1
+ 1
+
+ FAT32
+
+
+
+ 2
+ 2
+
+
+
+ 3
+ 3
+
+ C
+ NTFS
+
+
+
+
+
+
+
+ 0
+ 3
+
+ false
+
+
+
+ true
+ Never
+
+
+ false
+ Never
+
+
+ true
+ Docker
+ Windows for Docker
+
+ FHQNR-XYXYC-8PMHT-TV4PH-DRQ3H
+
+
+ false
+
+ false
+
+
+
+
+
+ D:\viostor\w10\amd64
+
+
+ D:\NetKVM\w10\amd64
+
+
+ D:\Balloon\w10\amd64
+
+
+ D:\pvpanic\w10\amd64
+
+
+ D:\qemupciserial\w10\amd64
+
+
+ D:\qxldod\w10\amd64
+
+
+ D:\vioinput\w10\amd64
+
+
+ D:\viorng\w10\amd64
+
+
+ D:\vioscsi\w10\amd64
+
+
+ D:\vioserial\w10\amd64
+
+
+ D:\viogpudo\w10\amd64
+
+
+ D:\sriov\w10\amd64
+
+
+ D:\viofs\w10\amd64
+
+
+
+
+
+
+ false
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+
+ Dockur
+ Windows for Docker
+
+ Windows for Docker
+
+
+ 1
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ true
+ true
+ https://google.com
+ about:blank
+
+
+ 0
+
+
+ 1
+
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+ false
+
+
+ 0
+
+
+
+
+ true
+ Remote Desktop
+ all
+
+
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ true
+ true
+ true
+ true
+ Other
+ 3
+ true
+ true
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\PasswordLess\Device" /v "DevicePasswordLessBuildVersion" /t REG_DWORD /d 0 /f
+ Enable option for passwordless sign-in
+
+
+ 4
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 5
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 6
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 15
+ netsh advfirewall firewall set rule group="Network Discovery" new enable=Yes
+ Enable Network Discovery
+
+
+ 16
+ netsh advfirewall firewall set rule group="File and Printer Sharing" new enable=Yes
+ Enable File Sharing
+
+
+ 17
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/assets/winvistax64-enterprise.xml b/assets/winvistax64-enterprise.xml
new file mode 100644
index 0000000..8d64187
--- /dev/null
+++ b/assets/winvistax64-enterprise.xml
@@ -0,0 +1,270 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+
+ OnError
+
+ 0
+ true
+
+
+ 1
+ Primary
+ 100
+
+
+ 2
+ Primary
+ true
+
+
+
+
+ NTFS
+
+ 1
+ true
+ 1
+
+
+ true
+ NTFS
+
+ C
+ 2
+ 2
+
+
+
+
+
+
+
+
+ Windows Vista Enterprise
+ /IMAGE/NAME
+
+
+
+ 0
+ 2
+
+ OnError
+ false
+
+
+
+ true
+ Docker
+ Windows for Docker
+
+ VKK3X-68KWM-X2YGT-QR4M6-4BWMV
+
+
+
+
+
+
+ D:\viostor\2k8\amd64
+
+
+ D:\NetKVM\2k8\amd64
+
+
+ D:\vioscsi\2k8\amd64
+
+
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+ VKK3X-68KWM-X2YGT-QR4M6-4BWMV
+ Pacific Standard Time
+
+ Dockur
+ Windows for Docker
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+
+
+ false
+
+
+
+
+ 0409:00000409
+ en-US
+ en-US
+
+
+ about:blank
+
+
+ 0
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ Other
+ 3
+ true
+ false
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 4
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 5
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 6
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\NetworkList\NewNetworks" /v NetworkList /t REG_MULTI_SZ /d "" /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ netsh.exe advfirewall firewall set rule group="Remote Desktop" new enable=Yes
+ Add RDP in firewall
+
+
+ 15
+ netsh.exe Advfirewall set allprofiles state off
+ Disable firewall
+
+
+ 16
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Terminal Server" /v fDenyTSConnections /t REG_DWORD /d 0 /f
+ Enable RDP
+
+
+ 17
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\Windows\Sidebar" /v "TurnOffSidebar" /t REG_DWORD /d 1 /f
+ Turn off sidebar
+
+
+ 18
+ reg.exe add "HKCU\Control Panel\Desktop" /v "ScreenSaveActive" /t REG_DWORD /d 0 /f
+ Disable screensaver
+
+
+ 19
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 20
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/assets/winvistax64-ultimate.xml b/assets/winvistax64-ultimate.xml
new file mode 100644
index 0000000..b613f6f
--- /dev/null
+++ b/assets/winvistax64-ultimate.xml
@@ -0,0 +1,270 @@
+
+
+
+
+
+ en-US
+
+ 0409:00000409
+ en-US
+ en-US
+ en-US
+
+
+
+ OnError
+
+ 0
+ true
+
+
+ 1
+ Primary
+ 100
+
+
+ 2
+ Primary
+ true
+
+
+
+
+ NTFS
+
+ 1
+ true
+ 1
+
+
+ true
+ NTFS
+
+ C
+ 2
+ 2
+
+
+
+
+
+
+
+
+ Windows Vista Ultimate
+ /IMAGE/NAME
+
+
+
+ 0
+ 2
+
+ OnError
+ false
+
+
+
+ true
+ Docker
+ Windows for Docker
+
+ VMCB9-FDRV6-6CDQM-RV23K-RP8F7
+
+
+
+
+
+
+ D:\viostor\2k8\amd64
+
+
+ D:\NetKVM\2k8\amd64
+
+
+ D:\vioscsi\2k8\amd64
+
+
+
+
+
+
+ true
+
+
+ 1
+
+
+
+
+ true
+
+
+ *
+ VMCB9-FDRV6-6CDQM-RV23K-RP8F7
+ Pacific Standard Time
+
+ Dockur
+ Windows for Docker
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+
+
+ false
+
+
+
+
+ 0409:00000409
+ en-US
+ en-US
+
+
+ about:blank
+
+
+ 0
+
+
+
+
+
+ Docker
+ Administrators
+
+
+ true
+
+
+
+
+ password
+ true
+
+
+
+ Docker
+ true
+ 65432
+
+
+ true
+
+
+
+ true
+ Other
+ 3
+ true
+ false
+
+ Dockur
+ Windows for Docker
+
+
+ 1
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters" /v "AllowInsecureGuestAuth" /t REG_DWORD /d 1 /f
+ Allow guest access to network shares
+
+
+ 2
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Lsa" /v LimitBlankPasswordUse /t REG_DWORD /d 0 /f
+ Allow RDP login with blank password
+
+
+ 3
+ cmd /C wmic useraccount where name="Docker" set PasswordExpires=false
+ Password Never Expires
+
+
+ 4
+ cmd /C POWERCFG -H OFF
+ Disable Hibernation
+
+
+ 5
+ cmd /C POWERCFG -X -monitor-timeout-ac 0
+ Disable monitor blanking
+
+
+ 6
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NewNetworkWindowOff" /f
+ Disable Network Discovery popup
+
+
+ 7
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Network\NetworkLocationWizard" /v "HideWizard" /t REG_DWORD /d 1 /f
+ Disable Network Discovery popup
+
+
+ 8
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\NetworkList\NewNetworks" /v NetworkList /t REG_MULTI_SZ /d "" /f
+ Disable Network Discovery popup
+
+
+ 9
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Edge" /v "HideFirstRunExperience" /t REG_DWORD /d 1 /f
+ Disable first-run experience in Edge
+
+
+ 10
+ reg.exe add "HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "HideFileExt" /t REG_DWORD /d 0 /f
+ Show file extensions in Explorer
+
+
+ 11
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateFileSizePercent" /t REG_DWORD /d 0 /f
+ Zero Hibernation File
+
+
+ 12
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Power" /v "HibernateEnabled" /t REG_DWORD /d 0 /f
+ Disable Hibernation
+
+
+ 13
+ cmd /C POWERCFG -X -standby-timeout-ac 0
+ Disable Sleep
+
+
+ 14
+ netsh.exe advfirewall firewall set rule group="Remote Desktop" new enable=Yes
+ Add RDP in firewall
+
+
+ 15
+ netsh.exe Advfirewall set allprofiles state off
+ Disable firewall
+
+
+ 16
+ reg.exe add "HKLM\SYSTEM\CurrentControlSet\Control\Terminal Server" /v fDenyTSConnections /t REG_DWORD /d 0 /f
+ Enable RDP
+
+
+ 17
+ reg.exe add "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\Windows\Sidebar" /v "TurnOffSidebar" /t REG_DWORD /d 1 /f
+ Turn off sidebar
+
+
+ 18
+ reg.exe add "HKCU\Control Panel\Desktop" /v "ScreenSaveActive" /t REG_DWORD /d 0 /f
+ Disable screensaver
+
+
+ 19
+ reg.exe add "HKLM\SOFTWARE\Policies\Microsoft\Windows NT\Terminal Services" /v "fAllowUnlistedRemotePrograms" /t REG_DWORD /d 1 /f
+ Enable RemoteAPP to launch unlisted programs
+
+
+ 20
+ cmd /C if exist "C:\OEM\install.bat" start "Install" "cmd /C C:\OEM\install.bat"
+ Execute custom script from the OEM folder if exists
+
+
+
+
+
diff --git a/readme.md b/readme.md
index b12e1de..6205235 100644
--- a/readme.md
+++ b/readme.md
@@ -78,25 +78,28 @@ docker run -it --rm --name windows -p 8006:8006 --device=/dev/kvm --cap-add NET_
Select from the values below:
- | **Value** | **Description** | **Source** | **Transfer** | **Size** |
- |---|---|---|---|---|
- | `win11` | Windows 11 Pro | Microsoft | Fast | 6.4 GB |
- | `win10` | Windows 10 Pro | Microsoft | Fast | 5.8 GB |
- | `ltsc10` | Windows 10 LTSC | Microsoft | Fast | 4.6 GB |
- | `win81` | Windows 8.1 Pro | Microsoft | Fast | 4.2 GB |
- | `win7` | Windows 7 SP1 | Bob Pony | Medium | 3.0 GB |
- | `vista` | Windows Vista SP2 | Bob Pony | Medium | 3.6 GB |
- | `winxp` | Windows XP SP3 | Bob Pony | Medium | 0.6 GB |
- ||||||
- | `2022` | Windows Server 2022 | Microsoft | Fast | 4.7 GB |
- | `2019` | Windows Server 2019 | Microsoft | Fast | 5.3 GB |
- | `2016` | Windows Server 2016 | Microsoft | Fast | 6.5 GB |
- | `2012` | Windows Server 2012 R2 | Microsoft | Fast | 4.3 GB |
- | `2008` | Windows Server 2008 R2 | Microsoft | Fast | 3.0 GB |
- ||||||
- | `core11` | Tiny 11 Core | Archive.org | Slow | 2.1 GB |
- | `tiny11` | Tiny 11 | Archive.org | Slow | 3.8 GB |
- | `tiny10` | Tiny 10 | Archive.org | Slow | 3.6 GB |
+ | **Value** | **Version** | **Edition** | **Size** |
+ |---|---|---|---|
+ | `win11` | Windows 11 | Pro | 6.4 GB |
+ | `win11e` | Windows 11 | Enterprise | 5.8 GB |
+ | `win10` | Windows 10 | Pro | 5.8 GB |
+ | `ltsc10` | Windows 10 | LTSC | 4.6 GB |
+ | `win10e` | Windows 10 | Enterprise | 5.2 GB |
+ | `win81` | Windows 8.1 | Pro | 4.2 GB |
+ | `win81e` | Windows 8.1 | Enterprise | 3.8 GB |
+ | `win7` | Windows 7 | Enterprise | 3.0 GB |
+ | `vista` | Windows Vista | Ultimate | 3.6 GB |
+ | `winxp` | Windows XP | Pro | 0.6 GB |
+ |||||
+ | `2022` | Windows Server 2022 | Standard | 4.7 GB |
+ | `2019` | Windows Server 2019 | Standard | 5.3 GB |
+ | `2016` | Windows Server 2016 | Standard | 6.5 GB |
+ | `2012` | Windows Server 2012 | Standard | 4.3 GB |
+ | `2008` | Windows Server 2008 | Standard | 3.0 GB |
+ |||||
+ | `core11` | Tiny 11 | Core | 2.1 GB |
+ | `tiny11` | Tiny 11 | 2311 | 3.8 GB |
+ | `tiny10` | Tiny 10 | 23H2 | 3.6 GB |
To install ARM64 versions of Windows use [dockur/windows-arm](https://github.com/dockur/windows-arm/).
diff --git a/src/define.sh b/src/define.sh
new file mode 100644
index 0000000..518e405
--- /dev/null
+++ b/src/define.sh
@@ -0,0 +1,716 @@
+#!/usr/bin/env bash
+set -Eeuo pipefail
+
+: "${MANUAL:=""}"
+: "${VERSION:=""}"
+: "${DETECTED:=""}"
+: "${PLATFORM:="x64"}"
+
+parseVersion() {
+
+ [ -z "$VERSION" ] && VERSION="win11"
+
+ if [[ "${VERSION}" == \"*\" || "${VERSION}" == \'*\' ]]; then
+ VERSION="${VERSION:1:-1}"
+ fi
+
+ case "${VERSION,,}" in
+ "11" | "win11" | "windows11" | "windows 11")
+ VERSION="win11${PLATFORM,,}"
+ ;;
+ "11e" | "win11e" | "windows11e" | "windows 11e")
+ VERSION="win11${PLATFORM,,}-enterprise-eval"
+ ;;
+ "10" | "win10" | "windows10" | "windows 10")
+ VERSION="win10${PLATFORM,,}"
+ ;;
+ "10e" | "win10e" | "windows10e" | "windows 10e")
+ VERSION="win10${PLATFORM,,}-enterprise-eval"
+ ;;
+ "8" | "81" | "8.1" | "win8" | "win81" | "windows 8" | "windows 8.1")
+ VERSION="win81${PLATFORM,,}"
+ ;;
+ "8e" | "81e" | "8.1e" | "win8e" | "win81e" | "windows8e" | "windows 8e")
+ VERSION="win81${PLATFORM,,}-enterprise-eval"
+ ;;
+ "7" | "7e" | "win7" | "win7e" | "windows7" | "windows 7")
+ VERSION="win7${PLATFORM,,}"
+ DETECTED="win7${PLATFORM,,}-enterprise"
+ ;;
+ "vista" | "winvista" | "windowsvista" | "windows vista")
+ VERSION="winvista${PLATFORM,,}"
+ DETECTED="winvista${PLATFORM,,}-ultimate"
+ ;;
+ "xp" | "winxp" | "windowsxp" | "windows xp")
+ VERSION="winxpx86"
+ ;;
+ "xp64" | "winxp64" | "windowsxp64")
+ VERSION="winxpx64"
+ ;;
+ "22" | "2022" | "win22" | "win2022" | "windows2022" | "windows 2022")
+ VERSION="win2022-eval"
+ ;;
+ "19" | "2019" | "win19" | "win2019" | "windows2019" | "windows 2019")
+ VERSION="win2019-eval"
+ ;;
+ "16" | "2016" | "win16" | "win2016" | "windows2016" | "windows 2016")
+ VERSION="win2016-eval"
+ ;;
+ "2012" | "2012r2" | "win2012" | "win2012r2" | "windows2012" | "windows 2012")
+ VERSION="win2012r2-eval"
+ ;;
+ "2008" | "2008r2" | "win2008" | "win2008r2" | "windows2008" | "windows 2008")
+ VERSION="win2008r2"
+ ;;
+ "core11" | "core 11" | "tiny11" | "tiny 11")
+ DETECTED="win11${PLATFORM,,}"
+ ;;
+ "tiny10" | "tiny 10")
+ DETECTED="win10${PLATFORM,,}-ltsc"
+ ;;
+ "iot10" | "10iot" | "win10-iot" | "win10${PLATFORM,,}-iot" | "win10${PLATFORM,,}-enterprise-iot-eval")
+ DETECTED="win10${PLATFORM,,}-iot"
+ VERSION="win10${PLATFORM,,}-enterprise-iot-eval"
+ ;;
+ "ltsc10" | "10ltsc" | "win10-ltsc" | "win10${PLATFORM,,}-ltsc" | "win10${PLATFORM,,}-enterprise-ltsc-eval")
+ DETECTED="win10${PLATFORM,,}-ltsc"
+ VERSION="win10${PLATFORM,,}-enterprise-ltsc-eval"
+ ;;
+ esac
+
+ return 0
+}
+
+printVersion() {
+
+ local id="$1"
+ local desc="$2"
+
+ [[ "$id" == "win7"* ]] && desc="Windows 7"
+ [[ "$id" == "win8"* ]] && desc="Windows 8"
+ [[ "$id" == "win10"* ]] && desc="Windows 10"
+ [[ "$id" == "win11"* ]] && desc="Windows 11"
+ [[ "$id" == "winxp"* ]] && desc="Windows XP"
+ [[ "$id" == "winvista"* ]] && desc="Windows Vista"
+
+ [[ "$id" == "win2025"* ]] && desc="Windows Server 2025"
+ [[ "$id" == "win2022"* ]] && desc="Windows Server 2022"
+ [[ "$id" == "win2019"* ]] && desc="Windows Server 2019"
+ [[ "$id" == "win2016"* ]] && desc="Windows Server 2016"
+ [[ "$id" == "win2012"* ]] && desc="Windows Server 2012"
+ [[ "$id" == "win2008"* ]] && desc="Windows Server 2008"
+
+ [ -z "$desc" ] && desc="Windows"
+
+ echo "$desc"
+ return 0
+}
+
+getName() {
+
+ local file="$1"
+ local desc="$2"
+
+ [[ "${file,,}" == "win11"* ]] && desc="Windows 11"
+ [[ "${file,,}" == "win10"* ]] && desc="Windows 10"
+ [[ "${file,,}" == "win8"* ]] && desc="Windows 8"
+ [[ "${file,,}" == "win7"* ]] && desc="Windows 7"
+ [[ "${file,,}" == "winxp"* ]] && desc="Windows XP"
+ [[ "${file,,}" == "winvista"* ]] && desc="Windows Vista"
+ [[ "${file,,}" == "tiny10"* ]] && desc="Tiny 10"
+ [[ "${file,,}" == "tiny11"* ]] && desc="Tiny 11"
+ [[ "${file,,}" == "tiny11_core"* ]] && desc="Tiny 11 Core"
+ [[ "${file,,}" == *"windows11"* ]] && desc="Windows 11"
+ [[ "${file,,}" == *"windows10"* ]] && desc="Windows 10"
+ [[ "${file,,}" == *"windows8"* ]] && desc="Windows 8"
+ [[ "${file,,}" == *"windows7"* ]] && desc="Windows 7"
+ [[ "${file,,}" == *"windowsxp"* ]] && desc="Windows XP"
+ [[ "${file,,}" == *"windowsvista"* ]] && desc="Windows Vista"
+ [[ "${file,,}" == *"windows_11"* ]] && desc="Windows 11"
+ [[ "${file,,}" == *"windows_10"* ]] && desc="Windows 10"
+ [[ "${file,,}" == *"windows_8"* ]] && desc="Windows 8"
+ [[ "${file,,}" == *"windows_7"* ]] && desc="Windows 7"
+ [[ "${file,,}" == *"windows_xp"* ]] && desc="Windows XP"
+ [[ "${file,,}" == *"windows_vista"* ]] && desc="Windows Vista"
+ [[ "${file,,}" == *"windows 11"* ]] && desc="Windows 11"
+ [[ "${file,,}" == *"windows 10"* ]] && desc="Windows 10"
+ [[ "${file,,}" == *"windows 8"* ]] && desc="Windows 8"
+ [[ "${file,,}" == *"windows 7"* ]] && desc="Windows 7"
+ [[ "${file,,}" == *"windows xp"* ]] && desc="Windows XP"
+ [[ "${file,,}" == *"windows vista"* ]] && desc="Windows Vista"
+ [[ "${file,,}" == *"server2008"* ]] && desc="Windows Server 2008"
+ [[ "${file,,}" == *"server2012"* ]] && desc="Windows Server 2012"
+ [[ "${file,,}" == *"server2016"* ]] && desc="Windows Server 2016"
+ [[ "${file,,}" == *"server2019"* ]] && desc="Windows Server 2019"
+ [[ "${file,,}" == *"server2022"* ]] && desc="Windows Server 2022"
+ [[ "${file,,}" == *"server2025"* ]] && desc="Windows Server 2025"
+ [[ "${file,,}" == *"server_2008"* ]] && desc="Windows Server 2008"
+ [[ "${file,,}" == *"server_2012"* ]] && desc="Windows Server 2012"
+ [[ "${file,,}" == *"server_2016"* ]] && desc="Windows Server 2016"
+ [[ "${file,,}" == *"server_2019"* ]] && desc="Windows Server 2019"
+ [[ "${file,,}" == *"server_2022"* ]] && desc="Windows Server 2022"
+ [[ "${file,,}" == *"server_2025"* ]] && desc="Windows Server 2025"
+ [[ "${file,,}" == *"server 2008"* ]] && desc="Windows Server 2008"
+ [[ "${file,,}" == *"server 2012"* ]] && desc="Windows Server 2012"
+ [[ "${file,,}" == *"server 2016"* ]] && desc="Windows Server 2016"
+ [[ "${file,,}" == *"server 2019"* ]] && desc="Windows Server 2019"
+ [[ "${file,,}" == *"server 2022"* ]] && desc="Windows Server 2022"
+ [[ "${file,,}" == *"server 2025"* ]] && desc="Windows Server 2025"
+
+ [ -z "$desc" ] && desc="Windows"
+
+ echo "$desc"
+ return 0
+}
+
+getVersion() {
+
+ local name="$1"
+ local detected=""
+
+ if [[ "${name,,}" == *"windows 7"* ]]; then
+ detected="win7${PLATFORM,,}"
+ [[ "${name,,}" == *"ultimate"* ]] && detected="win7${PLATFORM,,}-ultimate"
+ [[ "${name,,}" == *"enterprise"* ]] && detected="win7${PLATFORM,,}-enterprise"
+ fi
+
+ if [[ "${name,,}" == *"windows vista"* ]]; then
+ detected="winvista${PLATFORM,,}"
+ [[ "${name,,}" == *"ultimate"* ]] && detected="winvista${PLATFORM,,}-ultimate"
+ [[ "${name,,}" == *"enterprise"* ]] && detected="winvista${PLATFORM,,}-enterprise"
+ fi
+
+ if [[ "${name,,}" == *"server 2025"* ]]; then
+ detected="win2025"
+ [[ "${name,,}" == *"evaluation"* ]] && detected="win2025-eval"
+ fi
+
+ if [[ "${name,,}" == *"server 2022"* ]]; then
+ detected="win2022"
+ [[ "${name,,}" == *"evaluation"* ]] && detected="win2022-eval"
+ fi
+
+ if [[ "${name,,}" == *"server 2019"* ]]; then
+ detected="win2019"
+ [[ "${name,,}" == *"evaluation"* ]] && detected="win2019-eval"
+ fi
+
+ if [[ "${name,,}" == *"server 2016"* ]]; then
+ detected="win2016"
+ [[ "${name,,}" == *"evaluation"* ]] && detected="win2016-eval"
+ fi
+
+ if [[ "${name,,}" == *"server 2012"* ]]; then
+ detected="win2012r2"
+ [[ "${name,,}" == *"evaluation"* ]] && detected="win2012r2-eval"
+ fi
+
+ if [[ "${name,,}" == *"server 2008"* ]]; then
+ detected="win2008r2"
+ [[ "${name,,}" == *"evaluation"* ]] && detected="win2008r2-eval"
+ fi
+
+ if [[ "${name,,}" == *"windows 8"* ]]; then
+ detected="win81${PLATFORM,,}"
+ [[ "${name,,}" == *"enterprise"* ]] && detected="win81${PLATFORM,,}-enterprise"
+ [[ "${name,,}" == *"enterprise evaluation"* ]] && detected="win81${PLATFORM,,}-enterprise-eval"
+ fi
+
+ if [[ "${name,,}" == *"windows 11"* ]]; then
+ detected="win11${PLATFORM,,}"
+ [[ "${name,,}" == *"enterprise"* ]] && detected="win11${PLATFORM,,}-enterprise"
+ [[ "${name,,}" == *"enterprise evaluation"* ]] && detected="win11${PLATFORM,,}-enterprise-eval"
+ fi
+
+ if [[ "${name,,}" == *"windows 10"* ]]; then
+ detected="win10${PLATFORM,,}"
+ if [[ "${name,,}" == *" iot "* ]]; then
+ detected="win10${PLATFORM,,}-iot"
+ else
+ if [[ "${name,,}" == *"ltsc"* ]]; then
+ detected="win10${PLATFORM,,}-ltsc"
+ else
+ [[ "${name,,}" == *"enterprise"* ]] && detected="win10${PLATFORM,,}-enterprise"
+ [[ "${name,,}" == *"enterprise evaluation"* ]] && detected="win10${PLATFORM,,}-enterprise-eval"
+ fi
+ fi
+ fi
+
+ echo "$detected"
+ return 0
+}
+
+switchEdition() {
+
+ local id="$1"
+
+ case "${id,,}" in
+ "win11${PLATFORM,,}-enterprise-eval")
+ DETECTED="win11${PLATFORM,,}-enterprise"
+ ;;
+ "win10${PLATFORM,,}-enterprise-eval")
+ DETECTED="win10${PLATFORM,,}-enterprise"
+ ;;
+ "win81${PLATFORM,,}-enterprise-eval")
+ DETECTED="win81${PLATFORM,,}-enterprise"
+ ;;
+ "win2022-eval")
+ DETECTED="win2022"
+ ;;
+ "win2019-eval")
+ DETECTED="win2019"
+ ;;
+ "win2016-eval")
+ DETECTED="win2016"
+ ;;
+ "win2012r2-eval")
+ DETECTED="win2012r2"
+ ;;
+ "win2008r2-eval")
+ DETECTED="win2008r2"
+ ;;
+ esac
+
+ return 0
+}
+
+isESD() {
+
+ local id="$1"
+
+ case "${id,,}" in
+ "win11${PLATFORM,,}")
+ return 0
+ ;;
+ "win10${PLATFORM,,}")
+ return 0
+ ;;
+ esac
+
+ return 1
+}
+
+isMido() {
+
+ local id="$1"
+
+ case "${id,,}" in
+ "win11${PLATFORM,,}" | "win11${PLATFORM,,}-enterprise-eval")
+ return 0
+ ;;
+ "win10${PLATFORM,,}" | "win10${PLATFORM,,}-enterprise-eval" | "win10${PLATFORM,,}-enterprise-ltsc-eval")
+ return 0
+ ;;
+ "win81${PLATFORM,,}" | "win81${PLATFORM,,}-enterprise-eval")
+ return 0
+ ;;
+ "win2022-eval" | "win2019-eval" | "win2016-eval" | "win2012r2-eval" | "win2008r2")
+ return 0
+ ;;
+ esac
+
+ return 1
+}
+
+getLink() {
+
+ # Fallbacks for users who cannot connect to the Microsoft servers
+
+ local id="$1"
+ local url=""
+ local host="https://dl.bobpony.com"
+
+ case "${id,,}" in
+ "win11${PLATFORM,,}")
+ url="$host/windows/11/en-us_windows_11_23h2_${PLATFORM,,}.iso"
+ ;;
+ "win10${PLATFORM,,}")
+ url="$host/windows/10/en-us_windows_10_22h2_${PLATFORM,,}.iso"
+ ;;
+ "win10${PLATFORM,,}-iot" | "win10${PLATFORM,,}-enterprise-iot-eval")
+ url="$host/windows/10/en-us_windows_10_iot_enterprise_ltsc_2021_${PLATFORM,,}_dvd_257ad90f.iso"
+ ;;
+ "win10${PLATFORM,,}-ltsc" | "win10${PLATFORM,,}-enterprise-ltsc-eval")
+ url="$host/windows/10/en-us_windows_10_enterprise_ltsc_2021_${PLATFORM,,}_dvd_d289cf96.iso"
+ ;;
+ "win81${PLATFORM,,}")
+ url="$host/windows/8.x/8.1/en_windows_8.1_with_update_${PLATFORM,,}_dvd_6051480.iso"
+ ;;
+ "win2022" | "win2022-eval")
+ url="$host/windows/server/2022/en-us_windows_server_2022_updated_jan_2024_${PLATFORM,,}_dvd_2b7a0c9f.iso"
+ ;;
+ "win2019" | "win2019-eval")
+ url="$host/windows/server/2019/en-us_windows_server_2019_updated_aug_2021_${PLATFORM,,}_dvd_a6431a28.iso"
+ ;;
+ "win2016" | "win2016-eval")
+ url="$host/windows/server/2016/en_windows_server_2016_updated_feb_2018_${PLATFORM,,}_dvd_11636692.iso"
+ ;;
+ "win2012r2" | "win2012r2-eval")
+ url="$host/windows/server/2012r2/en_windows_server_2012_r2_with_update_${PLATFORM,,}_dvd_6052708-004.iso"
+ ;;
+ "win2008r2" | "win2008r2-eval")
+ url="$host/windows/server/2008r2/en_windows_server_2008_r2_with_sp1_${PLATFORM,,}_dvd_617601-018.iso"
+ ;;
+ "win7${PLATFORM,,}" | "win7${PLATFORM,,}-enterprise")
+ url="$host/windows/7/en_windows_7_enterprise_with_sp1_${PLATFORM,,}_dvd_u_677651.iso"
+ ;;
+ "winvista${PLATFORM,,}" | "winvista${PLATFORM,,}-ultimate")
+ url="$host/windows/vista/en_windows_vista_sp2_${PLATFORM,,}_dvd_342267.iso"
+ ;;
+ "winxpx86")
+ url="$host/windows/xp/professional/en_windows_xp_professional_with_service_pack_3_x86_cd_x14-80428.iso"
+ ;;
+ "winxpx64")
+ url="$host/windows/xp/professional/en_win_xp_pro_${PLATFORM,,}_vl.iso"
+ ;;
+ "core11")
+ url="https://file.cnxiaobai.com/Windows/%E7%B3%BB%E7%BB%9F%E5%AE%89%E8%A3%85%E5%8C%85/Tiny%2010_11/tiny11%20core%20${PLATFORM,,}%20beta%201.iso"
+ ;;
+ "tiny11")
+ url="https://file.cnxiaobai.com/Windows/%E7%B3%BB%E7%BB%9F%E5%AE%89%E8%A3%85%E5%8C%85/Tiny%2010_11/tiny11%202311%20${PLATFORM,,}.iso"
+ ;;
+ "tiny10")
+ url="https://file.cnxiaobai.com/Windows/%E7%B3%BB%E7%BB%9F%E5%AE%89%E8%A3%85%E5%8C%85/Tiny%2010_11/tiny10%2023H2%20${PLATFORM,,}.iso"
+ ;;
+ esac
+
+ echo "$url"
+ return 0
+}
+
+secondLink() {
+
+ # Fallbacks for users who cannot connect to the Microsoft servers
+
+ local id="$1"
+ local url=""
+ local host="https://drive.massgrave.dev"
+
+ case "${id,,}" in
+ "win11${PLATFORM,,}")
+ url="$host/en-us_windows_11_consumer_editions_version_23h2_updated_april_2024_${PLATFORM,,}_dvd_d986680b.iso"
+ ;;
+ "win11${PLATFORM,,}-enterprise" | "win11${PLATFORM,,}-enterprise-eval")
+ url="$host/en-us_windows_11_business_editions_version_23h2_updated_april_2024_${PLATFORM,,}_dvd_349cd577.iso"
+ ;;
+ "win11${PLATFORM,,}-iot" | "win11${PLATFORM,,}-enterprise-iot-eval")
+ url="$host/en-us_windows_11_iot_enterprise_version_23h2_${PLATFORM,,}_dvd_fb37549c.iso"
+ ;;
+ "win10${PLATFORM,,}")
+ url="$host/en-us_windows_10_consumer_editions_version_22h2_updated_april_2024_${PLATFORM,,}_dvd_9a92dc89.iso"
+ ;;
+ "win10${PLATFORM,,}-enterprise" | "win10${PLATFORM,,}-enterprise-eval")
+ url="$host/en-us_windows_10_business_editions_version_22h2_updated_april_2024_${PLATFORM,,}_dvd_c00090a7.iso"
+ ;;
+ "win10${PLATFORM,,}-iot" | "win10${PLATFORM,,}-enterprise-iot-eval")
+ url="$host/en-us_windows_10_iot_enterprise_ltsc_2021_${PLATFORM,,}_dvd_257ad90f.iso"
+ ;;
+ "win10${PLATFORM,,}-ltsc" | "win10${PLATFORM,,}-enterprise-ltsc-eval")
+ url="$host/en-us_windows_10_enterprise_ltsc_2021_${PLATFORM,,}_dvd_d289cf96.iso"
+ ;;
+ "win81${PLATFORM,,}")
+ url="$host/en_windows_8.1_pro_vl_with_update_${PLATFORM,,}_dvd_6050880.iso"
+ ;;
+ "win81${PLATFORM,,}-enterprise" | "win81${PLATFORM,,}-enterprise-eval")
+ url="$host/en_windows_8.1_enterprise_with_update_${PLATFORM,,}_dvd_6054382.iso"
+ ;;
+ "win2022" | "win2022-eval")
+ url="$host/en-us_windows_server_2022_updated_april_2024_${PLATFORM,,}_dvd_164349f3.iso"
+ ;;
+ "win2019" | "win2019-eval")
+ url="$host/en_windows_server_2019_${PLATFORM,,}_dvd_4cb967d8.iso"
+ ;;
+ "win2016" | "win2016-eval")
+ url="$host/en_windows_server_2016_${PLATFORM,,}_dvd_9327751.iso"
+ ;;
+ "win2012r2" | "win2012r2-eval")
+ url="$host/en_windows_server_2012_r2_with_update_${PLATFORM,,}_dvd_6052708.iso"
+ ;;
+ "win2008r2" | "win2008r2-eval")
+ url="$host/en_windows_server_2008_r2_with_sp1_${PLATFORM,,}_dvd_617601.iso"
+ ;;
+ "win7${PLATFORM,,}" | "win7${PLATFORM,,}-enterprise")
+ url="$host/en_windows_7_enterprise_with_sp1_${PLATFORM,,}_dvd_u_677651.iso"
+ ;;
+ "winvista${PLATFORM,,}" | "winvista${PLATFORM,,}-ultimate")
+ url="$host/en_windows_vista_sp2_${PLATFORM,,}_dvd_342267.iso"
+ ;;
+ "winxpx86")
+ url="$host/en_windows_xp_professional_with_service_pack_3_x86_cd_vl_x14-73974.iso"
+ ;;
+ "winxpx64")
+ url="$host/en_win_xp_pro_${PLATFORM,,}_with_sp2_vl_x13-41611.iso"
+ ;;
+ "core11")
+ url="https://archive.org/download/tiny-11-core-x-64-beta-1/tiny11%20core%20${PLATFORM,,}%20beta%201.iso"
+ ;;
+ "tiny11")
+ url="https://archive.org/download/tiny11-2311/tiny11%202311%20${PLATFORM,,}.iso"
+ ;;
+ "tiny10")
+ url="https://archive.org/download/tiny-10-23-h2/tiny10%20${PLATFORM,,}%2023h2.iso"
+ ;;
+ esac
+
+ echo "$url"
+ return 0
+}
+
+validVersion() {
+
+ local id="$1"
+ local url
+
+ isESD "$id" && return 0
+ isMido "$id" && return 0
+
+ url=$(getLink "$id")
+ [ -n "$url" ] && return 0
+
+ url=$(secondLink "$id")
+ [ -n "$url" ] && return 0
+
+ return 1
+}
+
+migrateFiles() {
+
+ local base="$1"
+ local version="$2"
+ local file=""
+
+ [ -f "$STORAGE/$base" ] && return 0
+
+ [[ "${version,,}" == "tiny10" ]] && file="tiny10_${PLATFORM,,}_23h2.iso"
+ [[ "${version,,}" == "tiny11" ]] && file="tiny11_2311_${PLATFORM,,}.iso"
+ [[ "${version,,}" == "core11" ]] && file="tiny11_core_${PLATFORM,,}_beta_1.iso"
+ [[ "${version,,}" == "winxpx86" ]] && file="en_windows_xp_professional_with_service_pack_3_x86_cd_x14-80428.iso"
+ [[ "${version,,}" == "winvista${PLATFORM,,}" ]] && file="en_windows_vista_sp2_${PLATFORM,,}_dvd_342267.iso"
+ [[ "${version,,}" == "win7${PLATFORM,,}" ]] && file="en_windows_7_enterprise_with_sp1_${PLATFORM,,}_dvd_u_677651.iso"
+
+ [ -z "$file" ] && return 0
+ [ ! -f "$STORAGE/$file" ] && return 0
+
+ ! mv "$STORAGE/$file" "$STORAGE/$base" && return 1
+
+ return 0
+}
+
+configXP() {
+
+ local dir="$1"
+ local arch="x86"
+ local target="$dir/I386"
+ local drivers="$TMP/drivers"
+
+ if [ -d "$dir/AMD64" ]; then
+ arch="amd64"
+ target="$dir/AMD64"
+ fi
+
+ rm -rf "$drivers"
+
+ if ! 7z x /run/drivers.iso -o"$drivers" > /dev/null; then
+ error "Failed to extract driver ISO file!" && return 1
+ fi
+
+ cp "$drivers/viostor/xp/$arch/viostor.sys" "$target"
+
+ mkdir -p "$dir/\$OEM\$/\$1/Drivers/viostor"
+ cp "$drivers/viostor/xp/$arch/viostor.cat" "$dir/\$OEM\$/\$1/Drivers/viostor"
+ cp "$drivers/viostor/xp/$arch/viostor.inf" "$dir/\$OEM\$/\$1/Drivers/viostor"
+ cp "$drivers/viostor/xp/$arch/viostor.sys" "$dir/\$OEM\$/\$1/Drivers/viostor"
+
+ mkdir -p "$dir/\$OEM\$/\$1/Drivers/NetKVM"
+ cp "$drivers/NetKVM/xp/$arch/netkvm.cat" "$dir/\$OEM\$/\$1/Drivers/NetKVM"
+ cp "$drivers/NetKVM/xp/$arch/netkvm.inf" "$dir/\$OEM\$/\$1/Drivers/NetKVM"
+ cp "$drivers/NetKVM/xp/$arch/netkvm.sys" "$dir/\$OEM\$/\$1/Drivers/NetKVM"
+
+ sed -i '/^\[SCSI.Load\]/s/$/\nviostor=viostor.sys,4/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\nviostor.sys=1,,,,,,4_,4,1,,,1,4/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[SCSI\]/s/$/\nviostor=\"Red Hat VirtIO SCSI Disk Device\"/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[HardwareIdsDatabase\]/s/$/\nPCI\\VEN_1AF4\&DEV_1001\&SUBSYS_00000000=\"viostor\"/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[HardwareIdsDatabase\]/s/$/\nPCI\\VEN_1AF4\&DEV_1001\&SUBSYS_00020000=\"viostor\"/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[HardwareIdsDatabase\]/s/$/\nPCI\\VEN_1AF4\&DEV_1001\&SUBSYS_00021AF4=\"viostor\"/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[HardwareIdsDatabase\]/s/$/\nPCI\\VEN_1AF4\&DEV_1001\&SUBSYS_00000000=\"viostor\"/' "$target/TXTSETUP.SIF"
+
+ mkdir -p "$dir/\$OEM\$/\$1/Drivers/sata"
+
+ cp -a "$drivers/sata/xp/$arch/." "$dir/\$OEM\$/\$1/Drivers/sata"
+ cp -a "$drivers/sata/xp/$arch/." "$target"
+
+ sed -i '/^\[SCSI.Load\]/s/$/\niaStor=iaStor.sys,4/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[FileFlags\]/s/$/\niaStor.sys = 16/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaStor.cat = 1,,,,,,,1,0,0/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaStor.inf = 1,,,,,,,1,0,0/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaStor.sys = 1,,,,,,4_,4,1,,,1,4/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaStor.sys = 1,,,,,,,1,0,0/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaahci.cat = 1,,,,,,,1,0,0/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaAHCI.inf = 1,,,,,,,1,0,0/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[SCSI\]/s/$/\niaStor=\"Intel\(R\) SATA RAID\/AHCI Controller\"/' "$target/TXTSETUP.SIF"
+ sed -i '/^\[HardwareIdsDatabase\]/s/$/\nPCI\\VEN_8086\&DEV_2922\&CC_0106=\"iaStor\"/' "$target/TXTSETUP.SIF"
+
+ # Windows XP Pro generic key (no activation)
+ local key="DR8GV-C8V6J-BYXHG-7PYJR-DB66Y"
+
+ local pid setup
+ setup=$(find "$target" -maxdepth 1 -type f -iname setupp.ini | head -n 1)
+ pid=$(<"$setup")
+ pid="${pid:(-4)}"
+ pid="${pid:0:3}"
+
+ if [[ "$pid" == "270" ]]; then
+ info "Warning: this ISO requires a volume license, it will reject the generic key during installation."
+ fi
+
+ find "$target" -maxdepth 1 -type f -iname winnt.sif -exec rm {} \;
+
+ { echo "[Data]"
+ echo "AutoPartition=1"
+ echo "MsDosInitiated=\"0\""
+ echo "UnattendedInstall=\"Yes\""
+ echo "AutomaticUpdates=\"Yes\""
+ echo ""
+ echo "[Unattended]"
+ echo "UnattendSwitch=Yes"
+ echo "UnattendMode=FullUnattended"
+ echo "FileSystem=NTFS"
+ echo "OemSkipEula=Yes"
+ echo "OemPreinstall=Yes"
+ echo "Repartition=Yes"
+ echo "WaitForReboot=\"No\""
+ echo "DriverSigningPolicy=\"Ignore\""
+ echo "NonDriverSigningPolicy=\"Ignore\""
+ echo "OemPnPDriversPath=\"Drivers\viostor;Drivers\NetKVM;Drivers\sata\""
+ echo "NoWaitAfterTextMode=1"
+ echo "NoWaitAfterGUIMode=1"
+ echo "FileSystem-ConvertNTFS"
+ echo "ExtendOemPartition=0"
+ echo "Hibernation=\"No\""
+ echo ""
+ echo "[GuiUnattended]"
+ echo "OEMSkipRegional=1"
+ echo "OemSkipWelcome=1"
+ echo "AdminPassword=*"
+ echo "TimeZone=0"
+ echo "AutoLogon=Yes"
+ echo "AutoLogonCount=65432"
+ echo ""
+ echo "[UserData]"
+ echo "FullName=\"Docker\""
+ echo "ComputerName=\"*\""
+ echo "OrgName=\"Windows for Docker\""
+ echo "ProductKey=$key"
+ echo ""
+ echo "[Identification]"
+ echo "JoinWorkgroup = WORKGROUP"
+ echo ""
+ echo "[Networking]"
+ echo "InstallDefaultComponents=Yes"
+ echo ""
+ echo "[Branding]"
+ echo "BrandIEUsingUnattended=Yes"
+ echo ""
+ echo "[URL]"
+ echo "Home_Page = http://www.google.com"
+ echo "Search_Page = http://www.google.com"
+ echo ""
+ echo "[RegionalSettings]"
+ echo "Language=00000409"
+ echo ""
+ echo "[TerminalServices]"
+ echo "AllowConnections=1"
+ } | unix2dos > "$target/WINNT.SIF"
+
+ { echo "Windows Registry Editor Version 5.00"
+ echo ""
+ echo "[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Security]"
+ echo "\"FirstRunDisabled\"=dword:00000001"
+ echo "\"AntiVirusOverride\"=dword:00000001"
+ echo "\"FirewallOverride\"=dword:00000001"
+ echo "\"FirewallDisableNotify\"=dword:00000001"
+ echo "\"UpdatesDisableNotify\"=dword:00000001"
+ echo "\"AntiVirusDisableNotify\"=dword:00000001"
+ echo ""
+ echo "[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\wscsvc]"
+ echo "\"Start\"=dword:00000004"
+ echo ""
+ echo "[HKEY_LOCAL_MACHINE\Software\Policies\Microsoft\WindowsFirewall\StandardProfile]"
+ echo "\"EnableFirewall\"=dword:00000000"
+ echo ""
+ echo "[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\SharedAccess]"
+ echo "\"Start\"=dword:00000004"
+ echo
+ echo "[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\SharedAccess\Parameters\FirewallPolicy\StandardProfile\GloballyOpenPorts\List]"
+ echo "\"3389:TCP\"=\"3389:TCP:*:Enabled:@xpsp2res.dll,-22009\""
+ echo ""
+ echo "[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Lsa]"
+ echo "\"LimitBlankPasswordUse\"=dword:00000000"
+ echo ""
+ echo "[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Applets\Tour]"
+ echo "\"RunCount\"=dword:00000000"
+ echo ""
+ echo "[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\Advanced]"
+ echo "\"HideFileExt\"=dword:00000000"
+ echo ""
+ echo "[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon]"
+ echo "\"DefaultUserName\"=\"Docker\""
+ echo "\"DefaultDomainName\"=\"Dockur\""
+ echo "\"AltDefaultUserName\"=\"Docker\""
+ echo "\"AltDefaultDomainName\"=\"Dockur\""
+ echo "\"AutoAdminLogon\"=\"1\""
+ } | unix2dos > "$dir/\$OEM\$/install.reg"
+
+ { echo "Set WshShell = WScript.CreateObject(\"WScript.Shell\")"
+ echo "Set WshNetwork = WScript.CreateObject(\"WScript.Network\")"
+ echo "Set oMachine = GetObject(\"WinNT://\" & WshNetwork.ComputerName)"
+ echo "Set oInfoUser = GetObject(\"WinNT://\" & WshNetwork.ComputerName & \"/Administrator,user\")"
+ echo "Set oUser = oMachine.MoveHere(oInfoUser.ADsPath,\"Docker\")"
+ } | unix2dos > "$dir/\$OEM\$/admin.vbs"
+
+ { echo "[COMMANDS]"
+ echo "\"REGEDIT /s install.reg\""
+ echo "\"Wscript admin.vbs\""
+ } | unix2dos > "$dir/\$OEM\$/cmdlines.txt"
+
+ rm -rf "$drivers"
+ return 0
+}
+
+prepareXP() {
+
+ local iso="$1"
+ local dir="$2"
+
+ MACHINE="pc-q35-2.10"
+ BOOT_MODE="windows_legacy"
+ ETFS="[BOOT]/Boot-NoEmul.img"
+
+ [[ "$MANUAL" == [Yy1]* ]] && return 0
+ configXP "$dir" && return 0
+
+ error "Failed to generate XP configuration files!" && exit 66
+}
+
+prepareLegacy() {
+
+ local iso="$1"
+ local dir="$2"
+
+ ETFS="boot.img"
+ BOOT_MODE="windows_legacy"
+
+ rm -f "$dir/$ETFS"
+
+ local len offset
+ len=$(isoinfo -d -i "$iso" | grep "Nsect " | grep -o "[^ ]*$")
+ offset=$(isoinfo -d -i "$iso" | grep "Bootoff " | grep -o "[^ ]*$")
+
+ if ! dd "if=$iso" "of=$dir/$ETFS" bs=2048 "count=$len" "skip=$offset" status=none; then
+ error "Failed to extract boot image from ISO!" && exit 67
+ fi
+
+ return 0
+}
+
+return 0
diff --git a/src/entry.sh b/src/entry.sh
index 200c591..8893716 100644
--- a/src/entry.sh
+++ b/src/entry.sh
@@ -9,6 +9,7 @@ SUPPORT="https://github.com/dockur/windows"
cd /run
. reset.sh # Initialize system
+. define.sh # Define versions
. install.sh # Run installation
. disk.sh # Initialize disks
. display.sh # Initialize graphics
@@ -28,8 +29,8 @@ info "Booting ${APP}${BOOT_DESC}..."
(( rc != 0 )) && error "$(<"$QEMU_LOG")" && exit 15
terminal
+( sleep 10; boot ) &
tail -fn +0 "$QEMU_LOG" 2>/dev/null &
-( sleep 10; [ ! -f "$QEMU_END" ] && info "Windows started succesfully, visit http://localhost:8006/ to view the screen..." ) &
cat "$QEMU_TERM" 2> /dev/null | tee "$QEMU_PTY" &
wait $! || :
diff --git a/src/install.sh b/src/install.sh
index dcf0a82..70aec16 100644
--- a/src/install.sh
+++ b/src/install.sh
@@ -1,244 +1,13 @@
#!/usr/bin/env bash
set -Eeuo pipefail
-: "${MANUAL:=""}"
-: "${VERSION:=""}"
-: "${DETECTED:=""}"
-
-[ -z "$VERSION" ] && VERSION="win11x64"
-
-if [[ "${VERSION}" == \"*\" || "${VERSION}" == \'*\' ]]; then
- VERSION="${VERSION:1:-1}"
-fi
-
-[[ "${VERSION,,}" == "11" ]] && VERSION="win11x64"
-[[ "${VERSION,,}" == "win11" ]] && VERSION="win11x64"
-
-[[ "${VERSION,,}" == "10" ]] && VERSION="win10x64"
-[[ "${VERSION,,}" == "win10" ]] && VERSION="win10x64"
-
-[[ "${VERSION,,}" == "8" ]] && VERSION="win81x64"
-[[ "${VERSION,,}" == "81" ]] && VERSION="win81x64"
-[[ "${VERSION,,}" == "8.1" ]] && VERSION="win81x64"
-[[ "${VERSION,,}" == "win8" ]] && VERSION="win81x64"
-[[ "${VERSION,,}" == "win81" ]] && VERSION="win81x64"
-
-[[ "${VERSION,,}" == "7" ]] && VERSION="win7x64"
-[[ "${VERSION,,}" == "win7" ]] && VERSION="win7x64"
-
-[[ "${VERSION,,}" == "vista" ]] && VERSION="winvistax64"
-[[ "${VERSION,,}" == "winvista" ]] && VERSION="winvistax64"
-
-[[ "${VERSION,,}" == "xp" ]] && VERSION="winxpx86"
-[[ "${VERSION,,}" == "winxp" ]] && VERSION="winxpx86"
-
-[[ "${VERSION,,}" == "22" ]] && VERSION="win2022-eval"
-[[ "${VERSION,,}" == "2022" ]] && VERSION="win2022-eval"
-[[ "${VERSION,,}" == "win22" ]] && VERSION="win2022-eval"
-[[ "${VERSION,,}" == "win2022" ]] && VERSION="win2022-eval"
-
-[[ "${VERSION,,}" == "19" ]] && VERSION="win2019-eval"
-[[ "${VERSION,,}" == "2019" ]] && VERSION="win2019-eval"
-[[ "${VERSION,,}" == "win19" ]] && VERSION="win2019-eval"
-[[ "${VERSION,,}" == "win2019" ]] && VERSION="win2019-eval"
-
-[[ "${VERSION,,}" == "16" ]] && VERSION="win2016-eval"
-[[ "${VERSION,,}" == "2016" ]] && VERSION="win2016-eval"
-[[ "${VERSION,,}" == "win16" ]] && VERSION="win2016-eval"
-[[ "${VERSION,,}" == "win2016" ]] && VERSION="win2016-eval"
-
-[[ "${VERSION,,}" == "2012" ]] && VERSION="win2012r2-eval"
-[[ "${VERSION,,}" == "win2012" ]] && VERSION="win2012r2-eval"
-
-[[ "${VERSION,,}" == "2008" ]] && VERSION="win2008r2"
-[[ "${VERSION,,}" == "win2008" ]] && VERSION="win2008r2"
-
-[[ "${VERSION,,}" == "ltsc10" ]] && VERSION="win10x64-enterprise-ltsc-eval"
-[[ "${VERSION,,}" == "10ltsc" ]] && VERSION="win10x64-enterprise-ltsc-eval"
-[[ "${VERSION,,}" == "win10-ltsc" ]] && VERSION="win10x64-enterprise-ltsc-eval"
-[[ "${VERSION,,}" == "win10x64-ltsc" ]] && VERSION="win10x64-enterprise-ltsc-eval"
-
-if [[ "${VERSION,,}" == "win10x64-enterprise-ltsc-eval" ]]; then
- DETECTED="win10x64-ltsc"
-fi
-
-if [[ "${VERSION,,}" == "win7x64" ]]; then
- DETECTED="win7x64"
- VERSION="https://dl.bobpony.com/windows/7/en_windows_7_enterprise_with_sp1_x64_dvd_u_677651.iso"
-fi
-
-if [[ "${VERSION,,}" == "winvistax64" ]]; then
- DETECTED="winvistax64"
- VERSION="https://dl.bobpony.com/windows/vista/en_windows_vista_sp2_x64_dvd_342267.iso"
-fi
-
-if [[ "${VERSION,,}" == "winxpx86" ]]; then
- DETECTED="winxpx86"
- VERSION="https://dl.bobpony.com/windows/xp/professional/en_windows_xp_professional_with_service_pack_3_x86_cd_x14-80428.iso"
-fi
-
-if [[ "${VERSION,,}" == "core11" ]]; then
- DETECTED="win11x64"
- VERSION="https://archive.org/download/tiny-11-core-x-64-beta-1/tiny11%20core%20x64%20beta%201.iso"
-fi
-
-if [[ "${VERSION,,}" == "tiny11" ]]; then
- DETECTED="win11x64"
- VERSION="https://archive.org/download/tiny11-2311/tiny11%202311%20x64.iso"
-fi
-
-if [[ "${VERSION,,}" == "tiny10" ]]; then
- DETECTED="win10x64-ltsc"
- VERSION="https://archive.org/download/tiny-10-23-h2/tiny10%20x64%2023h2.iso"
-fi
-
-CUSTOM=$(find "$STORAGE" -maxdepth 1 -type f -iname windows.iso -printf "%f\n" | head -n 1)
-[ -z "$CUSTOM" ] && CUSTOM=$(find "$STORAGE" -maxdepth 1 -type f -iname custom.iso -printf "%f\n" | head -n 1)
-[ -z "$CUSTOM" ] && CUSTOM=$(find "$STORAGE" -maxdepth 1 -type f -iname boot.iso -printf "%f\n" | head -n 1)
-[ -z "$CUSTOM" ] && CUSTOM=$(find "$STORAGE" -maxdepth 1 -type f -iname custom.img -printf "%f\n" | head -n 1)
-
-if [ -z "$CUSTOM" ] && [[ "${VERSION,,}" != "http"* ]]; then
- FN="${VERSION/\/storage\//}"
- [[ "$FN" == "."* ]] && FN="${FN:1}"
- CUSTOM=$(find "$STORAGE" -maxdepth 1 -type f -iname "$FN" -printf "%f\n" | head -n 1)
-fi
-
ESD_URL=""
-MACHINE="q35"
-PLATFORM="x64"
TMP="$STORAGE/tmp"
DIR="$TMP/unpack"
FB="falling back to manual installation!"
ETFS="boot/etfsboot.com"
EFISYS="efi/microsoft/boot/efisys_noprompt.bin"
-printVersion() {
-
- local id="$1"
- local desc="$2"
-
- [[ "$id" == "win7"* ]] && desc="Windows 7"
- [[ "$id" == "win8"* ]] && desc="Windows 8"
- [[ "$id" == "win10"* ]] && desc="Windows 10"
- [[ "$id" == "win11"* ]] && desc="Windows 11"
- [[ "$id" == "winxp"* ]] && desc="Windows XP"
- [[ "$id" == "winvista"* ]] && desc="Windows Vista"
- [[ "$id" == "win2025"* ]] && desc="Windows Server 2025"
- [[ "$id" == "win2022"* ]] && desc="Windows Server 2022"
- [[ "$id" == "win2019"* ]] && desc="Windows Server 2019"
- [[ "$id" == "win2016"* ]] && desc="Windows Server 2016"
- [[ "$id" == "win2012"* ]] && desc="Windows Server 2012"
- [[ "$id" == "win2008"* ]] && desc="Windows Server 2008"
- [[ "$id" == "win10x64-iot" ]] && desc="Windows 10 IoT"
- [[ "$id" == "win11x64-iot" ]] && desc="Windows 11 IoT"
- [[ "$id" == "win10x64-ltsc" ]] && desc="Windows 10 LTSC"
- [[ "$id" == "win11x64-ltsc" ]] && desc="Windows 11 LTSC"
- [[ "$id" == "win81x64-enterprise-eval" ]] && desc="Windows 8 Enterprise"
- [[ "$id" == "win10x64-enterprise-eval" ]] && desc="Windows 10 Enterprise"
- [[ "$id" == "win11x64-enterprise-eval" ]] && desc="Windows 11 Enterprise"
-
- [ -z "$desc" ] && desc="Windows"
-
- echo "$desc"
- return 0
-}
-
-getName() {
-
- local file="$1"
- local desc="$2"
-
- [[ "${file,,}" == "win11"* ]] && desc="Windows 11"
- [[ "${file,,}" == "win10"* ]] && desc="Windows 10"
- [[ "${file,,}" == "win8"* ]] && desc="Windows 8"
- [[ "${file,,}" == "win7"* ]] && desc="Windows 7"
- [[ "${file,,}" == "winxp"* ]] && desc="Windows XP"
- [[ "${file,,}" == "winvista"* ]] && desc="Windows Vista"
- [[ "${file,,}" == "tiny10"* ]] && desc="Tiny 10"
- [[ "${file,,}" == "tiny11"* ]] && desc="Tiny 11"
- [[ "${file,,}" == "tiny11_core"* ]] && desc="Tiny 11 Core"
- [[ "${file,,}" == *"windows11"* ]] && desc="Windows 11"
- [[ "${file,,}" == *"windows10"* ]] && desc="Windows 10"
- [[ "${file,,}" == *"windows8"* ]] && desc="Windows 8"
- [[ "${file,,}" == *"windows7"* ]] && desc="Windows 7"
- [[ "${file,,}" == *"windowsxp"* ]] && desc="Windows XP"
- [[ "${file,,}" == *"windowsvista"* ]] && desc="Windows Vista"
- [[ "${file,,}" == *"windows_11"* ]] && desc="Windows 11"
- [[ "${file,,}" == *"windows_10"* ]] && desc="Windows 10"
- [[ "${file,,}" == *"windows_8"* ]] && desc="Windows 8"
- [[ "${file,,}" == *"windows_7"* ]] && desc="Windows 7"
- [[ "${file,,}" == *"windows_xp"* ]] && desc="Windows XP"
- [[ "${file,,}" == *"windows_vista"* ]] && desc="Windows Vista"
- [[ "${file,,}" == *"server2008"* ]] && desc="Windows Server 2008"
- [[ "${file,,}" == *"server2012"* ]] && desc="Windows Server 2012"
- [[ "${file,,}" == *"server2016"* ]] && desc="Windows Server 2016"
- [[ "${file,,}" == *"server2019"* ]] && desc="Windows Server 2019"
- [[ "${file,,}" == *"server2022"* ]] && desc="Windows Server 2022"
- [[ "${file,,}" == *"server2025"* ]] && desc="Windows Server 2025"
- [[ "${file,,}" == *"server_2008"* ]] && desc="Windows Server 2008"
- [[ "${file,,}" == *"server_2012"* ]] && desc="Windows Server 2012"
- [[ "${file,,}" == *"server_2016"* ]] && desc="Windows Server 2016"
- [[ "${file,,}" == *"server_2019"* ]] && desc="Windows Server 2019"
- [[ "${file,,}" == *"server_2022"* ]] && desc="Windows Server 2022"
- [[ "${file,,}" == *"server_2025"* ]] && desc="Windows Server 2025"
-
- [ -z "$desc" ] && desc="Windows"
-
- echo "$desc"
- return 0
-}
-
-getVersion() {
-
- local name="$1"
- local detected=""
-
- [[ "${name,,}" == *"windows 7"* ]] && detected="win7x64"
- [[ "${name,,}" == *"windows vista"* ]] && detected="winvistax64"
-
- [[ "${name,,}" == *"server 2008"* ]] && detected="win2008r2"
- [[ "${name,,}" == *"server 2025"* ]] && detected="win2025-eval"
- [[ "${name,,}" == *"server 2022"* ]] && detected="win2022-eval"
- [[ "${name,,}" == *"server 2019"* ]] && detected="win2019-eval"
- [[ "${name,,}" == *"server 2016"* ]] && detected="win2016-eval"
- [[ "${name,,}" == *"server 2012"* ]] && detected="win2012r2-eval"
-
- if [[ "${name,,}" == *"windows 8"* ]]; then
- if [[ "${name,,}" == *"enterprise evaluation"* ]]; then
- detected="win81x64-enterprise-eval"
- else
- detected="win81x64"
- fi
- fi
-
- if [[ "${name,,}" == *"windows 11"* ]]; then
- if [[ "${name,,}" == *"enterprise evaluation"* ]]; then
- detected="win11x64-enterprise-eval"
- else
- detected="win11x64"
- fi
- fi
-
- if [[ "${name,,}" == *"windows 10"* ]]; then
- if [[ "${name,,}" == *" iot "* ]]; then
- detected="win10x64-iot"
- else
- if [[ "${name,,}" == *"ltsc"* ]]; then
- detected="win10x64-ltsc"
- else
- if [[ "${name,,}" == *"enterprise evaluation"* ]]; then
- detected="win10x64-enterprise-eval"
- else
- detected="win10x64"
- fi
- fi
- fi
- fi
-
- echo "$detected"
- return 0
-}
-
hasDisk() {
[ -b "${DEVICE:-}" ] && return 0
@@ -265,13 +34,13 @@ finishInstall() {
local aborted="$2"
if [ ! -s "$iso" ] || [ ! -f "$iso" ]; then
- error "Failed to find ISO: $iso" && return 1
+ error "Failed to find ISO file: $iso" && return 1
fi
if [ -w "$iso" ] && [[ "$aborted" != [Yy1]* ]]; then
# Mark ISO as prepared via magic byte
if ! printf '\x16' | dd of="$iso" bs=1 seek=0 count=1 conv=notrunc status=none; then
- error "Failed to set magic byte!" && return 1
+ error "Failed to set magic byte in ISO file: $iso" && return 1
fi
fi
@@ -282,17 +51,19 @@ finishInstall() {
cp /run/version "$STORAGE/windows.ver"
- if [[ "${BOOT_MODE,,}" == "windows_legacy" ]]; then
- if [[ "${MACHINE,,}" != "q35" ]]; then
- echo "$MACHINE" > "$STORAGE/windows.old"
- fi
- echo "$BOOT_MODE" > "$STORAGE/windows.mode"
- else
- # Enable secure boot + TPM on manual installs as Win11 requires
- if [[ "$MANUAL" == [Yy1]* ]] || [[ "$aborted" == [Yy1]* ]]; then
- if [[ "${DETECTED,,}" == "win11"* ]]; then
- BOOT_MODE="windows_secure"
- echo "$BOOT_MODE" > "$STORAGE/windows.mode"
+ if [[ "${PLATFORM,,}" == "x64" ]]; then
+ if [[ "${BOOT_MODE,,}" == "windows_legacy" ]]; then
+ echo "$BOOT_MODE" > "$STORAGE/windows.mode"
+ if [[ "${MACHINE,,}" != "q35" ]]; then
+ echo "$MACHINE" > "$STORAGE/windows.old"
+ fi
+ else
+ # Enable secure boot + TPM on manual installs as Win11 requires
+ if [[ "$MANUAL" == [Yy1]* ]] || [[ "$aborted" == [Yy1]* ]]; then
+ if [[ "${DETECTED,,}" == "win11"* ]]; then
+ BOOT_MODE="windows_secure"
+ echo "$BOOT_MODE" > "$STORAGE/windows.mode"
+ fi
fi
fi
fi
@@ -307,7 +78,7 @@ abortInstall() {
if [[ "$iso" != "$STORAGE/$BASE" ]]; then
if ! mv -f "$iso" "$STORAGE/$BASE"; then
- error "Failed to move ISO: $iso" && return 1
+ error "Failed to move ISO file: $iso" && return 1
fi
fi
@@ -331,18 +102,14 @@ startInstall() {
CUSTOM=""
- if [[ "${VERSION,,}" == "http"* ]]; then
- EXTERNAL="Y"
- else
+ if [[ "${VERSION,,}" != "http"* ]]; then
+
EXTERNAL="N"
- fi
-
- if [[ "$EXTERNAL" != [Yy1]* ]]; then
-
BASE="$VERSION.iso"
else
+ EXTERNAL="Y"
BASE=$(basename "${VERSION%%\?*}")
: "${BASE//+/ }"; printf -v BASE '%b' "${_//%/\\x}"
BASE=$(echo "$BASE" | sed -e 's/[^A-Za-z0-9._-]/_/g')
@@ -350,8 +117,13 @@ startInstall() {
fi
fi
+ if [[ "${PLATFORM,,}" == "x64" ]]; then
+ ! migrateFiles "$BASE" "$VERSION" && error "Migration failed!" && exit 57
+ fi
+
if skipInstall; then
[ ! -f "$STORAGE/$BASE" ] && BASE=""
+ [[ "${PLATFORM,,}" == "arm64" ]] && VGA="virtio-gpu"
return 1
fi
@@ -388,12 +160,29 @@ startInstall() {
return 0
}
+detectCustom() {
+
+ CUSTOM=$(find "$STORAGE" -maxdepth 1 -type f -iname windows.iso -printf "%f\n" | head -n 1)
+ [ -z "$CUSTOM" ] && CUSTOM=$(find "$STORAGE" -maxdepth 1 -type f -iname custom.iso -printf "%f\n" | head -n 1)
+ [ -z "$CUSTOM" ] && CUSTOM=$(find "$STORAGE" -maxdepth 1 -type f -iname boot.iso -printf "%f\n" | head -n 1)
+ [ -z "$CUSTOM" ] && CUSTOM=$(find "$STORAGE" -maxdepth 1 -type f -iname custom.img -printf "%f\n" | head -n 1)
+
+ if [ -z "$CUSTOM" ] && [[ "${VERSION,,}" != "http"* ]]; then
+ FN="${VERSION/\/storage\//}"
+ [[ "$FN" == "."* ]] && FN="${FN:1}"
+ CUSTOM=$(find "$STORAGE" -maxdepth 1 -type f -iname "$FN" -printf "%f\n" | head -n 1)
+ fi
+
+ return 0
+}
+
getESD() {
local dir="$1"
+ local version="$2"
local winCatalog size
- case "${VERSION,,}" in
+ case "${version,,}" in
"win11${PLATFORM,,}")
winCatalog="https://go.microsoft.com/fwlink?linkid=2156292"
;;
@@ -401,7 +190,7 @@ getESD() {
winCatalog="https://go.microsoft.com/fwlink/?LinkId=841361"
;;
*)
- error "Invalid ESD version specified: $VERSION" && return 1
+ error "Invalid VERSION specified, value \"$version\" is not recognized!" && return 1
;;
esac
@@ -412,41 +201,44 @@ getESD() {
mkdir -p "$dir"
local wFile="catalog.cab"
+ local xFile="products.xml"
+ local eFile="esd_edition.xml"
+ local fFile="products_filter.xml"
- { wget "$winCatalog" -O "$dir/$wFile" -q --no-check-certificate; rc=$?; } || :
+ { wget "$winCatalog" -O "$dir/$wFile" -q; rc=$?; } || :
(( rc != 0 )) && error "Failed to download $winCatalog , reason: $rc" && return 1
cd "$dir"
if ! cabextract "$wFile" > /dev/null; then
cd /run
- error "Failed to extract CAB file!" && return 1
+ error "Failed to extract $wFile!" && return 1
fi
cd /run
- if [ ! -s "$dir/products.xml" ]; then
- error "Failed to find products.xml!" && return 1
+ if [ ! -s "$dir/$xFile" ]; then
+ error "Failed to find $xFile in $wFile!" && return 1
fi
local esdLang="en-us"
local editionName="Professional"
local edQuery='//File[Architecture="'${PLATFORM}'"][Edition="'${editionName}'"]'
- echo -e '' > "${dir}/products_filter.xml"
- xmllint --nonet --xpath "${edQuery}" "${dir}/products.xml" >> "${dir}/products_filter.xml" 2>/dev/null
- echo -e ''>> "${dir}/products_filter.xml"
- xmllint --nonet --xpath '//File[LanguageCode="'${esdLang}'"]' "${dir}/products_filter.xml" >"${dir}/esd_edition.xml"
+ echo -e '' > "$dir/$fFile"
+ xmllint --nonet --xpath "${edQuery}" "$dir/$xFile" >> "$dir/$fFile" 2>/dev/null
+ echo -e ''>> "$dir/$fFile"
+ xmllint --nonet --xpath '//File[LanguageCode="'${esdLang}'"]' "$dir/$fFile" >"$dir/$eFile"
- size=$(stat -c%s "${dir}/esd_edition.xml")
+ size=$(stat -c%s "$dir/$eFile")
if ((size<20)); then
- error "Failed to find Windows product!" && return 1
+ error "Failed to find Windows product in $eFile!" && return 1
fi
- ESD_URL=$(xmllint --nonet --xpath '//FilePath' "${dir}/esd_edition.xml" | sed -E -e 's/<[\/]?FilePath>//g')
+ ESD_URL=$(xmllint --nonet --xpath '//FilePath' "$dir/$eFile" | sed -E -e 's/<[\/]?FilePath>//g')
if [ -z "$ESD_URL" ]; then
- error "Failed to find ESD URL!" && return 1
+ error "Failed to find ESD URL in $eFile!" && return 1
fi
rm -rf "$dir"
@@ -456,7 +248,7 @@ getESD() {
doMido() {
local iso="$1"
- local url="$2"
+ local version="$2"
local desc="$3"
local rc
@@ -468,7 +260,7 @@ doMido() {
/run/progress.sh "$iso.PART" "Downloading $desc ([P])..." &
cd "$TMP"
- { /run/mido.sh "$url"; rc=$?; } || :
+ { /run/mido.sh "${version,,}"; rc=$?; } || :
cd /run
fKill "progress.sh"
@@ -490,7 +282,7 @@ downloadFile() {
local iso="$1"
local url="$2"
local desc="$3"
- local rc progress
+ local rc progress domain
rm -f "$iso"
@@ -502,10 +294,15 @@ downloadFile() {
fi
local msg="Downloading $desc..."
+
+ domain=$(echo "$url" | awk -F/ '{print $3}')
+ domain=$(expr "$domain" : '.*\.\(.*\..*\)')
+ [[ "${domain,,}" != *"microsoft.com" ]] && msg="Downloading $desc from $domain..."
+
info "$msg" && html "$msg"
/run/progress.sh "$iso" "Downloading $desc ([P])..." &
- { wget "$url" -O "$iso" -q --no-check-certificate --show-progress "$progress"; rc=$?; } || :
+ { wget "$url" -O "$iso" -q --show-progress "$progress"; rc=$?; } || :
fKill "progress.sh"
@@ -524,70 +321,77 @@ downloadFile() {
downloadImage() {
local iso="$1"
- local url="$2"
- local rc desc
+ local version="$2"
+ local tried="n"
+ local url desc
- if [[ "$EXTERNAL" != [Yy1]* ]]; then
-
- desc=$(printVersion "$VERSION" "Windows")
-
- else
+ if [[ "${version,,}" == "http"* ]]; then
desc=$(getName "$BASE" "$BASE")
+ downloadFile "$iso" "$version" "$desc" && return 0
+ return 1
fi
- if [[ "$EXTERNAL" != [Yy1]* ]]; then
+ if ! validVersion "$version"; then
+ error "Invalid VERSION specified, value \"$version\" is not recognized!" && return 1
+ fi
- doMido "$iso" "$url" "$desc" && return 0
+ if [[ "${PLATFORM,,}" == "x64" ]]; then
+ desc=$(printVersion "$version" "Windows")
+ else
+ desc=$(printVersion "$version" "Windows for ${PLATFORM}")
+ fi
- if [[ "$VERSION" != "win10${PLATFORM,,}" ]] && [[ "$VERSION" != "win11${PLATFORM,,}" ]]; then
- return 1
+ if [[ "${PLATFORM,,}" == "x64" ]]; then
+ if isMido "$version"; then
+ tried="y"
+ doMido "$iso" "$version" "$desc" && return 0
+ fi
+ switchEdition "$version"
+ fi
+
+ if isESD "$version"; then
+
+ if [[ "$tried" != "n" ]]; then
+ info "Failed to download $desc using Mido, will try a diferent method now..."
fi
- info "Failed to download $desc using Mido, will try a different method now..."
+ tried="y"
- rm -rf "$TMP"
- mkdir -p "$TMP"
-
- ISO="$TMP/$VERSION.esd"
- iso="$ISO"
-
- if ! getESD "$TMP/esd"; then
- url=""
- else
- url="$ESD_URL"
+ if getESD "$TMP/esd" "$version"; then
+ ISO="$TMP/$version.esd"
+ downloadFile "$ISO" "$ESD_URL" "$desc" && return 0
+ ISO="$TMP/$BASE"
fi
fi
+ url=$(getLink "$version")
+
if [ -n "$url" ]; then
+
+ if [[ "$tried" != "n" ]]; then
+ info "Failed to download $desc from Microsoft, will try another mirror now..."
+ fi
+
+ tried="y"
downloadFile "$iso" "$url" "$desc" && return 0
+
fi
- [[ "$EXTERNAL" == [Yy1]* ]] && return 1
+ url=$(secondLink "$version")
- case "${VERSION,,}" in
- "win11${PLATFORM,,}")
- url="https://dl.bobpony.com/windows/11/en-us_windows_11_23h2_${PLATFORM,,}.iso"
- ;;
- "win10${PLATFORM,,}")
- url="https://dl.bobpony.com/windows/10/en-us_windows_10_22h2_${PLATFORM,,}.iso"
- ;;
- *)
- return 1
- ;;
- esac
+ if [ -n "$url" ]; then
- info "Failed to download $desc from Microsoft, will try another mirror now..."
+ if [[ "$tried" != "n" ]]; then
+ info "Failed to download $desc, will try another mirror now..."
+ fi
- rm -rf "$TMP"
- mkdir -p "$TMP"
+ tried="y"
+ downloadFile "$iso" "$url" "$desc" && return 0
- ISO="$TMP/$BASE"
- iso="$ISO"
-
- downloadFile "$iso" "$url" "$desc" && return 0
+ fi
return 1
}
@@ -596,9 +400,10 @@ extractESD() {
local iso="$1"
local dir="$2"
+ local version="$3"
+ local desc="$4"
local size size_gb space space_gb desc
- desc=$(printVersion "$VERSION" "Windows")
local msg="Extracting $desc bootdisk..."
info "$msg" && html "$msg"
@@ -623,7 +428,7 @@ extractESD() {
wimlib-imagex apply "$iso" 1 "${dir}" --quiet 2>/dev/null || {
retVal=$?
- error "Extracting bootdisk failed" && return $retVal
+ error "Extracting $desc bootdisk failed" && return $retVal
}
local bootWimFile="${dir}/sources/boot.wim"
@@ -650,7 +455,7 @@ extractESD() {
local edition imageIndex imageEdition
- case "${VERSION,,}" in
+ case "${version,,}" in
"win11${PLATFORM,,}")
edition="11 pro"
;;
@@ -658,7 +463,7 @@ extractESD() {
edition="10 pro"
;;
*)
- error "Invalid version specified: $VERSION" && return 1
+ error "Invalid VERSION specified, value \"$version\" is not recognized!" && return 1
;;
esac
@@ -667,7 +472,7 @@ extractESD() {
[[ "${imageEdition,,}" != *"$edition"* ]] && continue
wimlib-imagex export "${iso}" ${imageIndex} "${installWimFile}" --compress=LZMS --chunk-size 128K --quiet || {
retVal=$?
- error "Addition of ${imageIndex} to the image failed" && return $retVal
+ error "Addition of ${imageIndex} to the $desc image failed" && return $retVal
}
return 0
done
@@ -679,16 +484,17 @@ extractImage() {
local iso="$1"
local dir="$2"
+ local version="$3"
local desc="downloaded ISO"
local size size_gb space space_gb
- if [[ "${iso,,}" == *".esd" ]]; then
- extractESD "$iso" "$dir" && return 0
- return 1
+ if [[ "$EXTERNAL" != [Yy1]* ]] && [ -z "$CUSTOM" ]; then
+ desc=$(printVersion "$version" "downloaded ISO")
fi
- if [[ "$EXTERNAL" != [Yy1]* ]] && [ -z "$CUSTOM" ]; then
- desc=$(printVersion "$VERSION" "downloaded ISO")
+ if [[ "${iso,,}" == *".esd" ]]; then
+ extractESD "$iso" "$dir" "$version" "$desc" && return 0
+ return 1
fi
local msg="Extracting $desc image..."
@@ -723,6 +529,7 @@ extractImage() {
detectImage() {
XML=""
+ local dsc
local dir="$1"
if [ -n "$CUSTOM" ]; then
@@ -742,10 +549,9 @@ detectImage() {
if [[ "${DETECTED,,}" != "winxp"* ]]; then
- local dsc
dsc=$(printVersion "$DETECTED" "$DETECTED")
- warn "got $dsc, but no matching XML file exists, $FB."
+ warn "got $dsc, but no matching file called $DETECTED.xml exists, $FB."
fi
return 0
@@ -753,16 +559,24 @@ detectImage() {
info "Detecting Windows version from ISO image..."
- if [ -f "$dir/WIN51" ] || [ -f "$dir/SETUPXP.HTM" ]; then
- DETECTED="winxpx86"
- info "Detected: Windows XP" && return 0
+ if [[ "${PLATFORM,,}" == "x64" ]]; then
+ if [ -f "$dir/WIN51" ] || [ -f "$dir/SETUPXP.HTM" ]; then
+ if [ -d "$dir/AMD64" ]; then
+ DETECTED="winxpx64"
+ else
+ DETECTED="winxpx86"
+ fi
+ dsc=$(printVersion "$DETECTED" "$DETECTED")
+ info "Detected: $dsc"
+ return 0
+ fi
fi
local src loc tag result name name2 desc
src=$(find "$dir" -maxdepth 1 -type d -iname sources | head -n 1)
if [ ! -d "$src" ]; then
- BOOT_MODE="windows_legacy"
+ [[ "${PLATFORM,,}" == "x64" ]] && BOOT_MODE="windows_legacy"
warn "failed to locate 'sources' folder in ISO image, $FB" && return 1
fi
@@ -770,7 +584,7 @@ detectImage() {
[ ! -f "$loc" ] && loc=$(find "$src" -maxdepth 1 -type f -iname install.esd | head -n 1)
if [ ! -f "$loc" ]; then
- BOOT_MODE="windows_legacy"
+ [[ "${PLATFORM,,}" == "x64" ]] && BOOT_MODE="windows_legacy"
warn "failed to locate 'install.wim' or 'install.esd' in ISO image, $FB" && return 1
fi
@@ -798,206 +612,7 @@ detectImage() {
[[ "$MANUAL" != [Yy1]* ]] && XML="$DETECTED.xml"
info "Detected: $desc"
else
- warn "detected $desc, but no matching XML file exists, $FB."
- fi
-
- return 0
-}
-
-prepareXP() {
-
- local iso="$1"
- local dir="$2"
- local arch="x86"
- local target="$dir/I386"
-
- if [ -d "$dir/AMD64" ]; then
- arch="amd64"
- target="$dir/AMD64"
- fi
-
- MACHINE="pc-q35-2.10"
- BOOT_MODE="windows_legacy"
- ETFS="[BOOT]/Boot-NoEmul.img"
-
- [[ "$MANUAL" == [Yy1]* ]] && return 0
-
- local drivers="$TMP/drivers"
- rm -rf "$drivers"
-
- if ! 7z x /run/drivers.iso -o"$drivers" > /dev/null; then
- error "Failed to extract driver ISO file!" && exit 66
- fi
-
- cp "$drivers/viostor/xp/$arch/viostor.sys" "$target"
-
- mkdir -p "$dir/\$OEM\$/\$1/Drivers/viostor"
- cp "$drivers/viostor/xp/$arch/viostor.cat" "$dir/\$OEM\$/\$1/Drivers/viostor"
- cp "$drivers/viostor/xp/$arch/viostor.inf" "$dir/\$OEM\$/\$1/Drivers/viostor"
- cp "$drivers/viostor/xp/$arch/viostor.sys" "$dir/\$OEM\$/\$1/Drivers/viostor"
-
- mkdir -p "$dir/\$OEM\$/\$1/Drivers/NetKVM"
- cp "$drivers/NetKVM/xp/$arch/netkvm.cat" "$dir/\$OEM\$/\$1/Drivers/NetKVM"
- cp "$drivers/NetKVM/xp/$arch/netkvm.inf" "$dir/\$OEM\$/\$1/Drivers/NetKVM"
- cp "$drivers/NetKVM/xp/$arch/netkvm.sys" "$dir/\$OEM\$/\$1/Drivers/NetKVM"
-
- sed -i '/^\[SCSI.Load\]/s/$/\nviostor=viostor.sys,4/' "$target/TXTSETUP.SIF"
- sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\nviostor.sys=1,,,,,,4_,4,1,,,1,4/' "$target/TXTSETUP.SIF"
- sed -i '/^\[SCSI\]/s/$/\nviostor=\"Red Hat VirtIO SCSI Disk Device\"/' "$target/TXTSETUP.SIF"
- sed -i '/^\[HardwareIdsDatabase\]/s/$/\nPCI\\VEN_1AF4\&DEV_1001\&SUBSYS_00000000=\"viostor\"/' "$target/TXTSETUP.SIF"
- sed -i '/^\[HardwareIdsDatabase\]/s/$/\nPCI\\VEN_1AF4\&DEV_1001\&SUBSYS_00020000=\"viostor\"/' "$target/TXTSETUP.SIF"
- sed -i '/^\[HardwareIdsDatabase\]/s/$/\nPCI\\VEN_1AF4\&DEV_1001\&SUBSYS_00021AF4=\"viostor\"/' "$target/TXTSETUP.SIF"
- sed -i '/^\[HardwareIdsDatabase\]/s/$/\nPCI\\VEN_1AF4\&DEV_1001\&SUBSYS_00000000=\"viostor\"/' "$target/TXTSETUP.SIF"
-
- mkdir -p "$dir/\$OEM\$/\$1/Drivers/sata"
-
- cp -a "$drivers/sata/xp/$arch/." "$dir/\$OEM\$/\$1/Drivers/sata"
- cp -a "$drivers/sata/xp/$arch/." "$target"
-
- sed -i '/^\[SCSI.Load\]/s/$/\niaStor=iaStor.sys,4/' "$target/TXTSETUP.SIF"
- sed -i '/^\[FileFlags\]/s/$/\niaStor.sys = 16/' "$target/TXTSETUP.SIF"
- sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaStor.cat = 1,,,,,,,1,0,0/' "$target/TXTSETUP.SIF"
- sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaStor.inf = 1,,,,,,,1,0,0/' "$target/TXTSETUP.SIF"
- sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaStor.sys = 1,,,,,,4_,4,1,,,1,4/' "$target/TXTSETUP.SIF"
- sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaStor.sys = 1,,,,,,,1,0,0/' "$target/TXTSETUP.SIF"
- sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaahci.cat = 1,,,,,,,1,0,0/' "$target/TXTSETUP.SIF"
- sed -i '/^\[SourceDisksFiles.'"$arch"'\]/s/$/\niaAHCI.inf = 1,,,,,,,1,0,0/' "$target/TXTSETUP.SIF"
- sed -i '/^\[SCSI\]/s/$/\niaStor=\"Intel\(R\) SATA RAID\/AHCI Controller\"/' "$target/TXTSETUP.SIF"
- sed -i '/^\[HardwareIdsDatabase\]/s/$/\nPCI\\VEN_8086\&DEV_2922\&CC_0106=\"iaStor\"/' "$target/TXTSETUP.SIF"
-
- # Windows XP Pro generic key (no activation)
- local key="DR8GV-C8V6J-BYXHG-7PYJR-DB66Y"
-
- find "$target" -maxdepth 1 -type f -iname winnt.sif -exec rm {} \;
-
- { echo "[Data]"
- echo "AutoPartition=1"
- echo "MsDosInitiated=\"0\""
- echo "UnattendedInstall=\"Yes\""
- echo "AutomaticUpdates=\"Yes\""
- echo ""
- echo "[Unattended]"
- echo "UnattendSwitch=Yes"
- echo "UnattendMode=FullUnattended"
- echo "FileSystem=NTFS"
- echo "OemSkipEula=Yes"
- echo "OemPreinstall=Yes"
- echo "Repartition=Yes"
- echo "WaitForReboot=\"No\""
- echo "DriverSigningPolicy=\"Ignore\""
- echo "NonDriverSigningPolicy=\"Ignore\""
- echo "OemPnPDriversPath=\"Drivers\viostor;Drivers\NetKVM;Drivers\sata\""
- echo "NoWaitAfterTextMode=1"
- echo "NoWaitAfterGUIMode=1"
- echo "FileSystem-ConvertNTFS"
- echo "ExtendOemPartition=0"
- echo "Hibernation=\"No\""
- echo ""
- echo "[GuiUnattended]"
- echo "OEMSkipRegional=1"
- echo "OemSkipWelcome=1"
- echo "AdminPassword=*"
- echo "TimeZone=0"
- echo "AutoLogon=Yes"
- echo "AutoLogonCount=65432"
- echo ""
- echo "[UserData]"
- echo "FullName=\"Docker\""
- echo "ComputerName=\"*\""
- echo "OrgName=\"Windows for Docker\""
- echo "ProductKey=$key"
- echo ""
- echo "[Identification]"
- echo "JoinWorkgroup = WORKGROUP"
- echo ""
- echo "[Networking]"
- echo "InstallDefaultComponents=Yes"
- echo ""
- echo "[Branding]"
- echo "BrandIEUsingUnattended=Yes"
- echo ""
- echo "[URL]"
- echo "Home_Page = http://www.google.com"
- echo "Search_Page = http://www.google.com"
- echo ""
- echo "[RegionalSettings]"
- echo "Language=00000409"
- echo ""
- echo "[TerminalServices]"
- echo "AllowConnections=1"
- } | unix2dos > "$target/WINNT.SIF"
-
- { echo "Windows Registry Editor Version 5.00"
- echo ""
- echo "[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Security]"
- echo "\"FirstRunDisabled\"=dword:00000001"
- echo "\"AntiVirusOverride\"=dword:00000001"
- echo "\"FirewallOverride\"=dword:00000001"
- echo "\"FirewallDisableNotify\"=dword:00000001"
- echo "\"UpdatesDisableNotify\"=dword:00000001"
- echo "\"AntiVirusDisableNotify\"=dword:00000001"
- echo ""
- echo "[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\wscsvc]"
- echo "\"Start\"=dword:00000004"
- echo ""
- echo "[HKEY_LOCAL_MACHINE\Software\Policies\Microsoft\WindowsFirewall\StandardProfile]"
- echo "\"EnableFirewall\"=dword:00000000"
- echo ""
- echo "[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\SharedAccess]"
- echo "\"Start\"=dword:00000004"
- echo
- echo "[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\SharedAccess\Parameters\FirewallPolicy\StandardProfile\GloballyOpenPorts\List]"
- echo "\"3389:TCP\"=\"3389:TCP:*:Enabled:@xpsp2res.dll,-22009\""
- echo ""
- echo "[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Lsa]"
- echo "\"LimitBlankPasswordUse\"=dword:00000000"
- echo ""
- echo "[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Applets\Tour]"
- echo "\"RunCount\"=dword:00000000"
- echo ""
- echo "[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\Advanced]"
- echo "\"HideFileExt\"=dword:00000000"
- echo ""
- echo "[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon]"
- echo "\"DefaultUserName\"=\"Docker\""
- echo "\"DefaultDomainName\"=\"Dockur\""
- echo "\"AltDefaultUserName\"=\"Docker\""
- echo "\"AltDefaultDomainName\"=\"Dockur\""
- echo "\"AutoAdminLogon\"=\"1\""
- } | unix2dos > "$dir/\$OEM\$/install.reg"
-
- { echo "Set WshShell = WScript.CreateObject(\"WScript.Shell\")"
- echo "Set WshNetwork = WScript.CreateObject(\"WScript.Network\")"
- echo "Set oMachine = GetObject(\"WinNT://\" & WshNetwork.ComputerName)"
- echo "Set oInfoUser = GetObject(\"WinNT://\" & WshNetwork.ComputerName & \"/Administrator,user\")"
- echo "Set oUser = oMachine.MoveHere(oInfoUser.ADsPath,\"Docker\")"
- } | unix2dos > "$dir/\$OEM\$/admin.vbs"
-
- { echo "[COMMANDS]"
- echo "\"REGEDIT /s install.reg\""
- echo "\"Wscript admin.vbs\""
- } | unix2dos > "$dir/\$OEM\$/cmdlines.txt"
-
- rm -rf "$drivers"
- return 0
-}
-
-prepareLegacy() {
-
- local iso="$1"
- local dir="$2"
-
- ETFS="boot.img"
- BOOT_MODE="windows_legacy"
-
- rm -f "$dir/$ETFS"
-
- local len offset
- len=$(isoinfo -d -i "$iso" | grep "Nsect " | grep -o "[^ ]*$")
- offset=$(isoinfo -d -i "$iso" | grep "Bootoff " | grep -o "[^ ]*$")
-
- if ! dd "if=$iso" "of=$dir/$ETFS" bs=2048 "count=$len" "skip=$offset" status=none; then
- error "Failed to extract boot image from ISO!" && exit 67
+ warn "detected $desc, but no matching file called $DETECTED.xml exists, $FB."
fi
return 0
@@ -1026,6 +641,8 @@ prepareImage() {
fi
fi
+ [[ "${PLATFORM,,}" == "arm64" ]] && return 1
+
if [[ "${DETECTED,,}" == "winxp"* ]]; then
if ! prepareXP "$iso" "$dir"; then
error "Failed to prepare Windows XP ISO!" && return 1
@@ -1044,7 +661,7 @@ updateImage() {
local iso="$1"
local dir="$2"
local asset="/run/assets/$3"
- local path src loc index result
+ local path src loc xml index result
[ ! -s "$asset" ] || [ ! -f "$asset" ] && return 0
@@ -1054,7 +671,7 @@ updateImage() {
src=$(find "$dir" -maxdepth 1 -type d -iname sources | head -n 1)
if [ ! -d "$src" ]; then
- BOOT_MODE="windows_legacy"
+ [[ "${PLATFORM,,}" == "x64" ]] && BOOT_MODE="windows_legacy"
warn "failed to locate 'sources' folder in ISO image, $FB" && return 1
fi
@@ -1062,11 +679,12 @@ updateImage() {
[ ! -f "$loc" ] && loc=$(find "$src" -maxdepth 1 -type f -iname boot.esd | head -n 1)
if [ ! -f "$loc" ]; then
- BOOT_MODE="windows_legacy"
+ [[ "${PLATFORM,,}" == "x64" ]] && BOOT_MODE="windows_legacy"
warn "failed to locate 'boot.wim' or 'boot.esd' in ISO image, $FB" && return 1
fi
- info "Adding XML file for automatic installation..."
+ xml=$(basename "$asset")
+ info "Adding $xml for automatic installation..."
index="1"
result=$(wimlib-imagex info -xml "$loc" | tr -d '\000')
@@ -1076,7 +694,7 @@ updateImage() {
fi
if ! wimlib-imagex update "$loc" "$index" --command "add $asset /autounattend.xml" > /dev/null; then
- warn "failed to add XML to ISO image, $FB" && return 1
+ warn "failed to add $xml to ISO image, $FB" && return 1
fi
return 0
@@ -1185,23 +803,25 @@ buildImage() {
bootWindows() {
+ rm -rf "$TMP"
+
if [ -s "$STORAGE/windows.mode" ] && [ -f "$STORAGE/windows.mode" ]; then
BOOT_MODE=$(<"$STORAGE/windows.mode")
if [ -s "$STORAGE/windows.old" ] && [ -f "$STORAGE/windows.old" ]; then
- MACHINE=$(<"$STORAGE/windows.old")
+ [[ "${PLATFORM,,}" == "x64" ]] && MACHINE=$(<"$STORAGE/windows.old")
fi
- rm -rf "$TMP"
return 0
fi
# Migrations
+ [[ "${PLATFORM,,}" != "x64" ]] && return 0
+
if [ -f "$STORAGE/windows.old" ]; then
MACHINE=$(<"$STORAGE/windows.old")
[ -z "$MACHINE" ] && MACHINE="q35"
BOOT_MODE="windows_legacy"
echo "$BOOT_MODE" > "$STORAGE/windows.mode"
- rm -rf "$TMP"
return 0
fi
@@ -1227,12 +847,14 @@ bootWindows() {
fi
fi
- rm -rf "$TMP"
return 0
}
######################################
+! parseVersion && exit 58
+! detectCustom && exit 59
+
if ! startInstall; then
bootWindows && return 0
exit 68
@@ -1240,13 +862,13 @@ fi
if [ ! -s "$ISO" ] || [ ! -f "$ISO" ]; then
if ! downloadImage "$ISO" "$VERSION"; then
- rm -f "$ISO"
+ rm -f "$ISO" 2> /dev/null || true
exit 61
fi
fi
-if ! extractImage "$ISO" "$DIR"; then
- rm -f "$ISO"
+if ! extractImage "$ISO" "$DIR" "$VERSION"; then
+ rm -f "$ISO" 2> /dev/null || true
exit 62
fi
diff --git a/src/mido.sh b/src/mido.sh
index 642c7e9..3c3d1db 100644
--- a/src/mido.sh
+++ b/src/mido.sh
@@ -673,9 +673,6 @@ ending_summary() {
for media in $media_download_failed_list; do
media_download_failed_argument_list="$media_download_failed_argument_list ${media%%.iso}"
done
-
- # shellcheck disable=SC2086
- echo_err "Attempted download failed!"
fi
# Exit codes
diff --git a/src/power.sh b/src/power.sh
index 7326f86..0b500fc 100644
--- a/src/power.sh
+++ b/src/power.sh
@@ -23,6 +23,21 @@ _trap() {
done
}
+boot() {
+
+ [ -f "$QEMU_END" ] && return 0
+
+ if [ -s "$QEMU_PTY" ]; then
+ if grep -iq " hard" "$QEMU_PTY"; then
+ info "Windows started succesfully, visit http://localhost:8006/ to view the screen..."
+ return 0
+ fi
+ fi
+
+ error "Timeout while waiting for QEMU to boot the machine!"
+ return 0
+}
+
ready() {
[ -f "$STORAGE/windows.boot" ] && return 0