The topic is almost self explaining.
You need to monitor specific user-based certificates, to avoid a situation where they have already expired.
You can add this to your daily security compliance checklist.
Prerequisites for running CIs can be found here: Compliance Baseline prerequisites
-
Create Configuration Item
Go to Assets and Compliance, Compliance settings Configuration Items, right click and select Create a new configuration item:
data:image/s3,"s3://crabby-images/902e4/902e4f30b7f0bb4c72e59d9cb9dd33ba3a1f78cf" alt="Create Configuration Item"
Provide the name CI – Script – USER CERT Expiration check, leave the configuration item type as Windows and press Next:
data:image/s3,"s3://crabby-images/efb16/efb1620b86d5fa3da75d01f7ec378afed0d0b275" alt="Configuration Item Wizard"
Optionally you can provide a description that gives an overview of the configuration item and other relevant information that helps to identify it in the Configuration Manager console.
Select the OS where this configuration item assumes to be applied and click Next
data:image/s3,"s3://crabby-images/af605/af605bb72613ddd975e907c494c9476945d42349" alt="client operating systems that will assess this configuration item for compliance"
To create Configuration Item, click New:
data:image/s3,"s3://crabby-images/7ab47/7ab47d8972ff480225b3af8bd02e79074eb756b4" alt="Create Configuration Item Wizard"
Type in the name CI – Script, from drop down of settings type select Script and data type as String.
There are two options to specify where a script would reside
– Discovery Script
– Remediation Script
Remediation is not handled in this post.
To place discovery script since to evaluate compliance, click on Add Script.
Please note that this script needs to be runin the logged-on user context, therefore please check “Run scripts by using the logged on user credentials”
data:image/s3,"s3://crabby-images/3f07f/3f07f35b87fd53cb8fb14fb48e03923a57250b72" alt="Create Setting"
Select script language as Windows PowerShell and type in the script (see attached USER_CERT_Expiration _Discovery.ps1) in the Script field:
data:image/s3,"s3://crabby-images/76a4d/76a4d415972643719481f622c1a44ff420d4b845" alt="Edit Discovery Scripts"
#
$Compliance = ‘Compliant’
$Check = get-childitem -path cert:\currentuser -recurse | where-object {$_.thumbprint -eq ‘245c97df7514e7cf2df8be72ae957b9e04741e85’}| where { $_.notafter -le (get-date).AddDays(30)}
If ($Check) {$Compliance = ‘NonCompliant’}
$Compliance
#
Script download: [download id=”787″]
and click OK
Click Next
data:image/s3,"s3://crabby-images/4ca9c/4ca9c0eda021dced3a5bf77dae135a5e7f21077c" alt="Specify settings for this operating system"
After the script is in place, you can click the “Compliance Rules” tab. Now compliance rule needs to be created. This rule will determine how the compliance is reported once the script runs on a computer (based on how the compliance a machine could be either Compliant or NonCompliant).
Click on New
data:image/s3,"s3://crabby-images/ed933/ed933cdfa53c200400da8c2c84c82f7f23400c30" alt="Specify complance rules for this operating system"
Type in the com
pliance rule name and click on Browse:
Select the name of the configuration setting that just created (if not already selected and then click on Select):
data:image/s3,"s3://crabby-images/83fdc/83fdce9145ffaeefdf71feb7e0b2634ad80c2ea1" alt="Select a setting for this rule"
In the Rule Type select Value and then select if the value returned is Equals to Compliant.
Click OK
Click Next
data:image/s3,"s3://crabby-images/411c8/411c85a558358ade439ec7fc6f19cf1887962f05" alt="Use compliance rules to specify the condition that make a configuration item setting compliant"
Next screen presents the summary of the settings, if any changes are needed then you can go back and make changes here. Click Next.
data:image/s3,"s3://crabby-images/9fc0d/9fc0da2054c33336166fd15dafab3c9d525a42c1" alt="create an operating system configuration item with the following settings"
Configuration Item is ready now.
data:image/s3,"s3://crabby-images/65a19/65a19c51b13b7386580596d9665e23f8bcf08b53" alt="The Create Configuration Item Wizard completed successfully"
Next step is to create Configuration Baseline.
-
Create Configuration Baseline
Right click Configuration baseline and create configuration baseline.
data:image/s3,"s3://crabby-images/7eb95/7eb95e2ccb725d79f7d177eff9ac5c9c304c9017" alt="Create Configuration Baseline"
Type the name of configuration baseline CB – Script – USER CERT Expiration check. Click on add and select configuration item from drop down menu.
data:image/s3,"s3://crabby-images/5430c/5430cff051fa618502191f221d5d879c81a13685" alt="Specify general information about this configuration baseline"
Please make sure that Purpose set to Required!
Select the configuration item just created and click OK. This would finish creating configuration baseline.
data:image/s3,"s3://crabby-images/318a8/318a82bf04a4e78a8ef46d0d10e394aef50a59ec" alt="Add Configuration Item"
Now it is time to deploy this base line to relevant Users Collection(-s).
-
Deploy the Configuration Baseline
Go to configuration baseline and right click and select Deploy.
data:image/s3,"s3://crabby-images/7935e/7935ee8c342e3ce939df2d61a69541e032958abf" alt="Deploy Configuration Baseline"
Select the configuration baseline CB – Script – USER CERT Expiration check.
Browse and point it to targeted Users collection (its recommended to run it for some limited collection for testing before deployment to production)
Change the evaluation schedule as per as your requirements (taking in consideration that in case of it seems to be critical for your environment, in production running this CB probably once a day is recommended)
Again, the key thing here is to be sure that you deploy this CB to users and not to your systems!
data:image/s3,"s3://crabby-images/be3e4/be3e4f3637335ed1f6d33ed5300cd3a285c1b53a" alt="Select the configuration baseline that you want to deploy to a collection"
Click OK
Note: When the configuration baseline is deployed, please allow that it can be evaluated for compliance within about two hours of the start time that you schedule.
-
Verify that a device has evaluated the Configuration Baseline
To check it on a Windows PC client (general recommendation to do it for all targeted OS client types)
On a Device, go to Control Panel, System and Security and open the Configuration Manager applet. In the Configurations tab you’ll see what Configuration Baselines the client will evaluate at its specific schedule. Click on configurations and click on “Evaluate”, “Refresh” and then “View Report”.
As shown in the pictures below, Configuration Baseline was evaluated to be Compliant or Not
data:image/s3,"s3://crabby-images/e6ad9/e6ad995e7ba4259c565b385643aa4eaaf5e404ab" alt="Configuration Manager Properties"
data:image/s3,"s3://crabby-images/b8d16/b8d161de7ea7644a8cc9f980fc5d3f5952a1d5ca" alt="Report view"
data:image/s3,"s3://crabby-images/788d7/788d7e012849d3c5fbd7fc16196bd3e300142e88" alt="Report view, non-compliant"