data:image/s3,"s3://crabby-images/a51a4/a51a427f284ab0337cfbf15c51387c6aad94640f" alt=""
This article has not been completed yet. However, it may already contain helpful Information and therefore it has been published at this stage.
Prerequisites:
- Some linux based environment
Links that might be useful in this case:
Anyone who has been using the Windows Admin Center for longer than 60 days will probably run into a certificate problem. The latest browser from Microsft, called Edge, will then no longer allow access to the WAC portal at all.
data:image/s3,"s3://crabby-images/aa432/aa432be64d0821553961a32bfa95b517c6e4e6a9" alt=""
1) Scenario 1 - Local WAC Installation
The easiest way to get a new certificate is to initiate a repair installation. Enclosed are the necessary steps, if you have a local WAC - installation.
data:image/s3,"s3://crabby-images/ff12d/ff12db3469c08e73e03e47c820f1333bc7901aac" alt=""
data:image/s3,"s3://crabby-images/56c79/56c797edcdc9cd299327f99936a4a668ecd12cca" alt=""
data:image/s3,"s3://crabby-images/05a54/05a5427fd81f0398f4343bdc8745c3c00d544a35" alt=""
data:image/s3,"s3://crabby-images/3379d/3379dd56cc5c5a2aa237e6d7df5aa978901e9a15" alt=""
data:image/s3,"s3://crabby-images/40397/40397bc8a61eb84b7b998084c0b96b6688b4f0a0" alt=""
You could also use a separately created certificate at this point by providing its Thumprint ID to perform the necessary reassignment.
data:image/s3,"s3://crabby-images/8b3d4/8b3d49fcabe11be371f3de10c01a8319768ba379" alt=""
data:image/s3,"s3://crabby-images/8a193/8a193f9846b7ec0b0cd6ba15de292061b96060ac" alt=""
data:image/s3,"s3://crabby-images/c7715/c771589b50cc42e8bf6a108180e2cf4e4b6c9403" alt=""
2) Scenario 2 - WAC - Gateway Installation
In order to avoid getting an expired certificate again in 60 days, I create myself a certificate which is valid for 10 years.
For this I switch to my Linux environment. In my case a WSL installation based on Ubuntu.
# Creating a cert - folder
mkdir certs
data:image/s3,"s3://crabby-images/7973d/7973d1d634090876bfd645cec5ca06f5496532ee" alt=""
# Changing Directory
cd certs
# Generating the Cert
openssl req -x509 -newkey rsa:4096 -sha256 -days 3650 -nodes \
-keyout cert.key -out cert.crt -extensions san -config \
<(echo "[req]";
echo distinguished_name=req;
echo "[san]";
echo subjectAltName=DNS:<fqdn>
) \
-subj "/CN=<fqdn>"
# Looking for the new generated certs
ls
data:image/s3,"s3://crabby-images/62e5e/62e5e98d877ce3476b44d46edc9e73b1e6eaf79f" alt=""
# Certificate conversion - CRT+Key = PFX
openssl pkcs12 -export -in cert.crt -inkey cert.key -out wac.pfx
data:image/s3,"s3://crabby-images/a1e0c/a1e0c2e8eef3e80d9240e8fb405990daf0ecf8a6" alt=""
# Obtaining the certificates via Windows Explorer
\\wsl$\Ubuntu\home\bruendlt\certs
data:image/s3,"s3://crabby-images/cb9cc/cb9ccfe5ebccf45e509fce9c72740edf745102c3" alt=""
data:image/s3,"s3://crabby-images/9032c/9032c9efacc00542b3a7328e7d58248e159068b3" alt=""
The changeover process:
# var
$GatewayServerName="<Hostname WAC - Gateway>"
# session
$Session=New-PSSession -ComputerName $GatewayServerName
# copy
Copy-Item -Path "$env:USERPROFILE\Downloads\wac.pfx" -Destination "$env:USERPROFILE\Downloads\wac.pfx" -ToSession $Session
# cert import
Invoke-Command -ComputerName $GatewayServerName -ScriptBlock {Import-PfxCertificate -FilePath "$env:USERPROFILE\Downloads\wac.pfx" -CertStoreLocation Cert:LocalMachine\My -Exportable -Password (ConvertTo-SecureString -String '<PFX - File Password>' -AsPlainText -Force)}
# extract appId
$pattern = '(?<=\{).+?(?=\})'
$appId=[regex]::Matches((Invoke-Command -ComputerName $GatewayServerName -ScriptBlock {netsh http show sslcert})[8], $pattern).Value
# thumprint
$Thumbprint = (Invoke-Command -ComputerName $GatewayServerName -ScriptBlock {Get-ChildItem -Path Cert:\LocalMachine\MY | Where-Object {$_.Subject -Match "$GatewayServerName"} | Select-Object FriendlyName, Thumbprint, Subject, NotBefore, NotAfter| Sort-Object -Property NotAfter -Descending | Select-Object -first 1}).Thumbprint
# delete old binding
Invoke-Command -ComputerName $GatewayServerName -ScriptBlock {netsh http delete sslcert ipport=0.0.0.0:443}
# add new binding
$NetshArgumentList = "http add sslcert ipport=0.0.0.0:443 certhash="+$Thumbprint+" appid=`'{"+$appId+"}`'"
Invoke-Command -ComputerName $GatewayServerName -ScriptBlock {Invoke-Expression "netsh $using:NetshArgumentList"}
# restart
Invoke-Command -ComputerName $GatewayServerName -ScriptBlock {Restart-Service ServerManagementGateway}
#add certificate to trusted root certs
$Subject = (Invoke-Command -ComputerName $GatewayServerName -ScriptBlock {Get-ChildItem -Path Cert:\LocalMachine\MY | Where-Object {$_.Subject -Match "$GatewayServerName"} | Select-Object FriendlyName, Thumbprint, Subject, NotBefore, NotAfter| Sort-Object -Property NotAfter -Descending | Select-Object -first 1}).Subject
start-sleep 10
$cert = Invoke-Command -ComputerName $GatewayServerName -ScriptBlock {Get-ChildItem Cert:\LocalMachine\My\ |where subject -eq "$using:Subject"}
$cert | Export-Certificate -FilePath $env:TEMP\WACCert.cer
Import-Certificate -FilePath $env:TEMP\WACCert.cer -CertStoreLocation Cert:\LocalMachine\Root\
data:image/s3,"s3://crabby-images/5152b/5152baf88ac41fb443b2bd2b1163fd0bd5342707" alt=""
References:
data:image/s3,"s3://crabby-images/b72ab/b72ab7833b3994cf20f087af3f295644384821f8" alt=""
https://it-infrastructure.solutions/windows-admin-center-hybrid-hub-to-the-cloud-azure-part-2/
Setting up WSL2 (Windows Subsytem for Linux) on Windows 10
Generating self-signed certificate files (Linux - Debian)
data:image/s3,"s3://crabby-images/81665/81665b489848307b97df8373000645ff5a8a8758" alt=""
data:image/s3,"s3://crabby-images/a6e73/a6e7359a006a575a075254fcbbde56df6f409c8b" alt=""