bin/Invoke-VerifySubject.ps1
function Invoke-VerifySubject { # Determine if a Client Cert exist in the Request. if ($null -ne $script:ClientCert) { # First, Validate that the RootCA matches. . $RestPSLocalRoot\bin\Invoke-VerifyRootCA.ps1 $script:VerifyStatus = Invoke-VerifyRootCA if ($script:VerifyStatus -eq $true) { # Root CA Matched, Verifying the ACL list . $RestPSLocalRoot\bin\Get-RestAclList.ps1 $RestACL = Get-RestAclList Write-Output "ACL is:" $RestACL if ($null -ne $RestACL) { $RawSubject = $script:ClientCert.Subject $1, $Subject = $RawSubject.split("=") Write-Output "Subject name is" $Subject if ($null -ne $Subject) { if ($RestACL.contains($Subject)) { Write-Output "Client access is Verified." $script:VerifyStatus = $true } else { Write-Output "Client does not exist in ACL." $script:VerifyStatus = $false } } else { Write-Output "Client Subject Name does not exist." $script:VerifyStatus = $false } } else { Write-Output "No ACL list available." $script:VerifyStatus = $false } } else { Write-Output "The Root CA did not match, Not attempting to Validate ACL List." $script:VerifyStatus = $false } } else { Write-Output "No Client Certificate Received." $script:VerifyStatus = $false } $script:VerifyStatus } |