From 93fd1090c1c001af54112490a669510bedc74642 Mon Sep 17 00:00:00 2001 From: James Ruskin Date: Fri, 22 Mar 2024 12:15:51 +0000 Subject: [PATCH] (#160) Rewrite Set-NexusCert to match Set-JenkinsCert --- Set-SslSecurity.ps1 | 7 +--- scripts/Get-Helpers.ps1 | 76 +++++++++++++++++++++-------------------- 2 files changed, 40 insertions(+), 43 deletions(-) diff --git a/Set-SslSecurity.ps1 b/Set-SslSecurity.ps1 index c7507c6..fb43e59 100644 --- a/Set-SslSecurity.ps1 +++ b/Set-SslSecurity.ps1 @@ -259,7 +259,6 @@ process { $EndpointScript = "$ScriptDir\Register-C4bEndpoint.ps1" if ($Hardened) { - $ClientSaltValue = New-CCMSalt $ServiceSaltValue = New-CCMSalt $ScriptBlock = @" @@ -301,10 +300,7 @@ process { } Install-ChocolateyAgent @agentArgs - } - - else { - + } else { # Agent Setup $agentArgs = @{ CentralManagementServiceUrl = "https://$($SubjectWithoutCn):24020/ChocolateyManagementService" @@ -339,7 +335,6 @@ Invoke-Expression (`$downloader.DownloadString("http://`$(`$HostName):80/Import- } $SslJson | ConvertTo-Json | Out-File "$env:SystemDrive\choco-setup\logs\ssl.json" } - end { Write-Host 'Writing README to Desktop; this file contains login information for all C4B services.' New-QuickstartReadme diff --git a/scripts/Get-Helpers.ps1 b/scripts/Get-Helpers.ps1 index 2b20d2d..1afaf75 100644 --- a/scripts/Get-Helpers.ps1 +++ b/scripts/Get-Helpers.ps1 @@ -1645,47 +1645,58 @@ function Set-NexusCert { $Port = 8443 ) - if ((Test-Path C:\ProgramData\nexus\etc\ssl\keystore.jks)) { - Remove-Item C:\ProgramData\nexus\etc\ssl\keystore.jks -Force - } - $KeyTool = "C:\ProgramData\nexus\jre\bin\keytool.exe" - $password = "chocolatey" | ConvertTo-SecureString -AsPlainText -Force - $certificate = Get-ChildItem Cert:\LocalMachine\TrustedPeople\ | Where-Object { $_.Thumbprint -eq $Thumbprint } | Sort-Object | Select-Object -First 1 + $KeyStorePath = 'C:\ProgramData\nexus\etc\ssl\keystore.jks' + $KeystoreCredential = [NetworkCredential]::new( + "Keystore", + (New-ServicePassword) + ) + $TempCertPath = Join-Path $env:TEMP "$(New-Guid).pfx" - Write-Host "Exporting .pfx file to C:\, will remove when finished" -ForegroundColor Green - $certificate | Export-PfxCertificate -FilePath C:\cert.pfx -Password $password - Get-ChildItem -Path c:\cert.pfx | Import-PfxCertificate -CertStoreLocation Cert:\LocalMachine\My -Exportable -Password $password - Write-Warning -Message "You'll now see prompts and other outputs, things are working as expected, don't do anything" - $string = ("chocolatey" | & $KeyTool -list -v -keystore C:\cert.pfx) -match '^Alias.*' - $currentAlias = ($string -split ':')[1].Trim() + try { + Write-Verbose "Exporting .pfx file to C:\, will remove when finished" + Get-ChildItem Cert:\LocalMachine\TrustedPeople\ | Where-Object { $_.Thumbprint -eq $Thumbprint } | Sort-Object | Select-Object -First 1 | Export-PfxCertificate -FilePath $TempCertPath -Password $KeystoreCredential.SecurePassword + # TODO: Is this the right place for this? # Get-ChildItem -Path $TempCertPath | Import-PfxCertificate -CertStoreLocation Cert:\LocalMachine\My -Exportable -Password $KeystoreCredential.SecurePassword + Write-Warning -Message "You'll now see prompts and other outputs, things are working as expected, don't do anything" + $string = ($KeystoreCredential.Password | & $KeyTool -list -v -keystore $TempCertPath) -match '^Alias.*' + $currentAlias = ($string -split ':')[1].Trim() - $passkey = '9hPRGDmfYE3bGyBZCer6AUsh4RTZXbkw' - & $KeyTool -importkeystore -srckeystore C:\cert.pfx -srcstoretype PKCS12 -srcstorepass chocolatey -destkeystore C:\ProgramData\nexus\etc\ssl\keystore.jks -deststoretype JKS -alias $currentAlias -destalias jetty -deststorepass $passkey - & $KeyTool -keypasswd -keystore C:\ProgramData\nexus\etc\ssl\keystore.jks -alias jetty -storepass $passkey -keypass chocolatey -new $passkey + if ((Test-Path $KeyStorePath)) { + Remove-Item $KeyStorePath -Force + } - $xmlPath = 'C:\ProgramData\nexus\etc\jetty\jetty-https.xml' - [xml]$xml = Get-Content -Path 'C:\ProgramData\nexus\etc\jetty\jetty-https.xml' - foreach ($entry in $xml.Configure.New.Where{ $_.id -match 'ssl' }.Set.Where{ $_.name -match 'password' }) { - $entry.InnerText = $passkey - } + & $KeyTool -importkeystore -srckeystore $TempCertPath -srcstoretype PKCS12 -srcstorepass $KeystoreCredential.Password -destkeystore $KeyStorePath -deststoretype JKS -alias $currentAlias -destalias jetty -deststorepass $KeystoreCredential.Password + & $KeyTool -keypasswd -keystore $KeyStorePath -alias jetty -storepass $KeystoreCredential.Password -keypass chocolatey -new $KeystoreCredential.Password - $xml.OuterXml | Set-Content -Path $xmlPath + $xmlPath = 'C:\ProgramData\nexus\etc\jetty\jetty-https.xml' + [xml]$xml = Get-Content -Path 'C:\ProgramData\nexus\etc\jetty\jetty-https.xml' + foreach ($entry in $xml.Configure.New.Where{ $_.id -match 'ssl' }.Set.Where{ $_.name -match 'password' }) { + $entry.InnerText = $KeystoreCredential.Password + } - Remove-Item C:\cert.pfx + $xml.Save($xmlPath) + } finally { + if (Test-Path $TempCertPath) { + Remove-Item $TempCertPath -Force + } + } - $nexusPath = 'C:\ProgramData\sonatype-work\nexus3' - $configPath = "$nexusPath\etc\nexus.properties" + $configPath = "C:\ProgramData\sonatype-work\nexus3\etc\nexus.properties" + # Remove existing ssl config from the configuration (Get-Content $configPath) | Where-Object {$_ -notmatch "application-port-ssl="} | Set-Content $configPath - $configStrings = @('jetty.https.stsMaxAge=-1', "application-port-ssl=$Port", 'nexus-args=${jetty.etc}/jetty.xml,${jetty.etc}/jetty-https.xml,${jetty.etc}/jetty-requestlog.xml') - $configStrings | ForEach-Object { + # Ensure each line is added to the configuration + @( + 'jetty.https.stsMaxAge=-1' + "application-port-ssl=$Port" + 'nexus-args=${jetty.etc}/jetty.xml,${jetty.etc}/jetty-https.xml,${jetty.etc}/jetty-requestlog.xml' + ) | ForEach-Object { if ((Get-Content -Raw $configPath) -notmatch [regex]::Escape($_)) { $_ | Add-Content -Path $configPath } } - + if ((Get-Service Nexus).Status -eq 'Running') { Restart-Service Nexus } @@ -1697,18 +1708,9 @@ function Test-SelfSignedCertificate { [Parameter(ValueFromPipeline = $true)] $Certificate = (Get-ChildItem -Path Cert:LocalMachine\My | Where-Object { $_.FriendlyName -eq $SubjectWithoutCn }) ) - process { - - if ($Certificate.Subject -eq $Certificate.Issuer) { - return $true - } - else { - return $false - } - + $Certificate.Subject -eq $Certificate.Issuer } - } #endregion