Prerequisites
IIS must be installed and working from the clients that will need the RootCA or certs signed by the RootCA server. See more for a simple IIS install guide here: https://scito.dk/2023/08/15/install-iis-for-certificate-authority-crl-and-root-certificate-distribution/
RootCA must be present for signing the SubCA cert. Read more here: https://scito.dk/2023/08/15/two-tier-ca-structure-offline-rootca/
Steps
- Install Windows Server
- Fully Update Server
- Create C:\Windows\CAPolicy.inf
- Install ADCS Feature
- Config of the ADCS step 1
- Create a certificate for the SubCA
- Finish config of the ADCS
- Validate the CRL and CRT locations
- Create a GPO to trust the Root CA and Sub CA
Step 1
Install a Windows server.
Step 2
Make sure the server is fully updated
data:image/s3,"s3://crabby-images/91a8b/91a8b4fd18e3d856ff7363ed1b75463bd1be8a9b" alt=""
Step 3
Create the file C:\Windows\CAPolicy.inf
With the following text. Remember to Change URLs under the following sections
- [InternalPolicy]
- [AuthorityInformationAccess]
- [CRLDistributionPoint]
If there are a specific internal OID being used, then change the OID to the company provided OID under the [InternalPolicy] Section
[Version]
Signature="$Windows NT$"
[PolicyStatementExtension]
Policies=InternalPolicy
[InternalPolicy]
OID= 1.2.3.4.1455.67.90.5
URL=http://Win-Sub-CA01/certs/cps.html
[Certsrv_Server]
RenewalKeyLength=4096
RenewalValidityPeriod=Years
RenewalValidityPeriodUnits=20
CRLPeriod=Years
CRLPeriodUnits=1
CRLDeltaPeriod=Days
CRLDeltaPeriodUnits=0
ClockSkewMinutes=20
LoadDefaultTemplates=True
AlternateSignatureAlgorithm=0
ForceUTF8=0
EnableKeyCounting=0
[AuthorityInformationAccess]
URL=http://Win-Sub-CA01/certs/ScitoDK-SubCA.crt
URL=C:\Windows\System32\CertSrv\CertEnroll\ScitoDK-SubCA.crt
[CRLDistributionPoint]
URL= http://Win-Sub-CA01/certs/ScitoDK-SubCA.crl
URL= C:\Windows\System32\CertSrv\CertEnroll\ScitoDK-SubCA.crl
[PolicyStatementExtension]
Policies = AllIssuancePolicy
Critical = FALSE
[AllIssuancePolicy]
OID = 2.5.29.32.0
Step 4
Open Powershell and install the Windows Certificate Authority Feature
Add-WindowsFeature Adcs-Cert-Authority -IncludeManagementTools
data:image/s3,"s3://crabby-images/0adf5/0adf5bbf304221ce54f5905501a1422e761eca61" alt=""
Step 5
Configure the 1 step of the SubCA
Open Server manager
data:image/s3,"s3://crabby-images/16210/16210e50e405904db6bcedb4c849a1737dfa69d9" alt=""
Click on the notification icon within server manager
data:image/s3,"s3://crabby-images/a57c4/a57c4375693a0c151aecbc1d61cdcc7ccc16580c" alt=""
Click the Configure Active Directory Certificate Services on this server
data:image/s3,"s3://crabby-images/8ede6/8ede6f456ac05b32323f4b06d62d9e149a052479" alt=""
Click the next button
data:image/s3,"s3://crabby-images/755e5/755e5f9214533cd1341c23db81664a2619cededd" alt=""
Select Certificate Authority and press the Next button
data:image/s3,"s3://crabby-images/4c46a/4c46a0735b974564f32ef5e99866741a051d8190" alt=""
Select Enterprise CA and press the Next button
data:image/s3,"s3://crabby-images/19f78/19f78c40b82460a80296cf7140107469b4e2ac0d" alt=""
Select Subordinate CA and press the Next button
data:image/s3,"s3://crabby-images/d2102/d2102a436eb8fe7264755dc133e8ff219e10d3a8" alt=""
Select Create new private key and press the Next button
data:image/s3,"s3://crabby-images/fc021/fc021902afa40926892f0aea1995c26be5d84f55" alt=""
Select RSA#Microsoft Software Key Storage Provider
The Key should be at least 4096 in length and the signing algorithm should be at least SHA256.
Press the next button when ready to continue
data:image/s3,"s3://crabby-images/2bcbe/2bcbe461abb82943acbf4d818978489e898e6d99" alt=""
Write the Common name of the Certificate Authority. In this case it is ScitoDK-SubCA and press the Next button
I strongly recommend that this is not the server name. When the ADCS services will be moved at some point the naming will be mismatch and it will hurt any good technician eyes 🙂
data:image/s3,"s3://crabby-images/249d2/249d230580f87f15f54860f2e730100df5e46904" alt=""
Save the CSR file, so we can get it to the RootCA. Press the Next button
data:image/s3,"s3://crabby-images/7664d/7664d8030f20c569c191d2df33cf8650172037a6" alt=""
Press the Next button
data:image/s3,"s3://crabby-images/611df/611df786a024f18c0df64140b97108ac78221271" alt=""
Press the Configure button
data:image/s3,"s3://crabby-images/5349e/5349ed80ba350267d3ac92b59cfa401cc31efa14" alt=""
When Finished press the close button
data:image/s3,"s3://crabby-images/6ef51/6ef51d4106108480a19d7f89c67cf3c9656e1c32" alt=""
Step 6
Sign the certificat request on the RootCA.
The following is executed on the RootCA Server
Open Certificate Authority manager
data:image/s3,"s3://crabby-images/063b1/063b182a183d08f215002a4fa8ca62138974d193" alt=""
Right-click the CA name, select all tasks and then select subnet new request
data:image/s3,"s3://crabby-images/ce41e/ce41efaa3fa3c1c0dd44788269d476a2965f1b71" alt=""
Select the CSR file that the SubCA generated
data:image/s3,"s3://crabby-images/fc824/fc824a5075e4c24e51f6223ea554bf910674c787" alt=""
Select the pending requests, select the certificate, right-click select all tasks and select issue
data:image/s3,"s3://crabby-images/677ea/677ea18cc5b56a82d86186569c86055eb8c7da55" alt=""
The Certificate is now issued.
Select the issued certificates, select the certificate. Right-click and select open
data:image/s3,"s3://crabby-images/05f00/05f0006f2cedb4ec58a7cc81a1ac98534e33e970" alt=""
Select the details tab and click the copy to file button
data:image/s3,"s3://crabby-images/642b8/642b802e180c352c5435a6bd87e4a4940ee7449b" alt=""
Press next
data:image/s3,"s3://crabby-images/2c187/2c187ac088b4282acfd49b2a5b1979c8742f6349" alt=""
Select Base-64 encoded x.509 (.cer) and press next
data:image/s3,"s3://crabby-images/2d501/2d5017d79c114c844e3203de907b3ab70ce86e38" alt=""
Select the path where the cert should be saved to and press the next button
data:image/s3,"s3://crabby-images/a50e7/a50e714960f0d7393cb3dbf68092903943860f49" alt=""
Press finish
data:image/s3,"s3://crabby-images/335e6/335e6614907d9cccebcf7369f9de97df050dfaf8" alt=""
Step 7
Continue the SubCA Configuration
The following is executed on the SubCA Server
Open the Certificate Authority manager
data:image/s3,"s3://crabby-images/b9f78/b9f7884f1e6591eb72acd4c425811e0205045417" alt=""
Right-Click the CA name, select all tasks, then select Install CA Certificate
data:image/s3,"s3://crabby-images/78c4b/78c4bccc3f72ac87ba1848458f5f630b3e6ae716" alt=""
Select the certificate that we got from the RootCA
data:image/s3,"s3://crabby-images/e89fe/e89fe44d92cfd478f063f0083bda01e736ebb66b" alt=""
If it ask after the RootCA or if it should be trusted, press the OK button
data:image/s3,"s3://crabby-images/52c50/52c50b3af8ec70dba4902f3bcf84cad9fcedf886" alt=""
Right-click the CA name, select all tasks, then select start service
data:image/s3,"s3://crabby-images/f1628/f162890ffeccde03f0bc2ff20afe808b94395fa9" alt=""
The service is starting
data:image/s3,"s3://crabby-images/c0701/c0701229502d3fb6cb5e75301e686c87daeeef67" alt=""
The CA name will have a green icon when running
data:image/s3,"s3://crabby-images/39e2e/39e2ee5533d08caffd54f10009c46bb97b1803d8" alt=""
Open Powershell for additional configuration of the Windows Certificate Authority Feature.
Remember to change the URL for the Add-CACRLDistributionPoint and Add-CAAuthorityInformationAccess
$crllist = Get-CACrlDistributionPoint; foreach ($crl in $crllist) {Remove-CACrlDistributionPoint $crl.uri -Force};
Add-CACRLDistributionPoint -Uri C:\Windows\System32\CertSrv\CertEnroll\ScitoDK-SubCA.crl -PublishToServer -PublishDeltaToServer -Force
Add-CACRLDistributionPoint -Uri http://Win-Sub-CA01/certs/ScitoDK-SubCA.crl -AddToCertificateCDP -AddToFreshestCrl -Force
Get-CAAuthorityInformationAccess | Remove-CAAuthorityInformationAccess -Force
Add-CAAuthorityInformationAccess -AddToCertificateAia http://Win-Sub-CA01/certs/ScitoDK-SubCA.crt -Force
certutil.exe –setreg CA\CRLPeriodUnits 20
certutil.exe –setreg CA\CRLPeriod “Years”
certutil.exe –setreg CA\CRLOverlapPeriodUnits 3
certutil.exe –setreg CA\CRLOverlapPeriod “Weeks”
certutil.exe –setreg CA\ValidityPeriodUnits 10
certutil.exe –setreg CA\ValidityPeriod “Years”
certutil.exe -setreg CA\AuditFilter 127
Restart-Service certsvc
certutil -crl
data:image/s3,"s3://crabby-images/6229a/6229a90a9059db76526f90cc101c3b4e2ac275e3" alt=""
Step 7
Copy the Root Certificat and the CRL file to the web site where the CRL are stated in the certificate
The files are located in the file directory under C:\Windows\System32\CertSrv\CertEnroll
data:image/s3,"s3://crabby-images/9f94e/9f94ec51fcd1d92892d955a1d0aac83f5c21d29a" alt=""
Remember to rename the Certificate file to the correct name stated in the CRL url. In this case it is ScitoDK-SubCA.crt
Test if the AIA is working: in this example it is http://Win-Sub-CA01/certs/ScitoDK-SubCA.crt.
Otherwise the clients or Subordinates CA will not work if the check to find the CRL file
data:image/s3,"s3://crabby-images/b74b4/b74b4d960897f9d4c3d8bf412f0fe125c06b09b5" alt=""
Validate the CRL and AIA url:
data:image/s3,"s3://crabby-images/a1baf/a1baf0ab5351b120ff62fe8dcbed6cb3254b844b" alt=""
data:image/s3,"s3://crabby-images/55139/55139ace887b7952e6ef8fc8b365b23deea867a2" alt=""
data:image/s3,"s3://crabby-images/c93f7/c93f7758c2feef45399585b25f0e3abed18063e2" alt=""
data:image/s3,"s3://crabby-images/fedf1/fedf17bdf9b26ca80e861669dcb20b610fedeaed" alt=""
Step 9
Create a gpo so the servers and workstations trust the root-ca and sub-ca certificate.
Open run and enter gpmc.msc
data:image/s3,"s3://crabby-images/26e0c/26e0c105d0f06c5bc72f9d4e59a9ad0b7b0c6ccf" alt=""
Expand the tree and create two new policies.
One for the Domain controllers and one for the other servers and clients.
data:image/s3,"s3://crabby-images/51b13/51b139759a14a47170c7464ef0d1e1194e45e755" alt=""
To speed of the GPO Processing then either put these settings in an existing GPO or disable the user settings
data:image/s3,"s3://crabby-images/21682/216829d1fc65a8177775b19c3d63d63bff7e5d4e" alt=""
Settings for the GPO for Workstations and servers are like this:
data:image/s3,"s3://crabby-images/06ca3/06ca3a04cfdb6fb0fe6854c5ab6f6dc07b2f55ce" alt=""
Settings for the GPO for the domain controllers are like this
data:image/s3,"s3://crabby-images/2690f/2690f3c2ef60e67d4fd8b74a685962b004be2373" alt=""
Link the GPOs to the correct OUs.
In my case i have blocked inheritance on the domain controllers ou
data:image/s3,"s3://crabby-images/41988/41988fec0d233a2ca36209a069bff846db3c8eea" alt=""