Home > PowerShell > Function: Test-InvalidCerts – Ensuring Certificates Are In The Correct Certificate Store

Function: Test-InvalidCerts – Ensuring Certificates Are In The Correct Certificate Store

I learned some very valuable lessons on my first Lync Server deployment. If Lync doesn’t work, it’s probably certificate related. That’s still the case with Skype for Business. Simple certificate issues can cause all kinds of problems. That’s why I’ve written about them in Lync Users Can’t Download Address Book if Certificate Uses CNG and One Liner: Add Trusted Root Cert Authorities to Edge Servers (among others). Today I again saw another issue around McAfee solutions and Front End services not starting (see An intermediate certificate is installed under “Trusted Root Certification Authorities” for more info). Turns out some certificates are in the wrong certificate store. An example would be an intermediate certificate improperly placed in the ‘Trusted Root Certification Authorities’. The solution is to just move the cert into the correct store. But rather than manually looking at each one, surely there is a way to check them all and move them to the right store! Well, Shirley (see what I did there?), there is.

Here is a simple function that checks both the intermediate and trusted root stores for certificates that should be in the opposite store. If it finds them, it will move them. Run this in an elevated PowerShell session.

1function Test-InvalidCert {
2  <#
3  .SYNOPSIS
4    Checks root and intermediate certificate stores for certificates in the wrong store & moves them to the correct store.
5 
6  .DESCRIPTION
7    Checks root and intermediate certificate stores for certificates in the wrong store & moves them to the correct store. Certificates in the wrong store can be very problematic for Lync Server and Skype for Business Server.
8 
9  .NOTES
10    Version               : 1.2
11    Wish list             :
12    Rights Required       : Local administrator on server
13    Sched Task Required   : No
14    Lync/Skype4B Version  : N/A
15    Author/Copyright      : © Pat Richard, Office Servers and Services (Skype for Business) MVP - All Rights Reserved
16    Email/Blog/Twitter    : pat@innervation.com  https://ucunleashed.com  @patrichard
17    Donations             : https://www.paypal.me/PatRichard
18    Dedicated Post        : https://ucunleashed.com/3903
19    Disclaimer            : You running this script means you won't blame author(s) if this breaks your stuff. This script is
20                            provided AS IS without warranty of any kind. Author(s) disclaim all implied warranties including,
21                            without limitation, any implied warranties of merchantability or of fitness for a particular
22                            purpose. The entire risk arising out of the use or performance of the sample scripts and
23                            documentation remains with you. In no event shall author(s) be liable for any damages whatsoever
24                            (including, without limitation, damages for loss of business profits, business interruption,
25                            loss of business information, or other pecuniary loss) arising out of the use of or inability
26                            to use the script or documentation. Neither this script, nor any part of it other than those
27                            parts that are explicitly copied from others, may be republished without author(s) express written
28                            permission.
29    Acknowledgements      :
30    Assumptions           : ExecutionPolicy of AllSigned (recommended), RemoteSigned, or Unrestricted (not recommended)
31    Limitations           :
32    Known issues          : None yet, but I'm sure you'll find some!
33 
34  .LINK
35    <blockquote class="wp-embedded-content" data-secret="7JoUqmURIJ"><a href="https://www.ucunleashed.com/3903">Function: Test-InvalidCerts – Ensuring Certificates Are In The Correct Certificate Store</a></blockquote><iframe class="wp-embedded-content" sandbox="allow-scripts" security="restricted" style="position: absolute; clip: rect(1px, 1px, 1px, 1px);" title="“Function: Test-InvalidCerts – Ensuring Certificates Are In The Correct Certificate Store” — UC Unleashed" src="https://www.ucunleashed.com/3903/embed#?secret=nKu1hXAReP#?secret=7JoUqmURIJ" data-secret="7JoUqmURIJ" width="500" height="282" frameborder="0" marginwidth="0" marginheight="0" scrolling="no"></iframe>
36 
37  .EXAMPLE
38    .\Test-InvalidCerts.ps1
39 
40    Description
41    -----------
42    Checks root and intermediate store for certs in the wrong store & moves them to the proper store.
43 
44  .INPUTS
45    None. You cannot pipe objects to this script.
46  #>
47  [CmdletBinding(SupportsPaging)]
48  param(
49  ) # end of param block
50  process{
51    Write-Verbose -Message 'Checking for improper certs in root store'
52    $InvalidCertsInRoot = Get-Childitem -Path cert:\LocalMachine\root -Recurse | Where-Object {$_.Issuer -ne $_.Subject}   
53 
54    if ($InvalidCertsInRoot){       
55      Write-Verbose -Message ('{0} invalid certificates detected in Root Certificate Store' -f $InvalidCertsInRoot.count)
56      ForEach ($cert in $InvalidCertsInRoot){
57        Write-Verbose -Message ('Moving `"{0}`" to intermediate certificate store' -f $cert.subject)
58        Move-Item -Path $cert.PSPath -Destination Cert:\LocalMachine\CA
59      }
60    }else{
61      Write-Verbose -Message 'No invalid certs found in Root Certificate Store'
62    }
63    $InvalidCertsInInt = Get-Childitem -Path cert:\LocalMachine\Ca -Recurse | Where-Object {$_.Issuer -eq $_.Subject} 
64    if ($InvalidCertsInInt){
65      Write-Verbose -Message ('{0} invalid certificates detected in Intermediate Certificate Store' -f $InvalidCertsInInt.count)
66      ForEach ($cert in $InvalidCertsInInt){
67        Write-Verbose -Message ('Moving `"{0}`" to root certificate store' -f $cert.subject)
68        Move-Item -Path $cert.PSPath -Destination Cert:\LocalMachine\Root
69      }
70    }else{
71      Write-Verbose -Message 'No invalid certs found in Intermediate Certificate Store'
72    }
73  }
74} # end function Test-InvalidCert

All output is verbose, so if you want to see what it’s doing, run the function with -Verbose.

Donations

I’ve never been one to really solicit donations for my work. My offerings are created because *I* need to solve a problem, and once I do, it makes sense to offer the results of my work to the public. I mean, let’s face it: I can’t be the only one with that particular issue, right? Quite often, to my surprise, I’m asked why I don’t have a “donate” button so people can donate a few bucks. I’ve never really put much thought into it. But those inquiries are coming more often now, so I’m yielding to them. If you’d like to donate, you can send a few bucks via PayPal at https://www.paypal.me/PatRichard. Money collected from that will go to the costs of my website (hosting and domain names), as well as to my home lab.

Categories: PowerShell Tags:
  1. Wayne
    April 24th, 2017 at 04:48 | #1

    Hi, This works great on 2012R2, but errors when running on a 2008R2 server in ?, can’t see why ?. ANy help greatly appreciated

    The “=” operator is missing after a named argument.
    At C:\temp\Test-InvalidCerts.ps1:47 char:33
    + [CmdletBinding(SupportsPaging) <<<< ]
    + CategoryInfo : ParserError: (:) [], ParseException
    + FullyQualifiedErrorId : MissingEqualsInNamedArgument

  2. wayne
    April 25th, 2017 at 02:46 | #2

    Hi This works great on 2012 R2 servers but errors on 2008 R2

    The “=” operator is missing after a named argument.
    At C:\temp\Test-InvalidCerts.ps1:47 char:33
    + [CmdletBinding(SupportsPaging) <<<< ]
    + CategoryInfo : ParserError: (:) [], ParseException
    + FullyQualifiedErrorId : MissingEqualsInNamedArgument

  3. wayne
    April 25th, 2017 at 03:24 | #3

    Hi Pat, thanks , is it simple to change it to work with PowerShell 2.0 as the bulk of our estate is 2008R2

  4. Chris Krafcky
    May 31st, 2017 at 15:21 | #4

    @Wayne
    Hi. Is something supposed to be happening when I run the script? I don’t see anything happening at all. Is this as simple as saving it at the root of C, opening Powershell, and typing .\Test-InvalidCerts.ps1? I don’t see anything and it just goes to the next line.

  5. Chris Krafcky
    May 31st, 2017 at 16:11 | #6

    @Pat Richard
    Thank you Pat. I was wondering if I had to see some sort of output. I’m very new to this whole PowerShell thing, and certificates on all of my Lync Servers have made me pull my hair out.

  6. Chris Krafcky
    May 31st, 2017 at 16:24 | #7

    Can I ask another question… Do you know of any good documentation that would teach me about certificates, and how to identify if a certificate should be placed in the ‘Personal’, ‘Trusted Root’, or ‘Intermediate Certification’ store? What I’ve read so far makes no sense to me, or at least the light bulb hasn’t gone on yet.

  7. soder
    June 22nd, 2017 at 04:38 | #8

    @Chris Krafcky
    Attend a PKI training led by some professional certification company, sorry but there is no other easy solution other than learning this for years 🙁

  1. March 17th, 2017 at 17:13 | #1