This is the PowerShell script I use to automatically update a Let’s Encrypt SSL Certificate on Exchange 2016 running on Windows Server 2016 using Posh-ACME. Let’s Encrypt certificates are valid for 3 months, but I set the script to run once a month, so that if there is some type of temporary problem it gets two more tries before the expiration. Note that his example script modifies DNS hosted by GoDaddy to verify ownership of the domain. If you host your DNS at GoDaddy you will need to include your `GDKey` and `GDSecret` and otherwise adjust the script to your environemnt. If your DNS is hosted elsewhere or if you would like to use HTTP verification you will need to modify the script according to the instructions for the Posh-ACME plugins.
# Use TLS 1.2. [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 # Install the Posh-ACME module. Typically the module only needs to be installed once on a server. Install-Module -Name Posh-ACME # Update the Posh-ACME module. The install command above will not update a currently installed module. Update-Module -Name Posh-ACME # Use the production server. Set-PAServer LE_PROD # Define the variables. $contact = 'user@example.com' $pluginArguments =@{GDKey='xxxxxxxxxxxxxxxx';GDSecret='xxxxxxxxxxxxxxxx'} $pfxPassword = 'SuperSecretPassword' $certificatePath = 'C:\Users\administrator\AppData\Local\Posh-ACME\acme-v02.api.letsencrypt.org\xxxxxxxxx\mail.example.com\cert.pfx' $certFriendlyName = "mail.example.com_$($(get-date -format yyyy-MM-dd--HH-mm))" # Generate the certificate. New-PACertificate 'mail.example.com','autodiscover.example.com','mail.domain.com','autodiscover.domain.com' -AcceptTOS -Contact $contact -DnsPlugin GoDaddy,GoDaddy,GoDaddy,GoDaddy -PluginArgs $pluginArguments -DnsAlias 'mail.example.acme.example.com','autodiscover.example.acme.example.com','mail.domain.acme.example.com','autodiscover.domain.acme.example.com' -PfxPass $pfxPassword -force # Invoke the Exchange Management PowerShell snapin. Invoke-Expression "Add-PSSnapin Microsoft.Exchange.Management.PowerShell.SnapIn;" # Import the certificate into Exchange and set it to run all the necessary services. Import-ExchangeCertificate -FileName $certificatePath -FriendlyName $certFriendlyName -Password (ConvertTo-SecureString -String $pfxPassword -AsPlainText -Force) | Enable-ExchangeCertificate -Services POP,IMAP,SMTP,IIS -Force # Restart IIS. iisreset # Disable "Require SSL" for the Default Web Site. This allows IIS to redirect HTTP requests to HTTPS if configured (optional). Set-WebConfiguration -Location "Default Web Site" -Filter 'system.webserver/security/access' -Value None