mirror of
https://github.com/cmderdev/cmder.git
synced 2025-07-16 12:39:38 +08:00
Compare commits
29 Commits
v1.3.25
...
vagrant+pa
Author | SHA1 | Date | |
---|---|---|---|
396a9a0890 | |||
1ad836b288 | |||
320f928830 | |||
e0915777c0 | |||
23d3add2d1 | |||
1c399c470f | |||
65d6ecb9f1 | |||
5cb8705f65 | |||
aa56c778cb | |||
eae0a22782 | |||
2a62a045d9 | |||
b4ed3bac6d | |||
739dcb1f8c | |||
ce69566201 | |||
ffda6f70f7 | |||
95c833204f | |||
5d270b477c | |||
91939db852 | |||
e8d5528e5e | |||
0aad7daca3 | |||
80888644cc | |||
600552f061 | |||
bc0db6a7b6 | |||
eb2444d04a | |||
f318bcc1b5 | |||
c56559873c | |||
e33713a93f | |||
324aaf74f2 | |||
d73f9592d8 |
14
.github/workflows/build.yml
vendored
14
.github/workflows/build.yml
vendored
@ -11,7 +11,7 @@ on:
|
|||||||
tags:
|
tags:
|
||||||
- "v*"
|
- "v*"
|
||||||
pull_request:
|
pull_request:
|
||||||
branches: [ "master", "development" ]
|
branches: [ "master" ]
|
||||||
|
|
||||||
#---------------------------------#
|
#---------------------------------#
|
||||||
# environment configuration #
|
# environment configuration #
|
||||||
@ -40,7 +40,7 @@ jobs:
|
|||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Add MSBuild to PATH
|
- name: Add MSBuild to PATH
|
||||||
uses: microsoft/setup-msbuild@v2
|
uses: microsoft/setup-msbuild@v1
|
||||||
|
|
||||||
- name: Build Cmder Launcher
|
- name: Build Cmder Launcher
|
||||||
shell: pwsh
|
shell: pwsh
|
||||||
@ -53,32 +53,32 @@ jobs:
|
|||||||
run: .\pack.ps1 -verbose
|
run: .\pack.ps1 -verbose
|
||||||
|
|
||||||
- name: Upload artifact (cmder.zip)
|
- name: Upload artifact (cmder.zip)
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
path: build/cmder.zip
|
path: build/cmder.zip
|
||||||
name: cmder.zip
|
name: cmder.zip
|
||||||
if-no-files-found: error
|
if-no-files-found: error
|
||||||
|
|
||||||
- name: Upload artifact (cmder.7z)
|
- name: Upload artifact (cmder.7z)
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
path: build/cmder.7z
|
path: build/cmder.7z
|
||||||
name: cmder.7z
|
name: cmder.7z
|
||||||
|
|
||||||
- name: Upload artifact (cmder_mini.zip)
|
- name: Upload artifact (cmder_mini.zip)
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
path: build/cmder_mini.zip
|
path: build/cmder_mini.zip
|
||||||
name: cmder_mini.zip
|
name: cmder_mini.zip
|
||||||
|
|
||||||
- name: Upload artifact (hashes.txt)
|
- name: Upload artifact (hashes.txt)
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
path: build/hashes.txt
|
path: build/hashes.txt
|
||||||
name: hashes.txt
|
name: hashes.txt
|
||||||
|
|
||||||
- name: Create Release
|
- name: Create Release
|
||||||
uses: softprops/action-gh-release@v2
|
uses: softprops/action-gh-release@v1
|
||||||
with:
|
with:
|
||||||
files: |
|
files: |
|
||||||
build/cmder.zip
|
build/cmder.zip
|
||||||
|
10
.github/workflows/codeql.yml
vendored
10
.github/workflows/codeql.yml
vendored
@ -8,7 +8,7 @@ name: "CodeQL"
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: [ "master", "development" ]
|
branches: [ "master" ]
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- '**/*.md'
|
- '**/*.md'
|
||||||
- '**/*.txt'
|
- '**/*.txt'
|
||||||
@ -16,7 +16,7 @@ on:
|
|||||||
- '**/.gitignore'
|
- '**/.gitignore'
|
||||||
pull_request:
|
pull_request:
|
||||||
# The branches below must be a subset of the branches above
|
# The branches below must be a subset of the branches above
|
||||||
branches: [ "master", "development" ]
|
branches: [ "master" ]
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- '**/*.md'
|
- '**/*.md'
|
||||||
- '**/*.txt'
|
- '**/*.txt'
|
||||||
@ -49,7 +49,7 @@ jobs:
|
|||||||
|
|
||||||
# Initializes the CodeQL tools for scanning.
|
# Initializes the CodeQL tools for scanning.
|
||||||
- name: Initialize CodeQL
|
- name: Initialize CodeQL
|
||||||
uses: github/codeql-action/init@v3
|
uses: github/codeql-action/init@v2
|
||||||
with:
|
with:
|
||||||
languages: ${{ matrix.language }}
|
languages: ${{ matrix.language }}
|
||||||
# If you wish to specify custom queries, you can do so here or in a config file.
|
# If you wish to specify custom queries, you can do so here or in a config file.
|
||||||
@ -60,7 +60,7 @@ jobs:
|
|||||||
# queries: security-extended,security-and-quality
|
# queries: security-extended,security-and-quality
|
||||||
|
|
||||||
- name: Add MSBuild to PATH
|
- name: Add MSBuild to PATH
|
||||||
uses: microsoft/setup-msbuild@v2
|
uses: microsoft/setup-msbuild@v1
|
||||||
|
|
||||||
- name: Build Cmder Launcher
|
- name: Build Cmder Launcher
|
||||||
shell: pwsh
|
shell: pwsh
|
||||||
@ -68,6 +68,6 @@ jobs:
|
|||||||
run: .\build.ps1 -Compile -verbose
|
run: .\build.ps1 -Compile -verbose
|
||||||
|
|
||||||
- name: Perform CodeQL Analysis
|
- name: Perform CodeQL Analysis
|
||||||
uses: github/codeql-action/analyze@v3
|
uses: github/codeql-action/analyze@v2
|
||||||
with:
|
with:
|
||||||
category: "/language:${{matrix.language}}"
|
category: "/language:${{matrix.language}}"
|
||||||
|
2
.github/workflows/tests.yml
vendored
2
.github/workflows/tests.yml
vendored
@ -4,7 +4,6 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- master
|
- master
|
||||||
- development
|
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- '**/*.md'
|
- '**/*.md'
|
||||||
- '**/*.txt'
|
- '**/*.txt'
|
||||||
@ -13,7 +12,6 @@ on:
|
|||||||
pull_request:
|
pull_request:
|
||||||
branches:
|
branches:
|
||||||
- master
|
- master
|
||||||
- development
|
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- '**/*.md'
|
- '**/*.md'
|
||||||
- '**/*.txt'
|
- '**/*.txt'
|
||||||
|
2
.github/workflows/vendor.yml
vendored
2
.github/workflows/vendor.yml
vendored
@ -51,7 +51,7 @@ jobs:
|
|||||||
Set-GHVariable -Name LIST_UPDATED -Value $listUpdated.Trim(', ')
|
Set-GHVariable -Name LIST_UPDATED -Value $listUpdated.Trim(', ')
|
||||||
echo "UPDATE_MESSAGE<<<EOF`n$updateMessage`n<EOF" | Out-File -FilePath $env:GITHUB_ENV -Append -Encoding utf8
|
echo "UPDATE_MESSAGE<<<EOF`n$updateMessage`n<EOF" | Out-File -FilePath $env:GITHUB_ENV -Append -Encoding utf8
|
||||||
|
|
||||||
- uses: peter-evans/create-pull-request@v6
|
- uses: peter-evans/create-pull-request@v5
|
||||||
if: env.COUNT_UPDATED > 0
|
if: env.COUNT_UPDATED > 0
|
||||||
with:
|
with:
|
||||||
title: 'Updates to `${{ env.COUNT_UPDATED }}` vendored dependencies'
|
title: 'Updates to `${{ env.COUNT_UPDATED }}` vendored dependencies'
|
||||||
|
7
.gitignore
vendored
7
.gitignore
vendored
@ -31,3 +31,10 @@ launcher/src/version.rc2
|
|||||||
.vs/*
|
.vs/*
|
||||||
.vscode
|
.vscode
|
||||||
.idea
|
.idea
|
||||||
|
.vagrant/
|
||||||
|
scripts/packer/iso/*.iso
|
||||||
|
!scripts/packer/floppy/*.exe
|
||||||
|
scripts/packer/packer_cache
|
||||||
|
scripts/packer/output-*
|
||||||
|
*.box
|
||||||
|
|
||||||
|
66
Vagrantfile
vendored
Normal file
66
Vagrantfile
vendored
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
required_plugins = %w( vagrant-vbguest )
|
||||||
|
required_plugins.each do |plugin|
|
||||||
|
unless Vagrant.has_plugin? plugin
|
||||||
|
system "vagrant plugin install #{plugin}"
|
||||||
|
p "Run 'vagrant up' again to continue."
|
||||||
|
exit 0
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
Vagrant.configure("2") do |config|
|
||||||
|
# config.vbguest.iso_path = "../../../../usr/share/virtualbox/VBoxGuestAdditions.iso"
|
||||||
|
config.vbguest.allow_downgrade = true
|
||||||
|
|
||||||
|
config.vm.define "cmderdev-10" do |b|
|
||||||
|
b.vm.hostname = "cmderdev-10"
|
||||||
|
b.vm.box = "dgames/cmderdev-10"
|
||||||
|
b.vm.box_version = "1.0.0"
|
||||||
|
|
||||||
|
b.vm.provider :virtualbox do |v|
|
||||||
|
# v.customize ["modifyvm", :id, "--natdnshostresolver1", "on"]
|
||||||
|
v.customize ["modifyvm", :id, "--name", "cmderdev-10"]
|
||||||
|
v.customize ["modifyvm", :id, "--ostype", "Windows10_64"]
|
||||||
|
v.customize ["modifyvm", :id, "--graphicscontroller", "vboxsvga"]
|
||||||
|
v.customize ["modifyvm", :id, "--memory", 2048]
|
||||||
|
v.customize ["modifyvm", :id, "--clipboard", "bidirectional"]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
config.vm.define "cmderdev-10s" do |b|
|
||||||
|
b.vm.hostname = 'cmderdev-10'
|
||||||
|
b.vm.box = "dgames/cmderdev-10"
|
||||||
|
b.vm.box_version = "1.0.0"
|
||||||
|
|
||||||
|
b.vm.provider :virtualbox do |v|
|
||||||
|
# v.customize ["modifyvm", :id, "--natdnshostresolver1", "on"]
|
||||||
|
v.customize ["modifyvm", :id, "--name", "cmderdev-10s"]
|
||||||
|
v.customize ["modifyvm", :id, "--ostype", "Windows10_64"]
|
||||||
|
v.customize ["modifyvm", :id, "--graphicscontroller", "vboxsvga"]
|
||||||
|
v.customize ["modifyvm", :id, "--memory", 2048]
|
||||||
|
v.customize ["modifyvm", :id, "--clipboard", "bidirectional"]
|
||||||
|
v.customize ["setextradata", :id, "GUI/ScaleFactor", "1.75"]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
config.vm.define "cmderdev-11" do |b|
|
||||||
|
b.vm.box = "dgames/cmderdev-11"
|
||||||
|
b.vm.box_version = "1.0.0"
|
||||||
|
|
||||||
|
b.vm.provider :virtualbox do |v|
|
||||||
|
# v.customize ["modifyvm", :id, "--natdnshostresolver1", "on"]
|
||||||
|
v.customize ["modifyvm", :id, "--name", "cmderdev-11"]
|
||||||
|
v.customize ["modifyvm", :id, "--ostype", "Windows11_64"]
|
||||||
|
v.customize ["modifyvm", :id, "--graphicscontroller", "vboxvga"]
|
||||||
|
v.customize ["modifyvm", :id, "--memory", 4096]
|
||||||
|
v.customize ["modifyvm", :id, "--clipboard", "bidirectional"]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
config.vm.provision "file", source: "./scripts/vagrant/windows_terminal_settings.json.default", destination: "windows_terminal_settings.json.default"
|
||||||
|
config.vm.provision "file", source: "./scripts/vagrant/windows_terminal_state.json.default", destination: "windows_terminal_state.json.default"
|
||||||
|
config.vm.provision "file", source: "./vendor/bin/set-shortcut.ps1", destination: "c:\\windows\\set-shortcut.ps1"
|
||||||
|
config.vm.provision "shell", path: './scripts/vagrant/add-cmder.ps1'
|
||||||
|
config.vm.provision "shell", path: './vendor/bin/add-vscodeprofile.ps1'
|
||||||
|
config.vm.provision "shell", path: './vendor/bin/add-windowsterminalprofiles.ps1'
|
||||||
|
config.vm.provision "shell", path: './vendor/bin/add-cmdertodesktop.ps1'
|
||||||
|
end
|
@ -469,6 +469,9 @@ void StartCmder(std::wstring path = L"", bool is_single_mode = false, std::wstr
|
|||||||
MessageBox(NULL, _T("Unable to create the ConEmu process!"), _T("Error"), MB_OK);
|
MessageBox(NULL, _T("Unable to create the ConEmu process!"), _T("Error"), MB_OK);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LRESULT lr = SendMessageTimeout(HWND_BROADCAST, WM_SETTINGCHANGE, 0, (LPARAM)"Environment", SMTO_ABORTIFHUNG | SMTO_NOTIMEOUTIFNOTHUNG, 5000, NULL);
|
||||||
|
lr = SendMessageTimeout(HWND_BROADCAST, WM_SETTINGCHANGE, 0, (LPARAM)L"Environment", SMTO_ABORTIFHUNG | SMTO_NOTIMEOUTIFNOTHUNG, 5000, NULL); // For Windows >= 8
|
||||||
}
|
}
|
||||||
|
|
||||||
bool IsUserOnly(std::wstring opt)
|
bool IsUserOnly(std::wstring opt)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* WARNING: do NOT modify this file! the content of this file should be
|
* WARNING: do NOT modify this file! the content of this file should be
|
||||||
* automatically generated before AppVeyor builds using the
|
* automatically genereted before AppVeyor builds using the
|
||||||
* respective .ps1 Powershell scripts.
|
* respective .ps1 Powershell scripts.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@ -25,3 +25,5 @@ vendor\git-prompt.sh
|
|||||||
config\user-*
|
config\user-*
|
||||||
clink_history*
|
clink_history*
|
||||||
*.log
|
*.log
|
||||||
|
Vagrantfile
|
||||||
|
*.box
|
||||||
|
@ -79,7 +79,7 @@ if ($Compile) {
|
|||||||
|
|
||||||
Write-Verbose "Building the launcher..."
|
Write-Verbose "Building the launcher..."
|
||||||
|
|
||||||
# Reference: https://docs.microsoft.com/visualstudio/msbuild/msbuild-command-line-reference
|
# Referene: https://docs.microsoft.com/visualstudio/msbuild/msbuild-command-line-reference
|
||||||
msbuild CmderLauncher.vcxproj /t:Clean,Build /p:configuration=Release /m
|
msbuild CmderLauncher.vcxproj /t:Clean,Build /p:configuration=Release /m
|
||||||
|
|
||||||
if ($LastExitCode -ne 0) {
|
if ($LastExitCode -ne 0) {
|
||||||
|
8
scripts/packer/README.md
Normal file
8
scripts/packer/README.md
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# Packer Support - Release Notes
|
||||||
|
|
||||||
|
Most of the Packer support for Cmder is shamelessly being borrowed from the following repositories.
|
||||||
|
|
||||||
|
- [StefanScherer/packer-windows](https://github.com/StefanScherer/packer-windows)
|
||||||
|
- [Baune8D/packer-windows-desktop](https://github.com/Baune8D/packer-windows-desktop)
|
||||||
|
|
||||||
|
Thank you both for the good work!
|
228
scripts/packer/answer_files/10_efi/Autounattend.xml
Normal file
228
scripts/packer/answer_files/10_efi/Autounattend.xml
Normal file
@ -0,0 +1,228 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<unattend xmlns="urn:schemas-microsoft-com:unattend">
|
||||||
|
<servicing/>
|
||||||
|
<settings pass="windowsPE">
|
||||||
|
<component xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" name="Microsoft-Windows-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<DiskConfiguration>
|
||||||
|
<Disk wcm:action="add">
|
||||||
|
<CreatePartitions>
|
||||||
|
<CreatePartition wcm:action="add">
|
||||||
|
<Order>1</Order>
|
||||||
|
<Size>500</Size>
|
||||||
|
<Type>EFI</Type>
|
||||||
|
</CreatePartition>
|
||||||
|
<CreatePartition wcm:action="add">
|
||||||
|
<Order>2</Order>
|
||||||
|
<Size>128</Size>
|
||||||
|
<Type>MSR</Type>
|
||||||
|
</CreatePartition>
|
||||||
|
<CreatePartition wcm:action="add">
|
||||||
|
<Order>3</Order>
|
||||||
|
<Extend>true</Extend>
|
||||||
|
<Type>Primary</Type>
|
||||||
|
</CreatePartition>
|
||||||
|
</CreatePartitions>
|
||||||
|
<DiskID>0</DiskID>
|
||||||
|
<WillWipeDisk>true</WillWipeDisk>
|
||||||
|
</Disk>
|
||||||
|
</DiskConfiguration>
|
||||||
|
<UserData>
|
||||||
|
<AcceptEula>true</AcceptEula>
|
||||||
|
<FullName>Vagrant</FullName>
|
||||||
|
<Organization>Vagrant</Organization>
|
||||||
|
<ProductKey>
|
||||||
|
<Key>W269N-WFGWX-YVC9B-4J6C9-T83GX</Key>
|
||||||
|
<WillShowUI>Never</WillShowUI>
|
||||||
|
</ProductKey>
|
||||||
|
</UserData>
|
||||||
|
<ImageInstall>
|
||||||
|
<OSImage>
|
||||||
|
<InstallTo>
|
||||||
|
<DiskID>0</DiskID>
|
||||||
|
<PartitionID>3</PartitionID>
|
||||||
|
</InstallTo>
|
||||||
|
<WillShowUI>OnError</WillShowUI>
|
||||||
|
<InstallToAvailablePartition>false</InstallToAvailablePartition>
|
||||||
|
</OSImage>
|
||||||
|
</ImageInstall>
|
||||||
|
</component>
|
||||||
|
<component xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" name="Microsoft-Windows-International-Core-WinPE" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<SetupUILanguage>
|
||||||
|
<UILanguage>en-US</UILanguage>
|
||||||
|
</SetupUILanguage>
|
||||||
|
<InputLocale>en-US</InputLocale>
|
||||||
|
<SystemLocale>en-US</SystemLocale>
|
||||||
|
<UILanguage>en-US</UILanguage>
|
||||||
|
<UILanguageFallback>en-US</UILanguageFallback>
|
||||||
|
<UserLocale>en-US</UserLocale>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<settings pass="offlineServicing">
|
||||||
|
<component name="Microsoft-Windows-LUA-Settings" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<EnableLUA>false</EnableLUA>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<settings pass="oobeSystem">
|
||||||
|
<component name="Microsoft-Windows-International-Core" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<InputLocale>en-US</InputLocale>
|
||||||
|
<SystemLocale>en-US</SystemLocale>
|
||||||
|
<UILanguage>en-US</UILanguage>
|
||||||
|
<UserLocale>en-US</UserLocale>
|
||||||
|
</component>
|
||||||
|
<component xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<UserAccounts>
|
||||||
|
<AdministratorPassword>
|
||||||
|
<Value>vagrant</Value>
|
||||||
|
<PlainText>true</PlainText>
|
||||||
|
</AdministratorPassword>
|
||||||
|
<LocalAccounts>
|
||||||
|
<LocalAccount wcm:action="add">
|
||||||
|
<Password>
|
||||||
|
<Value>vagrant</Value>
|
||||||
|
<PlainText>true</PlainText>
|
||||||
|
</Password>
|
||||||
|
<Description>Vagrant User</Description>
|
||||||
|
<DisplayName>vagrant</DisplayName>
|
||||||
|
<Group>administrators</Group>
|
||||||
|
<Name>vagrant</Name>
|
||||||
|
</LocalAccount>
|
||||||
|
</LocalAccounts>
|
||||||
|
</UserAccounts>
|
||||||
|
<OOBE>
|
||||||
|
<HideEULAPage>true</HideEULAPage>
|
||||||
|
<HideWirelessSetupInOOBE>true</HideWirelessSetupInOOBE>
|
||||||
|
<NetworkLocation>Home</NetworkLocation>
|
||||||
|
<ProtectYourPC>1</ProtectYourPC>
|
||||||
|
</OOBE>
|
||||||
|
<AutoLogon>
|
||||||
|
<Password>
|
||||||
|
<Value>vagrant</Value>
|
||||||
|
<PlainText>true</PlainText>
|
||||||
|
</Password>
|
||||||
|
<Username>vagrant</Username>
|
||||||
|
<Enabled>true</Enabled>
|
||||||
|
</AutoLogon>
|
||||||
|
<FirstLogonCommands>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c powershell -Command "Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Force"</CommandLine>
|
||||||
|
<Description>Set Execution Policy 64 Bit</Description>
|
||||||
|
<Order>1</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>C:\Windows\SysWOW64\cmd.exe /c powershell -Command "Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Force"</CommandLine>
|
||||||
|
<Description>Set Execution Policy 32 Bit</Description>
|
||||||
|
<Order>2</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c reg add "HKLM\System\CurrentControlSet\Control\Network\NewNetworkWindowOff"</CommandLine>
|
||||||
|
<Description>Network prompt</Description>
|
||||||
|
<Order>3</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -File e:\fixnetwork.ps1</CommandLine>
|
||||||
|
<Description>Fix public network</Description>
|
||||||
|
<Order>4</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -File e:\disable-winrm.ps1</CommandLine>
|
||||||
|
<Description>Disable WinRM</Description>
|
||||||
|
<Order>5</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\ /v HideFileExt /t REG_DWORD /d 0 /f</CommandLine>
|
||||||
|
<Order>6</Order>
|
||||||
|
<Description>Show file extensions in Explorer</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKCU\Console /v QuickEdit /t REG_DWORD /d 1 /f</CommandLine>
|
||||||
|
<Order>7</Order>
|
||||||
|
<Description>Enable QuickEdit mode</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\ /v Start_ShowRun /t REG_DWORD /d 1 /f</CommandLine>
|
||||||
|
<Order>8</Order>
|
||||||
|
<Description>Show Run command in Start Menu</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\ /v StartMenuAdminTools /t REG_DWORD /d 1 /f</CommandLine>
|
||||||
|
<Order>9</Order>
|
||||||
|
<Description>Show Administrative Tools in Start Menu</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKLM\SYSTEM\CurrentControlSet\Control\Power\ /v HibernateFileSizePercent /t REG_DWORD /d 0 /f</CommandLine>
|
||||||
|
<Order>10</Order>
|
||||||
|
<Description>Zero Hibernation File</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKLM\SYSTEM\CurrentControlSet\Control\Power\ /v HibernateEnabled /t REG_DWORD /d 0 /f</CommandLine>
|
||||||
|
<Order>11</Order>
|
||||||
|
<Description>Disable Hibernation Mode</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c wmic useraccount where "name='vagrant'" set PasswordExpires=FALSE</CommandLine>
|
||||||
|
<Order>12</Order>
|
||||||
|
<Description>Disable password expiration for vagrant user</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon" /v DefaultPassword /t REG_SZ /d "vagrant" /f</CommandLine>
|
||||||
|
<Order>13</Order>
|
||||||
|
<Description>Enable AutoLogon</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon" /v AutoAdminLogon /t REG_SZ /d 1 /f</CommandLine>
|
||||||
|
<Order>14</Order>
|
||||||
|
<Description>Enable AutoLogon</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<!-- WITHOUT WINDOWS UPDATES -->
|
||||||
|
<!--
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -File e:\enable-winrm.ps1</CommandLine>
|
||||||
|
<Description>Enable WinRM</Description>
|
||||||
|
<Order>99</Order>
|
||||||
|
</SynchronousCommand>
|
||||||
|
-->
|
||||||
|
<!-- END WITHOUT WINDOWS UPDATES -->
|
||||||
|
<!-- WITH WINDOWS UPDATES -->
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c e:\microsoft-updates.bat</CommandLine>
|
||||||
|
<Order>98</Order>
|
||||||
|
<Description>Enable Microsoft Updates</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -File e:\disable-screensaver.ps1</CommandLine>
|
||||||
|
<Description>Disable Screensaver</Description>
|
||||||
|
<Order>99</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -File e:\win-updates.ps1</CommandLine>
|
||||||
|
<Description>Install Windows Updates</Description>
|
||||||
|
<Order>100</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<!-- END WITH WINDOWS UPDATES -->
|
||||||
|
</FirstLogonCommands>
|
||||||
|
<ShowWindowsLive>false</ShowWindowsLive>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<settings pass="specialize">
|
||||||
|
<component name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<OEMInformation>
|
||||||
|
<HelpCustomized>false</HelpCustomized>
|
||||||
|
</OEMInformation>
|
||||||
|
<!-- Rename computer here. -->
|
||||||
|
<ComputerName>vagrant-win10</ComputerName>
|
||||||
|
<TimeZone>Pacific Standard Time</TimeZone>
|
||||||
|
<RegisteredOwner/>
|
||||||
|
</component>
|
||||||
|
<component xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" name="Microsoft-Windows-Security-SPP-UX" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<SkipAutoActivation>true</SkipAutoActivation>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<cpi:offlineImage xmlns:cpi="urn:schemas-microsoft-com:cpi" cpi:source="catalog:d:/sources/install_windows 7 ENTERPRISE.clg"/>
|
||||||
|
</unattend>
|
298
scripts/packer/answer_files/11/Autounattend.xml
Normal file
298
scripts/packer/answer_files/11/Autounattend.xml
Normal file
@ -0,0 +1,298 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<unattend xmlns="urn:schemas-microsoft-com:unattend">
|
||||||
|
<servicing/>
|
||||||
|
<settings pass="windowsPE">
|
||||||
|
<component name="Microsoft-Windows-PnpCustomizationsWinPE"
|
||||||
|
publicKeyToken="31bf3856ad364e35" language="neutral"
|
||||||
|
versionScope="nonSxS" processorArchitecture="amd64"
|
||||||
|
xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State">
|
||||||
|
|
||||||
|
<!--
|
||||||
|
This makes the VirtIO drivers available to Windows, assuming that
|
||||||
|
the VirtIO driver disk at https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso
|
||||||
|
(see https://docs.fedoraproject.org/en-US/quick-docs/creating-windows-virtual-machines-using-virtio-drivers/index.html#virtio-win-direct-downloads)
|
||||||
|
is available as drive E:
|
||||||
|
-->
|
||||||
|
<DriverPaths>
|
||||||
|
<PathAndCredentials wcm:action="add" wcm:keyValue="2">
|
||||||
|
<Path>E:\viostor\w10\amd64</Path>
|
||||||
|
</PathAndCredentials>
|
||||||
|
|
||||||
|
<PathAndCredentials wcm:action="add" wcm:keyValue="3">
|
||||||
|
<Path>E:\NetKVM\w10\amd64</Path>
|
||||||
|
</PathAndCredentials>
|
||||||
|
|
||||||
|
<PathAndCredentials wcm:action="add" wcm:keyValue="4">
|
||||||
|
<Path>E:\Balloon\w10\amd64</Path>
|
||||||
|
</PathAndCredentials>
|
||||||
|
|
||||||
|
<PathAndCredentials wcm:action="add" wcm:keyValue="5">
|
||||||
|
<Path>E:\pvpanic\w10\amd64</Path>
|
||||||
|
</PathAndCredentials>
|
||||||
|
|
||||||
|
<PathAndCredentials wcm:action="add" wcm:keyValue="6">
|
||||||
|
<Path>E:\qemupciserial\w10\amd64</Path>
|
||||||
|
</PathAndCredentials>
|
||||||
|
|
||||||
|
<PathAndCredentials wcm:action="add" wcm:keyValue="7">
|
||||||
|
<Path>E:\qxldod\w10\amd64</Path>
|
||||||
|
</PathAndCredentials>
|
||||||
|
|
||||||
|
<PathAndCredentials wcm:action="add" wcm:keyValue="8">
|
||||||
|
<Path>E:\vioinput\w10\amd64</Path>
|
||||||
|
</PathAndCredentials>
|
||||||
|
|
||||||
|
<PathAndCredentials wcm:action="add" wcm:keyValue="9">
|
||||||
|
<Path>E:\viorng\w10\amd64</Path>
|
||||||
|
</PathAndCredentials>
|
||||||
|
|
||||||
|
<PathAndCredentials wcm:action="add" wcm:keyValue="10">
|
||||||
|
<Path>E:\vioscsi\w10\amd64</Path>
|
||||||
|
</PathAndCredentials>
|
||||||
|
|
||||||
|
<PathAndCredentials wcm:action="add" wcm:keyValue="11">
|
||||||
|
<Path>E:\vioserial\w10\amd64</Path>
|
||||||
|
</PathAndCredentials>
|
||||||
|
</DriverPaths>
|
||||||
|
</component>
|
||||||
|
|
||||||
|
<component xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" name="Microsoft-Windows-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<DiskConfiguration>
|
||||||
|
<Disk wcm:action="add">
|
||||||
|
<CreatePartitions>
|
||||||
|
<CreatePartition wcm:action="add">
|
||||||
|
<Order>1</Order>
|
||||||
|
<Type>Primary</Type>
|
||||||
|
<Extend>true</Extend>
|
||||||
|
</CreatePartition>
|
||||||
|
</CreatePartitions>
|
||||||
|
<ModifyPartitions>
|
||||||
|
<ModifyPartition wcm:action="add">
|
||||||
|
<Extend>false</Extend>
|
||||||
|
<Format>NTFS</Format>
|
||||||
|
<Letter>C</Letter>
|
||||||
|
<Order>1</Order>
|
||||||
|
<PartitionID>1</PartitionID>
|
||||||
|
<Label>Windows 11</Label>
|
||||||
|
</ModifyPartition>
|
||||||
|
</ModifyPartitions>
|
||||||
|
<DiskID>0</DiskID>
|
||||||
|
<WillWipeDisk>true</WillWipeDisk>
|
||||||
|
</Disk>
|
||||||
|
<WillShowUI>OnError</WillShowUI>
|
||||||
|
</DiskConfiguration>
|
||||||
|
<UserData>
|
||||||
|
<AcceptEula>true</AcceptEula>
|
||||||
|
<FullName>Vagrant</FullName>
|
||||||
|
<Organization>Vagrant</Organization>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
NOTE: If you are re-configuring this for use of a retail key
|
||||||
|
and using a retail ISO, you need to adjust the <ProductKey> block
|
||||||
|
below to look like this:
|
||||||
|
|
||||||
|
<ProductKey>
|
||||||
|
<Key>W269N-WFGWX-YVC9B-4J6C9-T83GX</Key>
|
||||||
|
<WillShowUI>Never</WillShowUI>
|
||||||
|
</ProductKey>
|
||||||
|
|
||||||
|
Notice the addition of the `<Key>` element.
|
||||||
|
-->
|
||||||
|
</UserData>
|
||||||
|
<ImageInstall>
|
||||||
|
<OSImage>
|
||||||
|
<InstallTo>
|
||||||
|
<DiskID>0</DiskID>
|
||||||
|
<PartitionID>1</PartitionID>
|
||||||
|
</InstallTo>
|
||||||
|
<WillShowUI>OnError</WillShowUI>
|
||||||
|
<InstallToAvailablePartition>false</InstallToAvailablePartition>
|
||||||
|
<InstallFrom>
|
||||||
|
<MetaData wcm:action="add">
|
||||||
|
<Key>/IMAGE/NAME</Key>
|
||||||
|
<Value>Windows 11 Enterprise Evaluation</Value>
|
||||||
|
</MetaData>
|
||||||
|
</InstallFrom>
|
||||||
|
</OSImage>
|
||||||
|
</ImageInstall>
|
||||||
|
</component>
|
||||||
|
<component xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" name="Microsoft-Windows-International-Core-WinPE" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<SetupUILanguage>
|
||||||
|
<UILanguage>en-US</UILanguage>
|
||||||
|
</SetupUILanguage>
|
||||||
|
<InputLocale>en-US</InputLocale>
|
||||||
|
<SystemLocale>en-US</SystemLocale>
|
||||||
|
<UILanguage>en-US</UILanguage>
|
||||||
|
<UILanguageFallback>en-US</UILanguageFallback>
|
||||||
|
<UserLocale>en-US</UserLocale>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<settings pass="offlineServicing">
|
||||||
|
<component name="Microsoft-Windows-LUA-Settings" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<EnableLUA>false</EnableLUA>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<settings pass="oobeSystem">
|
||||||
|
<component name="Microsoft-Windows-International-Core" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<InputLocale>en-US</InputLocale>
|
||||||
|
<SystemLocale>en-US</SystemLocale>
|
||||||
|
<UILanguage>en-US</UILanguage>
|
||||||
|
<UserLocale>en-US</UserLocale>
|
||||||
|
</component>
|
||||||
|
<component xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<UserAccounts>
|
||||||
|
<AdministratorPassword>
|
||||||
|
<Value>vagrant</Value>
|
||||||
|
<PlainText>true</PlainText>
|
||||||
|
</AdministratorPassword>
|
||||||
|
<LocalAccounts>
|
||||||
|
<LocalAccount wcm:action="add">
|
||||||
|
<Password>
|
||||||
|
<Value>vagrant</Value>
|
||||||
|
<PlainText>true</PlainText>
|
||||||
|
</Password>
|
||||||
|
<Description>Vagrant User</Description>
|
||||||
|
<DisplayName>vagrant</DisplayName>
|
||||||
|
<Group>administrators</Group>
|
||||||
|
<Name>vagrant</Name>
|
||||||
|
</LocalAccount>
|
||||||
|
</LocalAccounts>
|
||||||
|
</UserAccounts>
|
||||||
|
<OOBE>
|
||||||
|
<HideEULAPage>true</HideEULAPage>
|
||||||
|
<HideWirelessSetupInOOBE>true</HideWirelessSetupInOOBE>
|
||||||
|
<NetworkLocation>Home</NetworkLocation>
|
||||||
|
<ProtectYourPC>1</ProtectYourPC>
|
||||||
|
</OOBE>
|
||||||
|
<AutoLogon>
|
||||||
|
<Password>
|
||||||
|
<Value>vagrant</Value>
|
||||||
|
<PlainText>true</PlainText>
|
||||||
|
</Password>
|
||||||
|
<Username>vagrant</Username>
|
||||||
|
<Enabled>true</Enabled>
|
||||||
|
</AutoLogon>
|
||||||
|
<FirstLogonCommands>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c powershell -Command "Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Force"</CommandLine>
|
||||||
|
<Description>Set Execution Policy 64 Bit</Description>
|
||||||
|
<Order>1</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>C:\Windows\SysWOW64\cmd.exe /c powershell -Command "Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Force"</CommandLine>
|
||||||
|
<Description>Set Execution Policy 32 Bit</Description>
|
||||||
|
<Order>2</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c reg add "HKLM\System\CurrentControlSet\Control\Network\NewNetworkWindowOff"</CommandLine>
|
||||||
|
<Description>Network prompt</Description>
|
||||||
|
<Order>3</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -File a:\fixnetwork.ps1</CommandLine>
|
||||||
|
<Description>Fix public network</Description>
|
||||||
|
<Order>4</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -File a:\disable-winrm.ps1</CommandLine>
|
||||||
|
<Description>Disable WinRM</Description>
|
||||||
|
<Order>5</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\ /v HideFileExt /t REG_DWORD /d 0 /f</CommandLine>
|
||||||
|
<Order>6</Order>
|
||||||
|
<Description>Show file extensions in Explorer</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKCU\Console /v QuickEdit /t REG_DWORD /d 1 /f</CommandLine>
|
||||||
|
<Order>7</Order>
|
||||||
|
<Description>Enable QuickEdit mode</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\ /v Start_ShowRun /t REG_DWORD /d 1 /f</CommandLine>
|
||||||
|
<Order>8</Order>
|
||||||
|
<Description>Show Run command in Start Menu</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced\ /v StartMenuAdminTools /t REG_DWORD /d 1 /f</CommandLine>
|
||||||
|
<Order>9</Order>
|
||||||
|
<Description>Show Administrative Tools in Start Menu</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKLM\SYSTEM\CurrentControlSet\Control\Power\ /v HibernateFileSizePercent /t REG_DWORD /d 0 /f</CommandLine>
|
||||||
|
<Order>10</Order>
|
||||||
|
<Description>Zero Hibernation File</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD HKLM\SYSTEM\CurrentControlSet\Control\Power\ /v HibernateEnabled /t REG_DWORD /d 0 /f</CommandLine>
|
||||||
|
<Order>11</Order>
|
||||||
|
<Description>Disable Hibernation Mode</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c wmic useraccount where "name='vagrant'" set PasswordExpires=FALSE</CommandLine>
|
||||||
|
<Order>12</Order>
|
||||||
|
<Description>Disable password expiration for vagrant user</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon" /v DefaultPassword /t REG_SZ /d "vagrant" /f</CommandLine>
|
||||||
|
<Order>13</Order>
|
||||||
|
<Description>Enable AutoLogon</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>%SystemRoot%\System32\reg.exe ADD "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon" /v AutoAdminLogon /t REG_SZ /d 1 /f</CommandLine>
|
||||||
|
<Order>14</Order>
|
||||||
|
<Description>Enable AutoLogon</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<!-- WITHOUT WINDOWS UPDATES -->
|
||||||
|
<!--
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -File a:\enable-winrm.ps1</CommandLine>
|
||||||
|
<Description>Enable WinRM</Description>
|
||||||
|
<Order>99</Order>
|
||||||
|
</SynchronousCommand>
|
||||||
|
-->
|
||||||
|
<!-- END WITHOUT WINDOWS UPDATES -->
|
||||||
|
<!-- WITH WINDOWS UPDATES -->
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c a:\microsoft-updates.bat</CommandLine>
|
||||||
|
<Order>98</Order>
|
||||||
|
<Description>Enable Microsoft Updates</Description>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -File a:\disable-screensaver.ps1</CommandLine>
|
||||||
|
<Description>Disable Screensaver</Description>
|
||||||
|
<Order>99</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<CommandLine>cmd.exe /c C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -File a:\win-updates.ps1</CommandLine>
|
||||||
|
<Description>Install Windows Updates</Description>
|
||||||
|
<Order>100</Order>
|
||||||
|
<RequiresUserInput>true</RequiresUserInput>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<!-- END WITH WINDOWS UPDATES -->
|
||||||
|
</FirstLogonCommands>
|
||||||
|
<ShowWindowsLive>false</ShowWindowsLive>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<settings pass="specialize">
|
||||||
|
<component name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<OEMInformation>
|
||||||
|
<HelpCustomized>false</HelpCustomized>
|
||||||
|
</OEMInformation>
|
||||||
|
<!-- Rename computer here. -->
|
||||||
|
<ComputerName>vagrant-11</ComputerName>
|
||||||
|
<TimeZone>Pacific Standard Time</TimeZone>
|
||||||
|
<RegisteredOwner/>
|
||||||
|
</component>
|
||||||
|
<component xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" name="Microsoft-Windows-Security-SPP-UX" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS">
|
||||||
|
<SkipAutoActivation>true</SkipAutoActivation>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<cpi:offlineImage xmlns:cpi="urn:schemas-microsoft-com:cpi" cpi:source="catalog:d:/sources/install_windows 7 ENTERPRISE.clg"/>
|
||||||
|
</unattend>
|
3
scripts/packer/build_windows_10.bat
Normal file
3
scripts/packer/build_windows_10.bat
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
@echo off
|
||||||
|
|
||||||
|
packer build --force --only=%~1-iso windows_10.json
|
3
scripts/packer/build_windows_10.sh
Executable file
3
scripts/packer/build_windows_10.sh
Executable file
@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
packer build --force --only=$1-iso windows_10.json
|
4
scripts/packer/build_windows_11.bat
Normal file
4
scripts/packer/build_windows_11.bat
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
@echo off
|
||||||
|
|
||||||
|
packer build --only=%1-iso windows_11.json
|
||||||
|
|
4
scripts/packer/build_windows_11.sh
Executable file
4
scripts/packer/build_windows_11.sh
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
packer build --only=$1-iso windows_11.json
|
||||||
|
|
BIN
scripts/packer/floppy/PinTo10.exe
Normal file
BIN
scripts/packer/floppy/PinTo10.exe
Normal file
Binary file not shown.
38
scripts/packer/floppy/ReadMe.txt
Normal file
38
scripts/packer/floppy/ReadMe.txt
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
: Release v1.2 - Stuart Pearson 16th Nov 2015
|
||||||
|
:
|
||||||
|
: Command line tool to pin and unpin exe / lnk files to the Windows 10 taskbar and start menu.
|
||||||
|
:
|
||||||
|
: PinTo10 is a command line tool to pin and unpin .exe or .lnk files to or from the Windows 10 taskbar and start menu.
|
||||||
|
: With it you can pin or unpin up to 10 different shortcuts to either the taskbar or start menu in one run of the command.
|
||||||
|
: It replaces functionality that Microsoft have removed from their Windows 10 scripting interface.
|
||||||
|
:
|
||||||
|
: The exe needs to be run with at least one pair of switches specified for each function to Pin / Unpin to Taskbar / Start Menu...
|
||||||
|
:
|
||||||
|
: To pin an application or shortcut to the taskbar (replace XX with 01-10)...
|
||||||
|
: /PTFOLXX: Followed by the folder containing the file you want to pin.
|
||||||
|
: /PTFILEXX: Followed by the name of the file you want to pin.
|
||||||
|
:
|
||||||
|
: To unpin an application or shortcut to the taskbar (replace XX with 01-10)...
|
||||||
|
: /UTFOLXX: Followed by the folder containing the file you want to unpin.
|
||||||
|
: /UTFILEXX: Followed by the name of the file you want to unpin.
|
||||||
|
|
||||||
|
: To pin an application or shortcut to the start menu (replace XX with 01-10)...
|
||||||
|
: /PSFOLXX: Followed by the folder containing the file you want to pin.
|
||||||
|
: /PSFILEXX: Followed by the name of the file you want to pin.
|
||||||
|
|
||||||
|
: To unpin an application or shortcut to the start menu (replace XX with 01-10)...
|
||||||
|
: /USFOLXX: Followed by the folder containing the file you want to unpin.
|
||||||
|
: /USFILEXX: Followed by the name of the file you want to unpin.
|
||||||
|
|
||||||
|
|
||||||
|
: Example for pinning two shortcuts to the taskbar...
|
||||||
|
PinTo10.exe /PTFOL01:'%USERPROFILE:%\Desktop' /PTFILE01:'Word 2016.lnk' /PTFOL02:'%USERPROFILE:%\Desktop' /PTFILE02:'Excel 2016.lnk'
|
||||||
|
|
||||||
|
: Example for unpinning a file to the taskbar...
|
||||||
|
PinTo10.exe /UTFOL01:'C\Windows' /UTFILE01:'notepad.exe'
|
||||||
|
|
||||||
|
: Example for pinning a file to the start menu...
|
||||||
|
PinTo10.exe /PSFOL01:'C\Windows' /PSFILE01:'notepad.exe'
|
||||||
|
|
||||||
|
: Example for unpinning a file from the start menu...
|
||||||
|
PinTo10.exe /USFOL01:'%USERPROFILE:%\Desktop' /USFILE01:'Word 2016.lnk'
|
BIN
scripts/packer/floppy/WindowsPowershell.lnk
Executable file
BIN
scripts/packer/floppy/WindowsPowershell.lnk
Executable file
Binary file not shown.
26
scripts/packer/iso/README.md
Normal file
26
scripts/packer/iso/README.md
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
### What Is This Directory For?
|
||||||
|
|
||||||
|
You should download your Windows Server ISO images from TechNet/MSDN and place them in this folder. We need to do this because MSDN / TechNet are protected by Microsoft (Live) ID, which does not support HTTP basic authentication or the OAuth2 username / password flow.
|
||||||
|
|
||||||
|
For example, you might want to start with one of the following:
|
||||||
|
|
||||||
|
* Windows Server 2008 R2 + SP1:
|
||||||
|
* File Name: en_windows_server_2008_r2_with_sp1_x64_dvd_617601.iso
|
||||||
|
* SHA1 Hash: D3FD7BF85EE1D5BDD72DE5B2C69A7B470733CD0A
|
||||||
|
* Direct Download: http://msdn.microsoft.com/subscriptions/json/GetDownloadRequest?brand=MSDN&locale=en-us&fileId=44782&activexDisabled=true&akamaiDL=false
|
||||||
|
* Windows Server 2008 R2 + SP1 (Volume License):
|
||||||
|
* File Name: en_windows_server_2008_r2_with_sp1_vl_build_x64_dvd_617403.iso
|
||||||
|
* SHA1 Hash: 7E7E9425041B3328CCF723A0855C2BC4F462EC57
|
||||||
|
* Direct Download: http://msdn.microsoft.com/subscriptions/json/GetDownloadRequest?brand=MSDN&locale=en-us&fileId=44783&activexDisabled=true&akamaiDL=false
|
||||||
|
* Windows Server 2012:
|
||||||
|
* File Name: en_windows_server_2012_x64_dvd_915478.iso
|
||||||
|
* SHA1 Hash: D09E752B1EE480BC7E93DFA7D5C3A9B8AAC477BA
|
||||||
|
* Direct Download: http://msdn.microsoft.com/subscriptions/json/GetDownloadRequest?brand=MSDN&locale=en-us&fileId=50539&activexDisabled=true&akamaiDL=false
|
||||||
|
* Windows Server 2012 (Volume License):
|
||||||
|
* File Name: en_windows_server_2012_vl_x64_dvd_917758.iso
|
||||||
|
* SHA1 Hash: 063BC26ED45C50D3745CCAD52DD7B3F3CE13F36D
|
||||||
|
* Direct Download: http://msdn.microsoft.com/subscriptions/json/GetDownloadRequest?brand=MSDN&locale=en-us&fileId=50573&activexDisabled=true&akamaiDL=false
|
||||||
|
|
||||||
|
Or Build one using the Windows Installation Media Creation Tools:
|
||||||
|
|
||||||
|
https://support.microsoft.com/en-us/windows/create-installation-media-for-windows-99a58364-8c02-206f-aa6f-40c3b507420d
|
1
scripts/packer/scripts/chocolatey.bat
Normal file
1
scripts/packer/scripts/chocolatey.bat
Normal file
@ -0,0 +1 @@
|
|||||||
|
powershell -NoProfile -ExecutionPolicy unrestricted -Command "[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; iex ((new-object net.webclient).DownloadString('https://chocolatey.org/install.ps1'))"
|
26
scripts/packer/scripts/chocopacks.ps1
Normal file
26
scripts/packer/scripts/chocopacks.ps1
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
choco install -y boxstarter.winconfig
|
||||||
|
|
||||||
|
# Editors
|
||||||
|
choco install -y notepadplusplus
|
||||||
|
|
||||||
|
# Terminals
|
||||||
|
choco install -y microsoft-windows-terminal
|
||||||
|
choco install -y fluent-terminal
|
||||||
|
choco install -y hyper
|
||||||
|
choco install -y tabby
|
||||||
|
choco install -y conemu
|
||||||
|
|
||||||
|
# other
|
||||||
|
choco install -y poshgit
|
||||||
|
|
||||||
|
# IDE/Software development
|
||||||
|
choco install -y vscode
|
||||||
|
choco install -y visualstudio2022community --execution-timeout 9000 --package-parameters "--add Microsoft.VisualStudio.Workload.NativeDesktop;includeRecommended"
|
||||||
|
|
||||||
|
md C:\users\vagrant\bin
|
||||||
|
if (test-path "a:/set-shortcut.ps1") {
|
||||||
|
copy "a:/set-shortcut.ps1" C:\users\vagrant\bin
|
||||||
|
} elseif (test-path "e:/set-shortcut.ps1") {
|
||||||
|
copy "e:/set-shortcut.ps1" C:\users\vagrant\bin
|
||||||
|
}
|
||||||
|
|
39
scripts/packer/scripts/compact.bat
Normal file
39
scripts/packer/scripts/compact.bat
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
if "%PACKER_BUILDER_TYPE:~0,6%"=="hyperv" (
|
||||||
|
echo "Skip compact steps in Hyper-V build."
|
||||||
|
goto :eof
|
||||||
|
)
|
||||||
|
if not exist "C:\Windows\Temp\7z1900-x64.msi" (
|
||||||
|
powershell -Command "(New-Object System.Net.WebClient).DownloadFile('https://www.7-zip.org/a/7z1900-x64.msi', 'C:\Windows\Temp\7z1900-x64.msi')" <NUL
|
||||||
|
)
|
||||||
|
msiexec /qb /i C:\Windows\Temp\7z1900-x64.msi
|
||||||
|
|
||||||
|
if not exist "C:\Windows\Temp\ultradefrag.zip" (
|
||||||
|
powershell -Command "[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; (New-Object System.Net.WebClient).DownloadFile('https://downloads.sourceforge.net/project/ultradefrag/stable-release/6.1.0/ultradefrag-portable-6.1.0.bin.amd64.zip', 'C:\Windows\Temp\ultradefrag.zip')" <NUL
|
||||||
|
)
|
||||||
|
|
||||||
|
if not exist "C:\Windows\Temp\ultradefrag-portable-6.1.0.amd64\udefrag.exe" (
|
||||||
|
cmd /c ""C:\Program Files\7-Zip\7z.exe" x C:\Windows\Temp\ultradefrag.zip -oC:\Windows\Temp"
|
||||||
|
)
|
||||||
|
|
||||||
|
if not exist "C:\Windows\Temp\SDelete.zip" (
|
||||||
|
powershell -Command "(New-Object System.Net.WebClient).DownloadFile('https://download.sysinternals.com/files/SDelete.zip', 'C:\Windows\Temp\SDelete.zip')" <NUL
|
||||||
|
powershell -Command "(New-Object System.Net.WebClient).DownloadFile('https://vagrantboxes.blob.core.windows.net/box/sdelete/v1.6.1/sdelete.exe', 'C:\Windows\Temp\sdelete.exe')" <NUL
|
||||||
|
)
|
||||||
|
|
||||||
|
if not exist "C:\Windows\Temp\sdelete.exe" (
|
||||||
|
cmd /c ""C:\Program Files\7-Zip\7z.exe" x C:\Windows\Temp\SDelete.zip -oC:\Windows\Temp"
|
||||||
|
)
|
||||||
|
|
||||||
|
msiexec /qb /x C:\Windows\Temp\7z1900-x64.msi
|
||||||
|
|
||||||
|
net stop wuauserv
|
||||||
|
rmdir /S /Q C:\Windows\SoftwareDistribution\Download
|
||||||
|
mkdir C:\Windows\SoftwareDistribution\Download
|
||||||
|
net start wuauserv
|
||||||
|
|
||||||
|
if "%PACKER_BUILDER_TYPE%" neq "hyperv-iso" (
|
||||||
|
cmd /c C:\Windows\Temp\ultradefrag-portable-6.1.0.amd64\udefrag.exe --optimize --repeat C:
|
||||||
|
|
||||||
|
cmd /c %SystemRoot%\System32\reg.exe ADD HKCU\Software\Sysinternals\SDelete /v EulaAccepted /t REG_DWORD /d 1 /f
|
||||||
|
cmd /c C:\Windows\Temp\sdelete.exe -q -z C:
|
||||||
|
)
|
17
scripts/packer/scripts/compile-dotnet-assemblies.bat
Normal file
17
scripts/packer/scripts/compile-dotnet-assemblies.bat
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
::http://support.microsoft.com/kb/2570538
|
||||||
|
::http://robrelyea.wordpress.com/2007/07/13/may-be-helpful-ngen-exe-executequeueditems/
|
||||||
|
|
||||||
|
if "%PROCESSOR_ARCHITECTURE%"=="AMD64" goto 64BIT
|
||||||
|
|
||||||
|
%windir%\microsoft.net\framework\v4.0.30319\ngen.exe update /force /queue > NUL
|
||||||
|
%windir%\microsoft.net\framework\v4.0.30319\ngen.exe executequeueditems > NUL
|
||||||
|
|
||||||
|
exit 0
|
||||||
|
|
||||||
|
:64BIT
|
||||||
|
%windir%\microsoft.net\framework\v4.0.30319\ngen.exe update /force /queue > NUL
|
||||||
|
%windir%\microsoft.net\framework64\v4.0.30319\ngen.exe update /force /queue > NUL
|
||||||
|
%windir%\microsoft.net\framework\v4.0.30319\ngen.exe executequeueditems > NUL
|
||||||
|
%windir%\microsoft.net\framework64\v4.0.30319\ngen.exe executequeueditems > NUL
|
||||||
|
|
||||||
|
exit 0
|
33
scripts/packer/scripts/debloat-windows.ps1
Normal file
33
scripts/packer/scripts/debloat-windows.ps1
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
if ($env:PACKER_BUILDER_TYPE -And $($env:PACKER_BUILDER_TYPE).startsWith("hyperv")) {
|
||||||
|
Write-Output Skip debloat steps in Hyper-V build.
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Write-Output Downloading debloat zip
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
|
||||||
|
$url = "https://github.com/StefanScherer/Debloat-Windows-10/archive/master.zip"
|
||||||
|
(New-Object System.Net.WebClient).DownloadFile($url, "$env:TEMP\debloat.zip")
|
||||||
|
Expand-Archive -Path $env:TEMP\debloat.zip -DestinationPath $env:TEMP -Force
|
||||||
|
|
||||||
|
#Write-Output Disable scheduled tasks
|
||||||
|
#. $env:TEMP\Debloat-Windows-10-master\utils\disable-scheduled-tasks.ps1
|
||||||
|
#Write-Output Block telemetry
|
||||||
|
#. $env:TEMP\Debloat-Windows-10-master\scripts\block-telemetry.ps1
|
||||||
|
#Write-Output Disable services
|
||||||
|
#. $env:TEMP\Debloat-Windows-10-master\scripts\disable-services.ps1
|
||||||
|
Write-Output Disable Windows Defender
|
||||||
|
if ($(Get-ItemProperty "HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion").ProductName.StartsWith("Windows 10")) {
|
||||||
|
. $env:TEMP\Debloat-Windows-10-master\scripts\disable-windows-defender.ps1
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Uninstall-WindowsFeature Windows-Defender
|
||||||
|
}
|
||||||
|
Write-Output Optimize Windows Update
|
||||||
|
. $env:TEMP\Debloat-Windows-10-master\scripts\optimize-windows-update.ps1
|
||||||
|
#Write-Output Disable Windows Update
|
||||||
|
#Set-Service wuauserv -StartupType Disabled
|
||||||
|
#Write-Output Remove OneDrive
|
||||||
|
#. $env:TEMP\Debloat-Windows-10-master\scripts\remove-onedrive.ps1
|
||||||
|
|
||||||
|
Remove-Item $env:TEMP\debloat.zip
|
||||||
|
Remove-Item -recurse $env:TEMP\Debloat-Windows-10-master
|
||||||
|
}
|
20
scripts/packer/scripts/dis-updates.bat
Normal file
20
scripts/packer/scripts/dis-updates.bat
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
rem http://www.windows-commandline.com/disable-automatic-updates-command-line/
|
||||||
|
reg add "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\WindowsUpdate\Auto Update" /v AUOptions /t REG_DWORD /d 1 /f
|
||||||
|
|
||||||
|
rem remove optional WSUS server settings
|
||||||
|
reg delete "HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate" /f
|
||||||
|
|
||||||
|
rem even harder, disable windows update service
|
||||||
|
rem sc config wuauserv start= disabled
|
||||||
|
rem net stop wuauserv
|
||||||
|
set logfile=C:\Windows\Temp\win-updates.log
|
||||||
|
|
||||||
|
if exist %logfile% (
|
||||||
|
echo Show Windows Updates log file %logfile%
|
||||||
|
dir %logfile%
|
||||||
|
type %logfile%
|
||||||
|
rem output of type command is not fully shown in packer/ssh session, so try PowerShell
|
||||||
|
rem but it will hang if log file is about 22 KByte
|
||||||
|
rem powershell -command "Get-Content %logfile%"
|
||||||
|
echo End of Windows Updates log file %logfile%
|
||||||
|
)
|
4
scripts/packer/scripts/disable-screensaver.ps1
Normal file
4
scripts/packer/scripts/disable-screensaver.ps1
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
Write-Output "Disabling Screensaver"
|
||||||
|
Set-ItemProperty "HKCU:\Control Panel\Desktop" -Name ScreenSaveActive -Value 0 -Type DWord
|
||||||
|
& powercfg -x -monitor-timeout-ac 0
|
||||||
|
& powercfg -x -monitor-timeout-dc 0
|
8
scripts/packer/scripts/disable-winrm.ps1
Normal file
8
scripts/packer/scripts/disable-winrm.ps1
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
netsh advfirewall firewall set rule name="Windows Remote Management (HTTP-In)" new enable=yes action=block
|
||||||
|
netsh advfirewall firewall set rule group="Windows Remote Management" new enable=yes
|
||||||
|
$winrmService = Get-Service -Name WinRM
|
||||||
|
if ($winrmService.Status -eq "Running") {
|
||||||
|
Disable-PSRemoting -Force
|
||||||
|
}
|
||||||
|
Stop-Service winrm
|
||||||
|
Set-Service -Name winrm -StartupType Disabled
|
@ -0,0 +1,4 @@
|
|||||||
|
$DefenderInstalled = Get-Command -Module Defender
|
||||||
|
if($null -ne $DefenderInstalled) {
|
||||||
|
Set-MpPreference -DisableRealtimeMonitoring $true
|
||||||
|
}
|
2
scripts/packer/scripts/enable-rdp.bat
Normal file
2
scripts/packer/scripts/enable-rdp.bat
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
netsh advfirewall firewall add rule name="Open Port 3389" dir=in action=allow protocol=TCP localport=3389
|
||||||
|
reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Terminal Server" /v fDenyTSConnections /t REG_DWORD /d 0 /f
|
27
scripts/packer/scripts/enable-winrm.ps1
Normal file
27
scripts/packer/scripts/enable-winrm.ps1
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
write-host "==> 'enable-winrm.ps1' - START..."
|
||||||
|
write-host "====> Getting Connections..."
|
||||||
|
Get-NetConnectionProfile | Set-NetConnectionProfile -NetworkCategory Private
|
||||||
|
|
||||||
|
write-host "====> Enable PSRemoting..."
|
||||||
|
Enable-PSRemoting -Force
|
||||||
|
|
||||||
|
write-host "====> WINRM Quick Config..."
|
||||||
|
winrm quickconfig -q
|
||||||
|
winrm quickconfig -transport:http
|
||||||
|
|
||||||
|
write-host "====> WINRM Set Config..."
|
||||||
|
winrm set winrm/config '@{MaxTimeoutms="1800000"}'
|
||||||
|
winrm set winrm/config/winrs '@{MaxMemoryPerShellMB="800"}'
|
||||||
|
winrm set winrm/config/service '@{AllowUnencrypted="true"}'
|
||||||
|
winrm set winrm/config/service/auth '@{Basic="true"}'
|
||||||
|
winrm set winrm/config/client/auth '@{Basic="true"}'
|
||||||
|
winrm set winrm/config/listener?Address=*+Transport=HTTP '@{Port="5985"}'
|
||||||
|
|
||||||
|
write-host "====> Configure Firewall..."
|
||||||
|
netsh advfirewall firewall set rule group="Windows Remote Administration" new enable=yes
|
||||||
|
netsh advfirewall firewall set rule name="Windows Remote Management (HTTP-In)" new enable=yes action=allow remoteip=any
|
||||||
|
write-host "====> Set WINRM Service Statup..."
|
||||||
|
Set-Service winrm -startuptype "auto"
|
||||||
|
write-host "====> Restart WINRM Service..."
|
||||||
|
Restart-Service winrm
|
||||||
|
write-host "==> 'enable-winrm.ps1' - END..."
|
30
scripts/packer/scripts/fixnetwork.ps1
Normal file
30
scripts/packer/scripts/fixnetwork.ps1
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
# You cannot enable Windows PowerShell Remoting on network connections that are set to Public
|
||||||
|
# Spin through all the network locations and if they are set to Public, set them to Private
|
||||||
|
# using the INetwork interface:
|
||||||
|
# http://msdn.microsoft.com/en-us/library/windows/desktop/aa370750(v=vs.85).aspx
|
||||||
|
# For more info, see:
|
||||||
|
# http://blogs.msdn.com/b/powershell/archive/2009/04/03/setting-network-location-to-private.aspx
|
||||||
|
|
||||||
|
function Set-NetworkTypeToPrivate {
|
||||||
|
[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingPositionalParameters', '')]
|
||||||
|
param()
|
||||||
|
# Network location feature was only introduced in Windows Vista - no need to bother with this
|
||||||
|
# if the operating system is older than Vista
|
||||||
|
if ([environment]::OSVersion.version.Major -lt 6) { return }
|
||||||
|
|
||||||
|
# You cannot change the network location if you are joined to a domain, so abort
|
||||||
|
if (1, 3, 4, 5 -contains (Get-CimInstance win32_computersystem).DomainRole) { return }
|
||||||
|
|
||||||
|
# Get network connections
|
||||||
|
$networkListManager = [Activator]::CreateInstance([Type]::GetTypeFromCLSID([Guid]"{DCB00C01-570F-4A9B-8D69-199FDBA5723B}"))
|
||||||
|
$connections = $networkListManager.GetNetworkConnections()
|
||||||
|
|
||||||
|
$connections | ForEach-Object {
|
||||||
|
Write-Output $_.GetNetwork().GetName() "category was previously set to" $_.GetNetwork().GetCategory()
|
||||||
|
#$_.GetNetwork().SetCategory(1)
|
||||||
|
Write-Output $_.GetNetwork().GetName() "changed to category" $_.GetNetwork().GetCategory()
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
Set-NetworkTypeToPrivate
|
12
scripts/packer/scripts/microsoft-updates.bat
Normal file
12
scripts/packer/scripts/microsoft-updates.bat
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
net stop wuauserv
|
||||||
|
|
||||||
|
reg add "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\WindowsUpdate\Auto Update" /v EnableFeaturedSoftware /t REG_DWORD /d 1 /f
|
||||||
|
|
||||||
|
reg add "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\WindowsUpdate\Auto Update" /v IncludeRecommendedUpdates /t REG_DWORD /d 1 /f
|
||||||
|
|
||||||
|
echo Set ServiceManager = CreateObject("Microsoft.Update.ServiceManager") > "%temp%\temp.vbs"
|
||||||
|
echo Set NewUpdateService = ServiceManager.AddService2("7971f918-a847-4430-9279-4a52d1efe18d",7,"") >> "%temp%\temp.vbs"
|
||||||
|
|
||||||
|
cscript "%temp%\temp.vbs"
|
||||||
|
|
||||||
|
net start wuauserv
|
12
scripts/packer/scripts/microsoft-updates.ps1
Normal file
12
scripts/packer/scripts/microsoft-updates.ps1
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
Stop-Service -Name 'wuauserv'
|
||||||
|
|
||||||
|
Set-ItemProperty 'HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\WindowsUpdate\Auto Update' -Name 'EnableFeaturedSoftware' -Value 1 -Type DWord
|
||||||
|
Set-ItemProperty 'HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\WindowsUpdate\Auto Update' -Name 'IncludeRecommendedUpdates' -Value 1 -Type DWord
|
||||||
|
|
||||||
|
"Set ServiceManager = CreateObject(""Microsoft.Update.ServiceManager"")" | Out-File -FilePath 'C:\temp.vbs'
|
||||||
|
"Set NewUpdateService = ServiceManager.AddService2(""7971f918-a847-4430-9279-4a52d1efe18d"",7,"""")" | Out-File -FilePath 'C:\temp.vbs' -Append
|
||||||
|
|
||||||
|
cscript C:\temp.vbs
|
||||||
|
Remove-Item -Path 'C:\temp.vbs' -Force
|
||||||
|
|
||||||
|
Start-Service -Name 'wuauserv'
|
16
scripts/packer/scripts/pin-powershell.bat
Normal file
16
scripts/packer/scripts/pin-powershell.bat
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
rem https://connect.microsoft.com/PowerShell/feedback/details/1609288/pin-to-taskbar-no-longer-working-in-windows-10
|
||||||
|
|
||||||
|
set ps_link=A:\WindowsPowerShell.lnk
|
||||||
|
if exist e:\WindowsPowerShell.lnk (
|
||||||
|
set ps_link=e:\WindowsPowerShell.lnk
|
||||||
|
)
|
||||||
|
|
||||||
|
set pin_to_10=A:\PinTo10.exe
|
||||||
|
if exist e:\PinTo10.exe (
|
||||||
|
set pin_to_10=e:\PinTo10.exe
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
copy "%ps_link%" "%TEMP%\Windows PowerShell.lnk"
|
||||||
|
%pin_to_10% /PTFOL01:'%TEMP%' /PTFILE01:'Windows PowerShell.lnk'
|
||||||
|
exit /b 0
|
19
scripts/packer/scripts/set-powerplan.ps1
Normal file
19
scripts/packer/scripts/set-powerplan.ps1
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
Try {
|
||||||
|
Write-Output "Set power plan to high performance"
|
||||||
|
|
||||||
|
$HighPerf = powercfg -l | ForEach-Object { if ($_.contains("High performance")) { $_.split()[3] } }
|
||||||
|
|
||||||
|
# $HighPerf cannot be $null, we try activate this power profile with powercfg
|
||||||
|
if ($null -eq $HighPerf) {
|
||||||
|
throw "Error: HighPerf is null"
|
||||||
|
}
|
||||||
|
|
||||||
|
$CurrPlan = $(powercfg -getactivescheme).split()[3]
|
||||||
|
|
||||||
|
if ($CurrPlan -ne $HighPerf) { powercfg -setactive $HighPerf }
|
||||||
|
|
||||||
|
}
|
||||||
|
Catch {
|
||||||
|
Write-Warning -Message "Unable to set power plan to high performance"
|
||||||
|
Write-Warning $Error[0]
|
||||||
|
}
|
21
scripts/packer/scripts/set-shortcut.ps1
Normal file
21
scripts/packer/scripts/set-shortcut.ps1
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
[CmdletBinding()]
|
||||||
|
param(
|
||||||
|
[Parameter()]
|
||||||
|
[string]$SourceExe,
|
||||||
|
[string]$Arguments,
|
||||||
|
[string]$DestinationPath,
|
||||||
|
[string]$WorkingDirectory,
|
||||||
|
[String]$IconLocation
|
||||||
|
)
|
||||||
|
|
||||||
|
if ($IconLocation -eq '') {
|
||||||
|
$IconLocation = $SourceExe
|
||||||
|
}
|
||||||
|
|
||||||
|
$WshShell = New-Object -comObject WScript.Shell
|
||||||
|
$Shortcut = $WshShell.CreateShortcut($destinationPath)
|
||||||
|
$Shortcut.TargetPath = $SourceExe
|
||||||
|
$Shortcut.Arguments = $Arguments
|
||||||
|
$shortcut.WorkingDirectory = $WorkingDirectory
|
||||||
|
$shortcut.IconLocation = $IconLocation
|
||||||
|
$Shortcut.Save()
|
2
scripts/packer/scripts/set-winrm-automatic.bat
Normal file
2
scripts/packer/scripts/set-winrm-automatic.bat
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
echo Set WinRM start type to auto
|
||||||
|
sc config winrm start= auto
|
1
scripts/packer/scripts/uac-enable.bat
Normal file
1
scripts/packer/scripts/uac-enable.bat
Normal file
@ -0,0 +1 @@
|
|||||||
|
reg add "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System" /f /v EnableLUA /t REG_DWORD /d 1
|
96
scripts/packer/scripts/vm-guest-tools.ps1
Normal file
96
scripts/packer/scripts/vm-guest-tools.ps1
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
if (!( Test-Path "C:\Windows\Temp\7z1900-x64.msi")) {
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; (New-Object System.Net.WebClient).DownloadFile('https://www.7-zip.org/a/7z1900-x64.msi', 'C:\Windows\Temp\7z1900-x64.msi')
|
||||||
|
}
|
||||||
|
if (!(Test-Path "C:\Windows\Temp\7z1900-x64.msi")) {
|
||||||
|
Start-Sleep 5; [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; (New-Object System.Net.WebClient).DownloadFile('https://www.7-zip.org/a/7z1900-x64.msi', 'C:\Windows\Temp\7z1900-x64.msi')
|
||||||
|
}
|
||||||
|
cmd /c msiexec /qb /i C:\Windows\Temp\7z1900-x64.msi
|
||||||
|
|
||||||
|
if ("$env:PACKER_BUILDER_TYPE" -eq "vmware-iso") {
|
||||||
|
|
||||||
|
Write-Output "Using VMware"
|
||||||
|
if (Test-Path "C:\Users\vagrant\windows.iso") {
|
||||||
|
Move-Item -force C:\Users\vagrant\windows.iso C:\Windows\Temp
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(Test-Path "C:\Windows\Temp\windows.iso")) {
|
||||||
|
Try {
|
||||||
|
# Disabling the progress bar speeds up IWR https://github.com/PowerShell/PowerShell/issues/2138
|
||||||
|
$ProgressPreference = 'SilentlyContinue'
|
||||||
|
$pageContentLinks = (Invoke-WebRequest('https://softwareupdate.vmware.com/cds/vmw-desktop/ws') -UseBasicParsing).Links | where-object { $_.href -Match "[0-9]" } | Select-Object href | ForEach-Object { $_.href.Trim('/') }
|
||||||
|
$versionObject = $pageContentLinks | ForEach-Object { new-object System.Version ($_) } | sort-object -Descending | select-object -First 1 -Property:Major, Minor, Build
|
||||||
|
$newestVersion = $versionObject.Major.ToString() + "." + $versionObject.Minor.ToString() + "." + $versionObject.Build.ToString() | out-string
|
||||||
|
$newestVersion = $newestVersion.TrimEnd("`r?`n")
|
||||||
|
|
||||||
|
$nextURISubdirectoryObject = (Invoke-WebRequest("https://softwareupdate.vmware.com/cds/vmw-desktop/ws/$newestVersion/") -UseBasicParsing).Links | where-object { $_.href -Match "[0-9]" } | Select-Object href | where-object { $_.href -Match "[0-9]" }
|
||||||
|
$nextUriSubdirectory = $nextURISubdirectoryObject.href | Out-String
|
||||||
|
$nextUriSubdirectory = $nextUriSubdirectory.TrimEnd("`r?`n")
|
||||||
|
$newestVMwareToolsURL = "https://softwareupdate.vmware.com/cds/vmw-desktop/ws/$newestVersion/$nextURISubdirectory/windows/packages/tools-windows.tar"
|
||||||
|
Write-Output "The latest version of VMware tools has been determined to be downloadable from $newestVMwareToolsURL"
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; (New-Object System.Net.WebClient).DownloadFile("$newestVMwareToolsURL", 'C:\Windows\Temp\vmware-tools.tar')
|
||||||
|
}
|
||||||
|
Catch {
|
||||||
|
Write-Output "Unable to determine the latest version of VMware tools. Falling back to hardcoded URL."
|
||||||
|
(New-Object System.Net.WebClient).DownloadFile('https://softwareupdate.vmware.com/cds/vmw-desktop/ws/15.5.5/16285975/windows/packages/tools-windows.tar', 'C:\Windows\Temp\vmware-tools.tar')
|
||||||
|
}
|
||||||
|
cmd /c "C:\PROGRA~1\7-Zip\7z.exe" x C:\Windows\Temp\vmware-tools.tar -oC:\Windows\Temp
|
||||||
|
Move-Item c:\windows\temp\VMware-tools-windows-*.iso c:\windows\temp\windows.iso
|
||||||
|
Try { Remove-Item "C:\Program Files (x86)\VMWare" -Recurse -Force -ErrorAction Stop } Catch { Write-Output "Directory didn't exist to be removed." }
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd /c "C:\PROGRA~1\7-Zip\7z.exe" x "C:\Windows\Temp\windows.iso" -oC:\Windows\Temp\VMWare
|
||||||
|
cmd /c C:\Windows\Temp\VMWare\setup.exe /S /v"/qn REBOOT=R\"
|
||||||
|
|
||||||
|
Remove-Item -Force "C:\Windows\Temp\vmware-tools.tar"
|
||||||
|
Remove-Item -Force "C:\Windows\Temp\windows.iso"
|
||||||
|
Remove-Item -Force -Recurse "C:\Windows\Temp\VMware"
|
||||||
|
}
|
||||||
|
|
||||||
|
if ("$env:PACKER_BUILDER_TYPE" -eq "virtualbox-iso") {
|
||||||
|
Write-Output "Using Virtualbox"
|
||||||
|
if (Test-Path "C:\Users\vagrant\VBoxGuestAdditions.iso") {
|
||||||
|
Move-Item -Force C:\Users\vagrant\VBoxGuestAdditions.iso C:\Windows\Temp
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(Test-Path "C:\Windows\Temp\VBoxGuestAdditions.iso")) {
|
||||||
|
Try {
|
||||||
|
$pageContentLinks = (Invoke-WebRequest('https://download.virtualbox.org/virtualbox') -UseBasicParsing).Links | where-object { $_.href -Match "[0-9]" } | Select-Object href | where-object { $_.href -NotMatch "BETA" } | where-object { $_.href -NotMatch "RC" } | where-object { $_.href -Match "[0-9]\.[0-9]" } | ForEach-Object { $_.href.Trim('/') }
|
||||||
|
$versionObject = $pageContentLinks | ForEach-Object { new-object System.Version ($_) } | sort-object -Descending | select-object -First 1 -Property:Major, Minor, Build
|
||||||
|
$newestVersion = $versionObject.Major.ToString() + "." + $versionObject.Minor.ToString() + "." + $versionObject.Build.ToString() | out-string
|
||||||
|
$newestVersion = $newestVersion.TrimEnd("`r?`n")
|
||||||
|
|
||||||
|
$nextURISubdirectoryObject = (Invoke-WebRequest("https://download.virtualbox.org/virtualbox/$newestVersion/") -UseBasicParsing).Links | Select-Object href | where-object { $_.href -Match "GuestAdditions" }
|
||||||
|
$nextUriSubdirectory = $nextURISubdirectoryObject.href | Out-String
|
||||||
|
$nextUriSubdirectory = $nextUriSubdirectory.TrimEnd("`r?`n")
|
||||||
|
$newestVboxToolsURL = "https://download.virtualbox.org/virtualbox/$newestVersion/$nextUriSubdirectory"
|
||||||
|
Write-Output "The latest version of VirtualBox tools has been determined to be downloadable from $newestVboxToolsURL"
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; (New-Object System.Net.WebClient).DownloadFile("$newestVboxToolsURL", 'C:\Windows\Temp\VBoxGuestAdditions.iso')
|
||||||
|
}
|
||||||
|
Catch {
|
||||||
|
Write-Output "Unable to determine the latest version of VBox tools. Falling back to hardcoded URL."
|
||||||
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; (New-Object System.Net.WebClient).DownloadFile('https://download.virtualbox.org/virtualbox/6.1.8/VBoxGuestAdditions_6.1.8.iso', 'C:\Windows\Temp\VBoxGuestAdditions.iso')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd /c ""C:\PROGRA~1\7-Zip\7z.exe" x C:\Windows\Temp\VBoxGuestAdditions.iso -oC:\Windows\Temp\virtualbox"
|
||||||
|
Get-ChildItem "C:\Windows\Temp\virtualbox\cert\" -Filter vbox*.cer | Foreach-Object { C:\Windows\Temp\virtualbox\cert\VBoxCertUtil add-trusted-publisher $_.FullName --root $_.FullName }
|
||||||
|
cmd /c C:\Windows\Temp\virtualbox\VBoxWindowsAdditions.exe /S
|
||||||
|
cmd /c rd /S /Q "C:\Windows\Temp\virtualbox"
|
||||||
|
}
|
||||||
|
|
||||||
|
if ("$env:PACKER_BUILDER_TYPE" -eq "parallels-iso") {
|
||||||
|
Write-Output "Using Parallels Desktop"
|
||||||
|
# This is required when using Parallels Desktop
|
||||||
|
# Currently the installation of Parallels Tools is broken if you're installing in Windows Server & Windows Server Core
|
||||||
|
# You will encounter an error in printui.dll module not found message.
|
||||||
|
# This feature will add the required libraries for printing services.
|
||||||
|
|
||||||
|
# Parallels Tools is required for sync_folder to work.
|
||||||
|
# Vagrantfile config: v.update_guest_tools = true will be installed with no issues
|
||||||
|
if ($(Get-ItemProperty "HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion").ProductName.StartsWith("Windows Server")) {
|
||||||
|
Write-Output "Installing Print Server service"
|
||||||
|
Install-WindowsFeature -Name Print-Server
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd /c msiexec /qb /x C:\Windows\Temp\7z1900-x64.msi
|
260
scripts/packer/scripts/win-updates.ps1
Normal file
260
scripts/packer/scripts/win-updates.ps1
Normal file
@ -0,0 +1,260 @@
|
|||||||
|
[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSReviewUnusedParameter', '')]
|
||||||
|
param($global:RestartRequired = 0,
|
||||||
|
$global:MoreUpdates = 0,
|
||||||
|
$global:MaxCycles = 5,
|
||||||
|
$MaxUpdatesPerCycle = 500,
|
||||||
|
$BeginWithRestart = 0)
|
||||||
|
|
||||||
|
$Logfile = "C:\Windows\Temp\win-updates.log"
|
||||||
|
|
||||||
|
$enable_winrm_script = 'a:\enable-winrm.ps1'
|
||||||
|
if (test-path 'e:\enable-winrm.ps1') {
|
||||||
|
$enable_winrm_script = 'e:\enable-winrm.ps1'
|
||||||
|
}
|
||||||
|
|
||||||
|
function LogWrite {
|
||||||
|
Param ([string]$logstring)
|
||||||
|
$now = Get-Date -format s
|
||||||
|
Add-Content $Logfile -value "$now $logstring"
|
||||||
|
Write-Output $logstring
|
||||||
|
}
|
||||||
|
|
||||||
|
function Check-ContinueRestartOrEnd() {
|
||||||
|
$RegistryKey = "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Run"
|
||||||
|
$RegistryEntry = "InstallWindowsUpdates"
|
||||||
|
switch ($global:RestartRequired) {
|
||||||
|
0 {
|
||||||
|
$prop = (Get-ItemProperty $RegistryKey).$RegistryEntry
|
||||||
|
if ($prop) {
|
||||||
|
LogWrite "Restart Registry Entry Exists - Removing It"
|
||||||
|
Remove-ItemProperty -Path $RegistryKey -Name $RegistryEntry -ErrorAction SilentlyContinue
|
||||||
|
}
|
||||||
|
|
||||||
|
LogWrite "No Restart Required"
|
||||||
|
Check-WindowsUpdates
|
||||||
|
|
||||||
|
if (($global:MoreUpdates -eq 1) -and ($script:Cycles -le $global:MaxCycles)) {
|
||||||
|
Install-WindowsUpdates
|
||||||
|
}
|
||||||
|
elseif ($script:Cycles -gt $global:MaxCycles) {
|
||||||
|
LogWrite "Exceeded Cycle Count - Stopping"
|
||||||
|
LogWrite "==> Running '$enable_winrm_script'..."
|
||||||
|
& $enable_winrm_script
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
LogWrite "Done Installing Windows Updates"
|
||||||
|
LogWrite "==> Running '$enable_winrm_script'..."
|
||||||
|
& $enable_winrm_script
|
||||||
|
}
|
||||||
|
}
|
||||||
|
1 {
|
||||||
|
$prop = (Get-ItemProperty $RegistryKey).$RegistryEntry
|
||||||
|
if (-not $prop) {
|
||||||
|
LogWrite "Restart Registry Entry Does Not Exist - Creating It"
|
||||||
|
Set-ItemProperty -Path $RegistryKey -Name $RegistryEntry -Value "C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -File $($script:ScriptPath) -MaxUpdatesPerCycle $($MaxUpdatesPerCycle)"
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
LogWrite "Restart Registry Entry Exists Already"
|
||||||
|
}
|
||||||
|
|
||||||
|
LogWrite "Restart Required - Restarting..."
|
||||||
|
Restart-Computer
|
||||||
|
}
|
||||||
|
default {
|
||||||
|
LogWrite "Unsure If A Restart Is Required"
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function Install-WindowsUpdates()
|
||||||
|
{
|
||||||
|
[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]
|
||||||
|
[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseSingularNouns', '')]
|
||||||
|
param()
|
||||||
|
$script:Cycles++
|
||||||
|
LogWrite "Evaluating Available Updates with limit of $($MaxUpdatesPerCycle):"
|
||||||
|
$UpdatesToDownload = New-Object -ComObject 'Microsoft.Update.UpdateColl'
|
||||||
|
$script:i = 0;
|
||||||
|
$CurrentUpdates = $SearchResult.Updates
|
||||||
|
while ($script:i -lt $CurrentUpdates.Count -and $script:CycleUpdateCount -lt $MaxUpdatesPerCycle) {
|
||||||
|
$Update = $CurrentUpdates.Item($script:i)
|
||||||
|
if ($null -ne $Update) {
|
||||||
|
[bool]$addThisUpdate = $false
|
||||||
|
if ($Update.InstallationBehavior.CanRequestUserInput) {
|
||||||
|
LogWrite "> Skipping: $($Update.Title) because it requires user input"
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (!($Update.EulaAccepted)) {
|
||||||
|
LogWrite "> Note: $($Update.Title) has a license agreement that must be accepted. Accepting the license."
|
||||||
|
$Update.AcceptEula()
|
||||||
|
[bool]$addThisUpdate = $true
|
||||||
|
$script:CycleUpdateCount++
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
[bool]$addThisUpdate = $true
|
||||||
|
$script:CycleUpdateCount++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ([bool]$addThisUpdate) {
|
||||||
|
LogWrite "Adding: $($Update.Title)"
|
||||||
|
$UpdatesToDownload.Add($Update) | Out-Null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$script:i++
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($UpdatesToDownload.Count -eq 0) {
|
||||||
|
LogWrite "No Updates To Download..."
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
LogWrite 'Downloading Updates...'
|
||||||
|
$ok = 0;
|
||||||
|
while (! $ok) {
|
||||||
|
try {
|
||||||
|
$Downloader = $UpdateSession.CreateUpdateDownloader()
|
||||||
|
$Downloader.Updates = $UpdatesToDownload
|
||||||
|
$Downloader.Download()
|
||||||
|
$ok = 1;
|
||||||
|
}
|
||||||
|
catch {
|
||||||
|
LogWrite $_.Exception | Format-List -force
|
||||||
|
LogWrite "Error downloading updates. Retrying in 30s."
|
||||||
|
$script:attempts = $script:attempts + 1
|
||||||
|
Start-Sleep -s 30
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$UpdatesToInstall = New-Object -ComObject 'Microsoft.Update.UpdateColl'
|
||||||
|
[bool]$rebootMayBeRequired = $false
|
||||||
|
LogWrite 'The following updates are downloaded and ready to be installed:'
|
||||||
|
foreach ($Update in $SearchResult.Updates) {
|
||||||
|
if (($Update.IsDownloaded)) {
|
||||||
|
LogWrite "> $($Update.Title)"
|
||||||
|
$UpdatesToInstall.Add($Update) | Out-Null
|
||||||
|
|
||||||
|
if ($Update.InstallationBehavior.RebootBehavior -gt 0) {
|
||||||
|
[bool]$rebootMayBeRequired = $true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($UpdatesToInstall.Count -eq 0) {
|
||||||
|
LogWrite 'No updates available to install...'
|
||||||
|
$global:MoreUpdates = 0
|
||||||
|
$global:RestartRequired = 0
|
||||||
|
LogWrite "==> Running '$enable_winrm_script'..."
|
||||||
|
& $enable_winrm_script
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($rebootMayBeRequired) {
|
||||||
|
LogWrite 'These updates may require a reboot'
|
||||||
|
$global:RestartRequired = 1
|
||||||
|
}
|
||||||
|
|
||||||
|
LogWrite 'Installing updates...'
|
||||||
|
|
||||||
|
$Installer = $script:UpdateSession.CreateUpdateInstaller()
|
||||||
|
$Installer.Updates = $UpdatesToInstall
|
||||||
|
$InstallationResult = $Installer.Install()
|
||||||
|
|
||||||
|
LogWrite "Installation Result: $($InstallationResult.ResultCode)"
|
||||||
|
LogWrite "Reboot Required: $($InstallationResult.RebootRequired)"
|
||||||
|
LogWrite 'Listing of updates installed and individual installation results:'
|
||||||
|
if ($InstallationResult.RebootRequired) {
|
||||||
|
$global:RestartRequired = 1
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$global:RestartRequired = 0
|
||||||
|
}
|
||||||
|
|
||||||
|
for ($i = 0; $i -lt $UpdatesToInstall.Count; $i++) {
|
||||||
|
New-Object -TypeName PSObject -Property @{
|
||||||
|
Title = $UpdatesToInstall.Item($i).Title
|
||||||
|
Result = $InstallationResult.GetUpdateResult($i).ResultCode
|
||||||
|
}
|
||||||
|
LogWrite "Item: $($UpdatesToInstall.Item($i).Title)"
|
||||||
|
LogWrite "Result: $($InstallationResult.GetUpdateResult($i).ResultCode)"
|
||||||
|
}
|
||||||
|
|
||||||
|
Check-ContinueRestartOrEnd
|
||||||
|
}
|
||||||
|
|
||||||
|
function Check-WindowsUpdates() {
|
||||||
|
[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]
|
||||||
|
[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseSingularNouns', '')]
|
||||||
|
param()
|
||||||
|
LogWrite "Checking For Windows Updates"
|
||||||
|
$Username = $env:USERDOMAIN + "\" + $env:USERNAME
|
||||||
|
LogWrite "Script: $script:ScriptPath `nScript User: $Username `nStarted: $(Get-Date)"
|
||||||
|
|
||||||
|
$script:UpdateSearcher = $script:UpdateSession.CreateUpdateSearcher()
|
||||||
|
$script:successful = $FALSE
|
||||||
|
$script:attempts = 0
|
||||||
|
$script:maxAttempts = 12
|
||||||
|
while (-not $script:successful -and $script:attempts -lt $script:maxAttempts) {
|
||||||
|
try {
|
||||||
|
$script:SearchResult = $script:UpdateSearcher.Search("IsInstalled=0 and Type='Software' and IsHidden=0")
|
||||||
|
$script:successful = $TRUE
|
||||||
|
}
|
||||||
|
catch {
|
||||||
|
LogWrite $_.Exception | Format-List -force
|
||||||
|
LogWrite "Search call to UpdateSearcher was unsuccessful. Retrying in 10s."
|
||||||
|
$script:attempts = $script:attempts + 1
|
||||||
|
Start-Sleep -s 10
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($SearchResult.Updates.Count -ne 0) {
|
||||||
|
$Message = "There are " + $SearchResult.Updates.Count + " more updates."
|
||||||
|
LogWrite $Message
|
||||||
|
try {
|
||||||
|
for ($i = 0; $i -lt $script:SearchResult.Updates.Count; $i++) {
|
||||||
|
LogWrite $script:SearchResult.Updates.Item($i).Title
|
||||||
|
LogWrite $script:SearchResult.Updates.Item($i).Description
|
||||||
|
LogWrite $script:SearchResult.Updates.Item($i).RebootRequired
|
||||||
|
LogWrite $script:SearchResult.Updates.Item($i).EulaAccepted
|
||||||
|
}
|
||||||
|
$global:MoreUpdates = 1
|
||||||
|
}
|
||||||
|
catch {
|
||||||
|
LogWrite $_.Exception | Format-List -force
|
||||||
|
LogWrite "Showing SearchResult was unsuccessful. Rebooting."
|
||||||
|
$global:RestartRequired = 1
|
||||||
|
$global:MoreUpdates = 0
|
||||||
|
Check-ContinueRestartOrEnd
|
||||||
|
LogWrite "Show never happen to see this text!"
|
||||||
|
Restart-Computer
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
LogWrite 'There are no applicable updates'
|
||||||
|
$global:RestartRequired = 0
|
||||||
|
$global:MoreUpdates = 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$script:ScriptName = $MyInvocation.MyCommand.ToString()
|
||||||
|
$script:ScriptPath = $MyInvocation.MyCommand.Path
|
||||||
|
$script:UpdateSession = New-Object -ComObject 'Microsoft.Update.Session'
|
||||||
|
$script:UpdateSession.ClientApplicationID = 'Packer Windows Update Installer'
|
||||||
|
$script:UpdateSearcher = $script:UpdateSession.CreateUpdateSearcher()
|
||||||
|
$script:SearchResult = New-Object -ComObject 'Microsoft.Update.UpdateColl'
|
||||||
|
$script:Cycles = 0
|
||||||
|
$script:CycleUpdateCount = 0
|
||||||
|
|
||||||
|
if ($BeginWithRestart) {
|
||||||
|
$global:RestartRequired = 1
|
||||||
|
Check-ContinueRestartOrEnd
|
||||||
|
}
|
||||||
|
|
||||||
|
Check-WindowsUpdates
|
||||||
|
if ($global:MoreUpdates -eq 1) {
|
||||||
|
Install-WindowsUpdates
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Check-ContinueRestartOrEnd
|
||||||
|
}
|
91
scripts/packer/vagrantfile-windows_10.template
Normal file
91
scripts/packer/vagrantfile-windows_10.template
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
# -*- mode: ruby -*-
|
||||||
|
# vi: set ft=ruby :
|
||||||
|
|
||||||
|
Vagrant.require_version ">= 1.6.2"
|
||||||
|
|
||||||
|
Vagrant.configure("2") do |config|
|
||||||
|
config.vm.define "vagrant-windows-10-preview"
|
||||||
|
config.vm.box = "windows_10_preview"
|
||||||
|
config.vm.communicator = "winrm"
|
||||||
|
|
||||||
|
# Admin user name and password
|
||||||
|
config.winrm.username = "vagrant"
|
||||||
|
config.winrm.password = "vagrant"
|
||||||
|
|
||||||
|
config.vm.guest = :windows
|
||||||
|
config.windows.halt_timeout = 15
|
||||||
|
|
||||||
|
config.vm.network :forwarded_port, guest: 3389, host: 3389, id: "rdp", auto_correct: true
|
||||||
|
|
||||||
|
config.vm.provider :virtualbox do |v, override|
|
||||||
|
#v.gui = true
|
||||||
|
v.customize ["modifyvm", :id, "--memory", 2048]
|
||||||
|
v.customize ["modifyvm", :id, "--cpus", 2]
|
||||||
|
v.customize ["modifyvm", :id, "--vram", 128]
|
||||||
|
v.customize ["modifyvm", :id, "--clipboard", "bidirectional"]
|
||||||
|
v.customize ["setextradata", "global", "GUI/SuppressMessages", "all" ]
|
||||||
|
end
|
||||||
|
|
||||||
|
config.vm.provider :vmware_fusion do |v, override|
|
||||||
|
v.gui = true
|
||||||
|
v.vmx["memsize"] = "2048"
|
||||||
|
v.vmx["numvcpus"] = "2"
|
||||||
|
v.vmx["ethernet0.virtualDev"] = "vmxnet3"
|
||||||
|
v.vmx["RemoteDisplay.vnc.enabled"] = "false"
|
||||||
|
v.vmx["RemoteDisplay.vnc.port"] = "5900"
|
||||||
|
v.vmx["scsi0.virtualDev"] = "lsisas1068"
|
||||||
|
v.vmx["gui.fitguestusingnativedisplayresolution"] = "TRUE"
|
||||||
|
v.vmx["mks.enable3d"] = "TRUE"
|
||||||
|
v.vmx["mks.forceDiscreteGPU"] = "TRUE"
|
||||||
|
v.vmx["gui.fullscreenatpoweron"] = "TRUE"
|
||||||
|
v.vmx["gui.viewmodeatpoweron"] = "fullscreen"
|
||||||
|
v.vmx["gui.lastPoweredViewMode"] = "fullscreen"
|
||||||
|
v.vmx["sound.startconnected"] = "FALSE"
|
||||||
|
v.vmx["sound.present"] = "FALSE"
|
||||||
|
v.vmx["sound.autodetect"] = "TRUE"
|
||||||
|
v.enable_vmrun_ip_lookup = false
|
||||||
|
v.whitelist_verified = true
|
||||||
|
v.vmx["hgfs.linkRootShare"] = "FALSE"
|
||||||
|
end
|
||||||
|
|
||||||
|
config.vm.provider :vmware_workstation do |v, override|
|
||||||
|
v.gui = true
|
||||||
|
v.vmx["memsize"] = "2048"
|
||||||
|
v.vmx["numvcpus"] = "2"
|
||||||
|
v.vmx["ethernet0.virtualDev"] = "vmxnet3"
|
||||||
|
v.vmx["RemoteDisplay.vnc.enabled"] = "false"
|
||||||
|
v.vmx["RemoteDisplay.vnc.port"] = "5900"
|
||||||
|
v.vmx["scsi0.virtualDev"] = "lsisas1068"
|
||||||
|
v.enable_vmrun_ip_lookup = false
|
||||||
|
v.whitelist_verified = true
|
||||||
|
v.vmx["hgfs.linkRootShare"] = "FALSE"
|
||||||
|
end
|
||||||
|
|
||||||
|
config.vm.provider "hyperv" do |v|
|
||||||
|
v.cpus = 2
|
||||||
|
v.maxmemory = 2048
|
||||||
|
v.linked_clone = true
|
||||||
|
end
|
||||||
|
|
||||||
|
config.vm.provider :libvirt do |libvirt, override|
|
||||||
|
libvirt.memory = 2048
|
||||||
|
libvirt.cpus = 2
|
||||||
|
|
||||||
|
# Use WinRM for the default synced folder; or disable it if
|
||||||
|
# WinRM is not available. Linux hosts don't support SMB,
|
||||||
|
# and Windows guests don't support NFS/9P/rsync
|
||||||
|
# See https://github.com/Cimpress-MCP/vagrant-winrm-syncedfolders
|
||||||
|
if Vagrant.has_plugin?("vagrant-winrm-syncedfolders")
|
||||||
|
override.vm.synced_folder ".", "/vagrant", type: "winrm"
|
||||||
|
else
|
||||||
|
override.vm.synced_folder ".", "/vagrant", disabled: true
|
||||||
|
end
|
||||||
|
|
||||||
|
# Enable Hyper-V enlightments, see
|
||||||
|
# https://blog.wikichoon.com/2014/07/enabling-hyper-v-enlightenments-with-kvm.html
|
||||||
|
libvirt.hyperv_feature :name => 'stimer', :state => 'on'
|
||||||
|
libvirt.hyperv_feature :name => 'relaxed', :state => 'on'
|
||||||
|
libvirt.hyperv_feature :name => 'vapic', :state => 'on'
|
||||||
|
libvirt.hyperv_feature :name => 'synic', :state => 'on'
|
||||||
|
end
|
||||||
|
end
|
230
scripts/packer/windows_10.json
Normal file
230
scripts/packer/windows_10.json
Normal file
@ -0,0 +1,230 @@
|
|||||||
|
{
|
||||||
|
"builders": [
|
||||||
|
{
|
||||||
|
"boot_command": ["a<wait>a<wait>a"],
|
||||||
|
"boot_wait": "-1s",
|
||||||
|
"cd_files": [
|
||||||
|
"{{user `autounattend`}}",
|
||||||
|
"./floppy/WindowsPowershell.lnk",
|
||||||
|
"./floppy/PinTo10.exe",
|
||||||
|
"./scripts/fixnetwork.ps1",
|
||||||
|
"./scripts/disable-screensaver.ps1",
|
||||||
|
"./scripts/disable-winrm.ps1",
|
||||||
|
"./scripts/enable-winrm.ps1",
|
||||||
|
"./scripts/microsoft-updates.ps1",
|
||||||
|
"./scripts/win-updates.ps1",
|
||||||
|
"./scripts/set-shortcut.ps1"
|
||||||
|
],
|
||||||
|
"communicator": "winrm",
|
||||||
|
"configuration_version": "10.0",
|
||||||
|
"cpus": "{{user `cpus`}}",
|
||||||
|
"disk_size": "{{user `disk_size`}}",
|
||||||
|
"enable_dynamic_memory": false,
|
||||||
|
"enable_mac_spoofing": true,
|
||||||
|
"enable_secure_boot": true,
|
||||||
|
"enable_virtualization_extensions": true,
|
||||||
|
"generation": "2",
|
||||||
|
"guest_additions_mode": "disable",
|
||||||
|
"iso_checksum": "{{user `iso_checksum`}}",
|
||||||
|
"iso_url": "{{user `iso_url`}}",
|
||||||
|
"memory": "{{user `memory`}}",
|
||||||
|
"shutdown_command": "shutdown /s /t 10 /f /d p:4:1 /c \"Packer Shutdown\"",
|
||||||
|
"switch_name": "Default Switch",
|
||||||
|
"type": "hyperv-iso",
|
||||||
|
"vm_name": "{{user `vm_name`}}",
|
||||||
|
"winrm_password": "vagrant",
|
||||||
|
"winrm_timeout": "{{ user `winrm_timeout` }}",
|
||||||
|
"winrm_username": "vagrant"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"boot_command": ["a<wait>a<wait>a"],
|
||||||
|
"boot_wait": "-1s",
|
||||||
|
"cd_files": [
|
||||||
|
"{{user `autounattend`}}",
|
||||||
|
"./floppy/WindowsPowershell.lnk",
|
||||||
|
"./floppy/PinTo10.exe",
|
||||||
|
"./scripts/fixnetwork.ps1",
|
||||||
|
"./scripts/disable-screensaver.ps1",
|
||||||
|
"./scripts/disable-winrm.ps1",
|
||||||
|
"./scripts/enable-winrm.ps1",
|
||||||
|
"./scripts/microsoft-updates.ps1",
|
||||||
|
"./scripts/win-updates.ps1",
|
||||||
|
"./scripts/set-shortcut.ps1"
|
||||||
|
],
|
||||||
|
"communicator": "winrm",
|
||||||
|
"cpus": "{{user `cpus`}}",
|
||||||
|
"disk_adapter_type": "lsisas1068",
|
||||||
|
"disk_size": "{{user `disk_size`}}",
|
||||||
|
"disk_type_id": "1",
|
||||||
|
"guest_os_type": "windows9-64",
|
||||||
|
"headless": "{{user `headless`}}",
|
||||||
|
"iso_checksum": "{{user `iso_checksum`}}",
|
||||||
|
"iso_url": "{{user `iso_url`}}",
|
||||||
|
"memory": "{{user `memory`}}",
|
||||||
|
"shutdown_command": "shutdown /s /t 10 /f /d p:4:1 /c \"Packer Shutdown\"",
|
||||||
|
"type": "vmware-iso",
|
||||||
|
"version": "19",
|
||||||
|
"vm_name": "{{user `vm_name`}}",
|
||||||
|
"vmx_data": {
|
||||||
|
"firmware": "efi",
|
||||||
|
"RemoteDisplay.vnc.enabled": "false",
|
||||||
|
"RemoteDisplay.vnc.port": "5900"
|
||||||
|
},
|
||||||
|
"vmx_remove_ethernet_interfaces": true,
|
||||||
|
"vnc_port_max": 5980,
|
||||||
|
"vnc_port_min": 5900,
|
||||||
|
"winrm_password": "vagrant",
|
||||||
|
"winrm_timeout": "{{ user `winrm_timeout` }}",
|
||||||
|
"winrm_username": "vagrant"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"boot_command": ["a<wait>a<wait>a"],
|
||||||
|
"boot_wait": "-1s",
|
||||||
|
"cd_files": [
|
||||||
|
"{{user `autounattend`}}",
|
||||||
|
"./floppy/WindowsPowershell.lnk",
|
||||||
|
"./floppy/PinTo10.exe",
|
||||||
|
"./scripts/fixnetwork.ps1",
|
||||||
|
"./scripts/disable-screensaver.ps1",
|
||||||
|
"./scripts/disable-winrm.ps1",
|
||||||
|
"./scripts/enable-winrm.ps1",
|
||||||
|
"./scripts/microsoft-updates.ps1",
|
||||||
|
"./scripts/win-updates.ps1",
|
||||||
|
"./scripts/set-shortcut.ps1"
|
||||||
|
],
|
||||||
|
"communicator": "winrm",
|
||||||
|
"cpus": "{{user `cpus`}}",
|
||||||
|
"disk_size": "{{user `disk_size`}}",
|
||||||
|
"firmware": "efi",
|
||||||
|
"guest_additions_mode": "disable",
|
||||||
|
"guest_os_type": "Windows10_64",
|
||||||
|
"headless": "{{user `headless`}}",
|
||||||
|
"iso_checksum": "{{user `iso_checksum`}}",
|
||||||
|
"iso_url": "{{user `iso_url`}}",
|
||||||
|
"memory": "{{user `memory`}}",
|
||||||
|
"shutdown_command": "shutdown /s /t 10 /f /d p:4:1 /c \"Packer Shutdown\"",
|
||||||
|
"type": "virtualbox-iso",
|
||||||
|
"vm_name": "{{user `vm_name`}}",
|
||||||
|
"winrm_password": "vagrant",
|
||||||
|
"winrm_timeout": "{{ user `winrm_timeout` }}",
|
||||||
|
"winrm_username": "vagrant"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"boot_command": "",
|
||||||
|
"boot_wait": "6m",
|
||||||
|
"communicator": "winrm",
|
||||||
|
"cpus": "{{user `cpus`}}",
|
||||||
|
"disk_size": "{{user `disk_size`}}",
|
||||||
|
"floppy_files": [
|
||||||
|
"{{user `autounattend`}}",
|
||||||
|
"./floppy/WindowsPowershell.lnk",
|
||||||
|
"./floppy/PinTo10.exe",
|
||||||
|
"./scripts/fixnetwork.ps1",
|
||||||
|
"./scripts/disable-screensaver.ps1",
|
||||||
|
"./scripts/disable-winrm.ps1",
|
||||||
|
"./scripts/enable-winrm.ps1",
|
||||||
|
"./scripts/microsoft-updates.ps1",
|
||||||
|
"./scripts/win-updates.ps1",
|
||||||
|
"./scripts/set-shortcut.ps1"
|
||||||
|
],
|
||||||
|
"guest_os_type": "win-10",
|
||||||
|
"iso_checksum": "{{user `iso_checksum`}}",
|
||||||
|
"iso_url": "{{user `iso_url`}}",
|
||||||
|
"memory": "{{user `memory`}}",
|
||||||
|
"shutdown_command": "shutdown /s /t 10 /f /d p:4:1 /c \"Packer Shutdown\"",
|
||||||
|
"type": "parallels-iso",
|
||||||
|
"parallels_tools_flavor": "win",
|
||||||
|
"prlctl": [
|
||||||
|
[
|
||||||
|
"set",
|
||||||
|
"{{.Name}}",
|
||||||
|
"--efi-boot",
|
||||||
|
"off"
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"vm_name": "{{user `vm_name`}}",
|
||||||
|
"winrm_password": "vagrant",
|
||||||
|
"winrm_timeout": "{{ user `winrm_timeout` }}",
|
||||||
|
"winrm_username": "vagrant"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"post-processors": [
|
||||||
|
{
|
||||||
|
"keep_input_artifact": false,
|
||||||
|
"output": "cmderdev-10_{{.Provider}}.box",
|
||||||
|
"type": "vagrant",
|
||||||
|
"vagrantfile_template": "vagrantfile-windows_10.template"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"provisioners": [
|
||||||
|
{
|
||||||
|
"execute_command": "{{ .Vars }} cmd /c \"{{ .Path }}\"",
|
||||||
|
"remote_path": "/tmp/script.bat",
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/enable-rdp.bat"
|
||||||
|
],
|
||||||
|
"type": "windows-shell"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/vm-guest-tools.ps1",
|
||||||
|
"./scripts/debloat-windows.ps1"
|
||||||
|
],
|
||||||
|
"type": "powershell"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"restart_timeout": "{{user `restart_timeout`}}",
|
||||||
|
"type": "windows-restart"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/set-powerplan.ps1",
|
||||||
|
"./scripts/docker/disable-windows-defender.ps1"
|
||||||
|
],
|
||||||
|
"type": "powershell"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"execute_command": "{{ .Vars }} cmd /c \"{{ .Path }}\"",
|
||||||
|
"remote_path": "/tmp/script.bat",
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/chocolatey.bat"
|
||||||
|
],
|
||||||
|
"type": "windows-shell"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/chocopacks.ps1"
|
||||||
|
],
|
||||||
|
"type": "powershell"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"execute_command": "{{ .Vars }} cmd /c \"{{ .Path }}\"",
|
||||||
|
"remote_path": "/tmp/script.bat",
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/pin-powershell.bat",
|
||||||
|
"./scripts/compile-dotnet-assemblies.bat",
|
||||||
|
"./scripts/set-winrm-automatic.bat",
|
||||||
|
"./scripts/uac-enable.bat",
|
||||||
|
"./scripts/dis-updates.bat",
|
||||||
|
"./scripts/compact.bat"
|
||||||
|
],
|
||||||
|
"type": "windows-shell"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"variables": {
|
||||||
|
"autounattend": "./answer_files/10_efi/Autounattend.xml",
|
||||||
|
"cpus": "2",
|
||||||
|
"disk_size": "262144",
|
||||||
|
"disk_type_id": "1",
|
||||||
|
"memory": "2048",
|
||||||
|
"headless": "false",
|
||||||
|
"iso_url": "./iso/Windows_10.iso",
|
||||||
|
"iso_checksum": "none",
|
||||||
|
"restart_timeout": "5m",
|
||||||
|
"vhv_enable": "false",
|
||||||
|
"virtio_win_iso": "~/virtio-win.iso",
|
||||||
|
"vm_name": "cmderdev10",
|
||||||
|
"winrm_timeout": "6h",
|
||||||
|
"vmx_version": "14"
|
||||||
|
}
|
||||||
|
}
|
249
scripts/packer/windows_11.json
Normal file
249
scripts/packer/windows_11.json
Normal file
@ -0,0 +1,249 @@
|
|||||||
|
{
|
||||||
|
"builders": [
|
||||||
|
{
|
||||||
|
"boot_command": [
|
||||||
|
"<leftShiftOn><f10><leftShiftOff><wait>",
|
||||||
|
"reg add HKLM\\SYSTEM\\Setup\\LabConfig /t REG_DWORD /v BypassTPMCheck /d 1<return>",
|
||||||
|
"reg add HKLM\\SYSTEM\\Setup\\LabConfig /t REG_DWORD /v BypassSecureBootCheck /d 1<return><wait>",
|
||||||
|
"exit<return>",
|
||||||
|
"<wait><return>"
|
||||||
|
],
|
||||||
|
"boot_wait": "2m",
|
||||||
|
"communicator": "winrm",
|
||||||
|
"configuration_version": "8.0",
|
||||||
|
"cpus": "2",
|
||||||
|
"disk_size": "{{user `disk_size`}}",
|
||||||
|
"floppy_files": [
|
||||||
|
"{{user `autounattend`}}",
|
||||||
|
"./floppy/WindowsPowershell.lnk",
|
||||||
|
"./floppy/PinTo10.exe",
|
||||||
|
"./scripts/fixnetwork.ps1",
|
||||||
|
"./scripts/disable-screensaver.ps1",
|
||||||
|
"./scripts/disable-winrm.ps1",
|
||||||
|
"./scripts/enable-winrm.ps1",
|
||||||
|
"./scripts/microsoft-updates.bat",
|
||||||
|
"./scripts/win-updates.ps1"
|
||||||
|
],
|
||||||
|
"guest_additions_mode": "none",
|
||||||
|
"iso_checksum": "{{user `iso_checksum`}}",
|
||||||
|
"iso_url": "{{user `iso_url`}}",
|
||||||
|
"memory": "{{user `memory`}}",
|
||||||
|
"shutdown_command": "shutdown /s /t 10 /f /d p:4:1 /c \"Packer Shutdown\"",
|
||||||
|
"switch_name": "{{user `switch_name`}}",
|
||||||
|
"type": "hyperv-iso",
|
||||||
|
"vm_name": "{{user `vm_name`}}",
|
||||||
|
"winrm_password": "vagrant",
|
||||||
|
"winrm_timeout": "{{user `winrm_timeout`}}",
|
||||||
|
"winrm_username": "vagrant"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"boot_command": [
|
||||||
|
"<leftShiftOn><f10><leftShiftOff><wait>",
|
||||||
|
"reg add HKLM\\SYSTEM\\Setup\\LabConfig /t REG_DWORD /v BypassTPMCheck /d 1<return>",
|
||||||
|
"reg add HKLM\\SYSTEM\\Setup\\LabConfig /t REG_DWORD /v BypassSecureBootCheck /d 1<return><wait>",
|
||||||
|
"exit<return>",
|
||||||
|
"<wait><return>"
|
||||||
|
],
|
||||||
|
"boot_wait": "2m",
|
||||||
|
"communicator": "winrm",
|
||||||
|
"cpus": 2,
|
||||||
|
"disk_adapter_type": "lsisas1068",
|
||||||
|
"disk_size": "{{user `disk_size`}}",
|
||||||
|
"disk_type_id": "{{user `disk_type_id`}}",
|
||||||
|
"floppy_files": [
|
||||||
|
"{{user `autounattend`}}",
|
||||||
|
"./floppy/WindowsPowershell.lnk",
|
||||||
|
"./floppy/PinTo10.exe",
|
||||||
|
"./scripts/fixnetwork.ps1",
|
||||||
|
"./scripts/disable-screensaver.ps1",
|
||||||
|
"./scripts/disable-winrm.ps1",
|
||||||
|
"./scripts/enable-winrm.ps1",
|
||||||
|
"./scripts/microsoft-updates.bat",
|
||||||
|
"./scripts/win-updates.ps1"
|
||||||
|
],
|
||||||
|
"guest_os_type": "windows9-64",
|
||||||
|
"headless": "{{user `headless`}}",
|
||||||
|
"iso_checksum": "{{user `iso_checksum`}}",
|
||||||
|
"iso_url": "{{user `iso_url`}}",
|
||||||
|
"memory": "{{user `memory`}}",
|
||||||
|
"shutdown_command": "shutdown /s /t 10 /f /d p:4:1 /c \"Packer Shutdown\"",
|
||||||
|
"type": "vmware-iso",
|
||||||
|
"version": "{{user `vmx_version`}}",
|
||||||
|
"vm_name": "{{user `vm_name`}}",
|
||||||
|
"vmx_data": {
|
||||||
|
"RemoteDisplay.vnc.enabled": "false",
|
||||||
|
"RemoteDisplay.vnc.port": "5900"
|
||||||
|
},
|
||||||
|
"vmx_remove_ethernet_interfaces": true,
|
||||||
|
"vnc_port_max": 5980,
|
||||||
|
"vnc_port_min": 5900,
|
||||||
|
"winrm_password": "vagrant",
|
||||||
|
"winrm_timeout": "{{user `winrm_timeout`}}",
|
||||||
|
"winrm_username": "vagrant"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"boot_command": [
|
||||||
|
"<leftShiftOn><f10><leftShiftOff><wait>",
|
||||||
|
"reg add HKLM\\SYSTEM\\Setup\\LabConfig /t REG_DWORD /v BypassTPMCheck /d 1<return>",
|
||||||
|
"reg add HKLM\\SYSTEM\\Setup\\LabConfig /t REG_DWORD /v BypassSecureBootCheck /d 1<return><wait>",
|
||||||
|
"exit<return>",
|
||||||
|
"<wait><return>"
|
||||||
|
],
|
||||||
|
"boot_wait": "2m",
|
||||||
|
"communicator": "winrm",
|
||||||
|
"cpus": 2,
|
||||||
|
"disk_size": "{{user `disk_size`}}",
|
||||||
|
"floppy_files": [
|
||||||
|
"{{user `autounattend`}}",
|
||||||
|
"./floppy/WindowsPowershell.lnk",
|
||||||
|
"./floppy/PinTo10.exe",
|
||||||
|
"./scripts/fixnetwork.ps1",
|
||||||
|
"./scripts/disable-screensaver.ps1",
|
||||||
|
"./scripts/disable-winrm.ps1",
|
||||||
|
"./scripts/enable-winrm.ps1",
|
||||||
|
"./scripts/microsoft-updates.bat",
|
||||||
|
"./scripts/win-updates.ps1"
|
||||||
|
],
|
||||||
|
"guest_additions_mode": "disable",
|
||||||
|
"guest_os_type": "Windows10_64",
|
||||||
|
"headless": "{{user `headless`}}",
|
||||||
|
"iso_checksum": "{{user `iso_checksum`}}",
|
||||||
|
"iso_url": "{{user `iso_url`}}",
|
||||||
|
"memory": "{{user `memory`}}",
|
||||||
|
"shutdown_command": "shutdown /s /t 10 /f /d p:4:1 /c \"Packer Shutdown\"",
|
||||||
|
"type": "virtualbox-iso",
|
||||||
|
"vm_name": "{{user `vm_name`}}",
|
||||||
|
"winrm_password": "vagrant",
|
||||||
|
"winrm_timeout": "{{user `winrm_timeout`}}",
|
||||||
|
"winrm_username": "vagrant"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"boot_command": [
|
||||||
|
"<leftShiftOn><f10><leftShiftOff><wait>",
|
||||||
|
"reg add HKLM\\SYSTEM\\Setup\\LabConfig /t REG_DWORD /v BypassTPMCheck /d 1<return>",
|
||||||
|
"reg add HKLM\\SYSTEM\\Setup\\LabConfig /t REG_DWORD /v BypassSecureBootCheck /d 1<return><wait>",
|
||||||
|
"exit<return>",
|
||||||
|
"<wait><return>"
|
||||||
|
],
|
||||||
|
"boot_wait": "2m",
|
||||||
|
"communicator": "winrm",
|
||||||
|
"cpus": 2,
|
||||||
|
"disk_size": "{{user `disk_size`}}",
|
||||||
|
"floppy_files": [
|
||||||
|
"{{user `autounattend`}}",
|
||||||
|
"./floppy/WindowsPowershell.lnk",
|
||||||
|
"./floppy/PinTo10.exe",
|
||||||
|
"./scripts/fixnetwork.ps1",
|
||||||
|
"./scripts/disable-screensaver.ps1",
|
||||||
|
"./scripts/disable-winrm.ps1",
|
||||||
|
"./scripts/enable-winrm.ps1",
|
||||||
|
"./scripts/microsoft-updates.bat",
|
||||||
|
"./scripts/win-updates.ps1"
|
||||||
|
],
|
||||||
|
"guest_os_type": "win-10",
|
||||||
|
"iso_checksum": "{{user `iso_checksum`}}",
|
||||||
|
"iso_url": "{{user `iso_url`}}",
|
||||||
|
"memory": "{{user `memory`}}",
|
||||||
|
"shutdown_command": "shutdown /s /t 10 /f /d p:4:1 /c \"Packer Shutdown\"",
|
||||||
|
"type": "parallels-iso",
|
||||||
|
"parallels_tools_flavor": "win",
|
||||||
|
"parallels_tools_mode": "disable",
|
||||||
|
"prlctl": [
|
||||||
|
[
|
||||||
|
"set",
|
||||||
|
"{{.Name}}",
|
||||||
|
"--adaptive-hypervisor",
|
||||||
|
"on"
|
||||||
|
],
|
||||||
|
[
|
||||||
|
"set",
|
||||||
|
"{{.Name}}",
|
||||||
|
"--efi-boot",
|
||||||
|
"off"
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"vm_name": "{{user `vm_name`}}",
|
||||||
|
"winrm_password": "vagrant",
|
||||||
|
"winrm_timeout": "{{user `winrm_timeout`}}",
|
||||||
|
"winrm_username": "vagrant"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"post-processors": [
|
||||||
|
{
|
||||||
|
"keep_input_artifact": false,
|
||||||
|
"output": "windows_11_{{.Provider}}.box",
|
||||||
|
"type": "vagrant",
|
||||||
|
"vagrantfile_template": "vagrantfile-windows_10.template"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"provisioners": [
|
||||||
|
{
|
||||||
|
"execute_command": "{{ .Vars }} cmd /c \"{{ .Path }}\"",
|
||||||
|
"remote_path": "/tmp/script.bat",
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/enable-rdp.bat"
|
||||||
|
],
|
||||||
|
"type": "windows-shell"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/vm-guest-tools.ps1",
|
||||||
|
"./scripts/debloat-windows.ps1"
|
||||||
|
],
|
||||||
|
"type": "powershell"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"restart_timeout": "{{user `restart_timeout`}}",
|
||||||
|
"type": "windows-restart"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/set-powerplan.ps1",
|
||||||
|
"./scripts/docker/disable-windows-defender.ps1"
|
||||||
|
],
|
||||||
|
"type": "powershell"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"execute_command": "{{ .Vars }} cmd /c \"{{ .Path }}\"",
|
||||||
|
"remote_path": "/tmp/script.bat",
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/chocolatey.bat"
|
||||||
|
],
|
||||||
|
"type": "windows-shell"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/chocopacks.ps1"
|
||||||
|
],
|
||||||
|
"type": "powershell"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"execute_command": "{{ .Vars }} cmd /c \"{{ .Path }}\"",
|
||||||
|
"remote_path": "/tmp/script.bat",
|
||||||
|
"scripts": [
|
||||||
|
"./scripts/pin-powershell.bat",
|
||||||
|
"./scripts/compile-dotnet-assemblies.bat",
|
||||||
|
"./scripts/set-winrm-automatic.bat",
|
||||||
|
"./scripts/uac-enable.bat",
|
||||||
|
"./scripts/dis-updates.bat",
|
||||||
|
"./scripts/compact.bat"
|
||||||
|
],
|
||||||
|
"type": "windows-shell"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"variables": {
|
||||||
|
"autounattend": "./answer_files/11/Autounattend.xml",
|
||||||
|
"disk_size": "61440",
|
||||||
|
"disk_type_id": "1",
|
||||||
|
"memory": "4096",
|
||||||
|
"headless": "false",
|
||||||
|
"iso_checksum": "sha256:e8b1d2a1a85a09b4bf6154084a8be8e3c814894a15a7bcf3e8e63fcfa9a528cb",
|
||||||
|
"iso_url": "https://software-download.microsoft.com/download/sg/22000.194.210913-1444.co_release_svc_refresh_CLIENTENTERPRISEEVAL_OEMRET_x64FRE_en-us.iso",
|
||||||
|
"restart_timeout": "5m",
|
||||||
|
"vhv_enable": "false",
|
||||||
|
"virtio_win_iso": "~/virtio-win.iso",
|
||||||
|
"vm_name": "windows_11",
|
||||||
|
"winrm_timeout": "6h",
|
||||||
|
"vmx_version": "14"
|
||||||
|
}
|
||||||
|
}
|
44
scripts/vagrant/add-cmder.ps1
Normal file
44
scripts/vagrant/add-cmder.ps1
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
choco install -y --force 7zip 7zip.install
|
||||||
|
choco install -y --force cmder
|
||||||
|
|
||||||
|
$env:path = "$env:path;c:\tools\cmder\vendor\git-for-windows\cmd;c:\tools\cmder\vendor\git-for-windows\usr\bin;c:\tools\cmder\vendor\git-for-windows\mingw64\bin"
|
||||||
|
c:
|
||||||
|
cd $env:userprofile
|
||||||
|
git clone https://github.com/cmderdev/cmder cmderdev 2>&1
|
||||||
|
|
||||||
|
if ("$env:USERNAME" -eq "vagrant" -and -not (test-path "$env:userprofile\cmderdev\vendor\git-for-windows")) {
|
||||||
|
invoke-expression -command "TAKEOWN /F `"$env:userprofile\cmderdev`" /R /D y /s localhost /u vagrant /p vagrant"
|
||||||
|
}
|
||||||
|
|
||||||
|
cd $env:userprofile/cmderdev
|
||||||
|
git remote add upstream https://github.com/cmderdev/cmder
|
||||||
|
|
||||||
|
Install-PackageProvider -Name NuGet -Force
|
||||||
|
install-module posh-git -force
|
||||||
|
|
||||||
|
cmd.exe /c "call `"C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\Build\vcvars64.bat`" && set > %temp%\vcvars.txt"
|
||||||
|
Get-Content "$env:temp\vcvars.txt" | Foreach-Object {
|
||||||
|
if ($_ -match "^(.*?)=(.*)$") {
|
||||||
|
Set-Content "env:\$($matches[1])" $matches[2]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
copy-item -erroraction silentlycontinue "C:\Tools\Cmder\Cmder.exe" "$env:userprofile\cmderdev"
|
||||||
|
remove-item -erroraction silentlycontinue "$env:userprofile\cmderdev\launcher\x64\release\cmder.exe" -force
|
||||||
|
|
||||||
|
start-process -erroraction silentlycontinue -nonewwindow -workingdirectory "$env:userprofile\cmderdev\scripts" -filepath "powershell.exe" -argumentlist ".\build.ps1 -verbose -compile"
|
||||||
|
|
||||||
|
copy-item -erroraction silentlycontinue "$env:userprofile\cmderdev\launcher\x64\release\cmder.exe" "$env:userprofile\cmderdev" -force
|
||||||
|
|
||||||
|
# tabby
|
||||||
|
setx cmder_root "${env:userprofile}\cmderdev"
|
||||||
|
|
||||||
|
# C:\Users\vagrant\AppData\Roaming\Hyper
|
||||||
|
# // shell: '',
|
||||||
|
# shell: 'cmd.exe',
|
||||||
|
# // for setting shell arguments (i.e. for using interactive shellArgs: `['-i']`)
|
||||||
|
# // by default `['--login']` will be used
|
||||||
|
# // shellArgs: ['--login'],
|
||||||
|
# shellArgs: ['/k', 'C:\\users\\vagrant\\cmderdev\\vendor\\init.bat'],
|
||||||
|
|
||||||
|
|
283
scripts/vagrant/windows_terminal_settings.json.default
Normal file
283
scripts/vagrant/windows_terminal_settings.json.default
Normal file
@ -0,0 +1,283 @@
|
|||||||
|
{
|
||||||
|
"$help": "https://aka.ms/terminal-documentation",
|
||||||
|
"$schema": "https://aka.ms/terminal-profiles-schema",
|
||||||
|
"actions":
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"command":
|
||||||
|
{
|
||||||
|
"action": "copy",
|
||||||
|
"singleLine": false
|
||||||
|
},
|
||||||
|
"keys": "ctrl+c"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"command": "paste",
|
||||||
|
"keys": "ctrl+v"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"command": "find",
|
||||||
|
"keys": "ctrl+shift+f"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"command":
|
||||||
|
{
|
||||||
|
"action": "splitPane",
|
||||||
|
"split": "auto",
|
||||||
|
"splitMode": "duplicate"
|
||||||
|
},
|
||||||
|
"keys": "alt+shift+d"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"copyFormatting": "none",
|
||||||
|
"copyOnSelect": false,
|
||||||
|
"defaultProfile": "{61c54bbd-c2c6-5271-96e7-009a87ff44bf}",
|
||||||
|
"profiles":
|
||||||
|
{
|
||||||
|
"defaults": {},
|
||||||
|
"list":
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"commandline": "%SystemRoot%\\System32\\WindowsPowerShell\\v1.0\\powershell.exe",
|
||||||
|
"guid": "{61c54bbd-c2c6-5271-96e7-009a87ff44bf}",
|
||||||
|
"hidden": false,
|
||||||
|
"name": "Windows PowerShell"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"commandline": "%SystemRoot%\\System32\\cmd.exe",
|
||||||
|
"guid": "{0caa0dad-35be-5f56-a8ff-afceeeaa6101}",
|
||||||
|
"hidden": false,
|
||||||
|
"name": "Command Prompt"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"guid": "{b453ae62-4e3d-5e58-b989-0a998ec441b8}",
|
||||||
|
"hidden": false,
|
||||||
|
"name": "Azure Cloud Shell",
|
||||||
|
"source": "Windows.Terminal.Azure"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"guid": "{3b26d644-1d3b-5a0c-ab09-39d4dd9ae00e}",
|
||||||
|
"hidden": false,
|
||||||
|
"name": "Developer Command Prompt for VS 2022",
|
||||||
|
"source": "Windows.Terminal.VisualStudio"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"guid": "{589cd367-e65f-5e6a-a1c7-2b8d6f250da8}",
|
||||||
|
"hidden": false,
|
||||||
|
"name": "Developer PowerShell for VS 2022",
|
||||||
|
"source": "Windows.Terminal.VisualStudio"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"schemes":
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"background": "#0C0C0C",
|
||||||
|
"black": "#0C0C0C",
|
||||||
|
"blue": "#0037DA",
|
||||||
|
"brightBlack": "#767676",
|
||||||
|
"brightBlue": "#3B78FF",
|
||||||
|
"brightCyan": "#61D6D6",
|
||||||
|
"brightGreen": "#16C60C",
|
||||||
|
"brightPurple": "#B4009E",
|
||||||
|
"brightRed": "#E74856",
|
||||||
|
"brightWhite": "#F2F2F2",
|
||||||
|
"brightYellow": "#F9F1A5",
|
||||||
|
"cursorColor": "#FFFFFF",
|
||||||
|
"cyan": "#3A96DD",
|
||||||
|
"foreground": "#CCCCCC",
|
||||||
|
"green": "#13A10E",
|
||||||
|
"name": "Campbell",
|
||||||
|
"purple": "#881798",
|
||||||
|
"red": "#C50F1F",
|
||||||
|
"selectionBackground": "#FFFFFF",
|
||||||
|
"white": "#CCCCCC",
|
||||||
|
"yellow": "#C19C00"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"background": "#012456",
|
||||||
|
"black": "#0C0C0C",
|
||||||
|
"blue": "#0037DA",
|
||||||
|
"brightBlack": "#767676",
|
||||||
|
"brightBlue": "#3B78FF",
|
||||||
|
"brightCyan": "#61D6D6",
|
||||||
|
"brightGreen": "#16C60C",
|
||||||
|
"brightPurple": "#B4009E",
|
||||||
|
"brightRed": "#E74856",
|
||||||
|
"brightWhite": "#F2F2F2",
|
||||||
|
"brightYellow": "#F9F1A5",
|
||||||
|
"cursorColor": "#FFFFFF",
|
||||||
|
"cyan": "#3A96DD",
|
||||||
|
"foreground": "#CCCCCC",
|
||||||
|
"green": "#13A10E",
|
||||||
|
"name": "Campbell Powershell",
|
||||||
|
"purple": "#881798",
|
||||||
|
"red": "#C50F1F",
|
||||||
|
"selectionBackground": "#FFFFFF",
|
||||||
|
"white": "#CCCCCC",
|
||||||
|
"yellow": "#C19C00"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"background": "#282C34",
|
||||||
|
"black": "#282C34",
|
||||||
|
"blue": "#61AFEF",
|
||||||
|
"brightBlack": "#5A6374",
|
||||||
|
"brightBlue": "#61AFEF",
|
||||||
|
"brightCyan": "#56B6C2",
|
||||||
|
"brightGreen": "#98C379",
|
||||||
|
"brightPurple": "#C678DD",
|
||||||
|
"brightRed": "#E06C75",
|
||||||
|
"brightWhite": "#DCDFE4",
|
||||||
|
"brightYellow": "#E5C07B",
|
||||||
|
"cursorColor": "#FFFFFF",
|
||||||
|
"cyan": "#56B6C2",
|
||||||
|
"foreground": "#DCDFE4",
|
||||||
|
"green": "#98C379",
|
||||||
|
"name": "One Half Dark",
|
||||||
|
"purple": "#C678DD",
|
||||||
|
"red": "#E06C75",
|
||||||
|
"selectionBackground": "#FFFFFF",
|
||||||
|
"white": "#DCDFE4",
|
||||||
|
"yellow": "#E5C07B"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"background": "#FAFAFA",
|
||||||
|
"black": "#383A42",
|
||||||
|
"blue": "#0184BC",
|
||||||
|
"brightBlack": "#4F525D",
|
||||||
|
"brightBlue": "#61AFEF",
|
||||||
|
"brightCyan": "#56B5C1",
|
||||||
|
"brightGreen": "#98C379",
|
||||||
|
"brightPurple": "#C577DD",
|
||||||
|
"brightRed": "#DF6C75",
|
||||||
|
"brightWhite": "#FFFFFF",
|
||||||
|
"brightYellow": "#E4C07A",
|
||||||
|
"cursorColor": "#4F525D",
|
||||||
|
"cyan": "#0997B3",
|
||||||
|
"foreground": "#383A42",
|
||||||
|
"green": "#50A14F",
|
||||||
|
"name": "One Half Light",
|
||||||
|
"purple": "#A626A4",
|
||||||
|
"red": "#E45649",
|
||||||
|
"selectionBackground": "#FFFFFF",
|
||||||
|
"white": "#FAFAFA",
|
||||||
|
"yellow": "#C18301"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"background": "#002B36",
|
||||||
|
"black": "#002B36",
|
||||||
|
"blue": "#268BD2",
|
||||||
|
"brightBlack": "#073642",
|
||||||
|
"brightBlue": "#839496",
|
||||||
|
"brightCyan": "#93A1A1",
|
||||||
|
"brightGreen": "#586E75",
|
||||||
|
"brightPurple": "#6C71C4",
|
||||||
|
"brightRed": "#CB4B16",
|
||||||
|
"brightWhite": "#FDF6E3",
|
||||||
|
"brightYellow": "#657B83",
|
||||||
|
"cursorColor": "#FFFFFF",
|
||||||
|
"cyan": "#2AA198",
|
||||||
|
"foreground": "#839496",
|
||||||
|
"green": "#859900",
|
||||||
|
"name": "Solarized Dark",
|
||||||
|
"purple": "#D33682",
|
||||||
|
"red": "#DC322F",
|
||||||
|
"selectionBackground": "#FFFFFF",
|
||||||
|
"white": "#EEE8D5",
|
||||||
|
"yellow": "#B58900"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"background": "#FDF6E3",
|
||||||
|
"black": "#002B36",
|
||||||
|
"blue": "#268BD2",
|
||||||
|
"brightBlack": "#073642",
|
||||||
|
"brightBlue": "#839496",
|
||||||
|
"brightCyan": "#93A1A1",
|
||||||
|
"brightGreen": "#586E75",
|
||||||
|
"brightPurple": "#6C71C4",
|
||||||
|
"brightRed": "#CB4B16",
|
||||||
|
"brightWhite": "#FDF6E3",
|
||||||
|
"brightYellow": "#657B83",
|
||||||
|
"cursorColor": "#002B36",
|
||||||
|
"cyan": "#2AA198",
|
||||||
|
"foreground": "#657B83",
|
||||||
|
"green": "#859900",
|
||||||
|
"name": "Solarized Light",
|
||||||
|
"purple": "#D33682",
|
||||||
|
"red": "#DC322F",
|
||||||
|
"selectionBackground": "#FFFFFF",
|
||||||
|
"white": "#EEE8D5",
|
||||||
|
"yellow": "#B58900"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"background": "#000000",
|
||||||
|
"black": "#000000",
|
||||||
|
"blue": "#3465A4",
|
||||||
|
"brightBlack": "#555753",
|
||||||
|
"brightBlue": "#729FCF",
|
||||||
|
"brightCyan": "#34E2E2",
|
||||||
|
"brightGreen": "#8AE234",
|
||||||
|
"brightPurple": "#AD7FA8",
|
||||||
|
"brightRed": "#EF2929",
|
||||||
|
"brightWhite": "#EEEEEC",
|
||||||
|
"brightYellow": "#FCE94F",
|
||||||
|
"cursorColor": "#FFFFFF",
|
||||||
|
"cyan": "#06989A",
|
||||||
|
"foreground": "#D3D7CF",
|
||||||
|
"green": "#4E9A06",
|
||||||
|
"name": "Tango Dark",
|
||||||
|
"purple": "#75507B",
|
||||||
|
"red": "#CC0000",
|
||||||
|
"selectionBackground": "#FFFFFF",
|
||||||
|
"white": "#D3D7CF",
|
||||||
|
"yellow": "#C4A000"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"background": "#FFFFFF",
|
||||||
|
"black": "#000000",
|
||||||
|
"blue": "#3465A4",
|
||||||
|
"brightBlack": "#555753",
|
||||||
|
"brightBlue": "#729FCF",
|
||||||
|
"brightCyan": "#34E2E2",
|
||||||
|
"brightGreen": "#8AE234",
|
||||||
|
"brightPurple": "#AD7FA8",
|
||||||
|
"brightRed": "#EF2929",
|
||||||
|
"brightWhite": "#EEEEEC",
|
||||||
|
"brightYellow": "#FCE94F",
|
||||||
|
"cursorColor": "#000000",
|
||||||
|
"cyan": "#06989A",
|
||||||
|
"foreground": "#555753",
|
||||||
|
"green": "#4E9A06",
|
||||||
|
"name": "Tango Light",
|
||||||
|
"purple": "#75507B",
|
||||||
|
"red": "#CC0000",
|
||||||
|
"selectionBackground": "#FFFFFF",
|
||||||
|
"white": "#D3D7CF",
|
||||||
|
"yellow": "#C4A000"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"background": "#000000",
|
||||||
|
"black": "#000000",
|
||||||
|
"blue": "#000080",
|
||||||
|
"brightBlack": "#808080",
|
||||||
|
"brightBlue": "#0000FF",
|
||||||
|
"brightCyan": "#00FFFF",
|
||||||
|
"brightGreen": "#00FF00",
|
||||||
|
"brightPurple": "#FF00FF",
|
||||||
|
"brightRed": "#FF0000",
|
||||||
|
"brightWhite": "#FFFFFF",
|
||||||
|
"brightYellow": "#FFFF00",
|
||||||
|
"cursorColor": "#FFFFFF",
|
||||||
|
"cyan": "#008080",
|
||||||
|
"foreground": "#C0C0C0",
|
||||||
|
"green": "#008000",
|
||||||
|
"name": "Vintage",
|
||||||
|
"purple": "#800080",
|
||||||
|
"red": "#800000",
|
||||||
|
"selectionBackground": "#FFFFFF",
|
||||||
|
"white": "#C0C0C0",
|
||||||
|
"yellow": "#808000"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"themes": []
|
||||||
|
}
|
9
scripts/vagrant/windows_terminal_state.json.default
Normal file
9
scripts/vagrant/windows_terminal_state.json.default
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
{
|
||||||
|
"generatedProfiles" :
|
||||||
|
[
|
||||||
|
"{b453ae62-4e3d-5e58-b989-0a998ec441b8}",
|
||||||
|
"{589cd367-e65f-5e6a-a1c7-2b8d6f250da8}",
|
||||||
|
"{3b26d644-1d3b-5a0c-ab09-39d4dd9ae00e}"
|
||||||
|
],
|
||||||
|
"settingsHash" : "6e0f2330b78337f3-01d95614596b3f65"
|
||||||
|
}
|
1
vendor/bin/add-cmderrootenvar.ps1
vendored
Normal file
1
vendor/bin/add-cmderrootenvar.ps1
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
setx cmder_root "${env:cmder_root}"
|
36
vendor/bin/add-cmdertodesktop.ps1
vendored
Normal file
36
vendor/bin/add-cmdertodesktop.ps1
vendored
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
if (test-path "c:\windows\set-shortcut.ps1") {
|
||||||
|
$setShortcut = "c:\windows\set-shortcut.ps1"
|
||||||
|
}
|
||||||
|
|
||||||
|
if (test-path "${env:USERPROFILE}\cmderdev") {
|
||||||
|
$env:cmder_root = "${env:USERPROFILE}\cmderdev"
|
||||||
|
write-host "Creating '${env:USERPROFILE}\Desktop\Cmderdev.lnk'..."
|
||||||
|
|
||||||
|
if (test-path "${env:USERPROFILE}\cmderdev\vendor\bin\set-shortcut.ps1") {
|
||||||
|
$setShortcut = "$env:cmder_root\vendor\bin\set-shortcut.ps1"
|
||||||
|
}
|
||||||
|
|
||||||
|
start-process -NoNewWindow -filePath "powershell.exe" -ArgumentList "-file `"${setShortcut}`" -sourceexe `"${env:cmder_root}\Cmder.exe`" -DestinationPath `"${env:USERPROFILE}\Desktop\Cmderdev.lnk`" -WorkingDirectory `"${env:cmder_root}`""
|
||||||
|
}
|
||||||
|
|
||||||
|
if (test-path "${env:USERPROFILE}\cmder") {
|
||||||
|
$env:cmder_root = "${env:USERPROFILE}\cmder"
|
||||||
|
|
||||||
|
if (test-path "${cmder_root}\vendor\bin\set-shortcut.ps1") {
|
||||||
|
$setShortcut = "$env:cmder_root\vendor\bin\set-shortcut.ps1"
|
||||||
|
}
|
||||||
|
|
||||||
|
write-host "Creating '${env:USERPROFILE}\Desktop\Cmder.lnk'..."
|
||||||
|
start-process -NoNewWindow -filePath "powershell.exe" -ArgumentList "-file `"${setShortcut}`" -sourceexe `"$env:cmder_root\Cmder.exe`" -DestinationPath `"${env:USERPROFILE}\Desktop\Cmder.lnk`" -WorkingDirectory `"${env:USERPROFILE}`""
|
||||||
|
} elseif (test-path "C:\tools\cmder") {
|
||||||
|
$env:cmder_root = "C:\tools\cmder"
|
||||||
|
|
||||||
|
if (test-path "${cmder_root}\vendor\bin\set-shortcut.ps1") {
|
||||||
|
$setShortcut = "$env:cmder_root\vendor\bin\set-shortcut.ps1"
|
||||||
|
}
|
||||||
|
|
||||||
|
write-host "Creating '${env:USERPROFILE}\Desktop\Cmder.lnk'..."
|
||||||
|
start-process -NoNewWindow -filePath "powershell.exe" -ArgumentList "-file `"${setShortcut}`" -sourceexe `"$env:cmder_root\Cmder.exe`" -DestinationPath `"${env:USERPROFILE}\Desktop\Cmder.lnk`" -WorkingDirectory `"${env:USERPROFILE}`""
|
||||||
|
}
|
||||||
|
|
||||||
|
|
39
vendor/bin/add-vscodeprofile.ps1
vendored
Normal file
39
vendor/bin/add-vscodeprofile.ps1
vendored
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
# VSCode
|
||||||
|
$VSCodeUserSettings = "$env:APPDATA/Code/User"
|
||||||
|
$VSCodeSettings = "$VSCodeUserSettings/settings.json";
|
||||||
|
$VSCodeSettingsNew = $VSCodeSettings.replace('.json', '-new.json')
|
||||||
|
|
||||||
|
if (test-path $VSCodeSettings) {
|
||||||
|
$data = get-content -path $VSCodeSettings -ErrorAction silentlycontinue | out-string | ConvertFrom-Json
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
New-Item -ItemType directory $VSCodeUserSettings -force
|
||||||
|
$data = @{}
|
||||||
|
}
|
||||||
|
|
||||||
|
write-host $data
|
||||||
|
|
||||||
|
$data | Add-Member -force -Name 'terminal.integrated.defaultProfile.windows' -MemberType NoteProperty -Value "Cmder"
|
||||||
|
|
||||||
|
if ($null -eq $data.'terminal.integrated.profiles.windows') {
|
||||||
|
write-host "Adding 'terminal.integrated.profiles.windows'..."
|
||||||
|
$data | Add-Member -force -Name 'terminal.integrated.profiles.windows' -MemberType NoteProperty -Value @{}
|
||||||
|
}
|
||||||
|
|
||||||
|
write-host "Adding 'terminal.integrated.profiles.windows.Cmder' profile..."
|
||||||
|
$data.'terminal.integrated.profiles.windows'.'Cmder' = @{
|
||||||
|
"name" = "Cmder";
|
||||||
|
"path" = @(
|
||||||
|
"`${env:windir}/Sysnative/cmd.exe";
|
||||||
|
"`${env:windir}/System32/cmd.exe";
|
||||||
|
);
|
||||||
|
"args" = @(
|
||||||
|
"/k";
|
||||||
|
"`${env:USERPROFILE}/cmderdev/vendor/bin/vscode_init.cmd");
|
||||||
|
"icon" = "terminal-cmd";
|
||||||
|
"color" = "terminal.ansiGreen";
|
||||||
|
};
|
||||||
|
|
||||||
|
$data | ConvertTo-Json -depth 100 | set-content $VSCodeSettings
|
||||||
|
|
||||||
|
|
74
vendor/bin/add-windowsterminalprofiles.ps1
vendored
Normal file
74
vendor/bin/add-windowsterminalprofiles.ps1
vendored
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
# Windows Terminal
|
||||||
|
$windowsTerminalFolder = (dir "$env:userprofile/AppData/Local/Packages/Microsoft.WindowsTerminal_*").name
|
||||||
|
$windowsTerminalPath = "$env:userprofile/AppData/Local/Packages/$windowsTerminalFolder"
|
||||||
|
$windowsTerminalSettings = $windowsTerminalPath + '/localState/settings.json'
|
||||||
|
$windowsTerminalSettingsNew = $windowsTerminalPath + '/localState/settings-new.json'
|
||||||
|
|
||||||
|
if (test-path "$env:userprofile/Documents/windows_terminal_settings.json.default") {
|
||||||
|
if (test-path "$windowsTerminalPath/LocalState/settings.json") {
|
||||||
|
del "$env:userprofile/Documents/windows_terminal_settings.json.default"
|
||||||
|
} else {
|
||||||
|
move-item -path $env:userprofile/Documents/windows_terminal_settings.json.default -destination $windowsTerminalPath/LocalState/settings.json
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (test-path "$env:userprofile/Documents/windows_terminal_state.json.default") {
|
||||||
|
if (test-path "$windowsTerminalPath/LocalState/state.json") {
|
||||||
|
del "$env:userprofile/Documents/windows_terminal_state.json.default"
|
||||||
|
} else {
|
||||||
|
move-item -path $env:userprofile/Documents/windows_terminal_state.json.default -destination $windowsTerminalPath/LocalState/state.json
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (test-path "$windowsTerminalPath/LocalState/state.json") {
|
||||||
|
$json = get-content $windowsTerminalSettings | ConvertFrom-Json
|
||||||
|
|
||||||
|
$json.defaultProfile="{00000000-0000-0000-ba54-000000000132}"
|
||||||
|
|
||||||
|
$cmderFound = $false
|
||||||
|
$cmderAsAdminFound = $false
|
||||||
|
|
||||||
|
foreach ($profile in $json.profiles.list) {
|
||||||
|
if ($profile.Name -eq "Cmder") {
|
||||||
|
$cmderFound = $true
|
||||||
|
}
|
||||||
|
elseIf ($profile.Name -eq "Cmder as Admin") {
|
||||||
|
$cmderAsAdminFound = $true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (-not $cmderFound) {
|
||||||
|
write-host "Adding 'Cmder' to Windows Terminal..."
|
||||||
|
|
||||||
|
$json.profiles.list += @{
|
||||||
|
commandline="cmd.exe /k `"%USERPROFILE%/cmderdev/vendor/init.bat`"";
|
||||||
|
startingDirectory="%USERPROFILE%/cmderdev";
|
||||||
|
icon="%USERPROFILE%/cmderdev/icons/cmder.ico";
|
||||||
|
closeOnExit="graceful";
|
||||||
|
guid="{00000000-0000-0000-ba54-000000000132}";
|
||||||
|
hidden=$false;
|
||||||
|
name="Cmder"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (-not $cmderAsAdminFound) {
|
||||||
|
write-host "Adding 'Cmder as Admin' to Windows Terminal..."
|
||||||
|
|
||||||
|
$json.profiles.list += @{
|
||||||
|
commandline="cmd.exe /k `"%USERPROFILE%/cmderdev/vendor/init.bat`"";
|
||||||
|
startingDirectory="%USERPROFILE%/cmderdev";
|
||||||
|
icon="%USERPROFILE%/cmderdev/icons/cmder_red.ico";
|
||||||
|
closeOnExit="graceful";
|
||||||
|
guid="{00000000-0000-0000-ba54-000000000133}";
|
||||||
|
hidden=$false;
|
||||||
|
elevate=$true;
|
||||||
|
name="Cmder as Admin"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$json | ConvertTo-Json -depth 100 | set-content $windowsTerminalSettings
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
write-host "Cannot add profiles for Windows Terminal. The Windows Terminal settings file does not exist!"
|
||||||
|
}
|
||||||
|
|
2
vendor/bin/cmder_shell.cmd
vendored
2
vendor/bin/cmder_shell.cmd
vendored
@ -9,5 +9,5 @@ if "%cmder_init%" == "1" (
|
|||||||
)
|
)
|
||||||
|
|
||||||
pushd "%CMDER_ROOT%"
|
pushd "%CMDER_ROOT%"
|
||||||
call "%CMDER_ROOT%\vendor\init.bat" /f %*
|
call "%CMDER_ROOT%\vendor\init.bat" /f
|
||||||
popd
|
popd
|
||||||
|
21
vendor/bin/set-shortcut.ps1
vendored
Normal file
21
vendor/bin/set-shortcut.ps1
vendored
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
[CmdletBinding()]
|
||||||
|
param(
|
||||||
|
[Parameter()]
|
||||||
|
[string]$SourceExe,
|
||||||
|
[string]$Arguments,
|
||||||
|
[string]$DestinationPath,
|
||||||
|
[string]$WorkingDirectory,
|
||||||
|
[String]$IconLocation
|
||||||
|
)
|
||||||
|
|
||||||
|
if ($IconLocation -eq '') {
|
||||||
|
$IconLocation = $SourceExe
|
||||||
|
}
|
||||||
|
|
||||||
|
$WshShell = New-Object -comObject WScript.Shell
|
||||||
|
$Shortcut = $WshShell.CreateShortcut($destinationPath)
|
||||||
|
$Shortcut.TargetPath = $SourceExe
|
||||||
|
$Shortcut.Arguments = $Arguments
|
||||||
|
$shortcut.WorkingDirectory = $WorkingDirectory
|
||||||
|
$shortcut.IconLocation = $IconLocation
|
||||||
|
$Shortcut.Save()
|
4
vendor/clink_settings.default
vendored
4
vendor/clink_settings.default
vendored
@ -1,10 +1,6 @@
|
|||||||
# For explanation of these and other settings see:
|
# For explanation of these and other settings see:
|
||||||
# https://chrisant996.github.io/clink/clink.html
|
# https://chrisant996.github.io/clink/clink.html
|
||||||
|
|
||||||
# name: Expand envvars when completing
|
|
||||||
# type: boolean
|
|
||||||
match.expand_envvars = True
|
|
||||||
|
|
||||||
# name: Sets how command history expansion is applied
|
# name: Sets how command history expansion is applied
|
||||||
# type: enum
|
# type: enum
|
||||||
# options: off,on,not_squoted,not_dquoted,not_quoted
|
# options: off,on,not_squoted,not_dquoted,not_quoted
|
||||||
|
1
vendor/lib/lib_git.cmd
vendored
1
vendor/lib/lib_git.cmd
vendored
@ -55,7 +55,6 @@ exit /b
|
|||||||
set "GIT_VERSION=%%C"
|
set "GIT_VERSION=%%C"
|
||||||
) else (
|
) else (
|
||||||
echo "'git --version' returned an improper version string!"
|
echo "'git --version' returned an improper version string!"
|
||||||
%print_debug% :read_version "returned string: '%%A %%B %%C' by executable path: %git_executable%"
|
|
||||||
pause
|
pause
|
||||||
exit /b
|
exit /b
|
||||||
)
|
)
|
||||||
|
12
vendor/sources.json
vendored
12
vendor/sources.json
vendored
@ -1,13 +1,13 @@
|
|||||||
[
|
[
|
||||||
{
|
{
|
||||||
"name": "git-for-windows",
|
"name": "git-for-windows",
|
||||||
"version": "2.45.1.windows.1",
|
"version": "2.41.0.windows.3",
|
||||||
"url": "https://github.com/git-for-windows/git/releases/download/v2.45.1.windows.1/PortableGit-2.45.1-64-bit.7z.exe"
|
"url": "https://github.com/git-for-windows/git/releases/download/v2.41.0.windows.3/PortableGit-2.41.0.3-64-bit.7z.exe"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "clink",
|
"name": "clink",
|
||||||
"version": "1.6.14",
|
"version": "1.5.1",
|
||||||
"url": "https://github.com/chrisant996/clink/releases/download/v1.6.14/clink.1.6.14.93b83f.zip"
|
"url": "https://github.com/chrisant996/clink/releases/download/v1.5.1/clink.1.5.1.1e9e51.zip"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "conemu-maximus5",
|
"name": "conemu-maximus5",
|
||||||
@ -16,7 +16,7 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "clink-completions",
|
"name": "clink-completions",
|
||||||
"version": "0.5.2",
|
"version": "0.4.10",
|
||||||
"url": "https://github.com/vladimir-kotikov/clink-completions/archive/v0.5.2.zip"
|
"url": "https://github.com/vladimir-kotikov/clink-completions/archive/v0.4.10.zip"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
Reference in New Issue
Block a user