I’m working on a couple of new modules for my free Automation Framework Community Edition showing you how to automatically setup VMware Horizon. In this post I’m going to show you how to change VMware Horizon Certificate with Powershell.
VMware Horizon Connection Server uses a self-signed certificate by default and this doesn’t fly both from a security perspective and SSL connection in general for remote connections.
If you don’t use VMware don’t worry, this post will teach you the fundamentals for working with certificates in PowerShell.
Certificate Location
Whatever Environment variable from Command Prompt (Set) can be put into a PowerShell variable. Here I’m getting the FQDN of the logon Domain and using that to set the FQDN path to my file server.
1 2 |
$DomainFQDN = ${env:UserDNSDomain} $PFXPath = "\\DC-01" + "." + "$DomainFQDN" |
Copy Certificate
The most important piece of information needed when working with certificates in PowerShell is the ThumbPrint. I already have my certificate and thumbprint saved on my file server. You can learn more in the post Generating wildcard certificate from internal certificate authority using PowerShell.
Then let’s install the required IIS Feature to work with certificates and copy the Certificate (pfx) and the Thumbprint (txt).
1 2 3 |
Install-WindowsFeature -Name Web-Server -IncludeManagementTools copy-item "$PFXPath\xa\Certificates\Wildcard.pfx" -Destination C:\Windows\Temp\wildcard.pfx copy-item "$PFXPath\xa\Certificates\Wildcard.txt" -Destination C:\Windows\Temp\wildcard.txt |
Import Certificate
Now let’s import the WebAdministration PowerShell module, set the path, password and finally import the certificate.
1 2 3 4 |
import-module webadministration $PFXPath="C:\Windows\Temp\wildcard.pfx" $PFXPassword="P@ssw0rd" certutil -f -importpfx -p $PFXPassword $PFXPath |
Change the Friendly Name
VMware Horizon Connection Server recognizes the self-signed certificate by the friendly name vdm. So first we’re going to change the friendly name of the self-signed certificate to old vdm and then set the friendly name of our new wildcard certificate to vdm.
1 2 3 4 5 6 7 |
# Add Certificate to VMware Horizon Connection Server $cert = Get-ChildItem -Path Cert:\LocalMachine\My | where{ $_.Subject –like "CN=$env:computername*" } $Thumbprint = $cert.Thumbprint (Get-ChildItem -Path Cert:\LocalMachine\My\$Thumbprint).FriendlyName = 'old vdm' $strThumb = Get-Content "${env:SystemRoot}\Temp\Wildcard.txt" (Get-ChildItem -Path Cert:\LocalMachine\My\$strThumb).FriendlyName = 'vdm' |
The Complete Script
How hard was that? Let me give you a bit of advice that can and will change your career, get started with PowerShell today. Sooner or later all workloads will run headless (Server Core).
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
Write-Verbose "Setting Arguments" -Verbose $StartDTM = (Get-Date) $PackageName = "Import and Bind VCS Certificate" $LogPS = "${env:SystemRoot}" + "\Temp\$PackageName PS Wrapper.log" Start-Transcript $LogPS $Domain = ${env:UserDomain} $DomainFQDN = ${env:UserDNSDomain} $PFXPath = "\\DC-01" + "." + "$DomainFQDN" Install-WindowsFeature -Name Web-Server -IncludeManagementTools copy-item "$PFXPath\xa\Certificates\Wildcard.pfx" -Destination C:\Windows\Temp\wildcard.pfx copy-item "$PFXPath\xa\Certificates\Wildcard.txt" -Destination C:\Windows\Temp\wildcard.txt import-module webadministration $PFXPath="C:\Windows\Temp\wildcard.pfx" $PFXPassword="P@ssw0rd" certutil -f -importpfx -p $PFXPassword $PFXPath # Add Certificate to VMware Horizon Connection Server $cert = Get-ChildItem -Path Cert:\LocalMachine\My | where{ $_.Subject –like "CN=$env:computername*" } $Thumbprint = $cert.Thumbprint (Get-ChildItem -Path Cert:\LocalMachine\My\$Thumbprint).FriendlyName = 'old vdm' $strThumb = Get-Content "${env:SystemRoot}\Temp\Wildcard.txt" (Get-ChildItem -Path Cert:\LocalMachine\My\$strThumb).FriendlyName = 'vdm' Set-Service W3SVC -startuptype "disabled" Write-Verbose "Stop logging" -Verbose $EndDTM = (Get-Date) Write-Verbose "Elapsed Time: $(($EndDTM-$StartDTM).TotalSeconds) Seconds" -Verbose Write-Verbose "Elapsed Time: $(($EndDTM-$StartDTM).TotalMinutes) Minutes" -Verbose Stop-Transcript |